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

ARM 常见汇编指令学习 9 - 缓存管理指令 DC 与 IC

文章目录

    • ARM64 DC 与 IC 指令

上篇文章:ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍

ARM64 DC 与 IC 指令

AArch64指令集中有两条关于缓存维护(cache maintenance)的指令,分别是IC和DC。

  • IC 是用于指令缓存操作;
  • DC 是用于数据缓存操作。

IC 和DC指令都属于系统指令(system instruction),系统指令还包括 AT,BRB,CFP,CPP,DVP和TLBI。

IC指令的语法格式如下

IC <ic_op>, {<Xt>}

其中,是可选的 64-bit 通用源寄存器。

  • IC IALLU: 表示 Invalidate all to PoU,无效化所有到PoU(Point of Unification,统一点)的指令缓存行。
  • IC IALLUIS: 表示 Invalidate all to PoU, Inner Shareable,无效化所有到PoU的,内部可共享(Inner Shareable)的指令缓存行。
  • IC IVAU: 表示 Invalidate Virtual Address to PoU,无效化虚拟地址到PoU的指令缓存行。

关于 shareable 及 POC, POC 见以前文章:
ARM Cache 系列文章 3 – Cache 与 MPU关系学习
ARM Cache 系列文章 2 – Cache Coherence及内存顺序模学习

在这里插入图片描述

DC指令的语法格式如下

DC <dc_op>, <Xt>

其中,是可选的64-bit通用源寄存器

DC 指令后操作选项 <dc_op> 用于指定具体的操作类型,比如:

  • DC IVAC:表示Invalidate Virtual Address to PoC,无效化虚拟地址到 PoC 的缓存行。

  • DC ISW: 表示Invalidate Set/Way,无效化缓存组/路。缓存维护操作可以通过缓存组(set),路(way)或虚拟地址(VA)执行。在做高速缓存维护操作前,需要知道高速缓存的一些信息,比如系统中有多少级高速缓存,缓存行的大小,每一级缓存的组织结构等等。这些基本信息保存在系统寄存器中,在系统上电过程中,操作系统访问这些寄存器来获得缓存的信息。这些寄存器有 CLIDR_EL1CSSELR_EL1CCSIDR_EL1CTR_EL1等。

  • DC CIVAC:这个指令的含义是:C–Clean, I–Invalidate,

    • Clean:将缓存中的数据写回到主存中,以确保主存中的数据是最新的。
    • Invalidate:使缓存中的指定数据无效,这样在下次访问该数据时,处理器会从主存中重新加载数据,而不是使用缓存中的旧数据。
    • Architectural Event Broadcast通道:这是一个硬件机制,用于在多核处理器中同步不同核之间的缓存操作。
  • 举例来说,如果你执行了 “DC CIVAC, X0” 这条指令,那么处理器会清除并无效化寄存器X0中指定的地址对应的缓存行。

adr x0, data_pool1
adr x1, data_pool2
adr x2, data_pool3/* clean adn invalidate */
dsb sy
dc CIVAC,x0
dc CIVAC,x1
dc CIVAC,x2
dsb sydata_pool1:...
data_pool2:...
data_pool3:...

上篇文章:ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍

相关文章:

ARM 常见汇编指令学习 9 - 缓存管理指令 DC 与 IC

文章目录 ARM64 DC 与 IC 指令 上篇文章&#xff1a;ARM 常见汇编指令学习 8 - dsb sy 指令及 dsb 参数介绍 ARM64 DC 与 IC 指令 AArch64指令集中有两条关于缓存维护&#xff08;cache maintenance&#xff09;的指令&#xff0c;分别是IC和DC。 IC 是用于指令缓存操作&…...

落地数字化管理,提升企业市场竞争力

数字化企业管理方案是一种利用数字技术和信息系统来提升企业管理效率和运营效果的策略。 潜在的数字化企业管理方案 1、企业资源规划&#xff08;ERP&#xff09;系统&#xff1a;建立一个集成的ERP系统来统一管理企业的各项业务流程&#xff0c;包括采购、销售、库存管理、财…...

2023华数杯数学建模竞赛C题思路解析

如下为&#xff1a;2023华数杯数学建模竞赛C题 母亲身心健康对婴儿成长的影响 的思路解析 C题 母亲身心健康对婴儿成长的影响 母亲是婴儿生命中最重要的人之一&#xff0c;她不仅为婴儿提供营养物质和身体保护&#xff0c;还为婴儿提供情感支持和安全感。母亲心理健康状态的不…...

Photon之如何解决Photon Server无法在局域网使用的bug

前言 先介绍一下Photon的两个服务器服务: Photon Cloud 是一个完全托管的软件即服务 (SaaS) 解决方案。我们可以完全专注于应用程序客户端,而托管、服务器操作和扩展均由光子官方负责。 Photon Server 是一个本地服务器应用程序,我们可以在本地或指定的计算机上运行和托管。…...

Redis两种持久化方案RDB持久化和AOF持久化

