Chinaunix首页 | 论坛 | 博客
  • 博客访问: 690787
  • 博文数量: 148
  • 博客积分: 4086
  • 博客等级: 上校
  • 技术积分: 1766
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-06 23:27
文章分类

全部博文(148)

文章存档

2013年(19)

2012年(9)

2011年(106)

2009年(14)

分类: WINDOWS

2011-03-23 14:41:49

    本文将不择手段搜集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) |
给主人留下些什么吧!~~