主要的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 --------- 最后生成的模块的文件名。

相关文章:

  • 2021-09-18
  • 2022-01-13
  • 2021-12-24
  • 2021-11-23
  • 2021-12-26
  • 2022-12-23
  • 2021-08-24
  • 2022-01-07
猜你喜欢
  • 2022-03-03
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-11-23
  • 2021-12-26
相关资源
相似解决方案