【ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍】

这篇具有很好参考价值的文章主要介绍了【ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

上篇文章:ARM 常见汇编指令学习 7 - LDR 指令与LDR伪指令及 mov指令
下篇文章:ARM 常见汇编指令学习 9 - 缓存管理指令 DC 与 IC

ARM dsb sy 指令

数据同步屏障是一种特殊类型的内存屏障。
只有当DSB指令执行完毕后,才会执行程序中位于此指令后的指令。 当满足以下条件时,此指令才会完成:

  • 位于此指令前的所有显式内存访问均完成;
  • 位于此指令前的所有缓存、跳转预测和 TLB 维护操作全部完成。

ARM 的 DSB 指令可以接受以下参数来控制其行为:

  • SY: 全系统DSB。这个屏障对所有的处理器都起作用,也就是说,这个指令会影响所有处理器上的内存访问。
  • ST: 存储DSB。等待所有存储操作及相关的缓存和缓冲区维护操作完成。
  • ISH: 内共享域DSB。等待在处理器的内共享域(Inner Shareable domain)里的所有内存访问以及相关的缓存和缓冲区维护操作完成。
  • ISHST: 内共享域存储DSB。等待在处理器的内共享域里的所有存储操作以及相关的缓存和缓冲区维护操作完成。
  • NSH: 非共享域DSB。等待在处理器的非共享域(Non-shareable domain)里的所有内存访问以及相关的缓存和缓冲区维护操作完成。
  • NSHST: 非共享域存储DSB。等待在处理器的非共享域里的所有存储操作以及相关的缓存和缓冲区维护操作完成。

一个常见的使用DSB指令的例子是在写入特殊的硬件寄存器之前和之后。在这种情况下,需要确保所有之前的内存操作都已完成,并且在写入操作完成之后,再执行后续的指令。以下是一个例子:

