导读:
Comp.mak        完成模块编译连接,生成bin
Gsm2.mak        主编译文件,完成clean,remake,new等工作
XXX_GPRS.mak 客户私有的配置,根据客户的不同,而设定不同的配置文件
Option.mak      工程中的基本配置及宏定义文件
Verno_XXX.bld 版本文件
Custom.bld      要保证在客户版本中都使用相同的配置的地方要写在这里,这个里面的一些文件不能被改变

第一步:

1.Make.bat 命令首先调用ChgFileMode.bat,将编译过程中需要用到的文件的只读属性修改为可读写,再调用make2.pl。
2.Make2.pl 的主要工作就是匹配gsm2.mak的参数,然后通过命令:

system("${makeCmd} -f${makeFolder}${myMF} -r -R CUSTOMER=$custom PROJECT=$project $action");

来调用gsm2.mak。


具体解析出来就是:


make -f makegsm2.mak -r –R CUSTOMER=工程名 PROJECT=gprs new|update|remake


第二步:整个过程如下

Gsm2.mak

Option.mak

XXX_GPRS.mak

REL_CR_MMI_GPRS.mak

USER_SPECIFIC.mak


1. 在Gsm2.mak文件的开始处调用了option.mak文件。


2. Option.mak又将make$(strip $(CUSTOMER))_$(strip$(PROJECT)).mak文件包含进来

        

      这个模式匹配结果为:make目录下,工程名称_GPRS.mak,如K500GSD_GPRS.mak。


3. 在$(strip $(CUSTOMER))_$(strip$(PROJECT)).mak文件中又调用了 REL_CR_MMI_$(strip$(PROJECT)).mak文件

     这个文件模式具体被解析为make目录下的 REL_CR_MMI_GPRS.mak文件。REL_CR_MMI_GPRS.mak这个文件定义了那些文件需要加入到编译目录中,其中定义了MMI部分的编译目录为MMIDIR = plutommi。


在变量CUS_REL_BASE_COMP中定义了资源的编译目录:


CUS_REL_BASE_COMP += $(strip $(MMIDIR))mmi $(strip $(MMIDIR))mtkapp $(strip$(MMIDIR))tool $(MMIDIR)WIN32FS

CUS_REL_BASE_COMP += $(strip$(MMIDIR))CustomerCustomerInc

$(strip $(MMIDIR))CustomerCustomize

$(strip $(MMIDIR))CustomerCustResource$(strip $(MMI_VERSION))

$(strip $(MMIDIR))Customerdebug

$(strip $(MMIDIR))CustomerImagesGameImages

$(strip $(MMIDIR))CustomerImagesdecoder

$(strip $(MMIDIR))CustomerRes_MMI

$(strip $(MMIDIR))CustomerResGenerator

$(strip $(MMIDIR))CustomerResourceDLL

$(strip $(MMIDIR))CustomerResources

$(strip $(MMIDIR))CustomerAudio


客户的资源需要编译如下文件:CUS_REL_SRC_COMP += mmiresource mtkapp gdi_arm plutommi vendorapp

图片名称为:CUS_REL_BASE_COMP += $(strip$(MMIDIR))CustomerImages$(strip $(MMI_PROJ))$(strip$(MAIN_LCD_SIZE)),

     可解析为如:plutommicustomerimagesK500GSD176X220


REL_CR_MMI_$(strip $(PROJECT)).mak

其中CUS_REL_OBJ_LIST这个变量存储了连接过程中所需要的文件名称


4.make$(strip $(CUSTOMER))_$(strip$(PROJECT)).mak文件的功能


CUSTOM_OPTION定义了所有需要编译进去的功能模块的宏。


COMPLIST变量的功能:

ifeq ($(strip $(RTOS)),NUCLEUS)

COMPLIST = nucleus nucleus_int nucleus_ctrl_code nucleus_critical_data

Endif

如果操作系统为NUCLEUS,那么COMPLIST为后面的值,COMPLIST为所要编译的文件列表,里面存放了很多*.inc文件,展开后就变为

configinclude

stacklibinclude

adaptationinclude

kalinclude

     等等


5. option.mak文件的在后面调用了makeUSER_SPECIFIC.mak
  如果使用CPU为ARM,则编译工具目录为如下定义

ifeq ($(strip $(COMPILER)),ADS)

DIR_ARM       =    c:progra~1armadsv1_2

DIR_ARM      := $(strip $(DIR_ARM))

DIR_TOOL     =    $(DIR_ARM)bin

DIR_ARMLIB =    $(DIR_ARM)lib

