一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙輕內(nèi)核源碼分析:MMU 協(xié)處理器

王程 ? 來源:jf_75796907 ? 作者:jf_75796907 ? 2024-02-20 14:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1、 ARM C15 協(xié)處理器

在 ARM 嵌入式應(yīng)用系統(tǒng)中, 很多系統(tǒng)控制由 ARM CP15 協(xié)處理器來完成的。CP15 協(xié)處理器包含編號 0-15 的 16 個 32 位的寄存器。例如,ARM 處理器使用 C15 協(xié)處理器的寄存器來控制 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 關(guān)系較大的有 C2、C7、C17 寄存器,這些寄存器的作用,從上圖可以看出,分別是:

CP15 C2 寄存器

Memory protection and control registers,內(nèi)存保護(hù)和控制寄存器,包含 Translation Table Base Register 0 (TTBR0)、Translation Table Base Register 1 (TTBR1) 和 Translation Table Base Control Register (TTBCR)。TTBR0、TTBR1 是 L1 轉(zhuǎn)換頁表的基地址,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 用于保存進(jìn)程標(biāo)識符(asid 地址空間編號)。

2、ARM C15 協(xié)處理器匯編指令

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

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

MCR 詳細(xì)的語義介紹如下:

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.協(xié)處理器的名稱,標(biāo)準(zhǔn)名稱為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.要寫入的協(xié)處理器寄存器。

MRC 詳細(xì)的語義介紹如下:

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.協(xié)處理器的名稱,標(biāo)準(zhǔn)名稱為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.要讀取的協(xié)處理器寄存器。

3、MMU 匯編代碼

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

3.1 CP15 C2 TTBR 轉(zhuǎn)換表基地址寄存器

代碼比較簡單,結(jié)合下圖,自行查看即可。該圖來自《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 高速緩存寄存器

代碼比較簡單,結(jié)合下圖,自行查看即可。該圖是 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 進(jìn)程標(biāo)識符寄存器

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

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 上下文切換

在之前的系列,我們了解到每個用戶進(jìn)程都有獨(dú)立的進(jìn)程空間。在進(jìn)程切換時,MMU 上下文也會切換,相應(yīng)的函數(shù)為 LOS_ArchMmuContextSwitch ()??焖俜治鱿略摵瘮?shù)的代碼。

⑴處讀取 TTBCR 寄存器的狀態(tài)值,如果傳入?yún)?shù) archMmu 不為空,執(zhí)行⑵使能 TTBR0,否則執(zhí)行⑶使其失能 TTBR0。⑷處把內(nèi)核地址空間的進(jìn)程空間標(biāo)識符 asid 寫入 C13 寄存器。⑸處更新 TTB 頁表基地址和 TTB 狀態(tài)信息到相應(yīng)寄存器。⑹處把進(jìn)程空間的進(jìn)程標(biāo)識符寫入 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 }



