微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ARM64 是否有故意未定义的操作码?

如何解决ARM64 是否有故意未定义的操作码?

我想触发一个有意的未定义操作码异常。 ARM64 是否有明确保留为未定义的指令,例如 x86 的 ud2 和 ARM32 的 udf

解决方法

是的,它也被称为 udf。它出现在 ARMv8 体系结构参考手册第 C6-1380 页中。它需要一个立即数操作数,它可以是任何 16 位值并被忽略,例如udf #0xdead

GNU 汇编器最近添加了对 udf 助记符的支持(我相信 2.35 版,2020 年 7 月发布),因此如果您有旧版本,则可能不支持。但是,udf #0 的编码很方便0x00000000,所以你可以直接写.inst 0,或者如果你打算大量使用它,也可以定义一个宏。

实际上,任何高 16 位为 0 的指令都是有保证的 udf,低 16 位是立即数。您可以使用不同的标记来标记代码的不同部分,以便在内存转储中轻松定位。因此,您也可以根据需要执行 .inst 0x0000dead

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。