MTK报错与分析

1.       编译前须关闭项目文件夹下的相关文件。


2.       Error: L6218E: Undefined symbol LCD_CtrlWrite_S6B33B1X (referred from MiscFunctions.obj).




3.       修改了.mak 文件后,必须NEW




4.       如新加了#include ... 后发现很多在一起的变量没定义,可以把该句移到其他#include 背后。




5.       当SVN系统,文件夹有黄色的叹号,表示冲突时,右击文件夹,选Resolved


即可




6.       Error: L6218E: Undefined symbol DBG_PutUartStr1 (referred from keybrd.obj).


此为keybrd.c 文件中引用了 DBG_PutUartStr1() 函数,而找不到该函数的定义,原因是remake 时未对包含该函数定义的文件进行重新编译链接,搜索发现DBG_PutUartStr1 的定义在 Drv_comm.c 文件中,故删除F:\Z1700(BW1199)\Code\build\B1199\gprs\MT6223Po\drv\ Drv_comm.obj , 使其重新编译链接后PASS.




8..SVN 上传更改的文件时, 检测到非ASCII字符,并且不能转换自UTF-8




上传时未添加log注释,添加log后解决。




7.       Fatal error: L6031U: Could not open scatter description file custom\system\MT6226_06B_BB\scatZ1204A_VICO.txt.


在此目录下自己新建一个scatZ1204A_VICO.txt






8.       Warning: L6340W: options first and last are ignored for link type of -scattered


Error: L6218E: Undefined symbol RA_Hw_Init (referred from ra_hw.o).


Error: L6218E: Undefined symbol RA_Power_On (referred from ra_hw.o).





出现很多Undefined 的这种错误,且都是一个模块的,(属于ry3601模块),在option.mak       中添加CUS_REL_SRC_COMP += ry3601,remake 后 OK.




9.       "plutommi\mtkapp\soundrecorder\soundrecordersrc\soundrecordersrc.c", line 517: Error: C2839E: junk at end of #endif line – ignored  


前面多了一个#endif , 去掉后OK




10.    "plutommi\mmi\gpio\gpiosrc\generaldeviceinterface.c", line 2085: Error: C2933E: type disagreement for 'PlayAndStopRuningHorseLedWithMusic'


      在函数定义前引用了此函数,而在文件头部没有进行声明,只须在文件前头端进行声明即可.


11.Error: L6218E: Undefined symbol __MAINLCD__MAINMENU__MATRIX__MM_BG_GIF (referred from themeres.obj).


查看代码发现__MAINLCD__MAINMENU__MATRIX__MM_BG_GIF的声明在 Themecomponents.h中,搜索发现有两个文件未关联至服务器,导致未更新。将关联的服务器上文件对它们进行替换即可。






12.文件夹有黄色叹号,进行CLEANUP 后出现如下提示:


。。。is not a working copy directory.


SOLUTION:删除该文件夹再重新下载




13. "plutommi\mmi\gui\gui_src\wgui_datetime.c", line 3534: Error: C2285E: expected ';' or ',' - inserted ';' before 'gui_clock_get_clock_show_time'


SOLUTION:在该函数前的语句忘了加分号“;”。




14. 命令语法不正确。


make: *** [mtkapp.lib] Error 1


"plutommi\MtkApp\EngineerMode\EngineerModeSrc\EngineerModeDeviceSrc.c", line 8249: Error: C3028E: <argument 1 to 'sprintf'>: implicit cast of pointer to non-equal pointer


SOLUTION:一个函数形参为U8 *string,而实际赋给他的是char *buffer,导致类型不符,调用时进行强制转换:(PU8)dispbuff即可。




15.修改gsm2.mak 后进行remake ,报错,大意是缺少分隔符.


SOLUTION:察看修改的地方发现有一句不像其他语句一样开头空了几格,便将他开头空上几格后ok.




16. Fatal error: L6002U: Could not open file .\build\Z1118\gprs\MT6225o\lib\mercury_master.lib.


