













分清两个核心:PC寄存器存的是【地址】,不是普通数据值💡
1. 一句话定死:PC = 存放「指令内存地址」的寄存器
CPU要去内存哪个位置取指令 ,全看PC里存的地址数字。
内存格子编号=地址(0x2004、0x2008......),格子里装的才是指令/数据(值)。
PC永远存格子编号(地址),不存格子里的内容。
2. 拿 0x2007 举例拆解
- 你写入PC的数字:0x2007(这是你想要跳转的目标地址)
你代码:MOV PC,#0x2007→ 你以为:去内存编号0x2007的格子拿指令 - ARM硬件规则生效:砍掉bit1:0,丢弃低2位
0x2007 → 抹掉末尾2bit → 0x2004 - 最终生效: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,硬件直接扔掉作废(门牌末尾两位不算数)



