模块编译Makefile的编写形式
主要的Makefile内容如下,非常的绕。
1 ifneq ($(KERNELRELEASE),)
2 # call from kernel build system
3
4 scull-objs := main.o pipe.o access.o
6 obj-m := scull.o
7
8 else
9
10 KERNELDIR ?= /lib/modules/$(shell uname -r)/build
11 PWD := $(shell pwd)
12
13 modules:
14 $(MAKE) -C $(KERNELDIR) M=$(PWD) LDDINC=$(PWD)/../include modules
16 endif
解释几个关键点:
else中:
modules标签中:
make -C ------- 进入$(KERNELDIR)
M=$(PWD) LDDINC=$... 是传给makefile的参数。
这么解释吧,假设当前这个makefile为A,在modules标签下面这条命令中,又是一个make命令,但是是到$(KERNELDIR)下面去找makefile,假设这个makefile为B,那么M LDDINC是传给B的参数,B可以使用这个参数进行运算。
第二次回到if中:
这次传给makefileB(其实是kernel的makefile)的参数为
scull-objs -------- 我这个模块每个文件.o文件。
obj-m --------- 最后生成的模块的文件名。