首页 > 极客资料 博客日记
Arm V8 - ADRP指令
2024-08-04 20:30:03极客资料围观39次
文章Arm V8 - ADRP指令分享给大家,欢迎收藏极客之家,专注分享技术知识
ADRP指令
- 作用
- 将当前指令所在页的基地址加/减去字节差,并写入目标寄存器
- 字节差:与目标地址页基地址的间隔字节数,其为PAGE_SIZE的整数倍
- 此时的字节差就是指令所操作的立即数
- 该指令通常配合add指令来向目标寄存器写入完整的地址
- 最后通过br、blr实现长跳转
- 将当前指令所在页的基地址加/减去字节差,并写入目标寄存器
- 字节码对应关系
- Adrp指令字节码案例
0x90 0xFF 0xFF 0xE1
- 对应二进制
1001 0000 1111 1111 1111 1111 1110 0001
- 寄存器位 4-0
0 0001
-> 表示x1寄存器- 如果是
0 0000
-> 则表示x0寄存器 - 以此类推
0 0010
-> x20 0011
-> x3n nnnn
-> x...
- 立即数位(高19位) 23-5
1111 1111 1111 1111 111
- adr指令位 28-24
10000
- 至于为什么是adr指令位而不是adrp指令位,是因为我发现两者是相同的
- adr与adrp的差异在于第31位是否为1
- 立即数位(低2位) 30-29
00
- 64位操作位 31
1
- 当该位为1时表示adrp指令,当为0时表示adr指令
- Adrp指令字节码案例
- 对照表
1 00 10000 1111 1111 1111 1111 111 00001
|31| 30-29 | 28-24 | 23-5 | 4-0 |
|sf| immlo | | immhi | rd |
ADRP指令操作数的推导过程
- 在armv8指令手册中是这么写的
- SignExtend(immhi:immlo:Zeros(12), 64);
- 字面理解就是
- 有符号扩展(操作数高位:操作数低位:12个0,总长64位)
- 根据上述案例配合表达式进行计算
- 拼接结果
- =
1111 1111 1111 1111 111 00 0000 0000 0000
- = 0x1 FFFF C000
- =
- 符号扩展步骤及结果
- = 0x1 FFFF C000 << 31 >>31
- = 0xFFFF FFFF FFFF C000
- = -16384
- 也就是说,要在当前指令所在页基地址基础上减去16384字节
- -16384/PAGE_SIZE = -4, 也就是4页的大小
- 拼接结果
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- Nuxt.js 应用中的 prerender:routes 事件钩子详解
- 【问题解决】Tomcat由低于8版本升级到高版本使用Tomcat自带连接池报错无法找到表空间的问题
- 【FAQ】HarmonyOS SDK 闭源开放能力 —Vision Kit
- 六、Spring Boot集成Spring Security之前后分离认证流程最佳方案
- 《JVM第7课》堆区
- .NET 8 高性能跨平台图像处理库 ImageSharp
- 还在为慢速数据传输苦恼?Linux 零拷贝技术来帮你!
- 刚毕业,去做边缘业务,还有救吗?
- 如何避免 HttpClient 丢失请求头:通过 HttpRequestMessage 解决并优化
- 让性能提升56%的Vue3.5响应式重构之“版本计数”