Linux内核Makefile执行流程

Linux内核Makefile执行流程

本文为看雪论坛优秀文章

看雪论坛作者ID:jmpcall





必备知识


1.1. Makefile基础语法


如果还不熟悉Makefile语法,建议先系统的学习一下,特别是以下几点:

(1) Makefile哪些部分包含的是shell语句:
编译规则中的指令部分
${shell XX},var != XX中的XX部分
$(if …, XX, XX)中的XX部分

(2) 变量展开:
=(延迟赋值)、:=(立即赋值)、!=(值为shell命令)、?=(条件赋值)、+=(追加)

(3) include:将指定的其它Makefile内容,展开到当前Makefile
-f/-C:嵌套执行指定(目录中的)Makefile
执行一个Makefile,并不是从第一行开始执行,而是从指定或默认的编译目标开始执行(位置目标编译规则之前的赋值语句,只在相应变量需要被使用时才会执行),其中,Makefile(包括include内容)中的第一个目标,为默认目标,如果make命令行中没有指定编译目标,则执行默认目标。

(4) 自动推导依赖文件

(5) 根据文件时间戳、中间文件(.d、.cmd),判断依赖更新,决定是否需要重新编译

(6) 重要的内置函数:
$(wildcard pattern)
$(patsubst pattern, replacement, text)
$(strip string)
$(filter pattern, text)
$(filter-out pattern, text)
$(call func, args..)

(7) 自动推导变量:
$@:编译目标
$<:依赖列表中的第一个依赖对象
$^:依赖列表中的所有对象
$?:依赖文件列表中所有有更新的文件
 
Makefile教程可以参考以下这2个:
深入解析Makefile系列:
https://zhuanlan.zhihu.com/p/362640343(简约,直指核心)
跟我一起写makefile(陈皓):
https://blog.csdn.net/whitefish520/article/details/103968609(精典,超级详细)


1.2. Kbuild内置函数


Linux内核源码包含一套Makefile程序,本文基于Linux-5.2.5内核源码分析,其中包括top Makefile,scripts/目录下的Makefile、Makefile.build、Makefile.lib、Kbuild.include、Makefile.modpost、kconfig/Makefile等,以及其它目录下的很多子Makefile,统称为Kbuild。Kbuild是按照框架设计思路实现的,使得内核自身包含或外部提供的大量驱动模块,只需要按照Kbuild框架的约定,各自提供一个简单的Makefile即可编译。

所以,理解内核或驱动文件的编译过程,其实就是要理解Kbuild这套Makefile程序的实现逻辑,既然是程序,就免不了会定义一些函数,由于很多关键的流程,都使用了$(build)和$(if_changed),所以以下先单独介绍(本文分析的Makefile内容,来自Linux-5.2.5内核源码):

1.2.1. $(build)


◆使用形式:$(Q)$(MAKE) $(build)=xx目录 [编译目标]

Linux内核Makefile执行流程

◆build内部过程

Linux内核Makefile执行流程

◆build作用概括

以下是$(build)的使用形式,以及每个部分的作用:

Linux内核Makefile执行流程


1.2.2. $(if_changed)


◆使用形式:$(call if_changed, xx)
Linux内核Makefile执行流程

◆if_changed内部过程

Linux内核Makefile执行流程

◆if_changed作用概括

以下是$(if_changed)的使用形式,及其参数的含义:
Linux内核Makefile执行流程




编译外部模块


2.1. 涉及Makefile内容


Linux内核Makefile执行流程

2.2. 概要流程


Linux内核Makefile执行流程


2.3. 详细流程


Linux内核Makefile执行流程




make menuconfig


3.1. 涉及Makefile内容


Linux内核Makefile执行流程

3.2. 概要流程


Linux内核Makefile执行流程


3.3. 详细流程


Linux内核Makefile执行流程





Make [all/_all/modules]


4.1. 涉及Makefile内容


make命令行指定all/_all/modules目标,或者不指定目标时,是为了生成vmlinux文件,而vmlinux目标间接依赖prepare目标,且prepare目标编译规则展开内容比较多,所以以下分开介绍:

◆vmlinux目标

Linux内核Makefile执行流程

◆prepare目标

Linux内核Makefile执行流程


4.2. 概要流程


◆vmlinux目标

Linux内核Makefile执行流程

◆prepare目标

Linux内核Makefile执行流程

4.3. 详细流程


◆vmlinux目标

Linux内核Makefile执行流程

◆vmlinuz目标

Linux内核Makefile执行流程

◆prepare目标

Linux内核Makefile执行流程




参考


linux Kbuild详解系列:
https://zhuanlan.zhihu.com/p/362640343
跟我一起写makefile:https://blog.csdn.net/whitefish520/article/details/103968609

 
点击文末 阅读原文 获取附件:文中部分图片,根据”执行流程.txt”内容截取,其余已经打包到”图.zip”文件



Linux内核Makefile执行流程


看雪ID:jmpcall

https://bbs.kanxue.com/user-home-815036.htm

*本文由看雪论坛 jmpcall 原创,转载请注明来自看雪社区

Linux内核Makefile执行流程

# 往期推荐

1、在 Windows下搭建LLVM 使用环境

2、深入学习smali语法

3、安卓加固脱壳分享

4、Flutter 逆向初探

5、一个简单实践理解栈空间转移

6、记一次某盾手游加固的脱壳与修复


Linux内核Makefile执行流程


Linux内核Makefile执行流程

球分享

Linux内核Makefile执行流程

球点赞

Linux内核Makefile执行流程

球在看

原文始发于微信公众号(看雪学苑):Linux内核Makefile执行流程

版权声明:admin 发表于 2023年5月11日 下午6:00。
转载请注明:Linux内核Makefile执行流程 | CTF导航

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...