内核模块的Makeflie在执行时首先进入到 内核代码树执行其顶层的Makefile执行,然后再次进入这里读取编译目标和文件依赖关系进行真正的编译工作,因此执行一次make此Makefile就会被执行两次,这两次过程需要用条件语句来判别,这里用了变量KERNELRELEASE,它原来为空,在执行内核顶层Makefile时被赋值(即第一次执行此模块Makefile时),因此第一次执行else后面的流程,当第二次进入时执行ifneq流程,从流程中可以看到模块的编译过程事实上由内核代码树中的makefile控制,第二次进入模块的Makeflie的目的是指明要生成的模块名字和代码文件的依赖关系(当模块只有一个代码文件时不需要指明依赖关系)。Makeflie代码例子如下
ifneq($(KERNELRELEASE),) #如果变量KERNELRELEASE不为空,则说明编译器第二次执行此Makefile
obj-m := myscull.o #告诉代码树需要生成的模块名字
else #第一次执行时的流程
KDIR := /home/yongjian/linux_source/linux-3.0.1 #指明内核代码树所在目录
PWD := $(shell pwd) #当前目录
module:
$(MAKE) -C $(KDIR) -M $(PWD) modules #这个make命令首先进入KDIR执行里面的Makefile然后再根据PWD的目录返回执行此Makefile
endif
ifneq($(KERNELRELEASE),) #如果变量KERNELRELEASE不为空,则说明编译器第二次执行此Makefile
obj-m := myscull.o #告诉代码树需要生成的模块名字
else #第一次执行时的流程
KDIR := /home/yongjian/linux_source/linux-3.0.1 #指明内核代码树所在目录
PWD := $(shell pwd) #当前目录
module:
$(MAKE) -C $(KDIR) -M $(PWD) modules #这个make命令首先进入KDIR执行里面的Makefile然后再根据PWD的目录返回执行此Makefile
endif