当前位置: > 华清远见教育科技集团 > 嵌入式学习 > 讲师博文 > 实验平台上Makefile详细的解释一
实验平台上Makefile详细的解释一
时间:2016-12-14作者:华清远见

# CORTEX-A8 PERI DRIVER CODE
        # VERSION 2.0
        # ATHUOR www.dev.hqyj.com
        # MODIFY DATE
        #2013.03.28 Makefile

/***(下面的解释将用这个的形式进行标注)
        写好的源文件,要编译成二进制文件.需要指定工具链的,这里指定我们的工具链是arm-none-eabi-,(arm体系结构,none厂商,eabi是编译环境,亦是arm-abi的编译环境),这里面的eabi的内容很多,可以理解成一个源文件是以何种方式生成可执行的二进制文件.后NAME指定是这个工程的工程名
        */

CROSS_COMPILE=arm-none-eabi-
        NAME=rtc

#==============================================================================================================#

/***为了使我们的Makefile简洁,需要将一些编译选项统统定义在CFLAGS中
        -g 表示为了调试gdb使用
        -O0 表示优化级别为0,就是不进行优化
        -mabi=apcs-gnu 使用gnu的apcs(ARM PROCEDUCE CALL STANDARD),它是指定用何种方式来实现函数的调用

        -mfpu=neno 硬件浮点单元
        -fno-builtin 表示不要使用编译器中默认的一些简单的内建函数,这里是因为我们重写了printf(使用了puts putc等等,将输出指定到串口上,输出到终端上),如果不使用这个编译选项,printf的输出结构将输出到tty上,也在我们的开发板上并没有这么一个用法。
        -nostdinc 不要在标准系统目录中寻找头文件.只搜索`-I'选项指定的目录(以及当前目录,如果合适).

        指定目标连接器
        LD = $(CROSS_COMPILE)ld
        指定目标编译器
        CC = $(CROSS_COMPILE)gcc
        目标复制命令生成二进制文件
        OBJCOPY = $(CROSS_COMPILE)objcopy
        目标倾倒命令(有点望文生义了)用来创建一个反汇编代码来检查生成的目标文件
        OBJDUMP = $(CROSS_COMPILE)objdump
        */

CFLAGS += -g -O0 -mabi=apcs-gnu -mfpu=neon -mfloat-abi=softfp -fno-builtin \
        -nostdinc -I ./common/include
        LD = $(CROSS_COMPILE)ld
        CC = $(CROSS_COMPILE)gcc
        OBJCOPY = $(CROSS_COMPILE)objcopy
        OBJDUMP = $(CROSS_COMPILE)objdump

#==============================================================================================================#

/**
        1、wildcard : 扩展通配符
        2、notdir : 去除路径
        3、patsubst :替换通配符

        注意下面的操作仅仅是一个字符串的通配、替换工作
        OBJSss :wildcard把 指定工程目录下的根目录/ 、 start/ 和 common/src/ 下的所有后缀是c的文件,和S文件全部展开。也就是OBJSss变量此时为全部相应的.c 和.S文件了(这里大家注意了这里用的是大S,大S好看一些吗?不是那是.S是支持gnu的汇编语法的文件,.s是只支持标准汇编的语法的文件)
        好下面就是字符串的替换了工作了
        OBJSs:将OBJSss中的.S文件带路径的替换成 .o文件,此时这个时候,OBJSs中只用.c和.o 了。
       &nbnbsp;OBJS将OBJSs中还没有替换掉的.c文件也替换成.o文件。
        现在再明白了吧,可是还没有完,做这些工作累死个人,就是仅仅的做字符串的替换?
        */

OBJSss := $(wildcard start/*.S) $(wildcard start/*.c)\ $(wildcard common/src/*.c) \
        $(wildcard common/src/*.S) $(wildcard *.c)\ $(wildcard *.S)
        OBJSs := $(patsubst %.S,%.o,$(OBJSss))
        OBJS := $(patsubst %.c,%.o,$(OBJSs))

#=============================================================================================================#

/***上面全是做一些准备工作,下面才到了编译的时候了,让我们继续
        all:是默认的终极目标,当我们执行make的时候,他就会去执行make all,当在整个Makefile中没有all的时候,一个目标标号就成了all(终极目标)
        当执行all的时候,首先将clean,然后需要依赖文件$(OBJS),这里比如a.o
        b.o c.o d.o,而在工程目录下,有a.c b.c c.s d.s ,然后这个时候当然是需要a.o了,发现在目标文件中去寻找a.S ,发现a.s不存在,发现存在a.c,便使用$(CC) $(CFLAGS) -c -o a.o a.c 来编译来生成a.o了
        */

%.o: %.S
        $(CC) $(CFLAGS) -c -o $@ $<
        %.o: %.c
        $(CC) $(CFLAGS) -c -o $@ $<
        all:clean $(OBJS)

发表评论
评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)