首页 > 其他 > 详细

Makefile 工程管理

时间:2016-03-05 00:06:57      阅读:249      评论:0      收藏:0      [点我收藏+]

Makefile 工程管理

Makefile 规则 --变量

Makefile中,用户除了可以自己定义变量外,还可以使用存在系统已经定义好的默认变量

$^:代表所有的依赖文件

$@:代表目标

$<:代表第一个依赖文件

Makefile使用技巧

--去回显

Makefile 中“#”字符后的内容被视作注释

@:取消回显

 

使用技巧 – 文件名

Make命令默认在当前目录下寻找名字为Makefile或者makefile的工程文件,当名字部位这两者之一时,可以使用如下方法指定:

make –f 文件名

 

结构化Makefile文件的编写

顶层Makefile

OBJS: = start.o main.o mem.o dev/dev.o lib/lib.o

CFLAGS: = -fno-builtin –I$(shell pwd)/include

export CFLAGS

 

gboot.bin : gboot.elf

arm-linux-objcopy –O binary gboot.elf gboot.bin

 

boot.elf : $(OBJS)

arm-linux-ld-Tgboot.lds –o gboot.elf $^

 

%.o : %s

arm-linux-gcc –g –c $^

 

lib/lib.o

make –C lib all

 

dev/dev.o

make –C dev all

 

.PHONY:clean

clean:

rm *.o *.elf *.bin

make –C lib clean

make –C dev clean

 

dev文件夹的Makefile

objs:= button.o interrupt.o led.o nandflash.o uart.o

 

all:$(objs)

arm-linux-ld –r –o dev.o $^

%.o : %.c

arm-linux-gcc ${CFLAGS} –C $^

%.o:%.S

arm-linux-gcc ${CFLAGS} –C $^


clean:

rm –f *.o

 

lib文件夹中的Makefiledev文件夹中的Makefile基本一样,就是objs后面的不一样

 

Makefile 工程管理

原文:http://www.cnblogs.com/love-linux/p/5243757.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!