# 一个Makefile的进化(三)

一个Makefile的进化(三)

makefile配置分离与交叉编译设置
目标:
1.分离makefile的配置
2.增加交叉编译的例子
3.增加定制显示输出的变量Q

string@asus:~/Projects/makefile$ tree 
.
├── config.mk
├── include
│   └── test.h
├── Makefile
├── rule.mk
└── src
    ├── Makefile
    ├── test.c
    └── test_fun1.c

上一篇已经完成一个比较成熟的Makefile, 但是为了让配置更容易,特地的在本片进一步修改,使期更加方便配置,看起来更加清晰明了
先放代码

主Makefile

include config.mk 
include rule.mk 

all:$(OUTDIR) .build.stamp

$(OUTDIR):
    $Qmkdir $@
    @echo creat:"$@"

.build.stamp: $(OBJS)
    $(Q) $(LINK.c) $^ $(LOADLIBES) $(LDLIBS) -o $(OUTDIR)/$(PROJECT)
    @echo link "\e[32;1m[$(PROJECT)]:$^"
    $(Q) touch $@ 
clean:
    $(Q) $(RM) .build.stamp
    $(Q) rm -rf $(OUTDIR)
    echo clean all

.PHONY : clean 

rule.mk

PROJECT:= $(notdir $(SRCDIR)) 
include $(SRCDIR)/Makefile
OBJS=$(addprefix $(OUTDIR)/,$(OBJ))

$(OUTDIR)/%.o:$(SRCDIR)/%.c
     $(Q) $(COMPILE.c) $(OUTPUT_OPTION) $<
     @echo compile [$(PROJECT)]:$<

config.mk

Q:=@
CPPFLAGS:=-Iinclude
#CC=arm-linux-gnueabi-gcc

OUTDIR:=out
SRCDIR:=src

分离原则

所有的生成规则放在rule.mk
所有的字符串拼接放在rule.mk
所有的变量赋值放在config.mk

代码解释:
在主Makefile包含两个配置mk,注意顺序不能变,因为在config.mk中有rule.mk需要的变量,有时候在实际工作中发现明明修改了一个变量的值但是却不生效,很可能是这个原因引起的

清注意一下config.mk的下面几行

Q:=@
#CC=arm-linux-gnueabi-gcc

这几行是对变量的赋值,第一个赋值是在make的时候信息显示开关变量,用于控制make的时候的输出内容,
第二个变量是在交叉编译的时候对编译连进行赋值,有了这一行就可以生成arm下可以运行的二进制,这里默认将其注释了,如果要编译arm版的,删除注释即可
演示中我已经删除注释,下面是make后的输出结果

string@asus:~/Projects/makefile$ make
creat:out
compile [test]:src/test.c
compile [test]:src/test_fun1.c
link [test]:out/test.o out/test_fun1.o
string@asus:~/Projects/makefile$ file out/test
out/test: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.3, for GNU/Linux 3.2.0, BuildID[sha1]=9bfee606c64bb9989671ffdee00660e4a26b7da8, not stripped
string@asus:~/Projects/makefile$ 

在这里我特意使用file看了以下文件的属性,注意生成的文件是ARM 版的文件
至此这篇已经结束
这篇的Makefile已经可以在设计工作中使用了,可能需要稍做修改,希望这篇文章可以帮助大家学习Makefile

你可能感兴趣的:(# 一个Makefile的进化(三))