CPU體系(2):ARM Store Buffer

来源:https://www.cnblogs.com/vaughnhuang/archive/2022/11/22/16915470.html
-Advertisement-
Play Games

本文主要翻譯自 Arm Cortex-M7 Processor Technical Reference Manual r1p2 其中章節 Memory System / L1 caches / Store Buffer 。 Store Buffer Cache中的數據,在寫入memory或 AXIM ...


本文主要翻譯自 Arm Cortex-M7 Processor Technical Reference Manual r1p2 其中章節 Memory System / L1 caches / Store Buffer 。

Store Buffer

Cache中的數據,在寫入memory或 AXIM 匯流排之前,先存放在store buffer中。store buffer有四個存儲單元,每個存儲單元由一個64bit數據存儲及一個32bit地址存儲組成。來自data-side的寫請求都會存放在store buffer中,但有兩個例外:寫往TCM 或 AHBP介面的數據。

註:名詞解釋 淺談嵌入式MCU CPU內核之ARM Cortex-M7內核高性能(Dual Issue ISA--雙髮指令)實現要點解析

  • AXIM :高性能內部匯流排互聯矩陣。ARM Cortex-M7內核配備了ARM第4代的AMBA匯流排矩陣--AXIM,給MCU/SOC提供64-bit的存儲器和外設匯流排互聯能力,通過AXIM訪問存儲器(SRAM和Flash)和外設時可以配置內核的MPU使能I-Cache和D-Cache,從而加速訪問,進一步提高系統效率。
  • AHBP :高性能外設介面。ARM Cortex-M7內核還為高性能低延遲的外設連接預留了一個32-bit的AHBP介面:通過該介面擴展的外設,讀寫訪問時無需經過系統匯流排互聯矩陣,從而保證了高性和低延遲。

Store buffer merging

  1. 來自同一個cache line的寫請求,被合併到同一個store buffer單元。store buffer寫請求合併只適合於帶有普通memory屬性的寫請求。
  2. 如果是強記憶體序(怎麼知道是強記憶體序??),或者是device memory屬性的記憶體頁,則不會發生store buffer寫請求合併。
  3. 遇到強記憶體序寫或者device memory屬性記憶體,會首先將store buffer中的數據全部寫回,即清空了store buffer中的數據。

Store buffer 寫請求轉發

在指定條件下,store buffer會將寫請求轉給 Cache控制器,AXIM匯流排等(即跳過store buffer,交由cache控制器,AXIM匯流排)。

  1. 比如針對 Non-Cacheable標記的數據,write-through 類型的cache,等操作,交由AXIM匯流排。
    比較難理解,不翻譯

Store buffer draining

有些情況下,需要先等store buffer中的數據全部寫回。有些情況下,需要等該單元的數據寫回。
需要等全部的情形:

  1. cache維護操作;
  2. 共用記憶體(Shared Memory)的獨占操作;
  3. DMB, DSB指令;
  4. 上面提到的強記憶體序地址,或device memory標記的數據。

定義memory maps的屬性許可權等

#define ioremap(addr, size)     __ioremap((addr), (size), __pgprot(PROT_DEVICE_nGnRE))
#define ioremap_nocache(addr, size) __ioremap((addr), (size), __pgprot(PROT_DEVICE_nGnRE))
#define ioremap_wc(addr, size)      __ioremap((addr), (size), __pgprot(PROT_NORMAL_NC))
#define ioremap_wt(addr, size)      __ioremap((addr), (size), __pgprot(PROT_DEVICE_nGnRE))

ARM memory models

  1. 介紹了 devices memory等等。Armv8-A memory model cnblog附件
  2. [譯]硬體記憶體模型
  3. 一步一圖帶你深入理解 Linux 物理記憶體管理

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、流式查詢 1、實體類 package com.wanqi.pojo; import java.util.Date; /** * @Description TODO * @Version 1.0.0 * @Date 2022/9/12 * @Author wandaren */ public cl ...
  • 最近在學習fastdfs時遇到了一個困擾我數小時的問題,結果很感人,特在此記錄下來,也是為了讓其他小伙伴們避坑 (這裡我的fastdfs運行環境是在docker中) 事情是這樣的,用APIfox測試fastdfs文件上傳的時候發現明明返回的成功的結果但是在瀏覽器中使用路徑卻訪問不到伺服器上的圖片,瀏 ...
  • NET 6 環境開發 實現 線程數量,任務隊列,非核心線程,及核心線程活躍時間的管理。 namespace CustomThreadPool; /// <summary> /// 線程池類 /// </summary> public class ThreadPoolExecutor { /// <s ...
  • 一:背景 1.講故事 前段時間有位朋友找到我,說他的程式在客戶的機器上跑著跑著會出現偶發卡死,然後就崩掉了,但在本地怎麼也沒復現,dump也抓到了,讓我幫忙看下到底怎麼回事,其實崩潰類的dump也有簡單的,也有非常複雜的,因為大多情況下都是非托管層面出現的各種故障,非常考驗對 C, C++, Win ...
  • 一 選擇排序 選擇排序的時間複雜度O(n2),額外空間複雜度O(1) public static void SelectionSort(int[] arr) { if (arr == null || arr.Length < 2) { return; } for (int i = 0; i < ar ...
  • apt-mirror 製作麒麟桌面版內網源 一、修改apt軟體安裝源 1、修改source.list安裝源 vi /etc/apt/sources.list 添加: deb http://archive.kylinos.cn/kylin/KYLIN-ALL 10.1 main universe mu ...
  • 3.1命令的基本格式 3.1.1 命令提示符 [root@localhost ~]# 這就是Linux系統的命令提示符。各部分含義如下: ●[]:這是提示符的分隔符號,沒有特殊含義。 ●root:顯示的是當前的登錄用戶,這裡使用的是root用戶登錄。 ●@:分隔符號,沒有特殊含義。 ●localho ...
  • 需要將系統語言切換為英文,即可完成註冊,後面使用可以用中文 註冊碼: 4C21U-2KK9Q-M8130-4V2QH-CF810 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...