嵌入式开发(八):makefie文件

makefie文件参数

     
-c 编译阶段使用,不做连接。生成ojb目标文件(.o)。如果不加该选项,直接完成编译与连接,并且不生成过程文件  
-o 指定输出文件,后面跟目标文件名,编译与连接阶段均可用                                                           
-g 生成调试信息  
-MD 生成目标文件的依赖关系,存放于.d文件中  
-MP 生成目标文件的依赖关系,存放于.d文件中  

 

    举例
$^ 所有依赖的名字,名字之间用空格隔开 $(F_EXE): $(SOURCES)
    $(CC) $(CFLAGS) $(CINCLUDES) $^ $(LDLIBS) $(LDFLAGS) -o $@
    $(STRIP) $(F_EXE)
$@ 目标文件名
$< 第一个依赖的文件  
all makefile文件默认只有1个目标,当有多个目标时,使用all指定最终的目标

all: $(F_EXE)

$(OBJECTS): %.o:%.cpp
    $(CC) $(CFLAGS) -c $(CINCLUDES) $^ -o $@

$(F_EXE): $(SOURCES)
    $(CC) $(CFLAGS) $(CINCLUDES) $^ $(LDLIBS) $(LDFLAGS) -o $@
    $(STRIP) $(F_EXE)

makefile自动化语句

1.自动获取到每个目录

#获取src目录内最大深度为3的所有子目录路径
SRC 	:= src
ALLSRC  := $(shell find $(SRC) -maxdepth 3 -type d)

2. 自动获取源文件及目标文件

#查找每个SUB_DIRS目录,获取到每个.c,赋值给到SRC
SRC := $(foreach dir, $(SUB_DIRS), $(wildcard $(dir)/*.c))
#自动获取到源文件对应的.o文件
OBJ := $(SRC:%.c=%.o)

CPPSRC := $(foreach dir, $(SUB_DIRS), $(wildcard $(dir)/*.cpp))
CPPOBJ := $(CPPSRC:%.cpp=%.o)

3. 在每个头文件目录路径名前加-I

CINCLUDES	:= $(patsubst %,-I%, $(INCLUDEDIRS:%/=%))

4. 每个库文件目录路径名前加-L

CLIBS		:= $(patsubst %,-L%, $(LIBDIRS:%/=%))

5. 静态(自动化)模式

下面代码中的第1行,$(OBJ)表示取目标名,%.o: %.c表示取目标中.o后缀的文件替换为.c,作为依赖文件。第2行的$<是指第1行中完成替换后的.c文件

$(OBJ): %.o: %.c
	$(CC) -c $< -o $@  $(INC_FLAGS) $(CFLAGS)

以上代码可简写为:

%.o: %.c
    $(CC) -c $< -o $@  $(INC_FLAGS) $(CFLAGS)

 

你可能感兴趣的:(嵌入式,makefile)