news 2026/4/16 11:00:21

ARM 架构 DSB 与 ISB 基础

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ARM 架构 DSB 与 ISB 基础

一、为什么需要 DSB 和 ISB?

在学习 DSB 和 ISB 之前,我们先明白一个前提 ——现代 CPU 会 自行优化,这些优化在普通场景下没问题,但在多核协作、操作硬件时可能出 bug:

  1. 乱序执行:CPU 为了快,会调整无依赖的指令顺序(比如先执行不依赖其他结果的指令);
  1. 缓存异步:CPU 有高速缓存,数据先写缓存再慢慢同步到内存,导致其他设备 / 核心可能读不到最新数据。

DSB 和 ISB 就是用来 “纠正” 这些优化的工具:当我们需要严格的执行顺序或数据同步时,用它们强制 CPU 按我们的要求来。

二、DSB 和 ISB 分别是做什么的?

1. DSB(数据同步屏障)

(1)通俗理解

DSB 就像一个 “交通指挥员”,让屏障前面所有和数据相关的操作(读数据、写数据)都完成后,才允许屏障后面的操作开始。比如:先确保数据写完并同步到内存,再执行下一步读操作。

(2)关键作用
  • 保证 “写数据” 真的写完:比如向硬件寄存器发命令,DSB 能确保命令真的传到硬件,而不是停在 CPU 缓存里;
  • 保证 “读数据” 读的是最新:比如从共享内存读数据,DSB 能确保读到的是其他核心刚写完的最新值。

2. ISB(指令同步屏障)

(1)通俗理解

ISB 就像一个 “刷新按钮”,会清空 CPU 里已经提前准备好的指令(指令流水线),让后续指令重新从内存读取。这样能确保执行的是最新的指令,而不是旧的 “缓存指令”。

(2)关键作用
  • 执行修改后的代码:比如程序自己修改了一段指令(如动态补丁),ISB 能让 CPU 重新读新指令,避免执行旧指令;
  • 切换权限后生效:比如从用户模式切换到内核模式,ISB 能确保后续指令按新权限执行。
(3)和 DSB 的核心区别

对比项

DSB(数据同步屏障)

ISB(指令同步屏障)

管什么

数据的读 / 写顺序和同步

指令的新鲜度(是否是最新)

典型场景

多核数据共享、操作硬件寄存器

修改代码后执行、切换权限

简单记忆

“数据要同步,就用 DSB”

“指令要刷新,就用 ISB”

三、常用场景

1. DSB 的常见场景

(1)多核 CPU 共享数据

比如核心 A 给核心 B 发数据,必须用 DSB 确保核心 B 读到最新值:

  • 核心 A:写完数据后用 DSB 同步到内存,再告诉核心 B “数据好了”;
  • 核心 B:收到通知后用 DSB 刷新,再读数据,确保读到最新的。
(2)操作硬件设备(如传感器、网卡)

比如给硬件发 “启动命令” 后,要读硬件状态,必须用 DSB 确保命令真的传到硬件:

  • 第一步:给硬件寄存器写 “启动命令”;
  • 第二步:用 DSB 同步,确保命令到硬件;
  • 第三步:读硬件状态,判断是否启动成功。

2. ISB 的常见场景

(1)程序自己修改了代码(如动态补丁)

比如程序运行中把一段旧指令改成新指令,必须用 ISB 让 CPU 读新指令:

  • 第一步:修改指令内容;
  • 第二步:用 DSB 确保修改同步到内存;
  • 第三步:用 ISB 刷新指令,再执行修改后的代码。
(2)切换权限(如从用户模式到内核模式)

比如通过系统调用进入内核,ISB 能确保后续指令按内核权限执行,避免权限错误。

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

LobeChat能否对接IFTTT自动化?跨应用触发器设定

LobeChat能否对接IFTTT自动化?跨应用触发器设定 在智能工具日益融合的今天,我们不再满足于“你问我答”式的AI交互。真正的智能助手应当能感知环境、响应事件,甚至在用户开口前就采取行动——比如当工作邮箱收到一封标有“紧急”的邮件时&…

作者头像 李华
网站建设 2026/4/15 22:11:51

互联网大厂Java求职面试场景对话及技术深度解析

互联网大厂Java求职面试场景对话及技术深度解析 场景介绍 本文设定在一家互联网大厂的Java开发岗位面试现场,面试官严肃专业,求职者谢飞机则风趣幽默。三轮问答围绕典型互联网业务场景展开,覆盖丰富的技术栈并逐步深入,适合Java初…

作者头像 李华
网站建设 2026/4/15 8:48:47

Telegram群组同步更新:国际用户沟通桥梁

Telegram群组同步更新:国际用户沟通桥梁 在跨国团队协作日益频繁的今天,如何让分布在全球各地的成员实现高效、无障碍的沟通,成为了一个现实挑战。语言差异、时区错配、信息碎片化等问题不断消耗着团队的协作效率。与此同时,AI助…

作者头像 李华
网站建设 2026/4/7 18:57:05

SAP如何打开物料帐期和财务账期

1)打开物料账期用事务代码MMPV,查看用MMRV2)打开财务账期用事务代码OB52假设今天是2025年6月1日,需要打开2025年6月份的账期。1)用事务代码MMPV打开物料账,如下图填写的数据。用MMRV检查2)事务代…

作者头像 李华
网站建设 2026/4/2 17:36:35

日志系统与结构化日志

目录日志系统与结构化日志引言1. 日志系统基础概念1.1 日志的重要性与价值1.2 日志系统的演进历程1.3 日志质量的金字塔模型2. 结构化日志基础2.1 什么是结构化日志?2.2 结构化日志 vs 非结构化日志2.3 结构化日志的数学表示3. 日志系统架构设计3.1 现代日志系统架构…

作者头像 李华
网站建设 2026/4/16 10:22:04

【天津财经大学主办】第五届社会科学与人文艺术国际学术会议 (SSHA 2026)

第五届社会科学与人文艺术国际学术会议 (SSHA 2026)于2026年2月06-08日在中国北京举行。会议旨在为从事“社会科学”与“人文艺术”研究的专家学者、工程技术人员、技术研发人员提供一个共享科研成果和前沿技术,了解学术发展趋势,拓宽研究思路&#xff0…

作者头像 李华