解决WINCE500中INTEL编译器无法完全卸载的问题

简介:

为PB FOR WINCE500安装好INTEL COMPILER后,在PB的TOOLS里会多出一个SELECT COMPILER,这时候用户会发现已经上当了,即使把INTEL COMPILER反选不用,仍然有些以前可以编译过去的汇编文件,现在不可编译通过,无法生成OBJ,那么在LINK成LIB/DLL/EXE的时候就编译出错停下了。其实这时候即使用户把INTEL COMPILIER卸载掉,然后再重启都是无济于事的。这使我想到一个词:流氓软件。

实际上关键点在这个文件里 \wince500\public\common\oak\misc\Makefile.def

让我们来看看使用INTEL编译器和PB自带的MS编译器时,makefile.def文件里的差异吧。只有四行的差异

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Line Num   |                         MS                |                      INTEL
1265         |    CFLAGS=$(CFLAGS)  -WX    |    #CFLAGS=$(CFLAGS)  -WX 
1360         |                                             |    TARGETLIBS=$(_SDKROOT)\bin\i386\x0_ar10.lib $(TARGETLIBS)
1485         |    ASSEMBLER=armarm -coff   |    #ASSEMBLER=armarm -coff
1486         |                                              |    ASSEMBLER=asxscce  -coff  -mcpu  3  -debug
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------

第1265行说的是,当编译.c文件时,treats all warnings as errors. If there are any warning messages, the compiler generates an error message, and continues compilation.  (评论,推荐自虐的人配合最高级的W4一起用, CFLAG=$(CFLAGS) -W4 -WX,这种条件下编译出的代码那语法真是天衣无缝了) 所以INTEL也就是在这里放宽了检查,给自己的编译器留条后路,某些原来不能通过编译的WARNING现在可以PASS了。

第1360行,在使用MS COMPILER的Makefile.def里并没有这句,INTEL强加了这个x0_ar10.lib,估计某些语句需要用到这个lib里的东西。典型的情况是在不使用INTEL COMPILER编译BetaPlayer中一些汇编文件的时候,会报错说找不到x0_ar10.lib,对这些文件的SETTING里指定使用INTEL COMPILER就OK了。

第1485和1486行,也就是指定编译器啦,可以看见两者之间明显的意图。后面 COFF 参数是指Common Object File Format,也就是说编译出来的文件得按照游戏规则填些MACHINE TYPE,TIME STAMP之类的东东。INTEL使用他们的ASXSCCE编译器那条语句后面那些参数就没地方查了。


本文转自Walzer博客园博客,原文链接:http://www.cnblogs.com/walzer/archive/2006/04/21/380861.html,如需转载请自行联系原作者

相关文章
|
2天前
|
Linux C语言 iOS开发
MacOS环境-手写操作系统-06-在mac下通过交叉编译:C语言结合汇编
MacOS环境-手写操作系统-06-在mac下通过交叉编译:C语言结合汇编
5 0
|
2月前
|
NoSQL Linux C语言
嵌入式GDB调试Linux C程序或交叉编译(开发板)
【8月更文挑战第24天】本文档介绍了如何在嵌入式环境下使用GDB调试Linux C程序及进行交叉编译。调试步骤包括:编译程序时加入`-g`选项以生成调试信息;启动GDB并加载程序;设置断点;运行程序至断点;单步执行代码;查看变量值;继续执行或退出GDB。对于交叉编译,需安装对应架构的交叉编译工具链,配置编译环境,使用工具链编译程序,并将程序传输到开发板进行调试。过程中可能遇到工具链不匹配等问题,需针对性解决。
|
5月前
|
物联网 编译器 测试技术
【嵌入式 交叉编译器】如何在 ARM 架构下选择和使用高版本交叉编译器
【嵌入式 交叉编译器】如何在 ARM 架构下选择和使用高版本交叉编译器
913 7
|
Linux C语言 芯片
linux网卡驱动程序的编译与安装
linux网卡驱动程序的编译与安装
|
NoSQL 网络协议 数据可视化
ARM深入理解-hypervisor调试方法二(QEMU+GDB调试ARM程序)
ARM深入理解-hypervisor调试方法二(QEMU+GDB调试ARM程序)
|
存储 Ubuntu 安全
|
Ubuntu Linux 编译器
iperf-2.0.9 在 Linux下的编译 与 海思(arm)平台的交叉编译
iperf-2.0.9 在 Linux下的编译 与 海思(arm)平台的交叉编译
643 0
iperf-2.0.9 在 Linux下的编译 与 海思(arm)平台的交叉编译
|
Linux 数据安全/隐私保护 Android开发
RISC-V ICE EVB 开发板 windows环境下烧写更新开发板镜像
ICE EVB 是基于 T-Head 自主研发的 C910 CPU 的 ICE 高性能 SoC 开发板。 本文介绍Windows环境下烧写ICE-EVB 开发板镜像,让用户快速上手。
947 1
RISC-V ICE EVB 开发板 windows环境下烧写更新开发板镜像