DIR_ARMINC =    $(DIR_ARM)include

Endif


连接打包工具等为如下几个:


DIR_TOOL := $(strip $(DIR_TOOL))

LINK = $(DIR_TOOL)armlink.exe # Linker

ASM   = $(DIR_TOOL)armasm.exe # ARM assembler

LIB    =          $(DIR_TOOL)armar.exe     # Library tool

BIN_CREATE = $(DIR_TOOL)fromelf.exe   # Binary tool


下面这段代码告诉我们需要用什么编译工具来编译

ifeq ($(strip $(COMPILER)),ADS)

ifeq ($(strip $(COMPILE_MODE)),INST16)

CC        =       $(DIR_TOOL)tcc.exe      # Thumb Mode(16bits), use tcc

CC32       =       $(DIR_TOOL)armcc.exe # ARM Mode(32bits), use armcc

CPPC   = $(DIR_TOOL)tcpp.exe    # Thumb Mode(16bits), use tcc

CPPC32   = $(DIR_TOOL)armcpp.exe # ARM Mode(32bits), use armcc

else

ifeq ($(strip $(COMPILE_MODE)),INST32)

CC         =       $(DIR_TOOL)armcc.exe   # ARM Mode(32bits), use armcc

CPPC       =       $(DIR_TOOL)armcpp.exe # ARM Mode(32bits), use armcc

else

CC         =       $(DIR_TOOL)tcc.exe        # Default tcc

CC32      =      $(DIR_TOOL)armcc.exe     # ARM Mode(32bits), use armcc

CPPC      =    $(DIR_TOOL)tcpp.exe       # Thumb Mode(16bits), use tcc

CPPC32 =     $(DIR_TOOL)armcpp.exe    # ARM Mode(32bits), use armcc

endif

endif

endif


ifeq ($(strip $(PLATFORM)),MT6223P)

AFLAGS := -g -littleend -cpu ARM7EJ-S

Endif


COMMINCDIRS变量在先包含了基本功能模块的inc目录后再包含如下文件

COMMINCDIRS += $(DIR_ARMINC) $(CUSTOM_COMMINC),


6.Option.mak中定义了一些附加功能模块的编译模式
     (是否被编译,被编译成什么样的结果),比如说蓝牙,UART3,WIFI,USB,WAP等等,还有一些编译器的设置。


我们的版本号和Scat文件被定义在这个变量中:5056L

SCATTERFILE = customsystem$(strip$(BOARD_VER))scat$(strip $(PLATFORM)).txt

VERNOFILE    = makeVerno_$(CUSTOMER).bld


.bin文件的名称设置在这个变量TARGNAME = $(CUSTOMER)_$(strip$(SUB_BOARD_VER))_$(PROJECT)_$(strip $(PLATFORM))_$(strip$(CHIP_VER))


TST_DB := $(strip $(TSTDIR))database_classb


然后被包含到Option.mak文件中来,include $(strip$(VERNOFILE))。


7.Gsm2.mak文件中new执行的指令


     new所执行的指令

new : cleanall cmmgen mmi_feature_check asngen codegen asnregen operator_check_lite update


update所执行的指令

update : cleanlog cleanbin mcddll_update codegen resgen cksysdrv remake


remake所执行的指令

remake : mcp_check cleanlog cleanbin genverno libs $(BIN_FILE) done


resgen用来编译资源文件:Res_XXX.c


(echo CUSTOM_OPTION = $(foreach def,$(BOARD_VER) $(PLATFORM) $(LCD_MODULE) $(EXT_CAM_MODULE)$(CMOS_SENSOR),-D "$(def)") >$(MMIDIR)customerresGeneratorcustom_option.txt)

首先将CUSTOM_OPTION重定向到custom_option.txt中


(type make~cus_opt.tmp >>$(MMIDIR)customerresGeneratorcustom_option.txt)

使用toolsstrcmpex.exe生成~cus_opt.tmp, ~tgt_opt.tmp,~inc.tmp三个文件

将~cus_opt.tmp 重定向到custom_option.txt中


(@del $(MMIDIR)mmiTargetOption.txt) &

(copy /Y make~tgt_opt.tmp $(MMIDIR)MMITargetOption.txt)

再将TargetOption.txt更新一下,将~tgt_opt.tmp重定向到TargetOption.txt中


(type make~inc.tmp >$(MMIDIR)customerresGeneratorcustom_include.tmp)

再将~inc.tmp重定向到custom_include.tmp中,


执行replace_project_name.pl文件,编译Res_XXX.c

再执行ResGenerator_HW.bat,编译资源文件。