10

我已经用谷歌的 nacl 编译器编译了一些 Qt 代码,但是 ncval 验证器并不能理解它。众多例子中的一个:

src/corelib/animation/qabstractanimation.cpp:165

以下是相关代码:

#define Q_GLOBAL_STATIC(TYPE, NAME)                                  \
    static TYPE *NAME()                                              \
    {                                                                \
        static TYPE thisVariable;                                    \
        static QGlobalStatic<TYPE > thisGlobalStatic(&thisVariable); \
        return thisGlobalStatic.pointer;                             \
    }

#ifndef QT_NO_THREAD
Q_GLOBAL_STATIC(QThreadStorage<QUnifiedTimer *>, unifiedTimer)
#endif

编译为:

00000480 <_ZL12unifiedTimerv>:
     480:       55                      push   %ebp
     481:       89 e5                   mov    %esp,%ebp
     483:       57                      push   %edi
     484:       56                      push   %esi
     485:       53                      push   %ebx
     486:       83 ec 2c                sub    $0x2c,%esp
     489:       c7 04 24 28 00 2e 10    movl   $0x102e0028,(%esp)
     490:       8d 74 26 00             lea    0x0(%esi,%eiz,1),%esi
     494:       8d bc 27 00 00 00 00    lea    0x0(%edi,%eiz,1),%edi
     49b:       e8 fc ff ff ff          call   49c <_ZL12unifiedTimerv+0x1c>
     4a0:       84 c0                   test   %al,%al
     4a2:       74 1c                   je     4c0 <_ZL12unifiedTimerv+0x40>
     4a4:       0f b6 05 2c 00 2e 10    movzbl 0x102e002c,%eax
     4ab:       83 f0 01                xor    $0x1,%eax
     4ae:       84 c0                   test   %al,%al
     4b0:       74 0e                   je     4c0 <_ZL12unifiedTimerv+0x40>
     4b2:       b8 01 00 00 00          mov    $0x1,%eax
     4b7:       eb 27                   jmp    4e0 <_ZL12unifiedTimerv+0x60>
     4b9:       8d b4 26 00 00 00 00    lea    0x0(%esi,%eiz,1),%esi
     4c0:       b8 00 00 00 00          mov    $0x0,%eax
     4c5:       eb 19                   jmp    4e0 <_ZL12unifiedTimerv+0x60>
     4c7:       90                      nop
     4c8:       90                      nop
     4c9:       90                      nop
     4ca:       90                      nop
     4cb:       90                      nop

检查49b 处的调用指令:这是验证器无法理解的。到底是什么可以诱使编译器发出一条调用自身中间的指令?有没有解决的办法?我用 -g -O0 -fno-inline 编译。编译器错误?

4

2 回答 2

3

大概它实际上是对外部符号的调用,它将在链接时填充。实际上会被调用的是 externalSymbol-4,这有点奇怪——也许这就是让 ncval 验证器失去意义的原因。

于 2012-05-09T19:56:48.563 回答
1

这是一个动态库还是一个尚未链接到可执行文件的静态对象?

在动态库中,这可能会出现,因为代码是根据位置构建的并链接到动态库中。试试“objdump -d -r -R”,如果你看到 TEXTREL,就是这样。NaCl 动态链接故事不支持 TEXTREL。(通过在代码编译期间使用 -fPIC 标志解决)

使用静态对象在链接到静态可执行文件后尝试验证。

于 2012-05-18T09:21:01.220 回答