【ARMv8/v9 系統寄存器 5 -- ARMv8 Cache 控制寄存器 SCTRL_EL1 使用詳細介紹】

關于ARM Cache 詳細學習推薦專欄
【ARM Cache 專欄】
【ARM ACE Bus 與 Cache 專欄】


文章目錄

    • ARMv8/v9 Cache 設置寄存器
      • ARMv8 指令 Cache 使能函數
      • 測試代碼

ARMv8/v9 Cache 設置寄存器

關于寄存器SCTRL_EL1 的詳細介紹見文章:【ARMv8/v9 異常模型入門及漸進2 - 系統控制寄存器 SCTRL_ELx 介紹】,這篇文章主要是介紹如果通過控制這個寄存器來 enable cache 和 disable cache的。
在這里插入圖片描述
如上圖所示,可以通過SCTRL_E1I 域 和 C 域來打開 指令cache和數據cache。接下來以使能指令cache為例進行簡單介紹。

ARMv8 指令 Cache 使能函數

  • 打開指令 cache 匯編代碼實現如下
.set CTRL_C_BIT,      (1 << 2)
.set CTRL_SA_BIT,     (1 << 3)
.set CTRL_I_BIT,      (1 << 12)func enable_icacheEL1_OR_EL2_OR_EL3 x1 
1: mrs     x0, sctlr_el1b       4f
2: mrs     x0, sctlr_el2b       4f
3: mrs     x0, sctlr_el3
4: and     x0, x0, #~CTRL_I_BITEL1_OR_EL2_OR_EL3 x1 
1: msr     sctlr_el1, x0b       4f
2: msr     sctlr_el2, x0b       4f
3: msr     sctlr_el3, x0
4: dsb     syisbret
endfunc enable_icache
  • 關閉指令 cache 的匯編代碼實現如下
func disable_icacheEL1_OR_EL2_OR_EL3 x1 
1: mrs     x0, sctlr_el1b       4f
2: mrs     x0, sctlr_el2b       4f
3: mrs     x0, sctlr_el3
4: and     x0, x0, #~CTRL_I_BITEL1_OR_EL2_OR_EL3 x1 
1: msr     sctlr_el1, x0b       4f
2: msr     sctlr_el2, x0b       4f
3: msr     sctlr_el3, x0
4: dsb     syisbret
endfunc disable_icache

既然有了指令cache的開和關,那么我們簡單看下,關閉指令cache和打開指令cache的芯片行程差異如何:

測試代碼

void foo(void)
{for (volatile int i = 0; i < 0x10000; i++)i++;
}int icache_test(void *data)
{uint64_t start, end;enable_icache();start = syscnt();foo();end = syscnt();log_info("when icache enable, cost time: 0x%llx\n", end -start);disable_icache();start = syscnt();foo();end = syscnt();log_info("when icache disable, cost time: 0x%llx\n", end -start);return 0;
}

關于匯編宏EL1_OR_EL2_OR_EL3 的實現將文章:【ARMv8/v9 系統寄存器 6 – EL 異常等級判定寄存器 CurrentEL 使用詳細將介紹】

測試結果
在這里插入圖片描述
可以看到打開指令cache和關閉指令cache兩者是有一定時間差的,隨著測試量的加大這個時間差將會進一步加大,所以代碼中一般都會將cache打開。

關于ARM Cache 詳細學習推薦專欄
【ARM Cache 專欄】
【ARM ACE Bus 與 Cache 專欄】

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/13017.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/13017.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/13017.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

純正英語新聞 5.15

seizing territory &#xff1a;奪取領土 battlefield:戰場 shrinking&#xff1a;縮小 paramedic&#xff1a;醫護人員 mercilessly destroy&#xff1a;無情地摧殘 blown up&#xff1a;炸毀 northern outskirts :北郊 terrified&#xff1a;害怕 shelling&#xff…

西南大學計算機考研,選學碩還是專碩?西南大學計算機考研考情分析!

西南大學&#xff08;Southwest University&#xff09;是教育部直屬&#xff0c;教育部、農業農村部、重慶市共建的重點綜合大學&#xff0c;是國家首批"雙一流"建設高校&#xff0c;"211工程"和"985工程優勢學科創新平臺"建設高校。現任黨委書…

【嵌入式大賽應用賽道】機械手臂

電機 進步電機&#xff1a;它的轉動是以確定的步數進行的&#xff0c;只要計算好脈沖數量和頻率&#xff0c;就可以準確預測和控制電機的轉動角度、速度以及停止的位置 伺服電機&#xff1a;將輸入的電信號&#xff08;如電壓或電流指令&#xff09;轉換成軸上的精確旋轉運動…

大模型算法(一):從Transformer到ViT再到LLaMA

單任務/單領域模型 深度學習最早的研究集中在針對單個領域或者單個任務設計相應的模型。 對于CV計算機視覺領域&#xff0c;最常用的模型是CNN卷積模型。其中針對計算機視覺中的不同具體任務例如分類任務&#xff0c;目標檢測任務&#xff0c;圖像分割任務&#xff0c;以CNN作…

【傳知代碼】VRT: 關于視頻修復的模型(論文復現)

前言&#xff1a;隨著數字媒體技術的普及&#xff0c;制作和傳播視頻內容變得日益普遍。但是&#xff0c;視頻中由于多種因素&#xff0c;例如傳輸、存儲和錄制設備等&#xff0c;經常出現質量上的問題&#xff0c;如圖像模糊、噪聲干擾和低清晰度等。這類問題對用戶的體驗和觀…

hive動態分區

hive動態分區概念:允許插入數據到分區表時,根據插入的數據內容自動創建相應的分區 1.啟用動態分區功能 hive.exec.dynamic.partitiontrue; 2.分區字段設置 在insert語句中, 動態分區的字段必須放在select語句的末尾,hive會根據這個字段的值來創建分區目錄 示例: --創建分區表…

