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

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

文章目录

    • ARM dsb sy 指令

上篇文章: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

相关文章:

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

文章目录 ARM dsb sy 指令 上篇文章:ARM 常见汇编指令学习 7 - LDR 指令与LDR伪指令及 mov指令 下篇文章:ARM 常见汇编指令学习 9 - 缓存管理指令 DC 与 IC ARM dsb sy 指令 数据同步屏障是一种特殊类型的内存屏障。 只有当DSB指令执行完毕后&#xff…...

YOLOv5本地模型训练报错解决

报错解决 页面文件太小,无法完成操作 训练过程中,发生下图所示的报错,同时pycharm崩溃 1. 更改虚拟内存 进入高级系统设置,应该都会进,就不说过程了 设置虚拟内存大小 2. 减小占用内容大小 新建一个fixNvPe.py程序…...

tomcat p12证书另存为nginx .crt证书和.key私钥

tomcat p12证书另存为nginx .crt证书和.key私钥 Tomcat使用的.pfx或.keystore文件都是私钥及公钥证书一起的,通过pin保证安全;nginx只需要使用.pem或.crt公钥证书文件和.key私钥即可,如果原ssl证书不方便重新下载,在已有tomcat证…...

Docker的userland-proxy

前言 Docker针对端口映射前后有两种方案,一种是1.7版本之前docker-proxyiptables DNAT 的方式;另一种则是1.7版本(及之后)提供的完全由iptables DNAT实现的端口映射。不过在目前docker 1.9.1中,前一种方式依旧是默认方式。但是从Docker 1.7版…...

uniapp封装request请求

在基础文件里面创建一个api文件 在创建两个 js文件 http.js 里面封装 request 请求 let baseUrl https://white.51.toponet.cn; //基地址 export const request (options {}) > {//异步封装接口,使用Promise处理异步请求return new Promise((resolve, reject…...

Go如何构建高效API接口| 青训营

Go语言作为一个高效的静态类型语言,在构建API服务时也表现出了很大的优势。本文将介绍如何使用Go语言构建高效的API服务,帮助开发者更好地应对日益增长的API需求。 一、选择适合的框架 首先,选择适合的框架是构建高效API服务的重要一步。在…...

【云原生K8s】二进制部署单master K8s+etcd集群