MOV r0, #0x5A       ;0x5A 写入 r0 寄存器 
STR r0, [r1]        ; 将 r0 寄存器的值存储到 r1 指向的内存地址 
DSB SY              ; 执行 DSB 指令,等待上述的存储操作完成 
MOV r0, #0xA5       ;0xA5 写入 r0 寄存器 
STR r0, [r1, #4]    ; 将 r0 寄存器的值存储到 r1 指向的内存地址偏移 4 个字节的位置

在上述例子中,DSB SY指令确保了第一个存储操作(STR r0, [r1])在第二个存储操作(STR r0, [r1, #4])之前已经完成。这是因为在某些情况下,如访问特殊硬件寄存器时,执行顺序是很重要的。

关于 ISB/DSB/DMB 的具体介绍见:ARM Cache 系列文章 5 – 内存屏障ISB/DSB/DMB

上篇文章:ARM 常见汇编指令学习 7 - LDR 指令与LDR伪指令及 mov指令
下篇文章:ARM 常见汇编指令学习 9 - 缓存管理指令 DC 与 IC文章来源地址https://www.toymoban.com/news/detail-698200.html

到了这里,关于【ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【ARM 常见汇编指令学习 5 -- arm64汇编指令 wzr 和 xzr】

    上篇文章:ARM 常见汇编指令学习 4 – ARM64 比较指令 cbnz 与 b.ne 区别 下篇文章:ARM 常见汇编指令学习 6 - bic(位清除), orr(位或), eor(异或) ARMv8 在硬件层名引入了一个新的 zero 寄存器 : XZR (64-bits), WZR (32-bits)。比如要将某一变量赋值为0x0, 由于ARM不允许直接操作内存单元上的数据

    2024年02月15日
    浏览(79)
  • ARM64 常见汇编指令学习 11 -- ARM 汇编宏 .macro 的学习

    下篇文章:ARM64 常见汇编指令学习 12 – ARM 汇编函数 的学习 上篇文章:ARM64 常见汇编指令学习 10 – 无符号位域提取指令 BFXIL 在 ARM 汇编中,“ .macro ” 是用来定义一个宏的指令。宏可以看作是一个可以在汇编程序中重用的代码段。当调用宏时,汇编器会将宏的内容插入到调

    2024年02月14日
    浏览(43)
  • 【ARM64 常见汇编指令学习 14 -- ARM 汇编 .balign,.balignw,.balign 伪指令学习】

    上篇文章:ARM64 常见汇编指令学习 13 – ARM 汇编 ORG 伪指令学习 下篇文章:ARM64 常见汇编指令学习 15 – ARM 标志位的学习 .balignl 是一个伪操作符,伪操作符的意思就是机器码里,并没有一个汇编指令与其对应,是编译器来实现其功能的。. balignl 是 .balign 的变体。 .balignl 完整

    2024年02月14日
    浏览(40)
  • 【ARM64 常见汇编指令学习 21 -- ARM RET 与 ERET】

    请阅读 【嵌入式开发学习必备专栏 】 在 ARMv8 架构中, RET 指令用于从函数或者过程返回。它主要负责从当前过程跳转回调用者,并恢复调用者的程序计数器 (PC) 的值。 语法: Xn 是一个可选的寄存器,通常为 X30 (也称为 LR ,链接寄存器),其中包含返回地址。如果没有指

    2024年04月10日
    浏览(136)
  • 【ARM 常见汇编指令学习 3 -- ARM64 无符号位域提取指令 UBFX】

    上篇文章:ARM 常见汇编指令学习 2 – 存储指令 STP 与 LDP 下篇文章:ARM 常见汇编指令学习 4 – ARM64 比较指令 cbnz 与 b.ne 区别 在代码中如何监控寄存器的某1bit, 或者某几bit ? ARM 提供了一个汇编指令:UBFX 就可以用于该功能。 UBFX 有2种语法分别是对32bit 寄存器和64bit寄存器。

    2024年02月15日
    浏览(35)
  • 【ARM 常见汇编指令学习 4 -- ARM64 比较指令 cbnz 与 b.ne 区别】

    上篇文章:ARM 常见汇编指令学习 3 – ARM64 无符号位域提取指令 UBFX 下篇文章:ARM 常见汇编指令学习 5 – arm64汇编指令 wzr 和 xzr B.NE 指令格式 B.NE指令的含义是:如果上一个指令的结果不等于零(即条件标志位Z为0),那么跳转到指定的地址。如果结果等于零,则继续执行下一

    2024年02月14日
    浏览(62)
  • 【ARM 常见汇编指令学习 2 -- 存储指令 STP 与 LDP】

    上篇文章:ARM 常见汇编指令学习 1 – 跳转指令 BL 与 BLR 区别 下篇文章:ARM 常见汇编指令学习 3 – ARM64 无符号位域提取指令 UBFX 在 ARMv8 架构中,STP指令用于将两个通用寄存器的值存储到内存中。STP指令的语法如下: 或 其中: Wt1 和 Wt2 表示两个要存储的32位通用寄存器, Xt

    2024年02月09日
    浏览(41)
  • ARM 常见汇编指令学习 9 - 缓存管理指令 DC 与 IC

    上篇文章:ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍 AArch64指令集中有两条关于缓存维护(cache maintenance)的指令,分别是IC和DC。 IC 是用于 指令缓存 操作; DC 是用于 数据缓存 操作。 IC 和DC指令都属于系统指令(system instruction), 系统指令 还包括 AT,BRB,CFP,CP

    2024年02月14日
    浏览(46)
  • 【ARM 常见汇编指令学习 1 -- 跳转指令 BL 与 BLR 区别】

    下篇文章:ARM 常见汇编指令学习 2 – 存储指令 STP 与 LDP ARM 中跳转指令主要分为无条件跳转和有条件跳转,有条件跳转是一种根据特定条件进行跳转的指令。它会根据条件码寄存器(Condition Code Register)中的状态,判断是否满足特定条件,然后根据条件的结果决定是否进行跳

    2024年02月07日
    浏览(37)
  • 【ARM 常见汇编指令学习 7 - LDR 指令与LDR伪指令及 mov指令】

    上篇文章:ARM 常见汇编指令学习 6 - bic(位清除), orr(位或), eor(异或) 下篇文章:ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍 LDR指令 与 LDR伪指令 两者虽然名字相同但是作用却不相同,区分两者的方法就是看第二个参数,如果有等号,就是LDR伪指令。 LDR 指令 上面语句的

    2024年02月14日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包