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,硬件直接扔掉作废(门牌末尾两位不算数)
相关推荐
AndyHeee9 天前
【SVC、PendSV(系统异常) 与 外设 IRQ 、NVIC笔记】
arm开发
暮云星影9 天前
瑞芯微rk3588利用Rockchip NPU运行大语言模型(LLM)
arm开发·人工智能·语言模型·自然语言处理
techdashen9 天前
绕过系统 ICMP:用 rawsock、Npcap 和 WMI 找到默认网卡
开发语言·arm开发·rust
振南的单片机世界9 天前
ARM中断比51快在哪?硬件压栈+NVIC集中管理
arm开发·stm32·单片机·嵌入式硬件
墨绿色的摆渡人9 天前
论文笔记(一百三十七)Learning Dual-Arm Push and Grasp Synergy in Dense Clutter
arm开发·论文阅读
暮云星影9 天前
全志linux开发屏幕适配(一)屏幕参数设置说明
linux·arm开发
m0_547486669 天前
《ARM Cortex-M4嵌入式应用技术——基于STM32F407、STM32CubeMX与Proteus》全套PPT课件
arm开发·stm32·proteus
Lanceli_van10 天前
SQLite 3.45.2(sqlite-autoconf-3450200)ARM 交叉编译完整步骤
arm开发·sqlite
暮云星影10 天前
全志linux开发屏幕适配(二)`HDMI`驱动适配说明
linux·arm开发·驱动开发
暮云星影10 天前
瑞芯微rk3566开发FIT Secure Boot
linux·arm开发·驱动开发·安全