多Makefile的例子

还是以前面的例子,通常我们并不将所有的源代码和Makefile放在同一个目录下,尤其对比较大的工程而言。在这里假设有led这个工程,在led这个工程目录下有个main目录,main目录下的文件为前面的main.c、delay.c和delay.h,main目录下的Makefile如下:
CC      = sdcc

all:delay.rel main.rel

delay.rel:delay.c
        $(CC) -c delay.c

main.rel:main.c delay.h
        $(CC) -c main.c

.PHONY:clean
clean:
        -rm delay.asm delay.lst delay.rel delay.sym delay.rst\
                main.asm main.lst main.rel main.sym main.rst
在main目录,只是对.c文件做编译,不进行最后的链接,而在上一个层的工程根目录下做最后的链接,Makefile如下:
CC      = sdcc

all:led.bin

led.bin:led.ihx
        makebin led.ihx led.bin

led.ihx:main/delay.rel main/main.rel
        $(CC) -o led.ihx main/delay.rel main/main.rel

main/delay.rel main/main.rel:
        cd main && make

.PHONY:clean
clean:
        -rm led.bin led.ihx led.lk led.map led.mem
        cd main && make clean


整个工程可以从这里下载:http://download.csdn.net/detail/mcgrady_tracy/6845081

你可能感兴趣的:(多Makefile的例子)