歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

實驗平台上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)   

Copyright © Linux教程網 All Rights Reserved