<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

鴻蒙輕內核源碼分析:MMU 協處理器

王程 ? 來源:jf_75796907 ? 作者:jf_75796907 ? 2024-02-20 14:28 ? 次閱讀

1、 ARM C15 協處理器

在 ARM 嵌入式應用系統中, 很多系統控制由 ARM CP15 協處理器來完成的。CP15 協處理器包含編號 0-15 的 16 個 32 位的寄存器。例如,ARM 處理器使用 C15 協處理器的寄存器來控制 cache、TCM(Tightly-Coupled Memory)和存儲器管理。CP15 的各個寄存器的概要信息如下圖,圖片來自官方資料《ARM? Cortex?-A Series Version: 4.0 Programmer’s Guide》。

wKgZomXURhaAGcYoAAMU1aaKtPg526.png

wKgaomXURh-AUmc6AAF_vM3IDzA715.png

wKgaomXURjKAZrqSAAHXMTBCZzI662.png


在這些 C15 寄存器中和 MMU 關系較大的有 C2、C7、C17 寄存器,這些寄存器的作用,從上圖可以看出,分別是:

CP15 C2 寄存器

Memory protection and control registers,內存保護和控制寄存器,包含 Translation Table Base Register 0 (TTBR0)、Translation Table Base Register 1 (TTBR1) 和 Translation Table Base Control Register (TTBCR)。TTBR0、TTBR1 是 L1 轉換頁表的基地址,TTCR 控制 TTBR0 和 TTBR1 的使用。

CP15 C7 寄存器

Cache and branch predictor maintenance functions、Data and instruction barrier operations 用于高速緩存和寫緩存控制。

CP15 C13 寄存器

Context ID Register (CONTEXTIDR)、Software thread ID registers 用于保存進程標識符(asid 地址空間編號)。

2、ARM C15 協處理器匯編指令

訪問 CP15 寄存器的指令主要是 MCR 和 MRC 這兩個指令。本小節詳細介紹下這 2 個匯編指令。先看下指令的含義,MCR 是 ARM 處理器寄存器到協處理器寄存器的數據傳送指令,英文為 Move CPU register to coprocessor register,MRC 是協處理器寄存器到 ARM 處理器寄存器的數據傳送指令,英文為 Move from coprocessor register to CPU register。這 2 個指令的語義格式如下,可以看出語義格式是一樣的,但是讀取寫入含義會有差異。MCR 是讀取 Rt 寄存器寫入協處理器寄存器 CRn、CRm,而 MRC 是讀取協處理器寄存器 CRn、CRm 寫入 Rt 寄存器。

MCR{cond} coproc, #opcode1, Rt, CRn, CRm{, #opcode2} MRC{cond} coproc, #opcode1, Rt, CRn, CRm{, #opcode2}

MCR 詳細的語義介紹如下:

Syntax MCR{cond} coproc, #opcode1, Rt, CRn, CRm{, #opcode2} where: cond is an optional condition code. 可選的條件碼。 coproc is the name of the coprocessor the instruction is for. The standard name is pn, where n is an integer in the range 0 to 15.協處理器的名稱,標準名稱為pn,其中n為0-15,例如p14、p15。 opcode1 is a 3-bit coprocessor-specific opcode. 3位的操作碼。 opcode2 is an optional 3-bit coprocessor-specific opcode.可選的3位操作碼。 Rt is an ARM source register. Rt must not be PC. 要讀取的ARM寄存器,不能為PC寄存器。 CRn, CRm are coprocessor registers.要寫入的協處理器寄存器。

MRC 詳細的語義介紹如下:

Syntax MRC{cond} coproc, #opcode1, Rt, CRn, CRm{, #opcode2} where: cond is an optional condition code. 可選的條件碼。 coproc is the name of the coprocessor the instruction is for. The standard name is pn, where n is an integer in the range 0 to 15.協處理器的名稱,標準名稱為pn,其中n為0-15,例如p14、p15。 opcode1 is a 3-bit coprocessor-specific opcode.3位的操作碼。 opcode2 is an optional 3-bit coprocessor-specific opcode.可選的3位操作碼 Rt is the ARM destination register. Rt must not be PC.要寫入的ARM寄存器,不能為PC寄存器。 Rt can be APSR_nzcv. This means that the coprocessor executes an instruction that changes the value of the condition flags in the APSR. Rt也可以為APSR_nzcv。 CRn, CRm are coprocessor registers.要讀取的協處理器寄存器。

3、MMU 匯編代碼

在 archarmarmincludearm.h 文件中,封裝了 CP15 協處理器相關的寄存器操作匯編函數。我們主要看下 MMU 相關的部分。