審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19882

    瀏覽量

    234967
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    134

    文章

    9347

    瀏覽量

    377209
  • 源碼
    +關(guān)注

    關(guān)注

    8

    文章

    671

    瀏覽量

    30309
  • MMU
    MMU
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    18741
  • 鴻蒙
    +關(guān)注

    關(guān)注

    60

    文章

    2613

    瀏覽量

    44013
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    請問NICE協(xié)處理器與傳統(tǒng)ocb外設(shè)相比的優(yōu)勢有什么?

    使用擴(kuò)展指令調(diào)用NICE協(xié)處理器完成預(yù)定操作,給出的優(yōu)勢通常為代替CPU處理數(shù)據(jù),但其實(shí)使用片上總線掛一個外設(shè),然后驅(qū)動外設(shè)完成操作也可以實(shí)現(xiàn)相同的功能,所以想問一下協(xié)
    發(fā)表于 05-29 08:21

    NICE協(xié)處理器與傳統(tǒng)ocb外設(shè)相比的優(yōu)勢有什么?

    使用擴(kuò)展指令調(diào)用NICE協(xié)處理器完成預(yù)定操作,給出的優(yōu)勢通常為代替CPU處理數(shù)據(jù),但其實(shí)使用片上總線掛一個外設(shè),然后驅(qū)動外設(shè)完成操作也可以實(shí)現(xiàn)相同的功能,所以想問一下協(xié)
    發(fā)表于 05-28 08:31

    Cadence推出Tensilica NeuroEdge 130 AI協(xié)處理器

    楷登電子(美國 Cadence 公司,Nasdaq:CDNS)近日宣布推出 Cadence Tensilica NeuroEdge 130 AI 協(xié)處理器(AICP)。這是一款新型處理器,專為補(bǔ)充
    的頭像 發(fā)表于 05-17 09:38 ?677次閱讀

    DS2476 DeepCover安全協(xié)處理器技術(shù)手冊

    DS2476為安全ECDSA和HMAC SHA-256協(xié)處理器,與DS28C36配套。協(xié)處理器可計(jì)算在DS28C36執(zhí)行任何運(yùn)算所必須的HMAC或ECDSA簽名。DS2476提供一組核
    的頭像 發(fā)表于 05-14 10:51 ?263次閱讀
    DS2476 DeepCover安全<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>技術(shù)手冊

    DS2478 DeepCover汽車安全協(xié)處理器技術(shù)手冊

    DS2478是一款DS28E40或DS28C40的DeepCover ^?^ 安全ECDSA和HMAC SHA-256協(xié)處理器配套器件。該協(xié)處理器可以計(jì)算任何所需的HMAC或ECDSA
    的頭像 發(fā)表于 05-13 11:43 ?246次閱讀
    DS2478 DeepCover汽車安全<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>技術(shù)手冊

    設(shè)計(jì)了一個基于浮點(diǎn)數(shù)運(yùn)算的協(xié)處理器,使用C語言編程時沒法輸入float型數(shù)據(jù),請問有哪些部分需要修改?

    我設(shè)計(jì)了一個基于浮點(diǎn)數(shù)運(yùn)算的協(xié)處理器,使用C語言編程時沒法輸入float型數(shù)據(jù),請問有哪些部分需要修改?SDK,EXU_decoder浮點(diǎn)寄存都需要修改嗎,謝謝
    發(fā)表于 03-07 16:03

    低功耗處理器的優(yōu)勢分析

    隨著科技的飛速發(fā)展,電子設(shè)備的種類和數(shù)量不斷增加,人們對設(shè)備的能效要求也越來越高。低功耗處理器因其在節(jié)能、環(huán)保和成本效益方面的優(yōu)勢而受到廣泛關(guān)注。 低功耗處理器的定義 低功耗處理器是指在設(shè)計(jì)時
    的頭像 發(fā)表于 02-07 09:14 ?1004次閱讀

    EE-345:SHARC處理器的啟動內(nèi)核定制和固件可升級性

    電子發(fā)燒友網(wǎng)站提供《EE-345:SHARC處理器的啟動內(nèi)核定制和固件可升級性.pdf》資料免費(fèi)下載
    發(fā)表于 01-07 14:14 ?0次下載
    EE-345:SHARC<b class='flag-5'>處理器</b>的啟動<b class='flag-5'>內(nèi)核</b>定制和固件可升級性

    EE-290:管理SHARC處理器上的內(nèi)核PLL

    電子發(fā)燒友網(wǎng)站提供《EE-290:管理SHARC處理器上的內(nèi)核PLL.pdf》資料免費(fèi)下載
    發(fā)表于 01-05 09:41 ?0次下載
    EE-290:管理SHARC<b class='flag-5'>處理器</b>上的<b class='flag-5'>內(nèi)核</b>PLL

    OpenHarmony源碼編譯后燒錄鏡像教程,RK3566鴻蒙開發(fā)板演示

    本文介紹瑞芯微主板/開發(fā)板編譯OpenHarmony源碼后燒錄鏡像的教程,觸覺智能Purple Pi OH鴻蒙開發(fā)板演示。搭載了瑞芯微RK3566四核處理器,樹莓派卡片電腦設(shè)計(jì),支持開源鴻蒙
    的頭像 發(fā)表于 12-30 10:08 ?823次閱讀
    OpenHarmony<b class='flag-5'>源碼</b>編譯后燒錄鏡像教程,RK3566<b class='flag-5'>鴻蒙</b>開發(fā)板演示

    全志T536系列處理器特性概述 集成RISC-V E907協(xié)處理器

    ,E907協(xié)處理器,含有2Tops NPU、G2D、VPU 4K高清視頻編解碼。支持多種多媒體接口MIPI-DSI、Parallel DSI、Dual-LVDS和MIPI-CSI、Parallel
    的頭像 發(fā)表于 11-18 15:21 ?3901次閱讀
    全志T536系列<b class='flag-5'>處理器</b>特性概述 集成RISC-V E907<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>

    使用TMS320C6416協(xié)處理器:Turbo協(xié)處理器(TCP)

    電子發(fā)燒友網(wǎng)站提供《使用TMS320C6416協(xié)處理器:Turbo協(xié)處理器(TCP).pdf》資料免費(fèi)下載
    發(fā)表于 10-23 10:16 ?0次下載
    使用TMS320C6416<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>:Turbo<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>(TCP)

    使用TMS320C6416協(xié)處理器:Viterbi協(xié)處理器(VCP)

    電子發(fā)燒友網(wǎng)站提供《使用TMS320C6416協(xié)處理器:Viterbi協(xié)處理器(VCP).pdf》資料免費(fèi)下載
    發(fā)表于 10-21 09:36 ?0次下載
    使用TMS320C6416<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>:Viterbi<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>(VCP)

    TMS320C6416協(xié)處理器和誤碼率

    電子發(fā)燒友網(wǎng)站提供《TMS320C6416協(xié)處理器和誤碼率.pdf》資料免費(fèi)下載
    發(fā)表于 10-17 10:35 ?0次下載
    TMS320C6416<b class='flag-5'>協(xié)</b><b class='flag-5'>處理器</b>和誤碼率

    【開源鴻蒙】使用QEMU運(yùn)行OpenHarmony量系統(tǒng)

    本文將會介紹如何從源碼安裝QEMU 6.2.0,以及如何使用QEMU運(yùn)行OpenHarmony量系統(tǒng)。通過本文,你將會對QEMU和OpenHarmony量系統(tǒng)又一個初步的認(rèn)知,并對如何使用QEMU又一個初步的理解和體會。
    的頭像 發(fā)表于 09-14 08:51 ?1332次閱讀
    【開源<b class='flag-5'>鴻蒙</b>】使用QEMU運(yùn)行OpenHarmony<b class='flag-5'>輕</b>量系統(tǒng)