原因:出现此ERROR时,使用的是 r plutommi,改为全remake 后,问题解决




17.新增一些代码后,编模拟器通不过,查看LOG,


..\..\kal\include\kal_trace.h(237) : fatal error C1083: Cannot open include file: 'ps_trace.h': No such file or directory


app_asyncfile.c


原因:添加的\make\AS6200\下少加了个.def文件, 加上后OK


或者提示:


..\..\kal\include\kal_trace.h(237) : fatal error C1083: Cannot open include file: 'ps_trace.h': No such file or directory
Error executing cl.exe.


查看make\modis_fs\modis_fs.def,看到:


0030:modis_fs.inc:020:1:14=48041e4b:16=47d21313:MoDIS\FileSystem\FileSystemInc
0030:modis_fs.lis:08F:1:14=48041e4b:16=47d21313:MoDIS\FileSystem\FileSystemSrc\FSSim_core.c
MoDIS\FileSystem\FileSystemSrc\FSSim_data.c
MoDIS\FileSystem\FileSystemSrc\FSSim_supplemental.c
0030:modis_fs.pth:020:1:14=48041e4b:16=47d21313:MoDIS\FileSystem\FileSystemSrc
make\modis_fs\modis_fs.def
0023:.:0:3:14=48041e4b:16=47d21313:0032:mtkdebug:000000000:2:14=48041e4b:16=47d21313:002F:mtkdebug.def:00:1:14=48041e4b:16=47d21313:


去掉上面垃圾内容即可。




18. Error: L6286E: Value(0x400f84) out of range(-0x400000 - 0x3fffff) for relocation #1 (wrt symbol __rt_sdiv) in m11303.obj(INTERNCODE)


Error: L6286E: Value(0x400786) out of range(-0x400000 - 0x3fffff) for relocation #1 (wrt symbol __rt_sdiv) in m11305.obj(INTERNCODE)


Error: L6286E: Value(0x400778) out of range(-0x400000 - 0x3fffff) for relocation #2 (wrt symbol __rt_sdiv) in m11305.obj(INTERNCODE)


Error: L6286E: Value(0x400766) out of range(-0x400000 - 0x3fffff) for relocation #4 (wrt symbol __rt_sdiv) in m11305.obj(INTERNCODE)


Error: L6286E: Value(0x400742) out of range(-0x400000 - 0x3fffff) for relocation #5 (wrt symbol __rt_sdiv) in m11305.obj(INTERNCODE)




SCAT文件中的代码分段,其中有的段超了。




19. make[1]: *** No rule to make target `custom\drv\misc_drv\mt6225_gemini_bb\codegen\eint_drv.h', needed by `eint_def.obj'. Stop.




20. make\gsm2.mak:1793: *** commands commence before first target. Stop.




21.进行remake 编译时,


F:\Z1801\Code\build\Z1801M\Z1801M_PCB01_gprs_MT6229_S02.MAUI_07B_W08_12_F2.bin\*, 是否确认(Y/N)?


将此目录删除后再remake ,OK!


22.Error: L6220E: Load region ROM size (14740464 bytes) exceeds limit (14680064 bytes).
Not enough information to produce a SYMDEFs file.


BIN超出限制,考虑给资源(字体,图片,音频等)减肥、关闭某摆设功能、关闭一些SP服务,三方软件等。


23.make: *** [.\tst\database_classb\BPLGUInfoCustomAppSrc] Error 1


仔细查看make目录下的文件。


24.Error: L6850E: Archive contains non ELF Object CustImgRes.obj
make[1]: *** [build/TELSDA25_GEMINI/gprs/MT6225o/lib/mmiresource.lib] Error 1


25.Error: C2831E: unprintable char 0x1f found - ignored


处理:将不可见字符转换为ASCII编码。


26.0 [main] sh 500 handle_exceptions: Exception: STATUS_ACCESS_VIOLATION
   2179 [main] sh 500 open_stackdumpfile: Dumping stack trace to sh.exe.stackdum
p


