linux实验三makefile,实验平台上Makefile详细的解释
作者:甘老師,華清遠見嵌入式學院講師。
# CORTEX-A8 PERI DRIVER CODE
# VERSION 2.0
# ATHUOR www.linuxidc.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 了。
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)
相關閱讀:
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的linux实验三makefile,实验平台上Makefile详细的解释的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 支付宝生活费是什么?支付宝生活费在哪领?
- 下一篇: 国际信用卡组织有哪些