幾個排序器的verilog及其資源占用、延時分析

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 前言 因為課題需要&#xff0c;調研了幾個快速排序方法&#xff0c;并手寫或者改進了若干待測試對象&#xff0c;包括記分板型冒泡排序&#xff08;這個是別人的&#xff09…

樹莓派|I2C通信

什么是I2C通信 I2C&#xff08;Inter-Integrated Circuit&#xff09;是一種串行通信協議&#xff0c;用于在集成電路(IC)之間傳輸數據。它由飛利浦公司&#xff08;現在的恩智浦半導體公司&#xff09;在20世紀80年代開發&#xff0c;并且成為了廣泛應用于各種電子設備中的通…

Spring Security 6.x 系列【73】認證篇之同端互斥登錄

有道無術,術尚可求,有術無道,止于術。 本系列Spring Boot 版本 3.1.0 本系列Spring Security 版本 6.1.0 源碼地址:https://gitee.com/pearl-organization/study-spring-security-demo 文章目錄 1. 概述2. 實現方案3. 案例演示3.1 內存會話3.1.1 并發控制流程分析3.1.2 功…

【35分鐘掌握金融風控策略28】貸中模型體系策略應用

目錄 貸中模型體系策略應用 信用模型體系和模型在策略中的應用 反欺詐模型體系和模型在策略中的應用 運營模型體系和模型在策略中的應用 貸中模型體系策略應用 在貸前模型部分已經講過&#xff0c;貸前開發的很多模型是可以在貸中直接使用的。貸中與貸前的不同點在于&…

ubuntu升級python

添加Python官方PPA源 sudo add-apt-repository ppa:deadsnakes/ppa 執行會顯示各個版本ubuntu可以安裝哪些python版本 更新軟件包索引 sudo apt update 安裝需要版本Python sudo apt install python3.11 檢查Python版本: which python11 /usr/bin/python3.11 設置為系統默認Pyt…

自定義一個starter

在Spring Boot中&#xff0c;創建一個自定義starter可以簡化特定功能或組件的配置過程&#xff0c;讓其他項目能夠輕松地重用這些功能。 這里我們以自定義一個xxl-job的starter為例&#xff0c;介紹下如何簡化配置。 添加依賴 <dependencies><dependency><gro…

STK中的光照計算模型

本文簡要闡述STK中光照計算的模型。 在航天任務中&#xff0c;通常需要分析地面站、飛行器在一定時間內的光照情況&#xff0c;具體包括&#xff1a; 地面站處在光照區和陰影區的具體時間范圍&#xff1b;考慮地形遮擋后&#xff0c;地面站的光照區和陰影區的變化情況&#x…

985大學電子信息專碩,考C語言+數據結構!中央民族大學25計算機考研考情分析!

中央民族大學&#xff08;Minzu University of China&#xff09;坐落于北京市學府林立的海淀區&#xff0c;南鄰國家圖書館&#xff0c;北依中關村科技園&#xff0c;校園環境典雅&#xff0c;古樸幽美&#xff0c;人文氛圍濃郁&#xff0c;具有鮮明的民族特色。由北京市、國家…

Java byte數據類型

在Java中&#xff0c;byte是一種基本的數據類型&#xff0c;用于表示整數值。它是8位帶符號的二進制補碼&#xff0c;范圍從-128到127&#xff08;包括&#xff09;。 以下是一些關于byte數據類型的重要信息&#xff1a; 大小和范圍&#xff1a;byte數據類型占用8位&#xff0…

Oracle 日志文件頭中的SCN

日志文件頭中的SCN主要分以下3類&#xff1a; 1、FIRST_CHANGE 2、NEXT_CHANGE 3、RESETLOGS_CHANGE# FIRST_CHANGE# FIRST_CHANGE#表示該在線日志文件被重用時的SCN。可以從VKaTeX parse error: Expected EOF, got # at position 25: …RY.FIRST_CHANGE#?列查詢&#xff0c;…

Cesium學習_-著色器

著色器GLSL CesiumJS PrimitiveAPI 高級著色入門 - 從參數化幾何與 Fabric 材質到著色器 - 下篇 - 知乎 明確一個定義&#xff0c;在 Primitive API 中應用著色器&#xff0c;實際上是給 Appearance 的 vertex- ShaderSource、fragmentShaderSource 或 Material 中的 fabric.…

Java 異步編程——為什么要使用多線程,以及在什么情況下使用多線程?

前言 單線程就是一個工人在搬磚&#xff0c;多線程就是多個工人在搬磚&#xff1b;在相同數量的磚要搬的情況下&#xff0c;多個工人搬磚肯定比一個人搬的快。 那多個工人做事一定比一個工人做事快嗎&#xff1f;那不一定&#xff0c;不過大多數情況下是的。多線程只是可以同…

Java并發編程——線程安全

在Java并發編程中&#xff0c;線程安全是一個非常重要的概念。當多個線程同時訪問共享數據時&#xff0c;如果沒有采取適當的同步措施&#xff0c;就可能會導致數據不一致或其他不可預期的行為&#xff0c;這就是線程不安全的情況。 為了保證線程安全&#xff0c;Java提供了一…

Google Ads谷歌廣告賬戶被封停怎么辦?

跨境出海業務少不了需要做Google Ads推廣業務&#xff1b;其中讓投手們聞風喪膽的消息就是帳戶被暫停。當 Google 檢測到任何違反其政策且可能損害用戶在線體驗的行為時&#xff0c;就會發生這種情況。那么如何在做廣告推廣的同時&#xff0c;保證賬號不被封禁呢&#xff1f;看…