本文将不择手段搜集WINCE
PB的各种编译不过的错误并给出解决方案或是相关思路,搜集资料来源:本人编译出错后得到解决后的学习笔记,网上搜集的资料,朋友的教导等,后面将会详细备注,大家一起交流。文章一式两份,一份在博客上,另外一份放到论坛中,并实时更新。[电子技术论坛:]
一:不能sysgen,sysgen变灰色
检查BSP包的命名,所建工程的命名是否正确!
二:*(LPDWORD) OEMMapMemAddr (dwImageStart, dwImageStart +
ROM_SIGNATURE_OFFSET)函数不等于“CECE”
如下函数不执行:[ROM_SIGNATURE=“CECE”]
if
(*(LPDWORD) OEMMapMemAddr (dwImageStart, dwImageStart +
ROM_SIGNATURE_OFFSET) == ROM_SIGNATURE)
{
//added by
lqm,2009.07.11
//EdbgOutputDebugString("*OEMMapMemAddr() = 0x%xrn",*(LPDWORD)
OEMMapMemAddr (dwImageStart, dwImageStart +
ROM_SIGNATURE_OFFSET));
EdbgOutputDebugString("*OEMMapMemAddr() = 0x%xrn",*(LPDWORD)
OEMMapMemAddr (0x80200000,0x80200040));
EdbgOutputDebugString("dwImageStart:0x%xrn",dwImageStart);
EdbgOutputDebugString("ROM_SIGNATURE_OFFSET:0x%xrn",ROM_SIGNATURE_OFFSET);
EdbgOutputDebugString("ROM_SIGNATURE:0x%xrn",ROM_SIGNATURE);
//
紧接着存放CECE的后面就是TOC,里面存有NK.exe的地址。其中sizeof(ULONG)用于顺延存放CECE的四个字节区域
dwpToc = *(LPDWORD) OEMMapMemAddr (dwImageStart, dwImageStart +
ROM_SIGNATURE_OFFSET + sizeof(ULONG));
//
为了修正指针,需要再次映射一次
// need to map the content again since the pointer is going to be
in a fixup address
dwpToc = (DWORD) OEMMapMemAddr (dwImageStart, dwpToc +
g_dwROMOffset);
EdbgOutputDebugString ("ROMHDR at Address 0x%Xrn", dwImageStart +
ROM_SIGNATURE_OFFSET + sizeof (DWORD)); // right after
signature
}
一起以为是没找着TOP里面的"CECE",后来经魏公公指点,原来是之前生成的XIP.bin不是XIP模式的。
将processbib.exe,preromimage.bat两个文件放到D:WINCE500PLATFORMSMDK2450Files目录下,先copy
files to release,
再make一下,生成的xip.bin就是xip模式的了。
三:PB编译时提示spawn failed:invalid argument错误
每次编译出错信息还不一样!
这次提示如下错误:
BUILD: [01:0000000836:PROGC ] Compiling .arcdlg.cpp
BUILD: [01:0000000839:PROGC ] Compiling .connectingdlg.cpp
BUILD: [01:0000000842:PROGC ] Compiling .dlgbase.cpp
BUILD: [01:0000000845:PROGC ] Compiling .events.cpp
BUILD: [01:0000000848:PROGC ] Compiling .mainwnd.cpp
BUILD: [01:0000000851:PROGC ] Compiling .rdrwarndlg.cpp
BUILD: [01:0000000854:PROGC ] Compiling .settings.cpp
BUILD: [01:0000000857:PROGC ] Compiling .utils.cpp
BUILD: [01:0000000860:PROGC ] Linking
C:WINCE500publicrdpoaklibA
RMV4Iretailcetscbase.lib
BUILD: [00:0000000865:PROGC ] Compiling
WINCE500PUBLICRDPOAKUITCETSCCLIP directory.
BUILD: [01:0000000872:PROGC ] Compiling .tscclip.cpp
BUILD: [01:0000000875:PROGC ] Linking
C:WINCE500publicrdpoaklibARMV4Iretailcetscclip.lib
BUILD: [00:0000000878:PROGC ] Compiling
WINCE500PUBLICRDPOAKUITCETSCUI directory.
BUILD: [01:0000000885:PROGC ] Compiling .tscui.cpp
BUILD: [01:0000000888:PROGC ] Compiling .maindlg.cpp
BUILD: [01:0000000891:PROGC ] Compiling .propdisplay.cpp
BUILD: [01:0000000894:PROGC ] Compiling .propgeneral.cpp
BUILD: [01:0000000897:PROGC ] Compiling .proplocalres.cpp
BUILD: [01:0000000900:ERRORE] NMAKE : U1045:
spawn failed : Invalid argument
BUILD: [01:0000000903:ERRORE] NMAKE.EXE -i -c
BUILDMSG=Stop. NOLINK=1 NOPASS0=1 failed - rc =
2
下面还有一个错误:
BUILD: [00:0000000101:PROGC ] Scan
WINCE500PUBLICWCESHELLFEOAKWATSONDWUI
BUILD: [00:0000000106:PROGC ] Scan
WINCE500PUBLICWCESHELLFEOAKWATSONDWCTLPNL
BUILD: [00:0000000109:PROGC ] Saving
C:WINCE500PUBLICWCESHELLFEBuild.dat.
BUILD: [00:0000000111:PROGC ] Total of 0 pass zero files to compile
in 14 directories.
BUILD: [00:0000000112:PROGC ] Building generated files in
WINCE500PUBLICWCESHELLFEOAKCTLPNLcplmain.
BUILD: [00:0000000119:PROGC ] Building generated files in
WINCE500PUBLICWCESHELLFEOAKCTLPNLADVBACKLIGHT.
BUILD: [00:0000000126:PROGC ] Building generated files in
WINCE500PUBLICWCESHELLFEOAKCTLPNLCONNPNL.
BUILD: [01:0000000129:ERRORE] NMAKE.EXE -i -c
BUILDMSG=Stop. NOLINK=1 PASS0ONLY=1 CLEANBUILD=1
failed - rc = 1
BUILD: [00:0000000130:PROGC ]
Files
Warnings
Errors
BUILD: [00:0000000131:PROGC ] Midl
0
0
0
BUILD: [00:0000000132:PROGC ] Resource
0
0
0
BUILD: [00:0000000133:PROGC ] Message
0
0
0
BUILD: [00:0000000134:PROGC ] Precomp Header
0
0
0
BUILD: [00:0000000135:PROGC ] C/Cpp/Cxx
0
0
0
BUILD: [00:0000000136:PROGC ] Assembler
0
0
0
BUILD: [00:0000000137:PROGC ] Static Libraries
0
0
0
BUILD: [00:0000000138:PROGC ] Dll's
0
0
0
BUILD: [00:0000000139:PROGC ] Exe's
0
0
0
BUILD: [00:0000000140:PROGC ] Resx
0
0
0
BUILD: [00:0000000141:PROGC ] Csharp Targets
0
0
0
BUILD: [00:0000000142:PROGC ] Other
0
0
1
BUILD: [00:0000000143:PROGC ]
BUILD: [00:0000000144:PROGC ] Total
0
0
1
BUILD: [00:0000000145:PROGC ]
BUILD: [00:0000000146:PROGC ] 0 Warnings, 1
Errors
最后提示的错误:
Build for Windows CE (Release) (Built on Apr 14 2005
13:54:39)
File names: Build.log Build.wrn Build.err Build.dat
CEBUILD: Running sysgen -p wceshellfe preproc
Starting sysgen phase for project ( wceshellfe )
Sysgening platform C:WINCE500platformsmdk2450
Sysgening platform C:WINCE500platformsmdk2450
WINCE500build.err
C:WINCE500build.err
C:WINCE500build.log
C:WINCE500build.wrn
已复制
3 个文件。
BLDDEMO: There were errors building 2450_p900
2450_p900 - 3 error(s), 10 warning(s)
这个问题比较麻烦,我通过重装系统(换用另外一张堞装,非ghost),成功过一次,换用台式机,也成功过。但是笔记本上后来又不行了,原因不明。
四:PB编译提示don't know how to make.........................
编译2450 bootloader出错,编译driver没错,
编译Eboot错误如下:
BUILD: [01:0000000039:PROGC ] Compiling .debug.c
BUILD: [01:0000000042:PROGC ] Compiling .ether.c
BUILD: [01:0000000045:PROGC ] Compiling .flash.c
BUILD: [01:0000000048:PROGC ] Compiling .nand.cpp
BUILD: [01:0000000051:PROGC ] Compiling .usb.c
BUILD: [01:0000000054:PROGC ] Assembling .usbs.s
BUILD: [00:0000000060:PROGC ] Linking
WINCE500PLATFORMSMDK2450SrcBootloaderEboot.Whimory
directory.
BUILD: [01:0000000067:ERRORE] NMAKE : U1073:
don't know how to make
'E:WINCE500platformsmdk2450libARMV4Iretailoal_memory_s3c2450.lib'
BUILD: [01:0000000069:ERRORE] NMAKE.EXE -i -c
BUILDMSG=Stop. LINKONLY=1 NOPASS0=1 failed - rc =
2
BUILD: [00:0000000070:PROGC
]
Files
Warnings
Errors
BUILD: [00:0000000071:PROGC ]
Midl
0
0
0
BUILD: [00:0000000072:PROGC ]
Resource
0
0
0
BUILD: [00:0000000073:PROGC ]
Message
0
0
0
BUILD: [00:0000000074:PROGC ] Precomp
Header
0
0
0
BUILD: [00:0000000075:PROGC ]
C/Cpp/Cxx
6
2
0
BUILD: [00:0000000076:PROGC ]
Assembler
3
0
0
BUILD: [00:0000000077:PROGC ] Static
Libraries
0
0
0
BUILD: [00:0000000078:PROGC ]
Dll's
0
0
0
BUILD: [00:0000000079:PROGC ]
Exe's
0
0
0
BUILD: [00:0000000080:PROGC ]
Resx
0
0
0
BUILD: [00:0000000081:PROGC ] Csharp
Targets
0
0
0
BUILD: [00:0000000082:PROGC ]
Other
0
0
2
BUILD: [00:0000000083:PROGC ]
BUILD: [00:0000000084:PROGC ]
Total
9
2
2
BUILD: [00:0000000085:PROGC ]
BUILD: [00:0000000086:PROGC ] 2 Warnings, 2
Errors
Build for Windows CE (Release) (Built on Apr 14 2005
13:54:39)
File names: Build.log Build.wrn Build.err Build.dat
2450_p900 - 2 error(s), 2 warning(s)
我按照提示的路径找不着这个静态库,oal_memory_s3c2450.lib
难道这个静态库PB装时给漏掉了?
后来重装WINCE,打04,05,06,07年的补丁,问题依旧。看来还是没经验啊,感谢CSDN的高手Veabol,编译SrcCommon后,果真生成了oal_memory_s3c2450.lib。
可是又出来一个CS8900*.lib的静态库,后面的字符不记得了,看来还有其他地方要生成该库。编译整个SMDK2450工程,看提示估计是该静态库是生成了,但是又
弹出另外一个对话框,提示某文件无法编译,该文件为我已前做好的备份文件,有中文名。删除该文件后,再编译,仍然提示该错,将BSP根目录的build.dat删除,
再编译,问题彻底解决。
看来很多静态库不是PB装好后本身就有的,而需要编译一些代码才能生成。
阅读(1370) | 评论(0) | 转发(0) |