make: *** [CustResDeclare.o] Error 101120
       Error in ResGenerating Process!!
       Please Check again!!


27Error: L6286E: Value(0x44573) out of range(0 - 0xff) for relocation #4 (wrt symbol GetCurrGuiBuffer) in engineermodedevicesrc.obj(i.EntryEmDevBtRfTXRX)
Error: L6286E: Value(0xf1c43) out of range(0 - 0xff) for relocation #3 (wrt symbol get_image) in phonebookmain.obj(i.mmi_phb_list_get_item)


28.MODIS Error:


OSC> main: MediaTek OSCAR START......
System > Initializing system memory...
System > Creating buffer pool...
System > Initializing KAL resource...
FSSim_Init(): fail to create directory E, error code = 183
[1] Assert fail: 0 fssim_core.c 440 0x0 0x0 0x0 - UNKNOWN
abnormal program termination
Press any key to continue


29.Error: C2832E: illegal option -Dinit\include


Compiling nvram/src/nvram_context.c ...
Error: C2832E: illegal option -Dinit\include
Error: C2832E: illegal option -Dl1\l1d
Error: C2832E: illegal option -Dnvram\src\nvram_handler_tst.c
Error: C2832E: illegal option -Dnvram\src\nvram_handler_read.c,     
Error: C2832E: illegal option -Dnvram\fd\include
Error: C2832E: illegal option -Dnvram\src\nvram_handler_write.c
Error: C2832E: illegal option -Dcustom\common
Error: C2832E: illegal option -Dnvram\src\nvram_ltable.c
Error: C2832E: illegal option -Dnvram\src\nvram_io.c
Error: C2832E: illegal option -Dnvram\src\nvram_handler_reset.c
Error: C2832E: illegal option -Ddrv\include
Error: C2832E: illegal option -D002E:nvram.lis:01C6:1:14=48041e4b:16=47d21313:nvram\src\nvram_context.c
Error: C2832E: illegal option -Dnvram\src\nvram_drval_fat.c
Error: C2832E: illegal option -Dnvram\src\nvram_data_items.c
Error: C2832E: illegal option -Dnvram\src\nvram_drv_int.c
Error: C2832E: illegal option -D002D:nvram.inc:06A:1:14=48041e4b:16=47d21313:nvram\include
Error: C2832E: illegal option -D0023:.:0:3:14=48041e4b:16=47d21313:0035:obigo03cadp:000000000:2:14=48041e4b:16=47d21313:0030:NO_SEC:000000000:2:14=48041e4b:16=47d21313:0033:obigo03cadp.def:0EA:1:14=48041e4b:16=47d21313:MMI_ON_HARDWARE_P
Error: C2832E: illegal option -Dnvram\src\nvram_ilm.c
Error: C2832E: illegal option -Dnvram\src\nvram_l1def.c
Error: C2832E: illegal option -Dnvram\src\nvram_ul1def.c
Error: C2832E: illegal option -D002C:nvram.pth:0B:1:14=48041e4b:16=47d21313:nvram\src
Error: C2832E: illegal option -Dapplib\misc\include
Error: C2832E: illegal option -Dnvram\src\nvram_interface.c
Error: C2832E: illegal option -Dnvram\src\nvram_handler_startup.c
Error: C2832E: illegal option -Dnvram\src\nvram_main.c
nvram\src\nvram_context.c: 0 warnings, 25 errors, 0 serious errors
make[1]: *** [nvram_context.obj] Error 1


遇見這問題,請檢查XXX\make\nvram\nvram.def文件


