#Created by JamieChu 2019-06-19 ;
#几乎全自动了,改一下TARGET_BIN的值,然后扔到工程目录下,运行make命令就可以了;
#也可以自行修改VPATH来搜寻其他目录;
#本makefile会自动生成依赖并在make的时候自动判断依赖文件是否为最新;
VPATH = src:../headers #设置makefile额外的代码搜寻目录,不同目录之间用:分开
TARGET_BIN := keyled.bin
TARGET_ELF := $(patsubst %.bin,%.elf,$(TARGET_BIN))
TARGET_DUMP := $(patsubst %.bin,%.dump,$(TARGET_BIN))
SRC_S := $(shell ls *.S) #shaell是执行系统命令行命令的函数,这里执行了ls
SRC_C := $(shell ls *.c)
SRC_H := $(shell ls *.h)
OBJ_S := $(patsubst %.S,%.o,$(SRC_S)) #patsubst是模式替换函数
OBJ_C := $(patsubst %.c,%.o,$(SRC_C))
DEP_FILES := $(patsubst %.c,%.o.d,$(SRC_C)) #每个.o文件的make依赖信息,这假设每个c文件都配有h文件
DEP_FILES := $(wildcard $(DEP_FILES)) #筛选出真实存在的.d文件,或者直接使用shell函数来ls *.d
CC := arm-linux-gcc
AS := arm-linux-as
LD := arm-linux-ld
CFLAGS := -mcpu=arm920t
$(TARGET_BIN):$(OBJ_S) $(OBJ_C)
arm-linux-ld -Ttext 0 $^ -o $(TARGET_ELF)
arm-linux-objcopy -O binary -S $(TARGET_ELF) $(TARGET_BIN)
arm-linux-objdump -D $(TARGET_ELF) > $(TARGET_DUMP)
ifneq ($(DEP_FILES),) #第一次编译,肯定没有.d文件,那么DEP_FILES就是空,所以不执行include
include $(DEP_FILES) #第二次编译刚好相反,所以include这个依赖信息进来
endif
%.o:%.S
$(AS) $(CFLAGS) $< -o $@
%.o:%.c
$(CC) $(CFLAGS) -c $< -o $@ -MD -MF $@.d
.PHONY:clean cleanall cleandepfiles
clean:
rm -rf *.o *.elf *.dump *.bin
cleanall:
rm -rf *.o *.elf *.dump *.bin *.d
cleandepfiles:
rm -rf *.d