`
csstome
  • 浏览: 1554906 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

MTK 软件工程的配置说明

阅读更多

本文详解MTK的编译过程,并会根据我的理解来更新。阅读上文对本文的一些文件和术语会有很好的帮助。

导读:
  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 make\gsm2.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))\Customer\CustomerInc \
  $(strip $(MMIDIR))\Customer\Customize \
  $(strip $(MMIDIR))\Customer\CustResource\$(strip $(MMI_VERSION))\
  $(strip $(MMIDIR))\Customer\debug \
  $(strip $(MMIDIR))\Customer\Images\GameImages \
  $(strip $(MMIDIR))\Customer\Images\decoder \
  $(strip $(MMIDIR))\Customer\Res_MMI \
  $(strip $(MMIDIR))\Customer\ResGenerator \
  $(strip $(MMIDIR))\Customer\ResourceDLL \
  $(strip $(MMIDIR))\Customer\Resources \
  $(strip $(MMIDIR))\Customer\Audio
  客户的资源需要编译如下文件:CUS_REL_SRC_COMP += mmiresource mtkapp gdi_arm plutommi vendorapp
  图片名称为:CUS_REL_BASE_COMP += $(strip$(MMIDIR))\Customer\Images\$(strip $(MMI_PROJ))$(strip$(MAIN_LCD_SIZE)),可解析为如:
  plutommi\customer\images\K500GSD176X220
  
  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文件,展开后就变为
  config\include
  stacklib\include
  adaptation\include
  kal\include等等
  
  5. option.mak文件的在后面调用了make\USER_SPECIFIC.mak
  如果使用CPU为ARM,则编译工具目录为如下定义
  ifeq ($(strip $(COMPILER)),ADS)
  DIR_ARM = c:\progra~1\arm\adsv1_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 = custom\system\$(strip$(BOARD_VER))\scat$(strip $(PLATFORM)).txt
  VERNOFILE = make\Verno_$(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 : 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)\customer\resGenerator\custom_option.txt)
  首先将CUSTOM_OPTION重定向到custom_option.txt中
  
  (type make\~cus_opt.tmp >>$(MMIDIR)\customer\resGenerator\custom_option.txt)
  使用tools\strcmpex.exe生成~cus_opt.tmp, ~tgt_opt.tmp,~inc.tmp三个文件
  将~cus_opt.tmp 重定向到custom_option.txt中
  
  (@del $(MMIDIR)\mmi\TargetOption.txt) &\
  (copy /Y make\~tgt_opt.tmp $(MMIDIR)\MMI\TargetOption.txt)
  再将TargetOption.txt更新一下,将~tgt_opt.tmp重定向到TargetOption.txt中
  
  (type make\~inc.tmp >$(MMIDIR)\customer\resGenerator\custom_include.tmp)
  再将~inc.tmp重定向到custom_include.tmp中,
  
  执行replace_project_name.pl文件,编译Res_XXX.c
  再执行ResGenerator_HW.bat,编译资源文件。
  
  8.Remake中的编译过程是在libs中完成的
  目标依赖:libs: cleanlib startbuildlibs $(COMPLIBLIST)
  Cleanlib在这个依赖中做的动作是清掉上次生成的.bin,.elf,.lis等文件,接着清掉需要重新来生成的.lib文件。$(COMPLIBLIST)这个依赖就是我们需要重新生成的.lib文件。
  .lib文件的依赖关系:%.lib:
  在这个依赖关系中所做的动作是设置编译器,链接器以及这个过程的参数等其他信息,然后将这些信息输出到:~compbld.tmp临时文件中。
  
  (tools\make.exe -fmake\comp.mak -k -r -R $(strip $(CMD_ARGU)) COMPONENT=$* >$(strip $(COMPLOGDIR))\$*.log) \
  调用了make命令来执行comp.mak文件,并且可以看到> $(strip$(COMPLOGDIR))\$*.log
  该语句将执行comp.mak文件时产生的信息存放在当前编译部分的.log文件中,通常看编译信息的比如custom.log等就是该中类型的文件。
  
  依赖关系:update_lib: $(TARGLIB)
  $(TARGLIB) : $(COBJS) $(CPPOBJS) $(AOBJS) $(ARMOBJS)
  $(TARGLIB)依赖很多.c和.obj
  .c.obj:
  @echo Compiling $< ...
  @tools\strcmpex.exe $(ACTION) remake e $(*F).via $(CINTWORK) -c $(CFLAGS) $(CDEFS) $(CINCDIRS) -o $(COMPOBJS_DIR)/$@$<
  @tools\strcmpex.exe $(ACTION) remake n $(*F).via $(CINTWORK) -c $(CFLAGS) $(CDEFS) $(CINCDIRS) $(MD) -o$(COMPOBJS_DIR)/$@ $<
  @if exist $(*F).via tools\warp.exe $(*F).via
  @if exist $(*F).via $(CMPLR) $(VIA) $(*F).via
  @if not $(ACTION)==remake if exist $(FIXPATH)\$(*F).d perl.\tools\pack_dep.pl $(FIXPATH)\$(*F).d >$(RULESDIR)\$(COMPONENT)_dep\$(*F).det
  @if not $(ACTION)==remake if exist $(FIXPATH)\$(*F).d del /f /q$(FIXPATH)\$(*F).d >nul
  @if exist $(*F).via del /f /q $(*F).via
  要生成.o依赖于.c文件,如果我的.c文件经过更新,那么该.o就需要重新生成,该.c就需要重新来编译。
  @tools\strcmpex.exe $(ACTION) remake e$(*F).via $(CINTWORK) -c $(CFLAGS) $(CDEFS)$(CINCDIRS) -o $(COMPOBJS_DIR)/$@ $<
  @tools\strcmpex.exe $(ACTION) remake n $(*F).via $(CINTWORK) -c $(CFLAGS) $(CDEFS) $(CINCDIRS) $(MD) -o$(COMPOBJS_DIR)/$@ $<
  有两个编译环节,针对不同的编译动作,两者的不同点在于中间有个$(MD)编译选项,在有该选项的时间编译的时候就会生成依赖关系文件.d。
  @if not $(ACTION)==remake if exist $(FIXPATH)\$(*F).d perl.\tools\pack_dep.pl $(FIXPATH)\$(*F).d >$(RULESDIR)\$(COMPONENT)_dep\$(*F).det
  在这个的语句中有$(FIXPATH)\$(*F).d >$(RULESDIR)\$ (COMPONENT)_dep\$(*F).det该动作又将.d文件作为.pl文件的参数,执行该perl文件后将结果输出放在.det文件中。
  @if not $(ACTION)==remake if exist $(FIXPATH)\$(*F).d del /f /q$(FIXPATH)\$(*F).d >nul
  然后又执行这个语句,将.d文件删除。
  在make文件中可以看到-include$(RULESDIR)\$(COMPONENT).dep
  在查看各个.o的依赖关系的时间要查看该.dep文件来决定是否需要来重新编译生成该.o。
  如果新添加了.h文件又没有来更新.dep文件就可能导致该.o查找依赖时没有依赖该.h。不去更新该.o。
  @if exist $(FIXPATH)\$(CUS_MTK_LIB)\$(COMPONENT).lib \
  (copy /z $(FIXPATH)\$(CUS_MTK_LIB)\$(COMPONENT).lib $(subst/,\,$(TARGLIB))) &\
  ($(LIB) -r $(TARGLIB) $(COMPOBJS_DIR)/*.obj) \
  else \
  ($(LIB) -create $(TARGLIB) $(COMPOBJS_DIR)/*.obj)
  在生成了.o文件后在.lib的依赖中可以看到($(LIB) -r$(TARGLIB) $(COMPOBJS_DIR)/*.obj)
  该语句将生成的.o文件打包成.lib库文件。
  
  连接过程:$(BIN_FILE):
  最后完成编译:done:
  # -----------------------------
  # Clean temporary files in make directory
  # -----------------------------
  @echo Cleaning make\~*.tmp files ...
  @if exist make\~*.tmp \
  del make\~*.tmp
  @echo Done.
  @perl tools\time.pl -n
  清掉临时文件,打出done信息,最后打出时间标签。

分享到:
评论

相关推荐

    MTK软件说明

    ### MTK软件说明知识点详解 #### 一、编译工具与辅助工具 MTK软件的编译流程涉及多个工具及步骤。首先,需要确保安装了正确的开发环境,具体包括: - **ADS1.2(Advanced Design System)**:用于ARM架构下的软件...

    MTK 平台生产软件使用说明

    ### MTK平台生产软件使用说明:测试流程与下载详解 #### 概述 MTK(MediaTek)平台生产软件在手机制造过程中扮演着至关重要的角色,涵盖了从SMT(Surface Mount Technology,表面贴装技术)后段测试到组装测试的全...

    MTK_生产平台软件

    - **路径更改**:如果更改了软件路径,则需要重新设置程序配置。 ##### 2.3 硬件环境 - **USB下载方式**:需要PC、直流电源、USB扩展卡以及USB下载线等设备,并确保安装了相应的驱动程序。 - **RS232下载方式**:...

    MTK trace信息说明

    ### MTK Trace信息详解及工具使用指南 #### 一、MTK Trace简介 MTK(MediaTek)是一家领先的全球无晶圆厂半导体...通过以上详细的步骤说明,相信开发者能够顺利地使用MTK Trace工具来进行问题排查和性能优化工作。

    mtk软件环境的搭建说明.doc

    ### mtk软件环境的搭建与熟悉指南 #### 一、软件环境搭建 ##### 1. 搭建目的 为了帮助开发者了解最新的手机开发平台和技术,本指南将详细介绍如何搭建mtk手机软件环境,以便进行软件系统的仿真和调试。 ##### 2....

    mtk -软件结构综合概述

    ### MTK - 软件结构综合概述 #### 手机软件概述 MTK(MediaTek Inc.)作为全球领先的移动通信技术提供...以上是MTK软件架构的综合概述,它涵盖了从操作系统到应用程序层的各个方面,为开发者提供了全面的理解和支持。

    MTK3G META_操作说明

    ### MTK3G META_操作说明 #### 一、引言与概述 MTK3G META 是一款专门针对MTK平台设计的测试工具,旨在帮助工程师们进行移动设备的测试、校准及调试等工作。这款工具对于提高产品的质量和生产效率具有重要作用。...

    MTK平台MT62XX系列手机刷机升级解密教程软件工具大全

    * MTK手机工程模式参数设置应用 * MTK6225山寨手机的串口连接选项参数设置方法 * MTK6225手机连接电脑无序列接口(串口)项的解决办法 * MTK平台各芯片功能简介和手机工厂模式指令参数详解 * MTK平台手机进入工程...

    MTK工程BIN文件图片资源提取器

    MTK工程BIN文件图片资源提取器是一款专门针对采用MediaTek(MTK)芯片平台的工程BIN文件进行图像资源提取的工具。它可以帮助开发者或者设计师从这些二进制文件中提取出 BMP、GIF 和 JPG 格式的图片资源,以便于进行...

    MTK手机软件开发教程 高手必备

    2. **MTK软件编译过程**: - `make custom=proj gprs new`:这是一个编译命令,定制项目(proj),开启GPRS功能,并创建新的编译。 - `clean`, `update`, `remake`:这些是make命令的不同选项,分别用于清理、更新...

    MTK抓catcher的使用说明

    - 开启手机并进入工程模式(通常通过输入特定代码实现,如示例中的*#3646633#),然后按照提示配置串口设置。 **5. 查看调试结果** - 在Catcher工具的界面上可以看到捕获的日志信息,包括之前定义的变量值等。 #...

    RK MTK单项目多dts配置.rar

    Android 11 rockchip rk3568 和 MTK 的mt8167 mt6765 项目工程加载不同配置project.dts 使用在一个项目工程中,需要根据硬件不同往往需要配置一个相对应的dts文件,基本上属于一对一,若是修改了硬件则需要重新修改...

    MTK BT认证测试,工具说明

    此外,测试说明也会说明如何设置测试环境、如何运行测试案例、如何记录测试数据以及如何根据测试结果进行故障诊断和优化。 为了确保蓝牙设备满足国际蓝牙技术联盟(Bluetooth SIG)的标准,MTK的BT认证测试流程会...

    MTK手机模拟器Modis使用说明!很详细

    1. **硬件模拟**:Modis能够模拟MTK芯片的各种硬件特性,包括处理器、内存、屏幕、摄像头、传感器等,使得开发者可以在没有物理设备的情况下进行软件开发和调试。 2. **操作系统支持**:它支持多种操作系统,如...

    MTK 指令与工程模式

    手机中的MTK芯片通常配备有独特的指令集和工程模式,供专业的技术人员或开发者进行调试和功能设置。MTK指令大全是关于这些指令的集合,而手机工程模式则是为专业人员提供了一个可以对手机内部设置进行调整的界面。...

    MTK6223mtk6223p资料介绍.rar

    1. **技术规格**:详细列出MTK6223的硬件参数,包括处理器频率、内存配置、I/O接口标准等。 2. **系统架构**:解释芯片的内部结构,如CPU核心、基带处理器、电源管理单元等。 3. **软件支持**:介绍支持的操作系统...

    MTK.rar_6M6225 射频_MTK 射频调试_MTK射频调试_mtk手机射频_射频调试软件

    2. **硬件调试**:详细说明如何连接和配置硬件设备,例如射频测试设备、示波器、频谱分析仪等,以便进行信号测量和分析。 3. **软件工具**:介绍MTK提供的射频调试软件,包括其功能、界面操作和具体应用,可能包括...

    MT2503GPS测试 PowerGPS_2.3.3_TRIAL_MTK

    MT2503GPS测试说明文档应该详细解释了如何使用这款测试工具,包括安装步骤、操作界面介绍、各个测试项目的设置方法、测试结果的解读以及常见问题的解决方案。这份文档对于开发者和测试工程师来说极其重要,因为正确...

    MTK_SOCKETCAMERA自动拍照短息自动回复自动录像系统time

    7. **Nucleus实时操作系统**:"nucleus实时操作系统MTK手机软件系统工程和配置.txt"涉及到MTK设备上使用的Nucleus实时操作系统,可能涵盖系统架构、任务调度、内存管理等概念,这些都是在MTK平台上开发高效、可靠...

Global site tag (gtag.js) - Google Analytics