转载注明转载址:http://blog.csdn.net/oyhb_1992/article/details/72763503
obj-m := helloword.o #你要编译的模块名称 这里必须和$(PWD)目录下C程序文件的名称相对应,如果C程序文件为helloword.c,那么必须修改 成obj-m=helloword.o
#General Purpose Makefile for Linux Kernel module by guoqingbo
KERN_DIR = /home/gqb/development/linux-kernel-2.6.37 #内核源码路径
#KERN_DIR = /usr/src/$(shell uname -r)
#KERN_DIR = /lib/modules/$(shell uname -r)/build
all:
make -C $(KERN_DIR) M=$(shellpwd) modules CROSS_COMPILE=arm-linux- ARCH=arm #进入内核源码路径,执行#make modules
clean:
make -C $(KERN_DIR) M=$(shell pwd) modules clean
rm -rf modules.order
KERN_DIR表示内核源码目录,这种方式适用于嵌入式开发的交叉编译,KERN_DIR目录中包含了内核驱动模块所需要的各种头文件及依赖。
-C表示change指定进入指定的目录即KERN_DIR,是内核源代码目录,调用该目录顶层下的Makefile,目标为modules。
M=$(shell pwd)选项让该Makefile在构造modules目标之前返回到模块源代码目录并在当前目录生成obj-m指定的xxx.o目标模块。
clean这个目标表示将模块清理掉
obj-m += xxx.o即指定当前目录要生成的目标模块,然后modules目标指向obj-m变量中设定的模块
make命令选项
-C的作用,-C是指ChangeDirectory。
M=$(PWD) 是指要编译的内核模块的源程序在那个目录下,$(PWD)指与Makefile在同一目录下,也就是当前目录。(pwd命令的作用是:printwork directory).
modules指明要按照内核模块的方式编译。
结合起来理解
就是进入$(KERNELDIR)的目录,并且执行make命令,如果没有M=$(PWD) modules,make–C $(KERNELDIR) CROSS_COMPILE=arm-linux- ARCH=arm将是编译Linux内核映像的指令。M=$(PWD) modules也就是按照$(KERNELDIR)中内核模块的方式编译$(PWD)目录下的程序。modules实际上是$(KERNELDIR)目录下的Makefile的一个Target目标入口.
既然是为$(KERNELDIR)编译内核模块,所以必须要求$(KERNELDIR)这个内核必须正确配置,并且得到编译的,以为编译模块的过程需要使用内核配置的相关信息,比如处理器的类型等。
正确的配置和编译了$(KERNELDIR)的内核,就可以编译hello的内核模块了,你将会在当前的目录中看到一个hello.ko的内核模块