1、vs2005开发WM5时,编译器和linker的选项配合问题

链接:http://www.mivi.name/blog/index_en.php?itemid=258

首先说ARM4 ARM4T 和 ARM4I

ARM4是纯32位的ARM,ARM4T是纯16位THUMB,ARM4还有一个分支ARM4I,是16位和32位混合的

ARM5则是向下兼容的,运行ARM4的程序没问题



在开发和编译Windows Mobile 5.0(ARM4I)的程序时,你也许碰到过如下的错误(PocketPC2003你不会碰到这个问题):

coredll.lib(COREDLL.dll) : fatal error LNK1112: module machine type 'THUMB' conflicts with target machine type 'ARM' 

说lib文件的THUMB模式与ARM模式不兼容



编译器的选项:

Project | Properties | Configuration | C++ | Advanced | Compile for Architecture

有选项ARM4 和 ARM4T

Project | Properties | Configuration | C++ | Advanced | Interwork ARM and ARM Thumb Calls

有选项是否允许混合ARM和THUMB调用(即ARM4I)

编译器的选项

Project | Properties | Configuration | Linker | Advanced | Target Machine

有选项MachineARM 和 MachineTHUMB



根据参考网页:

http://forums.microsoft.com/msdn/showpost.aspx?postid=122058&siteid=1&sb=0&d=1&at=7&ft=11&tf=0&pageid=1 

http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=195585&SiteID=1 

的说法,似乎编译WM5的程序时,必须选择的搭配是ARM4T+MachineTHUMB



但是实际使用 发现 如果开启允许混合调用的选项,ARM4或者ARM4T的选项无所谓,但是MachineType仍然必须是MachineTHUMB



而参考VS2005自己生成的Project,以及早期VS2005在beta版本时期的一个MSDN文档,

其实针对wm5.0的做法是:

编译选择ARM4,可以不起用混合调用,然后linker中的Target Machine选择Not Set 

这样就可以编译通过不报任何错误了。。。

2、fatal error LNK1112: module machine type 'THUMB' conflicts with target machine type 'ARM'

解决方法:

在WinCE下编程时,常常出现上述错误可以在Project->Setting->Link下将MACHINE:X86改成MACHINE:ARM,如果还不行,直接改为MACHINE:THUMB.

3.WM5.0下,fatal error LNK1112:错误解决方法

将工程从Pocket PC 2003转到Windows Mobile5.0 Pocket PC SDK下,就会出现coredll.lib(COREDLL.dll) : fatal error LNK1112: module machine type 'THUMB' conflicts with target machine type 'ARM',解决方法:ALT+F7打开工程设置,在Configuration Properties->Linker->Command
Line,在Additional options:把原来的 /subsystem:windowsce,4.20 /machine:ARM /ARMPADCODE删除,输入 /subsystem:windowsce,5.01就可以,注意此种方法仅适用由VC8.0所建的工程,并不适用于由EVC建的工程转到WM5.0下。

4.在VS 2005中建立的Win32工程总出现这样的运行错误:"MSVCR80D.dll not found"

转:http://www.cppblog.com/pengkuny/archive/2007/03/21/20332.html

在VS 2005中建立的Win32工程总出现这样的运行错误:"MSVCR80D.dll not found"

好几次了,总结各种解决方法如下:



     原因:(不知道在说啥)由于VS.net 2005 采用了一种新的DLL方案,搞成一个exe还要配有一个manifest文件(一般在嵌入文件里了,所以看不到,不过也可以不嵌入,这样会生产一个<程序名>.exe.manifest的文件,没它exe自己就转不了了:)这是个新功能,微软弄了个新工具(mt.exe),结果不好用,好像是fat32下时间戳有问题(在ntfs下这个问题就没有了),搞得manifest有时嵌入不到exe中(默认配置是嵌入的,所以就报错找不到 dll了。



      解决方法:(任选一个即可)

1.生成Debug版本项目时,未打开连接器的/MANIFEST开关。在 'Project Properties->Configuration Properties->Mainfest Tool->Input and Output->Embed Manifest' 将 YES 改成 NO 就可以了.



2.在“属性->配置属性->清单工具->常规“下有一个”使用FAT32解决办法,把它选成是,就可以了。



3、如果建立的是Win32的项目的话可以在项目-(项目名)属性-配置属性-C/C++-代码生成-运行时库 将其改为多线程调试 /MTd



4、在C:\Program Files\Microsoft Visual Studio 8\VC\redi

st\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT 下找到了下列文件:



msvcm80d.dll

msvcp80d.dll

msvcr80d.dll

Microsoft.VC80.DebugCRT.manifest



把这几个文件拷贝到目标机器上,与运行程序同一文件夹或放到system32下,就可以运行那个程序了。



5、将Debug版本中第一次生成的.res文件删除后重新Build一次



6、采用Release模式,不要采用Debug模式就可以了

试过第一个,确实可以。

05-11 18:31