什么是Makefile
为了实现对多个项目文件的编译,我们将编译和处理规则放入到Makefile文件中。通过Makefile工具解析Makefile中的文件来指导整个工程项目的编译过程。
Makefile文件的基本规则
以t40_sdk_sample中的makefile为例:
sample-Encoder-video: $(SDK_LIB_DIR)/libimp.a $(SDK_LIB_DIR)/libalog.a sample-common.o sample-Encoder-video.o
$(CPLUSPLUS) $(LDFLAG) -o $@ $^ $(LIBS) -lpthread -lm -lrt
$(STRIP) $@
sample-Encoder-video是所要生成的目标,目标的右边是生成目标所需要的依赖文件,包括静态库和编译文件等;接着下面table键之后是生成目标的执行命令,将库文件和依赖文件链接生成最终的目标可执行文件。
变量的使用
变量赋值
条件赋值: ?=
CROSS_COMPILE ?= mips-linux-gnu-
即如果变量没有被定义过,那么变量的值就是右侧的值,如果变量先前被定义过,则赋值语句不发挥作用
追加赋值: +=
CFLAGS += -muclibc
即在后面追加值
延迟展开赋值: =
x = $(y)
y = hello
不同于我们写代码时的顺序声明,Makefile中等号右侧的变量可以定义在文件中的任意一处
直接展开赋值: :=
x := hello
y := $(x) world
符合顺序声明变量,只能使用前面定义好的变量
如果如下面这种写法,则就有问题,这时x的值就不是hello world,而是world。
x := $(y) world
y := hello
常用的默认自动化变量
$^ :表示所有的依赖文件
$@:表示生成的目标文件
$< :表示第一个依赖文件
%.o:%.c sample-common.h
$(CC) -c $(CFLAGS) $< -o $@
包含头文件路径
CFLAGS = $(INCLUDES) -O2 -Wall -march=mips32r2 //-march=mips32r2 编译器针对mips32r2架构优化
INCLUDES = -I$(SDK_INC_DIR)
Makefike 打印调试方法
任意位置打印–可选择info warning error
$(info "xxx")
$(warning "xxx")
$(error "xxx")