3.1 CP15 C2 TTBR 轉換表基地址寄存器

代碼比較簡單,結合下圖,自行查看即可。該圖來自《ARM Cortex-A9 Technical Reference Manual r4p1》CP15 system control registers grouped by CRn order 部分。

wKgZomXURkuAVcDTAAC0gU-1zPI091.png

STATIC INLINE UINT32 OsArmReadTtbr(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c2,c0,0" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteTtbr(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c2,c0,0" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); } STATIC INLINE UINT32 OsArmReadTtbr0(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c2,c0,0" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteTtbr0(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c2,c0,0" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); } STATIC INLINE UINT32 OsArmReadTtbr1(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c2,c0,1" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteTtbr1(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c2,c0,1" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); } STATIC INLINE UINT32 OsArmReadTtbcr(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c2,c0,2" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteTtbcr(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c2,c0,2" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); }

3.2 CP15 C7 高速緩存寄存器

代碼比較簡單,結合下圖,自行查看即可。該圖是 C7 寄存器的部分截圖。

wKgZomXURlWASRI-AAD0Y7kcroU999.png

STATIC INLINE UINT32 OsArmReadBpiall(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c7,c5,6" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteBpiall(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c7,c5,6" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); } STATIC INLINE UINT32 OsArmReadBpiallis(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c7,c1,6" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteBpiallis(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c7,c1,6" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); }

3.3 CP15 C13 進程標識符寄存器

代碼比較簡單,結合下圖,自行查看即可。

wKgZomXURl6AMvzCAACc0RjQUio347.png

STATIC INLINE UINT32 OsArmReadContextidr(VOID) { UINT32 val; __asm__ volatile("mrc p15, 0, %0, c13,c0,1" : "=r"(val)); return val; } STATIC INLINE VOID OsArmWriteContextidr(UINT32 val) { __asm__ volatile("mcr p15, 0, %0, c13,c0,1" ::"r"(val)); __asm__ volatile("isb" ::: "memory"); }

4 MMU 上下文切換

在之前的系列,我們了解到每個用戶進程都有獨立的進程空間。在進程切換時,MMU 上下文也會切換,相應的函數為 LOS_ArchMmuContextSwitch ()??焖俜治鱿略摵瘮档拇a。

⑴處讀取 TTBCR 寄存器的狀態值,如果傳入參數 archMmu 不為空,執行⑵使能 TTBR0,否則執行⑶使其失能 TTBR0。⑷處把內核地址空間的進程空間標識符 asid 寫入 C13 寄存器。⑸處更新 TTB 頁表基地址和 TTB 狀態信息到相應寄存器。⑹處把進程空間的進程標識符寫入 C13 寄存器。