30."custom\system\XXX25_08A_GEMINI_BB\scatXXX25_08A_GEMINI.txt", line 304: Warning: L6314W: custom\system\XXX25_08A_GEMINI_BB\scatXXX25_08A_GEMINI.txt(line 304, col 45) No section matches pattern *(SBC_DYNAMIC_ZI).
"custom\system\XXX25_08A_GEMINI_BB\scatXXX25_08A_GEMINI.txt", line 309: Warning: L6314W: custom\system\XXX25_08A_GEMINI_BB\scatXXX25_08A_GEMINI.txt(line 309, col 44) No section matches pattern isp_comm.*obj(INTERNZI1).
Error: L6220E: Execution region INTSRAM_DATA size (25552 bytes) exceeds limit (23040 bytes).
Warning: L6318W: osstub.o(i.gdi_layer_find_valid_handle_abc) contains branch to a non-code symbol sccvv_fast.
Warning: L6318W: osstub.o(i.gdi_layer_flatten_to_base_1234) contains branch to a non-code symbol sccvv_fast.
Warning: L6318W: osstub.o(i.gdi_layer_flatten_to_base_ddd) contains branch to a non-code symbol sccvv_fast.


处理:INTSRAM_DATA这个部分超出了大小,把里面的内容挪动一下。


       31.C2319E: type 'enum' inconsistent with 'enum'


Compiling applib/misc/src/app_datetime.c ...
"plutommi\MMI\Framework\NVRAMManager\NVRAMManagerInc\NVRAMType.h", line 111: Serious error: C2319E: type 'enum' inconsistent with 'enum'
applib\misc\src\app_datetime.c: 0 warnings, 0 errors, 1 serious error


查看res_gen.log


In file included from CustResDeclare.c:37:
../../MMI/Inc/CustDataRes.h:264: error: parse error before "CUSTOM_STRING"
../../MMI/Inc/CustDataRes.h:279: error: parse error before "CUSTOM_STRING"
../../MMI/Inc/CustDataRes.h:285: error: parse error before '}' token
make[1]: *** [CustResDeclare.o] Error 1


比如我在这里查到的是CustDataRes.h文件中包含了#include "MMIDataType.h"这个,而在MMIDataType.h文件我才刚刚加了


#ifdef __XXX_MOBILE_MMI__
#include "..\\..\\XXX_Software\\Resource\\XXX_ResIDDef.h"
#endif //__XXX_MOBILE_MMI__


把上面屏蔽掉就编译通过,于是出错的地方就明显而知了,把错误地方改下就可以了。


在实在查找不出错误时,时刻记得查看是否是资源编译出错。


32.关于Image$$ZI$$Limit错误
Error: L6218E: Undefined symbol Image$$ZI$$Limit (referred from sys_stackheap.o).
Not enough information to produce a SYMDEFs file.


网上能查到的一堆信息我就不写了,经查找是我用了fopen函数,注释掉重写就可以了.其实malloc,printf,strdup等Clib函数的使用也会导致ADS出现这个问题.


33.


..\custresource\PLUTO_MMI\Res_MMI\Res_VT.c
..\custresource\PLUTO_MMI\Res_MMI\Res_Wap.c
已复制        86 个文件。
系统找不到指定的文件。
Making Resources...
系统找不到指定的路径。
reimp: mmicustomizer.lib: No such file or directory
      0 [main] sh 2348 handle_exceptions: Exception: STATUS_ACCESS_VIOLATION
    477 [main] sh 2348 open_stackdumpfile: Dumping stack trace to sh.exe.stackdu
mp
make: *** [CustResDeclare.o] Error 101120
Error in ResGenerating Process!!
Please Check again!!




34.make (e=2): 系统找不到指定的文件。
make: *** [gen_infolog] Error 2


原来是tools\strcmpex.exe 这个文件被360干掉了。




35.C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s: Assembler messages:
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600339: Warning: .stabs: description field '10b67' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600340: Warning: .stabs: description field '10bb6' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600341: Warning: .stabs: description field '10bc4' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600342: Warning: .stabs: description field '10bd1' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600343: Warning: .stabs: description field '10bde' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600344: Warning: .stabs: description field '11442' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600345: Warning: .stabs: description field '11475' too big, try a different debug format
C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/ccs9aaaa.s:600346: Warning: .stabs: description field '114f6' too big, try a different debug format

  • 0
    点赞
  • 0
    评论
  • 1
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

xajhsunei

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值