2. ARM处理器概论

分清两个核心:PC寄存器存的是【地址】,不是普通数据值💡

1. 一句话定死:PC = 存放「指令内存地址」的寄存器

CPU要去内存哪个位置取指令 ,全看PC里存的地址数字

内存格子编号=地址(0x2004、0x2008......),格子里装的才是指令/数据(值)。

PC永远存格子编号(地址),不存格子里的内容。

2. 拿 0x2007 举例拆解

  1. 你写入PC的数字:0x2007(这是你想要跳转的目标地址)
    你代码:MOV PC,#0x2007 → 你以为:去内存编号0x2007的格子拿指令
  2. ARM硬件规则生效:砍掉bit1:0,丢弃低2位
    0x2007 → 抹掉末尾2bit → 0x2004
  3. 最终生效:CPU实际访问地址 = 0x2004
    CPU无视你给的0x2007,强行去地址0x2004的内存取指令。

关键:

  • 0x2007你代码给PC的目标地址(无效地址,ARM指令不能放这)
  • 0x2004硬件修正后、CPU真实访问的有效地址

0x2005/0x2006/0x2007 这3个地址:ARM模式下不允许存放指令,只有0x2004、0x2008能存ARM指令,硬件自动兜底修正地址。

3. 区分【地址】和【存储的值】极简比喻

  • 地址 = 房间门牌号(0x2004)
  • 值 = 房间里面放的东西(ARM机器指令)
  • PC:专门记门牌号的小本本

你在本本上写门牌2007号,但ARM规定:只有门牌是4倍数的房间才有指令 ,2005/2006/2007是空房间,门卫(硬件)直接把门牌改成2004,CPU去2004房间拿指令。

4. 正确用法

想跳到地址0x2004 取指令 → 代码就给PC赋值0x2004,低位bit1:0=00,硬件不修改,正常跳转。


补充:bit31:2、bit1:0再简化

PC一共32位:

  • bit31~bit2真正用来生成有效地址的位(门牌号主体)
  • bit1~bit0无效位,不管填0/1,硬件直接扔掉作废(门牌末尾两位不算数)
相关推荐
secondyoung2 天前
Cortex-R52学习:MPU内存保护机制
arm开发·单片机·学习·arm·mpu
szxinmai主板定制专家2 天前
基于 ARM+FPGA精密多轴实时运动控制卡设计方案,适用于半导体设备等高精度领域(一)
arm开发·人工智能·嵌入式硬件·fpga开发·架构·语音识别
你疯了抱抱我2 天前
【Mac】安装并配置HomeBrew;ARM GCC;make;OpenOCD
arm开发·macos
WHS-_-20225 天前
When RDMA Meets Wireless
arm开发
szxinmai主板定制专家5 天前
基于 ARM+FPGA 数据机床实时工业控制设计--以雕刻机为例
arm开发·人工智能·嵌入式硬件·fpga开发
wandertp5 天前
对信号处理及滤波器的理解---基于robomaster机器人嵌入式控制系统
arm开发·stm32·算法·信号处理
XMAIPC_Robot5 天前
基于RK3588 ARM+FPGA电火花数控机床控制系统设计,兼顾ethercat软硬件实时
linux·arm开发·人工智能·嵌入式硬件·fpga开发
底层开发智库5 天前
C1-Ultra FVP调试并运行Linux kernel全程记录,硬核演示如何解决启动问题
linux·arm开发·内核·嵌入式·arm
XMAIPC_Robot5 天前
基于 ARM+FPGA 数据机床控制系统设计--以雕刻机为例
arm开发·fpga开发