AArch64 Linux 中的标记虚拟地址¶
作者:Will Deacon <will.deacon@arm.com>
日期:2013 年 6 月 12 日
本文档简要描述了 AArch64 转换系统中的标记虚拟地址的规定及其在 AArch64 Linux 中的潜在用途。
内核配置转换表,以便通过 TTBR0(即用户空间映射)进行的转换忽略虚拟地址的最高字节(位 63:56)。 这为应用程序使用释放了该字节。
将标记地址传递给内核¶
内核对用户空间内存地址的所有解释都假定地址标记为 0x00,除非应用程序显式启用 AArch64 标记地址 ABI(AArch64 标记地址 ABI)。
这包括但不限于以下位置找到的地址
系统调用的指针参数,包括传递给系统调用的结构中的指针,
堆栈指针 (sp),例如,在解释它以传递信号时,
帧指针 (x29) 和帧记录,例如,在解释它们以生成回溯或调用图时。
当用户空间应用程序未启用 AArch64 标记地址 ABI 时,在任何这些位置使用非零地址标记可能会导致返回错误代码,引发(致命)信号或其他故障模式。
由于这些原因,当禁用 AArch64 标记地址 ABI 时,禁止通过系统调用将非零地址标记传递给内核,并且强烈建议不要对 sp 使用非零地址标记。
维护使用非零地址标记的帧指针和帧记录的程序可能会受到调试和分析可见性受损或不准确的影响。
其他注意事项¶
使用标记指针时应特别小心,因为 C 编译器很可能不会对仅在最高字节中不同的两个虚拟地址进行哈希处理。