Redis持久化 Redis有两种持久化方案&#xff1a; RDB持久化AOF持久化 1.1.RDB持久化 RDB全称Redis Database Backup file&#xff08;Redis数据备份文件&#xff09;&#xff0c;也被叫做Redis数据快照。简单来说就是把内存中的所有数据都记录到磁盘中。当Redis实例故障重启…...

银河麒麟v10 vnc环境配置

方法一、启用自带远程桌面 银河麒麟默认已经自带远程桌面&#xff0c;如下图。此时即可用Realvnc Viewer访问该终端&#xff0c;仔细查看后自带的远程桌面是开源组件gnome-remote-desktopGNOME / gnome-remote-desktop GitLabhttps://gitlab.gnome.org/GNOME/gnome-remote-de…...

【动态内存管理助力程序优化与性能飞升】

本章重点 为什么存在动态内存分配 动态内存函数的介绍 malloc free calloc realloc 常见的动态内存错误 几个经典的笔试题 柔性数组 1. 为什么存在动态内存分配 我们已经掌握的内存开辟方式有&#xff1a; int val 20;//在栈空间上开辟四个字节 char arr[10] {0};//在栈…...

电动汽车设计、制造、研发的学科、技术和前沿科技综述

引言&#xff1a;电动汽车作为替代传统燃油汽车的一种先进交通工具&#xff0c;不仅具有环保、低噪音等优势&#xff0c;而且对于能源消耗和气候变化等全球性问题也具有重要意义。本文将综述与电动汽车设计、制造、研发相关的学科、技术和前沿科技&#xff0c;以期对电动汽车领…...

NsPack3.x脱壳手记

发现是NsPack3.x的壳 使用ESP守恒快速脱壳 F9遇到popfd后下面的jmp就是通往OEP了 打开LordPE准备转储映像, 首先调整下ImageSize, 接着dump full 接着不要退出目前的调试, 打开Scylla修复IAT, 把OEP的VA地址输入到OEP处, 接着按照如下图所示步骤 完成后如下, 但NsPack3.x…...

在.net 6.0中 调用远程服务器web服务,Webservices(xxx.asmx) ,RESTful 风格,2种解决方案。

1.使用 Connected Services&#xff1a; 右键单击您的项目&#xff0c;选择 "Add"&#xff08;添加&#xff09;-> "Connected Services"&#xff08;已连接的服务&#xff09;。 在 "Connected Services" 对话框中&#xff0c;选择 "W…...

深度学习基础01-深度学习简介

什么是深度学习&#xff1f; 深度学习是机器学习的一个分支&#xff0c;是一种基于人工神经网络的学习方法。它是一种模仿人脑神经元之间信息传递和学习的过程的机器学习算法。深度学习的核心思想是通过构建多层神经网络来学习从输入到输出的复杂映射关系&#xff0c;从而实现各…...

Flink DataStream API详解

DataStream API 参考&#xff1a;https://ci.apache.org/projects/flink/flink-docs-release-1.9/dev/datastream_api.html Data Sources Source是程序读取其输入的位置&#xff0c;您可以使用env.addSource&#xff08;sourceFunction&#xff09;将Source附加到程序中。Fl…...

【如何使用cv::erode()函数对图像进行腐蚀操作】

文章目录 `cv::erode()`函数主要用途`cv::erode()`函数的参数卷积核cv::erode()函数主要用途 cv::erode()函数主要用于进行图像的腐蚀操作。这是一种图像处理技术,通常用于消除图像中的噪声、分离两个连接在一起的物体、或者使物体的边界变得更加明显。 腐蚀操作的基本思想是…...

C++数据结构之BST(二叉搜索树)的实现

目录 BST 的方法摘要查找节点四个引用&#xff0c;都有妙用递归版非递归版 插入节点利用search的返回值更新高度的注意事项插入算法的完整代码 删除节点框架单分支&#xff0c;直接替代双分支&#xff0c;化繁为简代码 code BST 预告&#xff1a;本文是后续实现各种各样平衡二叉…...

QT以管理员身份运行

以下配置后&#xff0c;QT在QT Creator调试时&#xff0c;或者生成的.exe程序&#xff0c;都将会默认以管理员身份运行。 一、MSVC编译器 1、在Pro文件中添加以下代码&#xff1a; QMAKE_LFLAGS /MANIFESTUAC:\"level\requireAdministrator\ uiAccess\false\\" …...

java中的缓冲流

Java.io.BufferedOutputStream 字节缓冲输出流&#xff0c;继承自OutputStream 构造方法&#xff1a; BufferedOutputStream (OutputStream out) 创建一个新的缓冲输出流&#xff0c;将数据写入指定的底层输出流BufferedOutputStream (OutputStream out, int size) 创建一个新…...

【小吉带你学Git】idea操作(1)_配置环境并进行基本操作

&#x1f38a;专栏【Git】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【Counting Stars 】 欢迎并且感谢大家指出小吉的问题&#x1f970; 文章目录 &#x1f354;环境准备⭐配置Git忽略文件&#x1f384;方法&#x1f33a;创…...

DP-GAN-生成器代码

