標(biāo)題: MAKEFILE 心得(原創(chuàng)) [打印本頁]

作者: atrons    時(shí)間: 2017-1-19 07:48
標(biāo)題: MAKEFILE 心得(原創(chuàng))
make 程序接受了 -C選項(xiàng)面在參數(shù)它自己先跳到 -C后面選項(xiàng)的目錄中在解析Makefile執(zhí)行Makefile的命令
  make -C bsp/uboot -f $(UBOOT_MAK) clean
-k:發(fā)現(xiàn)錯(cuò)誤繼續(xù)編譯
  -n:輸出要執(zhí)行的步驟但不執(zhí)行,如($ make -n -f Makefile hello)
  -f:指定makefile的名字

export 會(huì)讓所有子makefile 享用變量 export BUILD_TOP_DIR  :=$(shell pwd)
變量賦值的時(shí)候,有冒號(hào)的當(dāng)時(shí)就解析,沒有冒號(hào)的會(huì)在用的地方解析, 效果是=號(hào)取最后的值,而冒號(hào)則是按當(dāng)前順序當(dāng)前的值
OUT_DIR :=$(subst \,/,$(OUT_DIR))
OUT_DIR =$(subst \,/,$(OUT_DIR))


foreach 基本用法
sublibs := $(foreach n,$(SUBCOMPONENTS),$(OUT_DIR)/$(n)/$(n).a)

替換換展名
COBJS = $(SRCC:.c=.o)
COBJS := $(COBJS:.C=.o)

增加前綴 addprefix
COBJS := $(addprefix $(O_DIR)/,$(COBJS))


WIN32 操作系統(tǒng)中要把路徑中的 '\' 變成 '/' , 要不問題無窮 (msys 會(huì)不認(rèn),但又得用win32 路徑找文件)
DEP_INC := $(subst \,/,$(DEP_INC))

msys 的路徑格式為
/c/work/OK2440/build

gcc 參數(shù)中只認(rèn)msys格式路徑
DEP_INC := $(subst C:,/c,$(DEP_INC))


ifneq ($(DEP_INC),)
        DEP_INC := -I$(DEP_INC)
endif


多級(jí)文件夾調(diào)用
SUBCOMPONENTS += $(blabla)
Make_Sub:
        @for subdir in $(SUBCOMPONENTS); do \
          mkdir -p $(OUT_DIR)/$$subdir;\
          (cd $$subdir && make -f $(MAKEFILE) sub_all O_DIR=$(OUT_DIR)/$$subdir); \
        done;



自動(dòng)推導(dǎo)
$(O_DIR)/%.o: ./%.c
        @echo compile $< to $@
        $(CC) -c -o $@ $(CFLAG) -I $(INCLUDES) $<  



生成depend,  $< 輸入的依賴文件 ,$@為目標(biāo)文件
gcc 生成depend 格式為 filename.o filename.c includes. 注意不同情況下要對(duì)生成結(jié)果進(jìn)行轉(zhuǎn)換,下面是在o前加上$(O_DIR),
echo的 -n 參數(shù)會(huì)不在行尾生成回車符
$(DEP_DIR)/%.d: %.c  
                @echo Depend: $< to $@
                @echo -n  $(O_DIR)/ > $@
                @$(GCC) $(DEP_OPT) -I$(DEP_INC) $< >> $@


clean 和其它操作不要depend , 傳入?yún)?shù) NODEP=yes
          (cd $$subdir && make -f $(MAKEFILE) sub_clean O_DIR=$(OUT_DIR)/$$subdir NODEP=yes) ; \



包含方式sinclude是兼容unix的-include, 沒有文件時(shí)不報(bào)錯(cuò), include 會(huì)報(bào)錯(cuò)停止

ifndef NODEP  
ifneq ($(DEPS),)  
        sinclude $(DEPS)  
endif                 
endif


還是msys 的格式,不認(rèn)'('和')', 得加轉(zhuǎn)義符
LINKFLAG=-armlib -map -entry __ENTRY -first 2440init.o(Init) -ro-base 0x30010000 -->
LINKFLAG=-armlib -map -entry __ENTRY -first 2440init.o\(Init\) -ro-base 0x30010000




2.1預(yù)處理gcc -E test.c -o test.i 或 gcc -E test.c可以輸出test.i文件中存放著test.c經(jīng)預(yù)處理之后的代碼。打開test.i文件,看一看,就明白了。后面那條指令,是直接在命令行窗口中輸出預(yù)處理后的代碼.gcc的-E選項(xiàng),可以讓編譯器在預(yù)處理后停止,并輸出預(yù)處理結(jié)果。在本例中,預(yù)處理結(jié)果就是將stdio.h 文件中的內(nèi)容插入到test.c中了。

2.2編譯為匯編代碼(Compilation)
預(yù)處理之后,可直接對(duì)生成的test.i文件編譯,生成匯編代碼:
gcc -S test.i -o test.s
gcc的-S選項(xiàng),表示在程序編譯期間,在生成匯編代碼后,停止,-o輸出匯編代碼文件。







歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1