news 2026/6/23 5:49:52

PC 指针为何不等于执行地址?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PC 指针为何不等于执行地址?

一、先明确两个核心概念

执行地址:CPU 当前正在"执行(Execute)"的指令地址(如正在运算的ADD指令地址)

PC 指针:CPU 下一个要"取指(Fetch)"的指令地址(告诉 CPU 下条指令在哪)

PC 天然指向"执行地址的后面",差异仅在于偏移多少——由流水线和架构决定。

二、根本原因:流水线 + 架构规范

1. 流水线机制:并行执行的必然结果

ARM 用 3 级流水线(取指→译码→执行)实现指令并行:当指令 A(执行地址)在执行时,指令 B 在译码,指令 C 在取指,PC 此时指向指令 C 的地址。

例:经典 ARM(32 位指令)中,执行地址0x00(A)→ PC0x08(C),偏移 +8;但 Cortex-M3/M4 有额外规范。

2. 架构规范:Cortex-M3/M4 的"强制偏移"

Cortex-M3/M4 仅支持 Thumb/Thumb-2 指令集(16/32 位指令),ARMv7-M 架构强制规定:无论指令是 16 位还是 32 位,PC = 执行地址 + 4。

执行 16 位指令(地址0x00)→ PC0x04

执行 32 位指令(地址0x00)→ PC0x04

目的是简化开发:无需判断指令长度,偏移规则统一。

三、Cortex-M3/M4 实战:正确获取执行地址

1. 手动计算:PC - 4

因PC = 执行地址 + 4,减 4 即得真实执行地址:

; 获取当前执行地址,存入R0

GetCurrentAddr:

MRS R0, PC ; R0 = PC(执行地址+4)

SUB R0, R0, #4 ; R0 = 执行地址(正确)

BX LR

2. 用伪指令:避免手动算偏移

日常开发优先用ADR/LDR =label,编译器自动处理 PC 偏移:

ADR R0, DataBuf ; 短距离:自动生成PC相对寻址(修正偏移)

LDR R1, =ConfigAddr ; 长距离:从字面池读地址(无需关心PC)

DataBuf: DCD 0x11223344

ConfigAddr: DCD 0x00001234

四、3 个必避误区

误区 1:按指令长度算偏移(16 位 +2、32 位 +4)→ 错!Cortex-M 强制 +4

误区 2:混用架构规则(把经典 ARM 的 +8 套到 Cortex-M)→ 错!Cortex-M 只 +4

误区 3:手动算偏移不用伪指令→ 错!ADR/LDR =label更稳定,避免代码修改后偏移失效

五、总结

PC≠执行地址,是 ARM"效率(流水线并行)"与"易用性(架构规范)"的平衡结果。对 Cortex-M3/M4 开发者,只需记住:

PC = 执行地址 + 4

获取执行地址用PC-4

日常用伪指令处理地址

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 19:33:56

新型基础设施运维(Infratech + GIS):一场被低估的结构性变革

在大多数人对地理信息系统(GIS)的认知中,它仍然主要服务于“建设阶段”:规划、选址、设计、验收。一旦基础设施建成,GIS 的使命似乎也随之完成。然而,正是在这一“建成之后”的漫长阶段,一场真正…

作者头像 李华
网站建设 2026/6/23 17:46:04

软件测试面试题个人总结

前面看到了一些面试题,总感觉会用得到,但是看一遍又记不住,所以我把面试题都整合在一起,都是来自各路大佬的分享,为了方便以后自己需要的时候刷一刷,不用再到处找题,今天把自己整理的这些面试题…

作者头像 李华
网站建设 2026/6/23 1:31:18

OpenWrt智能路由终极指南:如何实现多线路带宽叠加

OpenWrt智能路由终极指南:如何实现多线路带宽叠加 【免费下载链接】OpenWrt 基于 Lean 源码编译的 OpenWrt 固件——适配X86、R2C、R2S、R4S、R4SE、R5C、R5S、香橙派 R1 Plus、树莓派3B、树莓派4B、R66S、R68S、M68S、H28K、H66K、H68K、H88K、H69K、E25、N1、S905…

作者头像 李华
网站建设 2026/6/23 17:47:18

bibliometrix:科学文献分析的终极指南与快速上手教程

想要深入了解某个研究领域的发展脉络?希望快速识别学术热点和合作趋势?bibliometrix这款强大的文献计量分析工具就是你的最佳选择!🚀 作为一款专业的R语言工具包,它能够帮助你从海量科学文献中挖掘有价值的信息&#x…

作者头像 李华
网站建设 2026/6/23 17:27:52

React JSON Schema Form终极指南:3步构建专业表单应用

React JSON Schema Form终极指南:3步构建专业表单应用 【免费下载链接】react-jsonschema-form A React component for building Web forms from JSON Schema. 项目地址: https://gitcode.com/gh_mirrors/re/react-jsonschema-form React JSON Schema Form&a…

作者头像 李华
网站建设 2026/6/23 10:02:20

低价游陷阱专坑老年人?

「莫道桑榆晚,为霞尚满天」现在有越来越多退休的朋友,不再只是想着在家带带孙子孙女这类事情,而是跟老伙伴约好背上背包,到处去游历大江南北,朋友圈里那些拍摄美景时的笑容,就是老年人重新焕发出生机活力的…

作者头像 李华