一、实验设计 mater节点master01192.168.190.10kube-apiserver kube-controller-manager kube-scheduler etcd node节点node01192.168.190.20kubelet kube-proxy docker (容…...

TRUNC(截取)函数的用法

TRUNC函数在Oracle中用于截断日期、时间或数字的精度。其语法如下: 截取数字: TRUNC(number [, precision])其中: number 表示要截断的数字。 precision表示截断的精度。可以是负数、整数或者默认为空。正数表示保留小数位数,负…...

IELAB-网络工程师的路由答疑10问(1)

各位同学,我相信对于许多新学习的同学而言,在刚接触该的时候总会产生许多问题,今天 我们就简单讲解一下常见的几种问题: 什么是路由? 简单来讲,路由通常发生在网络层,为什么呢?首先…...

OpenLayers入门,OpenLayers加载TopoJson数据,使用行政区划边界作为示例

专栏目录: OpenLayers入门教程汇总目录 前言 本章讲解一下OpenLayers如何加载解析TopoJson格式的数据。 TopoJson介绍 TopoJson是用于表示地理空间数据的格式。是GeoJson格式的改进版,相比 GeoJSON 直接使用 Polygon、Point 之类的几何体来表示图形的方法,TopoJSON 中的…...

【图像去噪】基于原始对偶算法优化的TV-L1模型进行图像去噪研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

RISC-V基础之函数调用(五)函数递归调用及函数参数数量溢出(超出现有寄存器个数)约定(包含实例)

首先先解释一下栈在函数调用中的作用,更详细的部分请参照考研复习之数据结构笔记(五)栈和队列(上)(包含栈的相关内容)_管二狗赶快去工作!的博客-CSDN博客 函数嵌套调用栈的作用是用…...

力扣:48. 旋转图像(Python3)

题目: 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 来源:力扣(LeetCode) 链接&…...

HarmonyOS应用开发者基础与高级认证题库——中级篇

系列文章目录 HarmonyOS应用开发者基础与高级认证题库——基础篇 HarmonyOS应用开发者基础与高级认证题库——中级篇 文章目录 系列文章目录前言一、判断二、单选三、多选 前言 今天刚换了台果子手机就收到了华子鸿蒙开发认证邀请(认证链接)&#xff0…...

Python中实现多个列表、字典、元组、集合的连接

目录 目录 前言 一、列表 1、运算符 2、extend()方法 3、解包操作 * 二、字典 1、update()方法 2、解包操作 ** 三、元组 1、 运算符 2、解包操作 * 四、集合 1、union方法 2、| 运算符 3、解包操作 * 五、不同类…...

1005 继续(3n+1)猜想

描述 卡拉兹(Callatz)猜想已经在1001中给出了描述。在这个题目里,情况稍微有些复杂。 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数。例如对 n3 进行验证的时候,我们需要计算 3、5、8、4、…...

基于图片、无人机、摄像头拍摄进行智能检测功能

根据要求进行无人机拍摄的视频或图片进行智能识别,开发过程需要事项 1、根据图片案例进行标记,进行模型训练 2、视频模型训练 开发语言为python 根据需求功能进行测试结果如下 根据车辆识别标记进行的测试结果截图 测经过查看视频 8月1日...

Boost开发指南-4.2ignore_unused

ignore_unused 编写代码的过程中有时会出现一些暂时用不到但又必须保留的变量,GCC等编译器会对此发出警告,使用-Wunused可以关闭这些警告消息,不过这也有可能导致潜在的隐患。古老的办法是使用(void)var的形式来“使用”一下变量&#xff0c…...

【Mybatis】XML映射文件

目录 11.3XML映射文件 1.select 2.insert、update、delete 3.Sql 4.parameters(参数) 5.resultMap 6.resultMap 使用示例 (1)在先前创建的数据库stu中创建表student 2,并插入若干条数据,代码如下: (2)创建工程mybatis_ResultMap_demo。 (…...

11.2【MyBatis】主配置文件

目录 11.2【MyBatis】主配置文件 1.properties(属性) 2.settings(设置) 3.typeAliases(别名) 4.typeHandlers类型处理器 5.objectFactory 对象工厂 6.plugins(插件) 7.environments (配置环境) 8.mappers (映射器) 11.2【MyBatis】主配置文件 MyBatis的 …...

AI Agent开发实战系列 - LangGraph(8): 构建基于状态路由的动态决策图

1. 动态决策图的核心价值 想象一下你正在设计一个智能客服系统。当用户输入"我的订单怎么还没到?"时,系统需要自动识别这是物流查询问题,然后路由到物流处理模块;而当用户说"我要投诉产品质量"时,…...

FastAPI-React性能优化:Celery异步任务与Redis消息队列

FastAPI-React性能优化:Celery异步任务与Redis消息队列 【免费下载链接】fastapi-react 🚀 Cookiecutter Template for FastAPI React Projects. Using PostgreSQL, SQLAlchemy, and Docker 项目地址: https://gitcode.com/gh_mirrors/fa/fastapi-rea…...

SEGGER Embedded Studio高效开发GD32的5个隐藏技巧(含UTF-8乱码解决方案)

SEGGER Embedded Studio高效开发GD32的5个隐藏技巧(含UTF-8乱码解决方案) 在嵌入式开发领域,GD32系列MCU凭借其出色的性价比和丰富的资源赢得了众多开发者的青睐。而SEGGER Embedded Studio(简称SES)作为一款专业的集成…...

终极动态壁纸指南:让Linux桌面随时辰自动变换的完整教程

终极动态壁纸指南:让Linux桌面随时辰自动变换的完整教程 【免费下载链接】dynamic-wallpaper A simple bash script to set wallpapers according to current time, using cron job scheduler. 项目地址: https://gitcode.com/gh_mirrors/dy/dynamic-wallpaper …...

从SI仿真到示波器实测:一份给硬件工程师的有源晶振匹配电阻完整验证指南

从仿真到实测:有源晶振阻抗匹配的全流程实战解析 在高速数字电路设计中,有源晶振作为系统时钟的心脏,其输出信号的完整性直接影响整个系统的稳定性。我曾在一个千兆以太网项目中,因为忽视了晶振匹配电阻的优化,导致系统…...

如何在ComfyUI中实现专业级AI动作迁移:从零开始的完整指南

如何在ComfyUI中实现专业级AI动作迁移:从零开始的完整指南 【免费下载链接】ComfyUI-MimicMotionWrapper 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-MimicMotionWrapper 想要让静态图片中的人物"动起来"吗?想为你的虚拟角…...

有限差分法在不可压NS方程求解中的实践与优化

1. 有限差分法解NS方程的核心思路 我第一次用有限差分法解不可压NS方程时,整个人都是懵的。教科书上那些偏微分方程符号看得头大,直到把方程拆解成具体代码才恍然大悟。其实核心思路很简单:用离散的网格点代替连续空间,把微分方程…...

用STM32F407的FSMC总线给FPGA当外挂RAM?一个实战项目带你打通软硬件

STM32与FPGA的FSMC总线实战:打造高性能异构内存扩展方案 在嵌入式系统开发中,内存资源常常成为性能瓶颈。当STM32需要处理大规模数据时,内部SRAM可能捉襟见肘。本文将展示如何利用STM32F407的FSMC总线,将FPGA内部RAM无缝扩展为MCU…...

PyInstaller打包YOLO目标检测exe,文件体积太大?试试这几个优化技巧

PyInstaller打包YOLO目标检测exe的7个极致瘦身方案 当你兴奋地用PyInstaller打包完YOLO目标检测项目,却发现生成的.exe文件像个臃肿的巨人——动辄500MB起步,甚至轻松突破1GB。这种"肥胖症"不仅让程序启动缓慢,更让分发变得困难。本…...

文脉定序实战教程:如何将BGE-Reranker-v2-m3集成进现有ES/Meilisearch检索链

文脉定序实战教程:如何将BGE-Reranker-v2-m3集成进现有ES/Meilisearch检索链 你是不是也遇到过这样的问题?用Elasticsearch或者Meilisearch搭建的智能搜索系统,明明能搜到一大堆结果,但排在最前面的往往不是最相关的那个。用户输…...