因工作需要,现需要学习linux设备驱动,从最简单的字符设备驱动开始,把自己的学习点滴记录下来,坚持自己去思考和总结。
我为第一个hello world字符驱动程序写的makefile如下所示:
#KVERS = $(shell uname -r)
ifneq ($(KERNELRELEASE),)
obj-m += hello_world.o
else
KERDIR =/usr/src/linux-headers-3.2.0-33-generic
#/lib/modules/3.2.0-33-generic/build
#/usr/src/linux-headers-3.2.0-33-generic
CURDIR =/home/wangyihong/my-drivers/first-driver/
default:
$(MAKE)-C $(KERDIR) M=$(CURDIR) modules
clean:
$(MAKE)-C $(KERDIR) M=$(CURDIR) clean
endif
其中,第一句ifneq ($(KERNELRELEASE),)表示如果KERNELRELEASE已定义则执行下面的语句,如果没有定义则执行else分支。显然逗号后面为空,显然,开始make的时候KERNELRELEASE也为空,二者相等执行else分支语句
KERDIR =/usr/src/linux-headers-3.2.0-33-generic指定内核源码存放的目录,其实
KERDIR = /lib/modules/$(shelluname -r)/build也可以找到,他们的内部结构是一样的,$(shelluname -r)表示执行shell命令uname -r输出内核版本
CURDIR =/home/wangyihong/my-drivers/first-driver是我编写驱动源程序存放的路径。
当make的时候,首先执行else分支的default:$(MAKE) -C $(KERDIR) M=$(CURDIR)modules,$(MAKE)表示make,-C $(KERDIR) 表示到存放内核的目录执行其makefile,在执行过程中会定义KERNELRELEASE,然后M=$(CURDIR)表示返回到当前目录,再次执行makefile,modules表示编译成模块的意思。
而此时KERNELRELEASE已定义,则会执行obj-m += hello_world.o,表示会将hello_world.o目标编译成.ko模块。若有多个源文件,则采用如下方法:
obj-m := hello_world.o
hello_world-objs := file1.o file2.o file3.o
最后make clean目标的时候,会将make生成的文件全部给删除掉。
以上是我学习为hello world驱动模块加载编写的一个makefile的分析总结,若有错误之处,请指正,菜鸟启动linxu设备驱动之旅!
本文详细介绍了如何学习Linux设备驱动,从最简单的字符设备驱动开始,通过实例展示了如何编写和使用Makefile进行编译。重点分析了一个helloworld字符驱动程序的Makefile,解释了关键代码段的作用,包括内核源码目录设置、编译命令的执行流程及Makefile的执行逻辑。


被折叠的 条评论
为什么被折叠?



