2.6 内核模块的Makefile模板
2011-01-27 09:58
459 查看
# Makefile2.6 ifneq ($(KERNELRELEASE),) #kbuild syntax. dependency relationshsip of files and target modules are listed here. mymodule-objs := file1.o file2.o obj-m := mymodule.o else PWD := $(shell pwd) KVER ?= $(shell uname -r) KDIR := /lib/modules/$(KVER)/build all: $(MAKE) -C $(KDIR) M=$(PWD) clean: rm -rf .*.cmd *.o *.mod.c *.ko .tmp_versions endif
KERNELRELEASE是在内核源码的顶层Makefile中定义的一个变量,在第一次读取执行此Makefile时,KERNELRELEASE没有被定义, 所以make将读取执行else之后的内容。如果make的目标是clean,直接执行clean操作,然后结束。当make的目标为all时,-C $(KDIR) 指明跳转到内核源码目录下读取那里的Makefile;M=$(PWD) 表明然后返回到当前目录继续读入、执行当前的Makefile。当从内核源码目录返回时,KERNELRELEASE已被被定义,kbuild也被启动去解析kbuild语法的语句,make将继续读取else之前的内容。else之前的内容为kbuild语法的语句, 指明模块源码中各文件的依赖关系,以及要生成的目标模块名。mymodule-objs := file1.o file2.o表示mymoudule.o 由file1.o与file2.o 连接生成。obj-m := mymodule.o表示编译连接后将生成mymodule.o模块。
补充一点,"$(MAKE) -C $(KDIR) M=$(PWD)"与"$(MAKE) -C $(KDIR) SUBDIRS =$(PWD)"的作用是等效的,后者是较老的使用方法。推荐使用M而不是SUBDIRS,前者更明确。
通过以上比较可以看到,从Makefile编写来看,在2.6内核下,内核模块编译不必定义复杂的CFLAGS,而且模块中各文件依赖关系的表示简洁清晰。
转自:http://www.ibm.com/developerworks/cn/linux/l-module26/
相关文章推荐
- linux2.6内核模块编译的makefile模板
- 两个编译2.4与2.6内核模块的Makefile 模板
- 两个编译2.4与2.6内核模块的Makefile 模板
- 2.6 内核模块的Makefile模板
- 两个编译2.4与2.6内核模块的Makefile 模板(支持交叉编译)
- Linux 2.6 下内核模块的Makefile
- 模块编译KO文件Makefile 2.6内核通用
- linux 内核模块编译的Makefile模板
- linux 2.6内核 编译模块Makefile 详解!
- linux2.4与2.6内核模块的Makefile模版
- Linux 2.6内核驱动模块Makefile模版
- linux 2.6内核 编译模块Makefile 详解
- linux 2.6 内核模块的Makefile
- 内核模块编译Makefile模板
- Linux 2.6 下内核模块的Makefile
- linux 2.6内核 编译模块Makefile
- .mod.c是什么文件,及内核模块Makefile模板
- linux 2.6内核 编译模块Makefile 详解
- linux 内核2.6和linux内核2.4 驱动程序makefile的编写的区别!!!!
- 编译内核模块的Makefile中的($(KERNELRELEASE)