我知道了 jump table 的地址,从 rodata 中 dump 出了对应的数据,但不知道 jump table 中的数据是按照什么格式组织的
表的一行是 4 个字节,所以"fffe90d4", "fffe9124"这些值代表了地址的 offset ?但这些值也太大了吧,这个函数没这么多行。
我查了老半天,也没有查到相关的资料,求懂汇编的老哥帮忙看看。

使用这个jump table的汇编指令如下所示:
457c0:  f00000a9    adrp    x9, 5c000
457c4:  911c0129    add     x9, x9, #0x700
457c8:  b8a87928    ldrsw   x8, [x9, x8, lsl #2]
457cc:  8b090108    add     x8, x8, x9
457d0:  d61f0100    br      x8
|  |      1Nerv      2021-04-05 23:40:13 +08:00 via Android 只试过用 readelf 读取 linux x86-64 elf 文件的 symtable,不知道对应的 arm 版本有没有这种功能。 | 
|  |      2menyakun OP @Nerv 这个 jump table 是一个 switch-case 生成的,所以对应的目标地址没有记录在 symtable 里面 | 
|  |      3wezzard      2021-04-05 23:49:52 +08:00  1 這裡存儲的是一個相對偏移量,應該看成一個有符號的整數。你應該用該條記錄的基址加上這個有符號的相對偏移,然後得出跳轉目標地址。 | 
|  |      4akira      2021-04-06 01:52:48 +08:00 看到 feff 就觉得应该是 -100 | 
|  |      5levelworm      2021-04-06 02:27:34 +08:00 via Android 看到 ff 打头的我第一反应是 sign extended,具体得去查查。。。 | 
|      6zk8802      2021-04-06 06:31:13 +08:00 Jump table 中常见的地址 /偏移编码方式有好几种。你需要看一下对应的汇编指令是如何解析这个 jump table 的。 另外你这里面的负数大概率是相对 PC 的偏移。 |