对Linux 内核下的Makefile的基本认识
在Linux内核源码中编译内核模块(KO文件)时,内核源码必须先配置之后再编译,编译的时候
会先到源码的顶层目录的Makefile文件开始,然后再返回模块源码的所在目录继续编译。
内核下的Makefile模板
ifneq ($(KERNELRELEASE))
mymodule-objs:=mymodule1.o mymodule2.o
obj-m+=mymodule.o
else
PWD:=$(shell pwd)
KVER:=(shell uname -r)
KDIR:=/lib/module/$(KVER)/build
all:
$(MAKE) -C $(KDIR) M=$(PWD)
clean:
rm -rf *.o *mod.c *.ko *.symvers *markers *.order *~
endif
KERNELRELEASE变量的分析
其中$(KERNELRELEASE) 在执行make指令的死后指的是在/usr/src/linux-x.xx.x/Makefie中的一个变量。
这个变量子啊第一次make的时候是没有被设置的,因此Makefile的第一行ifneq判断为假的。执行else后面
即设置PWD、KVER、KDIR等变量。
伪命令all的分析
-C $(KDIR)指的是跳转到内核源码目录下读取Makefile.而 M=$(PWD)表示返回当前目录继续读入执行当前的
Makefile,第二次make,这时候$(KERNELRELEASE)已被定义,因此语句ifneq判断为真执行后面的内容。
ifneq后面的内容分析
其内容为kbuild语法,执行模块各个文件之间的依赖关系和目标文件
"mymodlie-objs:=mylodule1.o mymodule2.o"
表示 mymodlue.o 由mylodule1.o 和 mymodule2.o 链接生成。
"obj-m+=mymodule.o" 表示编译链接后将生成mymodule.ko模块
伪命令:clean分析
直接执行消除 *.o *mod.c *.ko *.symvers *markers *.order *~删除操作