一、Makefile介绍
Makefile是用于自动编译和链接的,一个工程有很多文件组成,每一个文件的改变都会导致工程的重新链接,但是不是所有的文件都需要重新编译,Makefile中纪录有文件的信息,在make时会决定在链接的时候需要重新编译哪些文件。
Makefile的宗旨就是:让编译器知道要编译一个文件需要依赖其他的哪些文件。当那些依赖文件有了改变,编译器会自动的发现最终的生成文件已经过时,而重新编译相应的模块。
二、Makefile写法
随着不断的学习当初学习HelloWorld模块时写的Makefile(obj-m := Hello.o)已经越来越不能满足需求,我终于意识到这个用于编译和链接的文件绝对不会这么简单,针对网上各种Makefile文件的写法,我们这种初学者一看就晕,我决定根据我学习的深入慢慢学习Makefile文件的写法:
当前我一般写Makefile文件一般写成:
obj-m := chardev.o
default:
make -Wall -C /lib/modules/`uname -r`/build M=`pwd` modules
clean:
rm *.ko modules.order Module* *.o *.mod.c
使用时很简单,make语句直接生成.ko文件,对模块重新编程后,使用make clean即可删除上次编译生成的文件,再次使用make即可生成修改后的模块文件(*.ko)!
下面贴上Makefile参考写法:
跟我一起写Makefile[1] http://blog.csdn.net/haoel/article/details/2886
Linux下Makefile 的automake生成详解 :http://blog.csdn.net/sooneboy/article/details/4030966