每個(gè) PMP 區(qū)域都由一個(gè) 8 位 pmpXcfg 字段描述,與一個(gè) 64 位 pmpaddrX寄存器結(jié)合使用,該寄存器保存受保護(hù)區(qū)域的基地址。每個(gè)區(qū)域的范圍取決于下一節(jié)中描述的尋址 (A) 模式。pmpXcfg 字段位于 64 位 pmpcfgY CSR中。
每個(gè) 8 位 pmpXcfg 字段包括一個(gè)讀、寫和執(zhí)行位,外加一個(gè)兩位地址匹配字段 A 和一個(gè)鎖定位 L。允許重疊區(qū)域,其中編號最小的 PMP條目勝出該區(qū)域。
PMP 配置寄存器
對于 RV64 架構(gòu),未實(shí)現(xiàn) pmpcfg1 和 pmpcfg3。這減少了占用空間,因?yàn)?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 個(gè)地址寄存器。每個(gè)地址寄存器 pmpaddrX 都與相應(yīng)的 pmpXcfg字段相關(guān)聯(lián)。每個(gè)地址寄存器都包含右移兩位的受保護(hù)區(qū)域的基地址,以實(shí)現(xiàn)最小 4 字節(jié)對齊。
根據(jù) RISC?V 指令集手冊,第二卷:特權(quán)架構(gòu),版本 1.10,最大編碼地址位為 [55:2]
-
寄存器
+關(guān)注
關(guān)注
31文章
5250瀏覽量
119200 -
內(nèi)核
+關(guān)注
關(guān)注
3文章
1336瀏覽量
40084 -
PMP
+關(guān)注
關(guān)注
0文章
45瀏覽量
18100 -
RISC
+關(guān)注
關(guān)注
6文章
460瀏覽量
83566 -
架構(gòu)
+關(guān)注
關(guān)注
1文章
501瀏覽量
25374 -
sifive
+關(guān)注
關(guān)注
0文章
34瀏覽量
9443
發(fā)布評論請先 登錄
相關(guān)推薦
評論