反汇编学习笔记4 ADRP

sp 需要16位对齐 函数参数从x0开始调用

常量的获取

adrp 指令: adr(address)p(page) adrp x0, x1 第一步:将1的值左移12位 (1 0000 0000 0000)= 0x1000 第二步:将pc寄存器的低12位清零 第三步:将前两步的结果相加,放入x0寄存器

adrp是用来计算指定的数据地址到当前(runtime)pc值的相对偏移 因为后12bit为0,所以得到的偏移量是不精确的,后面的12bit(4KB)是用来自己去精确确定的。这个指令的目的是在以的到的地址为基地址,4KB的偏移地址以内一定有你要找的数据。

下移条指令一般就是去精确这个偏移地址的

代码在编译的时已经确定了代码中的常量的地址,所以后面的偏移地址计算机本已经知道了。

全局变量是地址传递,所以里面是 int* 类型,要去到这个地址指向的值要用 *(int *) 所以要显示的时候是 p *(int *) 0x1002e8d10

外挂在游戏更新后就不能用了,是因为游戏更新的时候这些地址改变了,这些地址是在编译的时候确认的,重新编译会导致地址改变。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值