好,废话不多说,进入正题,来看我们今天的要讲的Makefile:
lcd.bin: start.o main.o led.o clock.o uart.o lib.o lcd.o
arm-linux-ld -Ttext 0x20000000 -o lcd.elf $^
arm-linux-objcopy -O binary lcd.elf $@
arm-linux-objdump -D lcd.elf > lcd.dis
gcc -o mktools mktools.c
./mktools $@ new_lcd.bin
%.o : %.S
arm-linux-gcc -o $@ $< -c
%.o : %.c
arm-linux-gcc -o $@ $< -c
clean:
rm *.o *.elf *.bin *.dis mktools
load:
dd iflag=dsync oflag=dsync if=new_lcd.bin of=/dev/sdb seek=1
1. Makefile的基本规则:
target... : prerequisites ...
command
target :目标文件,可以是obj文件,也可以是执行文件或标签
prerequisites: 要生成那个target所需要的文件或是目标。
command:make需要执行的命令,就是一些shell命令
注意: command前面是一个Tab,不是空格
2.第一行表示要编译出lcd.bin需要依赖后面的.o文件,接下来的四行就是command,通过它们来编译出lcd.bin。
3.arm-linux-ld是命令,交叉编译工具中的命令,-Ttext :指定代码段的起始地址 , -o :表示输出的文件。
4. $^ : 这是一个自动变量,它表示所有依赖目标的集合,即:start.o main.o led.o clock.o uart.o lib.o lcd.o 。
5.arm-linux-objcopy被用来复制一个目标文件的内容到另一个文件中,-O:输出的格式,在拷贝的过程中会进行格式转换。
6.$@ :这又是一个自动变量,它表示规则中的目标文件集,即lcd.bin
7. arm-linux-objcopy -O binary lcd.elf $@ : 这行是将.elf文件(lcd.elf)转换成二进制的.bin文件(lcd.bin)
8.arm-linux-objdump用来查看反汇编代码 , -D:表示反汇编所有的段。
9. 接着gcc编译mktools.c ,然后用编译出来的mktoos将lcd.bin转成new_lcd.bin
10.目标中的"%"定义表示对文件名的匹配,"%"表示长度任意的非空字符串, 如果要生成的start.o, 那么"%.s"表示start.s
11. $< : 依赖目标中的第一个目标名字。如果依赖目标是以模式(即"%")定义的,那么"$<"将是符合模式的一系列的文件集。注意,其是一个一个取出来的。
12.arm-linux-gcc -o $@ $< -c : 依次编译对应的目标, -c参数将对源程序进行预处理、编译、汇编操作。
13. load是一个label, 它下面的语句是执行dd命令,该命令的使用可以自行百度。
14.make执行流程: makefile一般是从上往下执行, 当执行第一行时,发现没有依赖对象,所以会先向下找,然后就找到有两个目标会编译出所需要的.o文件,所以依次执行arm-linux-gcc命令。编译出.o文件后就去第一行下面依次执行命令来编译出new_lcd.bin文件。
总结:该份Makefile比较复杂的就是那些自动变量和一些交叉编译命令,交叉编译命令比较少用,需要用的时候再查或直接拷贝过去用