From 5d426ff8a65b16ce164467c3a54103e25fde3b2d Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Thu, 12 Dec 2024 17:55:32 +0000 Subject: [PATCH] add more exception types to distinguish CHERI page fault types (#480) Fixes https://github.com/riscv/riscv-cheri/issues/470 --- src/hypervisor-integration.adoc | 8 ++++---- src/riscv-integration.adoc | 23 +++++++++++++++++------ 2 files changed, 21 insertions(+), 10 deletions(-) diff --git a/src/hypervisor-integration.adoc b/src/hypervisor-integration.adoc index 46f276d8..9e84649d 100644 --- a/src/hypervisor-integration.adoc +++ b/src/hypervisor-integration.adoc @@ -74,8 +74,8 @@ The <> register is an HSXLEN-bit read-write register, which is added as part of {cheri_base_ext_name} when the hypervisor extension is supported. Its CSR address is 0x64b. -<> is updated following the same rules as <> for CHERI exceptions -which are taken in HS-mode. +<> is updated following the same rules as <> for CHERI exceptions, +load page fault and store page fault exceptions which are taken in HS-mode. The fields are identical to <> for CHERI exceptions. @@ -195,8 +195,8 @@ include::img/vstdcreg.edn[] The <> register is a VSXLEN-bit read-write register. -<> is updated following the same rules as <> for CHERI exceptions -which are taken in VS-mode. +<> is updated following the same rules as <> for CHERI exceptions, +load page fault and store page faults which are taken in VS-mode. .Virtual supervisor trap value register [#vstval-format] diff --git a/src/riscv-integration.adoc b/src/riscv-integration.adoc index 776ba28c..315cadb3 100644 --- a/src/riscv-integration.adoc +++ b/src/riscv-integration.adoc @@ -426,7 +426,7 @@ include::generated/csr_renamed_purecap_mode_u_table_body.adoc[] === Machine-Level CSRs {cheri_base_ext_name} extends some M-mode CSRs to hold capabilities or -otherwise add new functions. <> in the <> is typically required for access. +otherwise add new functions. <> in the <> is typically required for access. [#mstatus,reftext="mstatus"] ==== Machine Status Registers (mstatus and mstatush) @@ -786,7 +786,9 @@ xref:mtval2-format[xrefstyle=short] to assist software in handling the trap. If <> is read-only zero for CHERI exceptions then <> is also read-only zero for CHERI exceptions. -.Machine trap value register 2 format for CHERI faults +===== mtval2 values for CHERI faults + +.Machine trap value register 2 format for CHERI Faults [#mtval2-format] include::img/mtval2reg.edn[] @@ -798,7 +800,7 @@ is the cause of the fault. The possible CHERI types and causes are encoded as shown in xref:mtval2-cheri-type[xrefstyle=short] and xref:mtval2-cheri-causes[xrefstyle=short] respectively. -.Encoding of TYPE field +.Encoding of TYPE field for CHERI Faults [#mtval2-cheri-type,width=65%,float="center",align="center",options=header,cols="30%,70%"] |============================================================================== | CHERI Type Code | Description @@ -828,11 +830,19 @@ CHERI violations have the following order in priority: . Invalid address violation . Bounds violation (_Lowest_) +===== mtval2 values for Load Page Faults + +If a load page fault is caused by a CHERI <> fault, then set bit zero of <> to 1 and all other bits to 0, otherwise set all bits to zero. + +===== mtval2 values for Store Page Faults + +If a store page fault is caused by a CHERI <> fault, then set bit zero of <> to 1 and all other bits to 0, otherwise set all bits to zero. + [#supervisor-level-csrs-section] === Supervisor-Level CSRs {cheri_base_ext_name} extends some of the existing RISC-V CSRs to be able to -hold capabilities or with other new functions. <> in the <> is typically required for access. +hold capabilities or with other new functions. <> in the <> is typically required for access. [#stvec,reftext="stvec"] ==== Supervisor Trap Vector Base Address Register (stvec) @@ -1040,7 +1050,8 @@ address is 0x14b. <> is updated following the same rules as <> for CHERI exceptions which are delegated to S-mode. -The fields are identical to <> for CHERI exceptions. +The fields are identical to <> for CHERI exceptions, and for load and +store page fault exceptions if {cheri_pte_ext_name} is implemented. NOTE: <> is not a standard RISC-V CSR, but <> is. @@ -1062,7 +1073,7 @@ NOTE: `auth_cap` is <> for {cheri_int_mode_name} and `cs1` for {cheri_cap_m [#cheri_exception_combs_descriptions] [width="100%",options=header,cols="2,1,1,1,3,4"] |========================================================================================= -| Instructions | Xcause | Xtval. TYPE | Xtval. CAUSE | Description | Check +| Instructions | Xcause | Xtval2. TYPE | Xtval2. CAUSE | Description | Check 6+| *All instructions have these exception checks first* | All | {cheri_excep_mcause} | {cheri_excep_type_pcc} | {cheri_excep_cause_tag} | <> tag | not(<>.tag) | All | {cheri_excep_mcause} | {cheri_excep_type_pcc} | {cheri_excep_cause_seal} | <> seal | isCapSealed(<>)^1^