g ++双精度手臂vs英特尔

时间:2014-06-23 22:58:48

标签: gcc g++ arm cross-compiling double-precision

这是一张图片,显示了英特尔和ARM中相同程序的输出:

http://screencast.com/t/1eA64D4rF

两者都显示读取二进制文件的输出,第一列中的数字是双精度浮点格式。为什么我无法在ARM环境中获得正确的结果(如英特尔 - 41784.998495,41784.998623)和(-8.1974E + 204f等)?

我正在使用的手臂处理器是:

Processor       : ARM926EJ-Sid(wb) rev 0 (v5l)

BogoMIPS        : 331.77

Features        : swp half thumb fastmult edsp java

CPU implementer : 0x41

CPU architecture: 5TEJ

CPU variant     : 0x0

CPU part        : 0x926

CPU revision    : 0

Cache type      : write-back

Cache clean     : cp15 c7 ops

Cache lockdown  : format C

Cache format    : Harvard
I size          : 32768
I assoc         : 1
I line length   : 32
I sets          : 1024
D size          : 32768
D assoc         : 1
D line length   : 32
D sets          : 1024

Hardware        : MV-88fxx81
Revision        : 0000
Serial          : 0000000000000000

我在ARM上的编译选项:g++ -Wall SC_SCID.cpp

如何在此处理器上正确读取双精度类型?是否需要启用任何编译器选项才能正确处理ARM上的双精度数字?

2 个答案:

答案 0 :(得分:0)

像41784.998495和-8.1974E + 204这样的数字之间的差异很可能是字节排序问题 - 英特尔处理器是小端的,而ARM是大端的。因此,如果您在一个文件上写一个二进制文件并想在另一个上读取它,那么您需要对这些值进行字节交换。

答案 1 :(得分:0)

注意:这是一个wiki答案;任何人都可以编辑。

根据wikipediadouble的ARM softfp仿真使用了大端和小端的混合。对于整数类型,ARM926EJ的原生格式肯定是 little endian

在问题Would float point format be affected by big-endian and little endian?

中阅读更多内容