- 博客(2)
- 收藏
- 关注
原创 ADRP指令分析
由于imm占用21bit,其中最高bit为符号位,所以可以表示的offset范围是[-1MB, 1MB], 同时offset的单位是4KB,所以通过ADRP可以查找[pc - 4GB, pc + 4GB)之间的地址。另外还有个ADR的指令,这个指令与ADRP类似,只是offset的单位是Byte,可以查找[pc - 1MB, pc + 4MB)之间的地址。然后将imm[2, 21]保存到指令编码的[5, 23]位段中,将imm[0, 1]保存到指令编码的[29,30]位段中;哪这个的imm是从哪里来的呢?
2024-04-02 23:17:14 572
原创 Linux Kernel线性映射代码分析
在Linux Kernel启动过程中,会根据物理内存的大小以及虚拟内存空间大小,决定线性映射区间的大小。在ARM64架构中,由于虚拟地址空间足够大,正常情况下都会对memory建立线性映射,有的也叫直接映射。本文主要是走读线性映射的代码。
2023-12-15 00:00:32 101
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人