VOID LOS_ArchMmuContextSwitch(LosArchMmu *archMmu) { UINT32 ttbr; ⑴ UINT32 ttbcr = OsArmReadTtbcr(); if (archMmu) { ⑵ ttbr = MMU_TTBRx_FLAGS | (archMmu->physTtb); /* enable TTBR0 */ ttbcr &= ~MMU_DESCRIPTOR_TTBCR_PD0; } else { ⑶ ttbr = 0; /* disable TTBR0 */ ttbcr |= MMU_DESCRIPTOR_TTBCR_PD0; } #ifdef LOSCFG_KERNEL_VM /* from armv7a arm B3.10.4, we should do synchronization changes of ASID and TTBR. */ ⑷ OsArmWriteContextidr(LOS_GetKVmSpace()->archMmu.asid); ISB; #endif ⑸ OsArmWriteTtbr0(ttbr); ISB; OsArmWriteTtbcr(ttbcr); ISB; #ifdef LOSCFG_KERNEL_VM if (archMmu) { ⑹ OsArmWriteContextidr(archMmu->asid); ISB; } #endif }



審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    18512

    瀏覽量

    223336
  • ARM
    ARM
    +關注

    關注

    134

    文章

    8708

    瀏覽量

    362609
  • 源碼
    +關注

    關注

    8

    文章

    582

    瀏覽量

    28663
  • MMU
    MMU
    +關注

    關注

    0

    文章

    91

    瀏覽量

    17995
  • 鴻蒙
    +關注

    關注

    55

    文章

    1866

    瀏覽量

    42180
收藏 人收藏

    評論

    相關推薦

    AOSP源碼定制-內核驅動編寫

    有時候為了分析一些殼的檢測,需要在內核層面對讀寫相關的操作進行監控,每次去修改對應的內核源碼編譯重刷過于耗時耗力,這里就來嘗試編寫一個內核
    的頭像 發表于 04-23 11:15 ?211次閱讀
    AOSP<b class='flag-5'>源碼</b>定制-<b class='flag-5'>內核</b>驅動編寫

    鴻蒙內核源碼分析:Newlib C

    使用 Musl C 庫的時候,內核提供了基于 LOS_XXX 適配實現 pthread、mqeue、fs、semaphore、time 等模塊的 posix 接口(//kernel/liteos_m
    的頭像 發表于 02-18 15:41 ?302次閱讀
    <b class='flag-5'>鴻蒙</b>輕<b class='flag-5'>內核</b><b class='flag-5'>源碼</b><b class='flag-5'>分析</b>:Newlib C

    獲取Linux內核源碼的方法

    (ELF1/ELF1S開發板及顯示屏)Linux內核是操作系統中最核心的部分,它負責管理計算機硬件資源,并提供對應用程序和其他系統組件的訪問接口,控制著計算機的內存、處理器、設備驅動程序和文
    的頭像 發表于 12-13 09:49 ?336次閱讀
    獲取Linux<b class='flag-5'>內核</b><b class='flag-5'>源碼</b>的方法

    MMU中的頁命中、缺頁介紹

    頁命中、缺頁 (1)頁命中 ? a) 處理器要對虛擬地址VA進行訪問。 ? b) MMU的TLB沒有命中,通過TWU遍歷主存頁表中的PTEA(PTE地址)。 ? c) 主存向MMU返回PTE
    的頭像 發表于 11-26 16:19 ?513次閱讀
    <b class='flag-5'>MMU</b>中的頁命中、缺頁介紹

    ARM處理器中控制MMU功能的過程

    MMU是Memory Manage Unit的縮寫,即存儲管理單元的意思。
    發表于 09-11 17:51 ?601次閱讀
    ARM<b class='flag-5'>處理器</b>中控制<b class='flag-5'>MMU</b>功能的過程

    ARM核心類型和修訂標識的應用說明

    ARM核心通過兩種機制進行識別。 第一種是通過系統控制處理器的寄存0,也稱為處理器15或CP15。 CP15僅在包含
    發表于 08-23 06:55

    關于串口組以及處理器如何加載的問題

    ,所屬USB始終被劃入dialout組,進而造成在make upload 時無法找到相應設備。 如何解決? 2。關于處理器nice接口,現在已經有了一個硬件功能模塊,但是不知道如何通過nice接口進行
    發表于 08-16 08:05

    請問nice處理器可以處理矩陣的乘法嗎?

    ; :\"=r\"(zero) :\"r\"(addr));} 這里把addr賦給x0,但是x0作為零寄存不會保存任何信息? 然后func3和func7定義為2,2的含義是? .insn是否為實現訪問處理器的意思?
    發表于 08-16 08:00

    NICE處理器最多可以處理多少個周期再抬高nice_rsp_valid???

    NICE處理器最多可以處理多少個周期再抬高nice_rsp_valid???
    發表于 08-16 07:56

    如何用處理器拓展指令實現更高級運算呢?

    按照這句話的意思,處理器拓展指令只能實現讀寫操作嗎,官方的案例貌似也只是讀寫指令。那如何用處理器拓展指令實現更高級運算呢,用內聯匯編嗎
    發表于 08-16 07:41

    關于蜂鳥E203處理器參考示例的問題

    問題一:在vivado中編寫約束文件時,由于nice接口的指令是由CPU、處理器和內存互相發送的,因此是否只需要約束clk和復位信號即可? 問題二:從軟件示例程序中可知,數據是由軟件輸入的,那
    發表于 08-16 07:24

    請問E203 Core和NICE處理器的主頻各是多少?

    請問E203 Core和 NICE處理器的主頻各是多少?
    發表于 08-12 08:06

    ARM922T處理器技術參考手冊

    ARM922T處理器是通用ARM9TDMI系列的一員微處理器,包括:?ARM9TDMI(核心)?ARM940T(核心加4K和4K緩存和保護單元)?ARM920T(核心加16K和16K緩存以及MMU
    發表于 08-02 15:44

    ARM920T處理器技術參考手冊

    ARM920T處理器是通用微處理器ARM9TDMI系列的成員,包括: ?ARM9TDMI(核心)?ARM940T(核心加緩存和保護單元)?ARM920T(核心+緩存和MMU)。 ARM9TDMI
    發表于 08-02 13:05

    ARM7TDMI (Rev 3)核心處理器產品概述

    ARM7系列包括ARM7TDMI、ARM7TDMI-S、ARM720T和ARM7EJ-S處理器。ARM7TDMI內核是業界應用最廣泛的32位嵌入式risc微處理器解決方案。ARM7TDMI解決方案
    發表于 08-02 10:25
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>