1.
makefile基本格式:
目标(target): 依赖 (prerequest)
命令(command)
当依赖比目标新的时候才会执行命令。
2.
如下,makefile只会执行生成第一个目标的命令,即arm-linux-gcc mystart.s。
而生成第二个目标的命令arm-linux-gcc -c mylowlevel_init.s命令并不会被执行。
3.
解决第二个目标的命令并不会被执行方法是,定义一个伪目标all。 all依赖mystart.o和mylowlevel_init.o.这样makefile会首先检查编译两个依赖mystart.o和mylowlevel_init.o。
4.
伪目标下面也可以添加命令,比如下面的arm-linux-ld -Tmyboot.lds -o myboot mystart.o mylowlevel_init.o, …
5.
为了能够让makefile检查到链接脚本myboot.lds是否有变化,我们重新定义一个真实的目标myboot.
6.
也可以只定义目标不添加依赖,在命令行直接使用make mksd执行目标command.
7.自动化变量$<的使用
$<在模式匹配中表示第一个依赖文件。例如makefile在解析myboot: mystart.o mylowlevel_init.o myboot.lds时,碰到mystart.o就会找mystart.s,碰到mylowlevel_init.o就会找mylowlevel_init.s。当然myboot.lds没有匹配到%.o,也就不会去找它的.s文件了。
makefile可以重写为:
8.自动化变量$@的使用
如果想要保留编译期间的目标文件.o文件,我们可以使用自动化变量$@来指定。
makefile可以重写为:
9.变量
常用:=定义变量