|
make 程序接受了 -C選項(xiàng)面在參數(shù)它自己先跳到 -C后面選項(xiàng)的目錄中在解析Makefile執(zhí)行Makefile的命令
make -C bsp/uboot -f $(UBOOT_MAK) clean -k:發(fā)現(xiàn)錯誤繼續(xù)編譯 -n:輸出要執(zhí)行的步驟但不執(zhí)行,如($ make -n -f Makefile hello)
-f:指定makefile的名字
export 會讓所有子makefile 享用變量 export BUILD_TOP_DIR :=$(shell pwd)
變量賦值的時候,有冒號的當(dāng)時就解析,沒有冒號的會在用的地方解析, 效果是=號取最后的值,而冒號則是按當(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 會不認(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
多級文件夾調(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ǎo)
$(O_DIR)/%.o: ./%.c
@echo compile $< to $@
$(CC) -c -o $@ $(CFLAG) -I $(INCLUDES) $<
生成depend, $< 輸入的依賴文件 ,$@為目標(biāo)文件
gcc 生成depend 格式為 filename.o filename.c includes. 注意不同情況下要對生成結(jié)果進(jìn)行轉(zhuǎn)換,下面是在o前加上$(O_DIR),
echo的 -n 參數(shù)會不在行尾生成回車符
$(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, 沒有文件時不報(bào)錯, include 會報(bào)錯停止
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ù)處理之后,可直接對生成的test.i文件編譯,生成匯編代碼:
gcc -S test.i -o test.s
gcc的-S選項(xiàng),表示在程序編譯期間,在生成匯編代碼后,停止,-o輸出匯編代碼文件。
|
|