首先看一下数据生成&#xff1a; 在预处理阶段会将label经过ont-hot编码转换为35个通道&#xff0c;即每个通道都是由&#xff08;0,1&#xff09;组成。 在train文件中&#xff0c;对生成器和判别器分别进行更新&#xff0c;根据loss的不同&#xff0c;分别计算对于的损失&a…...

2020-2023中国高等级自动驾驶产业发展趋势研究

1.1 概念界定 2020-2023中国高等级自动驾驶产业发展趋势研究Trends in China High-level Autonomous Driving from 2020 to 2023自动驾驶发展过程中&#xff0c;中国出现了诸多专注于研发L3级以上自动驾驶的公司&#xff0c;其在业界地位也越来越重要。本报告围绕“高等级自动…...

JDK19 - synchronized关键字导致的虚拟线程PINNED

JDK19 - synchronized关键字导致的虚拟线程PINNED 前言一. PINNED是什么意思1.1 synchronized 绑定测试1.2 synchronized 关键字的替代 二. -Djdk.tracePinnedThreads的作用和坑2.1 死锁案例测试2.2 发生原因的推测2.3 总结 前言 在 虚拟线程详解 这篇文章里面&#xff0c;我们…...

Akafugu TWILiquidCrystal:I²C LCD驱动库详解与工程实践

1. Akafugu TWILiquidCrystal 库概述Akafugu TWILiquidCrystal 是一套专为 Akafugu 公司设计的 TWI/IC 接口 LCD 控制器开发的固件与 Arduino 软件库组合方案。该方案的核心目标是以极简硬件连接&#xff08;仅需 4 根线&#xff09;和低资源开销&#xff0c;实现对标准 HD4478…...

Yosys内部数据结构与优化流程深度解析

1. Yosys工具与RTLIL数据结构概述 Yosys作为开源硬件综合工具链的核心组件&#xff0c;其内部实现了一套名为RTLIL&#xff08;Register Transfer Level Intermediate Language&#xff09;的中间表示语言。这套数据结构的设计直接决定了工具的性能上限和优化潜力。我第一次接触…...

现在不学AI原生区块链,2026Q3将错过最后窗口期:奇点大会认证工程师培养体系首度开放,仅剩217个内测席位

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AI原生区块链应用 2026奇点智能技术大会(https://ml-summit.org) 本届大会首次设立“AI原生区块链”主题轨道&#xff0c;聚焦大模型与去中心化基础设施的深度融合。不同于传统AI服务上链或简单Token化&#xff0c;AI原生…...

Qwen3-0.6B-FP8低资源运行效果:在消费级GPU上的性能实测

Qwen3-0.6B-FP8低资源运行效果&#xff1a;在消费级GPU上的性能实测 最近在折腾本地部署大模型的朋友&#xff0c;可能都有过这样的体验&#xff1a;看着那些动辄几十亿、上百亿参数的“巨无霸”模型&#xff0c;再看看自己手头的显卡&#xff0c;只能默默叹气。显存不够、速度…...

5分钟掌握QQ空间历史记录备份神器:GetQzonehistory完全指南

5分钟掌握QQ空间历史记录备份神器&#xff1a;GetQzonehistory完全指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾担心QQ空间中的青春记忆会随着时间流逝而消失&#xff1…...

闲鱼自动回复软件工具闪电鱼助手如何下载?

做闲鱼的人都知道&#xff0c;真正消耗精力的&#xff0c;往往不是上架商品&#xff0c;而是每天重复不断的咨询、议价、催发货和售后回复。这款软件支持在win系统上可以直接使用的软件工具&#xff0c;针对的是闲鱼卖家的“自动客服自动交付”效率工具。 闪电鱼软件 地址&…...

Razer-macos核心组件深度剖析:设备管理器与动画系统

Razer-macos核心组件深度剖析&#xff1a;设备管理器与动画系统 【免费下载链接】razer-macos Color effects manager for Razer devices for macOS. Supports High Sierra (10.13) to Monterey (12.0). Made by the community, based on openrazer. 项目地址: https://gitco…...

Docker 容器中运行 AI CLI 工具:用户隔离与持久化卷实战指南捉

环境安装 pip install keystone-engine capstone unicorn 这3个工具用法极其简单&#xff0c;下面通过示例来演示其用法。 Keystone 示例 from keystone import * CODE b"INC ECX; ADD EDX, ECX" try:ks Ks(KS_ARCH_X86, KS_MODE_64)encoding, count ks.asm(CODE)…...

重磅来袭!JetBrains首款Rust专属IDE——RustRover,亲测真香!

前言&#xff1a; 作为一名Rust老兵&#xff0c;从VSCode 各种插件到CLion Rust插件&#xff0c;配置环境真是让人头大。直到遇到了它——JetBrains官方出品的Rust专属IDE RustRover&#xff0c;我才真正体会到什么叫“开箱即用”的爽快感&#xff01;今天就跟大家好好唠唠这…...

League-Toolkit:5分钟掌握英雄联盟最强自动化助手,告别手忙脚乱

League-Toolkit&#xff1a;5分钟掌握英雄联盟最强自动化助手&#xff0c;告别手忙脚乱 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power &#x1f680;. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 还在为…...