5

我试图准确了解异常表 (.arm.extab) 的工作原理。我知道这取决于编译器,所以我将自己限制为 armcc(因为我使用的是 Keil)。

表中的典型条目如下所示: b0aa0380 2a002c00 01000000 00000000

据我了解,第一个词编码个性例程的指令,而第三个词是 R_ARM_PREL31 重定位到 catch 块的开头。

让我感到困惑的是第二个词 - 它似乎被分成 2 个短裤,其中第二个测量距离投掷功能开始的一段距离,但我不确定具体是什么(也不知道第一个短裤是做什么的)。

是否有任何地方记录了这些条目的结构?

我找到了 2 个相关文档,但据我所知,它们没有与编译器相关的信息,因此它们还不够:http: //infocenter.arm.com/help/topic/com.arm.doc。 ihi0044f/IHI0044F_aaelf.pdf http://infocenter.arm.com/help/topic/com.arm.doc.ihi0038b/IHI0038B_ehabi.pdf

4

1 回答 1

1

如果您碰巧错过了字节顺序,则适用以下内容。即使原始示例中的字节顺序正确,某些信息也可能有用。


extab并且exidx是 AAPCS 添加的部分,它是一个较新的 ARM ABI。

对于较旧的 APCS,帧指针fp是活动例程链接回主例程(或 _start)的根。使用 AAPCS 创建记录并将其放置在exidxextab部分中。fp当用作通用寄存器时,这些是展开堆栈(和资源)所必需的。

exidx是例程开始地址和extab索引(或无法展开)的有序表。可以PC检查(程序计数器)并通过表搜索以找到相应的extab条目。

ARM EHABI文档有一个关于异常处理表条目的第 6 节。这些是extab条目,您至少可以从那里开始了解更多信息。有两个定义,

  1. 通用(或 C++)
  2. ARM 紧凑型

紧凑模型将用于大多数“C”代码。与 C++ 一样,堆栈上没有要销毁的对象。十六进制8003aab0给出,

  • 1000b 表示前半字节,所以这是紧凑的。
  • 0000b 为索引。Su16—短
  • 03h - 弹出 16 个字节,一些局部变量或填充。
  • aah - 弹出 r4-r6
  • b0h - 完成

表 4,ARM 定义的帧展开指令给出了每个字节的展开数据。

下一个是0x002c002a通用人格常规的抵消。接下来的四个值应该是8.2 Data Structures,它们是一个大小并且应该为零……接下来是步幅,然后是一个四字节的对象类型信息。偏移量 0x2c002a 将调用对象析构函数或某种包装器来执行此操作。


我认为所有 C++ 代码都旨在使用这种通用方法。其他方法适用于不同的语言而不是编译器。

相关问答和链接:

于 2019-08-11T18:05:01.513 回答