每個 PMP 區(qū)域都由一個 8 位 pmpXcfg 字段描述,與一個 64 位 pmpaddrX寄存器結(jié)合使用,該寄存器保存受保護區(qū)域的基地址。每個區(qū)域的范圍取決于下一節(jié)中描述的尋址 (A) 模式。pmpXcfg 字段位于 64 位 pmpcfgY CSR中。
每個 8 位 pmpXcfg 字段包括一個讀、寫和執(zhí)行位,外加一個兩位地址匹配字段 A 和一個鎖定位 L。允許重疊區(qū)域,其中編號最小的 PMP條目勝出該區(qū)域。
PMP 配置寄存器
對于 RV64 架構(gòu),未實現(xiàn) pmpcfg1 和 pmpcfg3。這減少了占用空間,因為 pmpcfg2 已經(jīng)包含 RV32 和 pmp11cfg的配置字段 pmp8cfg 和 RV64。
pmpcfgY 和 pmpaddrX 寄存器只能通過 CSR 特定指令訪問,例如用于讀取的 csrr 和用于寫入的 csrw。
復(fù)位后,PMP 寄存器字段 A 和 L 設(shè)置為 0。RISC?V 指令集手冊第 II 卷:特權(quán)架構(gòu)版本 1.10 未指定所有其他 hart狀態(tài)。
下面是一些使用 NAPOT 地址模式的例子。
PMP 地址寄存器
PMP 有 8 個地址寄存器。每個地址寄存器 pmpaddrX 都與相應(yīng)的 pmpXcfg字段相關(guān)聯(lián)。每個地址寄存器都包含右移兩位的受保護區(qū)域的基地址,以實現(xiàn)最小 4 字節(jié)對齊。
根據(jù) RISC?V 指令集手冊,第二卷:特權(quán)架構(gòu),版本 1.10,最大編碼地址位為 [55:2]
-
寄存器
+關(guān)注
關(guān)注
31文章
5372瀏覽量
121295 -
內(nèi)核
+關(guān)注
關(guān)注
3文章
1384瀏覽量
40442 -
PMP
+關(guān)注
關(guān)注
0文章
45瀏覽量
18203 -
RISC
+關(guān)注
關(guān)注
6文章
468瀏覽量
83909 -
架構(gòu)
+關(guān)注
關(guān)注
1文章
520瀏覽量
25564 -
sifive
+關(guān)注
關(guān)注
0文章
36瀏覽量
9477
發(fā)布評論請先 登錄
相關(guān)推薦
【RISC-V開放架構(gòu)設(shè)計之道|閱讀體驗】RISC-V基礎(chǔ)整數(shù)指令集
RISC-V 基礎(chǔ)學(xué)習(xí):RISC-V 基礎(chǔ)介紹
RISC-V工作模式及寄存器基本知識
RISC-V基礎(chǔ)指令詳解
如何在RISC-V處理器上使用FreeRTOS?
RISC-V開源處理器核介紹
玄鐵VirtualZone:基于RISC-V架構(gòu)的安全擴展
初探RISC-V—《RISC-V體系結(jié)構(gòu)編程與實踐》
RISC-V 發(fā)展
AArch64寄存器介紹
RISC-V MCU gp全局指針說明
用于RISC-V處理器的三重模塊化冗余ALU和寄存器文件的設(shè)計示
RISC-V特權(quán)架構(gòu)和通用寄存器
![<b class='flag-5'>RISC-V</b>特權(quán)架構(gòu)和通用<b class='flag-5'>寄存器</b>](https://file1.elecfans.com/web2/M00/A7/32/wKgaomUiT2mAKmxkAABwE8f-JVE516.jpg)
評論