当前位置: 首页 > news >正文

原子操作与非原子操作

 原子操作的本质
// BSRR操作(原子):
GPIOA->BSRR = (1 << 5);  // 单条汇编指令: STR [addr], #bitmask
  • 硬件行为:CPU通过单次内存写入直接修改目标寄存器

  • 不可中断性:该指令执行时不会响应中断(执行完毕后才检查中断标志)

2. 非原子操作的风险
// ODR操作(非原子):
GPIOA->ODR |= (1 << 5);  
// 实际展开为:
// 1. LDR R0, [GPIOA_ODR_addr]  // 读取当前值 → 可能在此处被中断!
// 2. ORR R0, R0, #(1<<5)       // 修改值
// 3. STR R0, [GPIOA_ODR_addr]  // 写回
  • 中断插入点:任何两个步骤之间都可能被中断插入

  • 破坏现场:中断若修改同一寄存器,原始值会被“覆盖”


⚡ 中断触发机制的深层原理

阶段原子操作 (BSRR)非原子操作 (ODR)
指令开始锁定总线,独占访问无保护
执行中禁止中断响应可被高优先级中断抢占
内存写入单次完成全部位修改分步操作(读→改→写)
完成时释放总线,检查待处理中断各步骤间均可能响应中断

✅ 关键结论
中断只能在指令边界响应,而原子操作是单指令,非原子操作是多指令组合。


🧪 灾难性场景模拟(ODR操作被中断破坏)

假设初始状态:GPIOA->ODR = 0x0000
主程序尝试设置PA5:

GPIOA->ODR |= (1 << 5);  // 目标: 0x0020

中断函数尝试设置PA6:

GPIOA->ODR |= (1 << 6);  // 目标: 0x0040
危险时序:
主程序: [读ODR] → 读到0x0000│
中断触发: [读ODR] → 读到0x0000[改值]  → 0x0000 | 0x0040 = 0x0040[写回]  → ODR=0x0040│
主程序: [改值]   → 0x0000 | 0x0020 = 0x0020  // 错误!基于旧值0x0000修改[写回]   → ODR=0x0020              // PA6的修改被覆盖!

结果:PA5成功置位,但PA6的修改丢失!


🛡️ 解决方案对比

方法代码示例代价适用场景
BSRR原子操作GPIOA->BSRR = 1<<5;零开销首选方案
关中断保护__disable_irq();
`GPIOA->ODR
= ...;<br>__enable_irq();`中断延迟必须操作ODR时
硬件互斥锁LDREX/STREX 指令复杂指令周期多核系统

💎 终极结论

  1. 原子操作 = 1条指令 = 不可分割 = 安全
    (如BSRR/BTR寄存器操作)

  2. 非原子操作 = N条指令 = 可被中断切割 = 需保护
    (如ODR的读-改-写操作)

“非原子操作多条指令,可能导致指令没执行完就被中断把0/1换了”
—— 这正是嵌入式系统中最隐蔽的Bug来源之一!

http://www.lqws.cn/news/102457.html

相关文章:

  • leetcode hot100(两数之和、字母异位词分组、最长连续序列)
  • smartGit 试用突破30天
  • CSS设置移动端页面底部安全距离
  • PostgreSQL的扩展 passwordcheck
  • Git 使用规范指南
  • Ⅲ-2.计算机二级选择题(三大结构之选择结构)
  • ULVAC DC-10-4P 400V input 10kW DC Pulse power supply 爱发科直流电源
  • JVM—垃圾收集算法和HotSpot算法实现细节
  • 嵌入式开发学习日志(linux系统编程--系统编程之 进程间通信IPC)Day32
  • Java Lambda 表达式的缺点和替代方案
  • 为何选择Spring框架学习设计模式与编码技巧?
  • STM32F103C8T6:解锁无限可能的应用之旅
  • STM32单片机编程中标志变量的思想无处不在
  • 焊缝缺陷焊接缺陷识别分割数据集labelme格式5543张4类别
  • 人工智能在智能教育中的创新应用与未来趋势
  • MybatisPlus--核心功能--service接口
  • 登录vmware vcenter报vSphere Client service has stopped working错误
  • 悟饭游戏厅iOS版疑似流出:未测试版
  • 基于Halcon深度学习之分类
  • 历史记录隐藏的安全风险
  • 英语写作中“不少于(小于)”no less than替代no fewer than的用法
  • 工业智能网关保障冷冻仓储设备无人值守安全运行
  • Linux(线程概念)
  • 大模型、AI人工智能:核心技术与发展趋势
  • C++概率论算法详解:理论基础与实践应用
  • 【linux】VNC无头显示器启动方法
  • 2023-2025 时序大模型相关工作汇总
  • 第三十三天打卡复习
  • DPO 算法
  • 【Unity】减少模型内存占用