Armv8 - 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 -> x2
        • 0 0011 -> x3
        • n 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指令
  • 对照表

     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页的大小
相关推荐
7yewh4 分钟前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
小张认为的测试8 分钟前
Linux性能监控命令_nmon 安装与使用以及生成分析Excel图表
linux·服务器·测试工具·自动化·php·excel·压力测试
打鱼又晒网17 分钟前
linux网络套接字 | 深度解析守护进程 | 实现tcp服务守护进程化
linux·网络协议·计算机网络·tcp
良许Linux30 分钟前
0.96寸OLED显示屏详解
linux·服务器·后端·互联网
蜜獾云41 分钟前
docker 安装雷池WAF防火墙 守护Web服务器
linux·运维·服务器·网络·网络安全·docker·容器
小屁不止是运维42 分钟前
麒麟操作系统服务架构保姆级教程(五)NGINX中间件详解
linux·运维·服务器·nginx·中间件·架构
bitcsljl1 小时前
Linux 命令行快捷键
linux·运维·服务器
ac.char1 小时前
在 Ubuntu 下使用 Tauri 打包 EXE 应用
linux·运维·ubuntu
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
Youkiup1 小时前
【linux 常用命令】
linux·运维·服务器