From 2e8019ef8ddacd042ee2a4758551989a43fe89dd Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Tue, 19 Dec 2023 16:27:59 +0000 Subject: [PATCH 01/25] first attempt at CSRs and encodings for CHERI --- csrs.csv | 10 +++++++++ unratified/rv64_cheri | 51 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 unratified/rv64_cheri diff --git a/csrs.csv b/csrs.csv index 3c6328b9..ade506ee 100644 --- a/csrs.csv +++ b/csrs.csv @@ -240,7 +240,14 @@ 0x3ed, "pmpaddr61" 0x3ee, "pmpaddr62" 0x3ef, "pmpaddr63" +0x417, "jvtc" +0x505, "stvecc" +0x540, "sscratchc" +0x541, "sepcc" 0x747, "mseccfg" +0x760, "mscratchc" +0x761, "mepcc" +0x765, "mtvecc" 0x7a0, "tselect" 0x7a1, "tdata1" 0x7a2, "tdata2" @@ -253,6 +260,9 @@ 0x7b1, "dpc" 0x7b2, "dscratch0" 0x7b3, "dscratch1" +0x7b9, "dpcc" +0x7ba, "dscratch0c" +0x7bb, "dscratch1c" 0xB00, "mcycle" 0xB02, "minstret" 0xB03, "mhpmcounter3" diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri new file mode 100644 index 00000000..cc60f7fc --- /dev/null +++ b/unratified/rv64_cheri @@ -0,0 +1,51 @@ +lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 +sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 + +#maybe doesn't need full 12-bit immediate +cincoffsetimm rd rs1 imm12 14..12=1 6..2=0x04 1..0=3 +#can trim to 5-bit immediate +csetboundsimm rd rs1 imm12 14..12=5 6..2=0x04 1..0=3 + +cincoffset rd rs1 rs2 31..25=6 14..12=0 6..2=0x0C 1..0=3 +csetaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 +candperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 +csethigh rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 +csetequalexact rd rs1 rs2 31..25=6 14..12=4 6..2=0x0C 1..0=3 +cbuildcap rd rs1 rs2 31..25=6 14..12=5 6..2=0x0C 1..0=3 +ctestsubset rd rs1 rs2 31..25=6 14..12=6 6..2=0x0C 1..0=3 + +csetbounds rd rs1 rs2 31..25=7 14..12=0 6..2=0x0C 1..0=3 +csetboundsinexact rd rs1 rs2 31..25=7 14..12=1 6..2=0x0C 1..0=3 + +cgettag rd rs1 31..25=8 24..20=0 14..12=0 6..2=0x0C 1..0=3 +cgetperm rd rs1 31..25=8 24..20=1 14..12=0 6..2=0x0C 1..0=3 +cmove rd rs1 31..25=8 24..20=2 14..12=0 6..2=0x0C 1..0=3 +csetmode rd rs1 31..25=8 24..20=3 14..12=0 6..2=0x0C 1..0=3 +cgethigh rd rs1 31..25=8 24..20=4 14..12=0 6..2=0x0C 1..0=3 +cgetbase rd rs1 31..25=8 24..20=5 14..12=0 6..2=0x0C 1..0=3 +cgetlen rd rs1 31..25=8 24..20=6 14..12=0 6..2=0x0C 1..0=3 +cram rd rs1 31..25=8 24..20=7 14..12=0 6..2=0x0C 1..0=3 +cseal rd rs1 31..25=8 24..20=8 14..12=0 6..2=0x0C 1..0=3 + +cmodeswitch 31..25=9 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 + +#adjacent to c.not +c.cmodeswitch 15..13=4 12..10=7 9..7=0 6..5=3 4..2=7 1..0=1 + +#adjacent to JALR +jalr.pcc rd rs1 31..20=0 14..12=1 6..2=0x19 1..0=3 + +#adjacent to sh[123]add +sh4add rd rs1 rs2 31..25=16 14..12=7 6..2=0x0C 1..0=3 + +#adjacent to sh[123]add.uw +sh4add.uw rd rs1 rs2 31..25=16 14..12=7 6..2=0x0E 1..0=3 + +#regular encodings +lr.b rd rs1 24..20=0 aq rl 31..29=0 28..27=2 14..12=0 6..2=0x0B 1..0=3 +lr.h rd rs1 24..20=0 aq rl 31..29=0 28..27=2 14..12=1 6..2=0x0B 1..0=3 +sc.b rd rs1 rs2 aq rl 31..29=0 28..27=3 14..12=0 6..2=0x0B 1..0=3 +sc.h rd rs1 rs2 aq rl 31..29=0 28..27=3 14..12=1 6..2=0x0B 1..0=3 + +#regular encoding +amoswap.c rd rs1 rs2 aq rl 31..29=0 28..27=1 14..12=4 6..2=0x0B 1..0=3 From 5a54e195fdfdd5bda35333a36a5073564bdc1223 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Tue, 19 Dec 2023 16:40:54 +0000 Subject: [PATCH 02/25] note that lr/b etc will be a separate extension eventually --- unratified/rv64_cheri | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index cc60f7fc..ee76f405 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -41,7 +41,7 @@ sh4add rd rs1 rs2 31..25=16 14..12=7 6..2=0x0C 1..0=3 #adjacent to sh[123]add.uw sh4add.uw rd rs1 rs2 31..25=16 14..12=7 6..2=0x0E 1..0=3 -#regular encodings +#regular encodings - will become a separate extension lr.b rd rs1 24..20=0 aq rl 31..29=0 28..27=2 14..12=0 6..2=0x0B 1..0=3 lr.h rd rs1 24..20=0 aq rl 31..29=0 28..27=2 14..12=1 6..2=0x0B 1..0=3 sc.b rd rs1 rs2 aq rl 31..29=0 28..27=3 14..12=0 6..2=0x0B 1..0=3 From 17a3dd72c7f143c004dde7c81b498a4c694f26b8 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Thu, 4 Jan 2024 15:43:54 +0000 Subject: [PATCH 03/25] resolve overlapping encodings --- unratified/rv64_cheri | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index ee76f405..5ade1bd5 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -1,10 +1,10 @@ lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 -#maybe doesn't need full 12-bit immediate -cincoffsetimm rd rs1 imm12 14..12=1 6..2=0x04 1..0=3 -#can trim to 5-bit immediate -csetboundsimm rd rs1 imm12 14..12=5 6..2=0x04 1..0=3 +#6-bit immediate fits, should hopefully be enough? +cincoffsetimm rd rs1 imm6 31..26=1 14..12=1 6..2=0x04 1..0=3 +#5-bit immediate and 25 says whether to shift it +csetboundsimm rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 cincoffset rd rs1 rs2 31..25=6 14..12=0 6..2=0x0C 1..0=3 csetaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 From a9c455170460478310de1f68c1642b610e894250 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 8 Jan 2024 11:59:54 +0000 Subject: [PATCH 04/25] remap cincoffsetimm to op-imm-32 and make cincoffset with rs2=x0 decode as cmove --- unratified/rv64_cheri | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index 5ade1bd5..dec08bec 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -1,12 +1,14 @@ lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 -#6-bit immediate fits, should hopefully be enough? -cincoffsetimm rd rs1 imm6 31..26=1 14..12=1 6..2=0x04 1..0=3 +#need to ADDIW +cincoffsetimm rd rs1 imm12 14..12=2 6..2=0x06 1..0=3 #5-bit immediate and 25 says whether to shift it -csetboundsimm rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 +csetboundsimm rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 -cincoffset rd rs1 rs2 31..25=6 14..12=0 6..2=0x0C 1..0=3 +#if rs2=x0 decode as cmove +cincoffset rd rs1 rs2 31..25=6 14..12=0 6..2=0x06 1..0=3 +cmove rd rs1 24..20=0 31..25=6 14..12=0 6..2=0x06 1..0=3 csetaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 candperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 csethigh rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 @@ -19,7 +21,6 @@ csetboundsinexact rd rs1 rs2 31..25=7 14..12=1 6..2=0x0C 1..0=3 cgettag rd rs1 31..25=8 24..20=0 14..12=0 6..2=0x0C 1..0=3 cgetperm rd rs1 31..25=8 24..20=1 14..12=0 6..2=0x0C 1..0=3 -cmove rd rs1 31..25=8 24..20=2 14..12=0 6..2=0x0C 1..0=3 csetmode rd rs1 31..25=8 24..20=3 14..12=0 6..2=0x0C 1..0=3 cgethigh rd rs1 31..25=8 24..20=4 14..12=0 6..2=0x0C 1..0=3 cgetbase rd rs1 31..25=8 24..20=5 14..12=0 6..2=0x0C 1..0=3 From 2c62d98fa3176031d6dc6636e0832a7236766c62 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Wed, 24 Jan 2024 13:26:45 +0100 Subject: [PATCH 05/25] add rs2 to csetmode --- unratified/rv64_cheri | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index dec08bec..5f02206a 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -15,13 +15,13 @@ csethigh rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 csetequalexact rd rs1 rs2 31..25=6 14..12=4 6..2=0x0C 1..0=3 cbuildcap rd rs1 rs2 31..25=6 14..12=5 6..2=0x0C 1..0=3 ctestsubset rd rs1 rs2 31..25=6 14..12=6 6..2=0x0C 1..0=3 +csetmode rd rs1 rs2 31..25=6 14..12=7 6..2=0x0C 1..0=3 csetbounds rd rs1 rs2 31..25=7 14..12=0 6..2=0x0C 1..0=3 csetboundsinexact rd rs1 rs2 31..25=7 14..12=1 6..2=0x0C 1..0=3 cgettag rd rs1 31..25=8 24..20=0 14..12=0 6..2=0x0C 1..0=3 cgetperm rd rs1 31..25=8 24..20=1 14..12=0 6..2=0x0C 1..0=3 -csetmode rd rs1 31..25=8 24..20=3 14..12=0 6..2=0x0C 1..0=3 cgethigh rd rs1 31..25=8 24..20=4 14..12=0 6..2=0x0C 1..0=3 cgetbase rd rs1 31..25=8 24..20=5 14..12=0 6..2=0x0C 1..0=3 cgetlen rd rs1 31..25=8 24..20=6 14..12=0 6..2=0x0C 1..0=3 From 6fefa7defd297765f4705059ebdb8b57682ec5d6 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Tue, 13 Feb 2024 16:04:53 +0000 Subject: [PATCH 06/25] instruction renaming to match latest spec --- unratified/rv64_cheri | 47 +++++++++++++++++++++---------------------- 1 file changed, 23 insertions(+), 24 deletions(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index 5f02206a..fe2e62cf 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -2,39 +2,38 @@ lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 #need to ADDIW -cincoffsetimm rd rs1 imm12 14..12=2 6..2=0x06 1..0=3 +caddi rd rs1 imm12 14..12=2 6..2=0x06 1..0=3 #5-bit immediate and 25 says whether to shift it -csetboundsimm rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 +scbndsi rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 #if rs2=x0 decode as cmove -cincoffset rd rs1 rs2 31..25=6 14..12=0 6..2=0x06 1..0=3 -cmove rd rs1 24..20=0 31..25=6 14..12=0 6..2=0x06 1..0=3 -csetaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 -candperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 -csethigh rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 -csetequalexact rd rs1 rs2 31..25=6 14..12=4 6..2=0x0C 1..0=3 -cbuildcap rd rs1 rs2 31..25=6 14..12=5 6..2=0x0C 1..0=3 -ctestsubset rd rs1 rs2 31..25=6 14..12=6 6..2=0x0C 1..0=3 -csetmode rd rs1 rs2 31..25=6 14..12=7 6..2=0x0C 1..0=3 - -csetbounds rd rs1 rs2 31..25=7 14..12=0 6..2=0x0C 1..0=3 -csetboundsinexact rd rs1 rs2 31..25=7 14..12=1 6..2=0x0C 1..0=3 - -cgettag rd rs1 31..25=8 24..20=0 14..12=0 6..2=0x0C 1..0=3 -cgetperm rd rs1 31..25=8 24..20=1 14..12=0 6..2=0x0C 1..0=3 -cgethigh rd rs1 31..25=8 24..20=4 14..12=0 6..2=0x0C 1..0=3 -cgetbase rd rs1 31..25=8 24..20=5 14..12=0 6..2=0x0C 1..0=3 -cgetlen rd rs1 31..25=8 24..20=6 14..12=0 6..2=0x0C 1..0=3 +cadd rd rs1 rs2 31..25=6 14..12=0 6..2=0x06 1..0=3 +scaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 +acperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 +schi rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 +sceq rd rs1 rs2 31..25=6 14..12=4 6..2=0x0C 1..0=3 +cbld rd rs1 rs2 31..25=6 14..12=5 6..2=0x0C 1..0=3 +cscc rd rs1 rs2 31..25=6 14..12=6 6..2=0x0C 1..0=3 +scmode rd rs1 rs2 31..25=6 14..12=7 6..2=0x0C 1..0=3 + +scbnds rd rs1 rs2 31..25=7 14..12=0 6..2=0x0C 1..0=3 +scbndsr rd rs1 rs2 31..25=7 14..12=1 6..2=0x0C 1..0=3 + +gctag rd rs1 31..25=8 24..20=0 14..12=0 6..2=0x0C 1..0=3 +gcperm rd rs1 31..25=8 24..20=1 14..12=0 6..2=0x0C 1..0=3 +gchi rd rs1 31..25=8 24..20=4 14..12=0 6..2=0x0C 1..0=3 +gcbase rd rs1 31..25=8 24..20=5 14..12=0 6..2=0x0C 1..0=3 +gclen rd rs1 31..25=8 24..20=6 14..12=0 6..2=0x0C 1..0=3 cram rd rs1 31..25=8 24..20=7 14..12=0 6..2=0x0C 1..0=3 -cseal rd rs1 31..25=8 24..20=8 14..12=0 6..2=0x0C 1..0=3 +sentry rd rs1 31..25=8 24..20=8 14..12=0 6..2=0x0C 1..0=3 -cmodeswitch 31..25=9 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 +modesw 31..25=9 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 #adjacent to c.not -c.cmodeswitch 15..13=4 12..10=7 9..7=0 6..5=3 4..2=7 1..0=1 +c.modesw 15..13=4 12..10=7 9..7=0 6..5=3 4..2=7 1..0=1 #adjacent to JALR -jalr.pcc rd rs1 31..20=0 14..12=1 6..2=0x19 1..0=3 +jalr.mode rd rs1 31..20=0 14..12=1 6..2=0x19 1..0=3 #adjacent to sh[123]add sh4add rd rs1 rs2 31..25=16 14..12=7 6..2=0x0C 1..0=3 From 92a41e407265d125dcf3c98c3e7932eba1ed2a55 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Wed, 14 Feb 2024 14:44:23 +0000 Subject: [PATCH 07/25] add extra debug CSRs --- csrs.csv | 2 ++ 1 file changed, 2 insertions(+) diff --git a/csrs.csv b/csrs.csv index ade506ee..985a0ddf 100644 --- a/csrs.csv +++ b/csrs.csv @@ -263,6 +263,8 @@ 0x7b9, "dpcc" 0x7ba, "dscratch0c" 0x7bb, "dscratch1c" +0x7bc, "dddc" +0x7bd, "dinfcap" 0xB00, "mcycle" 0xB02, "minstret" 0xB03, "mhpmcounter3" From b003eddc51bf588d48e8fd340ade541720a47f33 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 19 Feb 2024 17:37:05 +0000 Subject: [PATCH 08/25] put cadd into OP --- unratified/rv64_cheri | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index fe2e62cf..da31ea12 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -7,7 +7,7 @@ caddi rd rs1 imm12 14..12=2 6..2=0x06 1..0=3 scbndsi rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 #if rs2=x0 decode as cmove -cadd rd rs1 rs2 31..25=6 14..12=0 6..2=0x06 1..0=3 +cadd rd rs1 rs2 31..25=6 14..12=0 6..2=0x0C 1..0=3 scaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 acperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 schi rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 From 20d441d879c89446c61b5d4152cf4e02f82b33c7 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Fri, 8 Mar 2024 15:05:43 +0100 Subject: [PATCH 09/25] add CLIC+CHERI registers --- csrs.csv | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/csrs.csv b/csrs.csv index 985a0ddf..cdb0f43f 100644 --- a/csrs.csv +++ b/csrs.csv @@ -125,11 +125,19 @@ 0x146, "sintstatus" 0x148, "sscratchcsw" 0x149, "sscratchcswl" +0x110, "stvtc" +0x111, "snxtic" +0x112, "sscratchcswc" +0x113, "sscratchcswlc" 0x307, "mtvt" 0x345, "mnxti" 0x346, "mintstatus" 0x348, "mscratchcsw" 0x349, "mscratchcswl" +0x310, "mtvtc" +0x311, "mnxtic" +0x312, "mscratchcswc" +0x313, "mscratchcswlc" 0x300, "mstatus" 0x301, "misa" 0x302, "medeleg" From edbd3c5fb24412de3b53a8d4e155cec2f56e7f14 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 8 Apr 2024 17:41:09 +0200 Subject: [PATCH 10/25] remove duplicate CSRS and add stid/util --- csrs.csv | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/csrs.csv b/csrs.csv index a6c0456b..dc80ec3b 100644 --- a/csrs.csv +++ b/csrs.csv @@ -43,6 +43,7 @@ 0xC20, "vl" 0xC21, "vtype" 0xC22, "vlenb" +0xCBF, "utid" 0x100, "sstatus" 0x102, "sedeleg" 0x103, "sideleg" @@ -90,6 +91,7 @@ 0x257, "vsireg6" 0x25C, "vstopei" 0x280, "vsatp" +0x500, "stid" 0x600, "hstatus" 0x602, "hedeleg" 0x603, "hideleg" @@ -249,14 +251,7 @@ 0x3ed, "pmpaddr61" 0x3ee, "pmpaddr62" 0x3ef, "pmpaddr63" -0x417, "jvtc" -0x505, "stvecc" -0x540, "sscratchc" -0x541, "sepcc" 0x747, "mseccfg" -0x760, "mscratchc" -0x761, "mepcc" -0x765, "mtvecc" 0x7a0, "tselect" 0x7a1, "tdata1" 0x7a2, "tdata2" @@ -269,9 +264,6 @@ 0x7b1, "dpc" 0x7b2, "dscratch0" 0x7b3, "dscratch1" -0x7b9, "dpcc" -0x7ba, "dscratch0c" -0x7bb, "dscratch1c" 0x7bc, "dddc" 0x7bd, "dinfcap" 0xB00, "mcycle" From 800d76ad5fb4404a8d65fb2bec72911d16a2a74d Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 8 Apr 2024 17:44:52 +0200 Subject: [PATCH 11/25] remove CLIC duplicated, and reinstate DDC --- csrs.csv | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/csrs.csv b/csrs.csv index dc80ec3b..da0c3f73 100644 --- a/csrs.csv +++ b/csrs.csv @@ -128,19 +128,11 @@ 0x146, "sintstatus" 0x148, "sscratchcsw" 0x149, "sscratchcswl" -0x110, "stvtc" -0x111, "snxtic" -0x112, "sscratchcswc" -0x113, "sscratchcswlc" 0x307, "mtvt" 0x345, "mnxti" 0x346, "mintstatus" 0x348, "mscratchcsw" 0x349, "mscratchcswl" -0x310, "mtvtc" -0x311, "mnxtic" -0x312, "mscratchcswc" -0x313, "mscratchcswlc" 0x300, "mstatus" 0x301, "misa" 0x302, "medeleg" @@ -251,6 +243,7 @@ 0x3ed, "pmpaddr61" 0x3ee, "pmpaddr62" 0x3ef, "pmpaddr63" +0x416, "ddc" 0x747, "mseccfg" 0x7a0, "tselect" 0x7a1, "tdata1" From 8a5cd206fa352d509c4f60c8962a0dd3b00e48ae Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 8 Apr 2024 17:52:12 +0200 Subject: [PATCH 12/25] make UTID/STID CSRs more consistent --- csrs.csv | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/csrs.csv b/csrs.csv index da0c3f73..d169186a 100644 --- a/csrs.csv +++ b/csrs.csv @@ -43,7 +43,7 @@ 0xC20, "vl" 0xC21, "vtype" 0xC22, "vlenb" -0xCBF, "utid" +0xC80, "utid" 0x100, "sstatus" 0x102, "sedeleg" 0x103, "sideleg" @@ -91,7 +91,7 @@ 0x257, "vsireg6" 0x25C, "vstopei" 0x280, "vsatp" -0x500, "stid" +0x580, "stid" 0x600, "hstatus" 0x602, "hedeleg" 0x603, "hideleg" From fa8a628dbd0f1c5b17941c30395771d247107276 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 8 Apr 2024 17:53:21 +0200 Subject: [PATCH 13/25] delete JALR.MODE --- unratified/rv64_cheri | 3 --- 1 file changed, 3 deletions(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index da31ea12..1526c5b7 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -32,9 +32,6 @@ modesw 31..25=9 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 #adjacent to c.not c.modesw 15..13=4 12..10=7 9..7=0 6..5=3 4..2=7 1..0=1 -#adjacent to JALR -jalr.mode rd rs1 31..20=0 14..12=1 6..2=0x19 1..0=3 - #adjacent to sh[123]add sh4add rd rs1 rs2 31..25=16 14..12=7 6..2=0x0C 1..0=3 From 239ce02d0521f9d39f4427d52fb541ecd45cc5f1 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Wed, 15 May 2024 17:41:03 +0200 Subject: [PATCH 14/25] fix mnemonic name --- unratified/rv64_cheri | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index 1526c5b7..e95a5b8b 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -13,7 +13,7 @@ acperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 schi rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 sceq rd rs1 rs2 31..25=6 14..12=4 6..2=0x0C 1..0=3 cbld rd rs1 rs2 31..25=6 14..12=5 6..2=0x0C 1..0=3 -cscc rd rs1 rs2 31..25=6 14..12=6 6..2=0x0C 1..0=3 +scss rd rs1 rs2 31..25=6 14..12=6 6..2=0x0C 1..0=3 scmode rd rs1 rs2 31..25=6 14..12=7 6..2=0x0C 1..0=3 scbnds rd rs1 rs2 31..25=7 14..12=0 6..2=0x0C 1..0=3 From 0ff84710cbaf7de84a514a969aeb65249ffe7b91 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 20 May 2024 10:39:14 +0200 Subject: [PATCH 15/25] add lr.c/sc.c --- unratified/rv64_cheri | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index e95a5b8b..0fd32d0c 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -44,5 +44,7 @@ lr.h rd rs1 24..20=0 aq rl 31..29=0 28..27=2 14..12=1 6..2=0x0B 1..0=3 sc.b rd rs1 rs2 aq rl 31..29=0 28..27=3 14..12=0 6..2=0x0B 1..0=3 sc.h rd rs1 rs2 aq rl 31..29=0 28..27=3 14..12=1 6..2=0x0B 1..0=3 -#regular encoding +#regular encodings for double width datatype amoswap.c rd rs1 rs2 aq rl 31..29=0 28..27=1 14..12=4 6..2=0x0B 1..0=3 +lr.c rd rs1 24..20=0 aq rl 31..29=0 28..27=2 14..12=4 6..2=0x0B 1..0=3 +sc.c rd rs1 rs2 aq rl 31..29=0 28..27=3 14..12=4 6..2=0x0B 1..0=3 From 4e2a3fd4f4b4852220c6757f36fceedbe6ae410e Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 3 Jun 2024 12:12:43 +0200 Subject: [PATCH 16/25] avoid conflict between cycleh and utid --- csrs.csv | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/csrs.csv b/csrs.csv index d169186a..540c5f69 100644 --- a/csrs.csv +++ b/csrs.csv @@ -43,7 +43,6 @@ 0xC20, "vl" 0xC21, "vtype" 0xC22, "vlenb" -0xC80, "utid" 0x100, "sstatus" 0x102, "sedeleg" 0x103, "sideleg" @@ -91,6 +90,7 @@ 0x257, "vsireg6" 0x25C, "vstopei" 0x280, "vsatp" +0x480, "utid" 0x580, "stid" 0x600, "hstatus" 0x602, "hedeleg" From acf7da3764ec02847450f98250ca65d0384600d5 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 3 Jun 2024 12:16:53 +0200 Subject: [PATCH 17/25] make it read only --- csrs.csv | 1 - 1 file changed, 1 deletion(-) diff --git a/csrs.csv b/csrs.csv index 540c5f69..2ffcaf9e 100644 --- a/csrs.csv +++ b/csrs.csv @@ -90,7 +90,6 @@ 0x257, "vsireg6" 0x25C, "vstopei" 0x280, "vsatp" -0x480, "utid" 0x580, "stid" 0x600, "hstatus" 0x602, "hedeleg" From 29a9ab44e6c2c68eaa32cbf5dee59d656274007e Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 3 Jun 2024 12:18:22 +0200 Subject: [PATCH 18/25] re-instate utid --- csrs.csv | 1 + 1 file changed, 1 insertion(+) diff --git a/csrs.csv b/csrs.csv index 2ffcaf9e..1c3866c6 100644 --- a/csrs.csv +++ b/csrs.csv @@ -90,6 +90,7 @@ 0x257, "vsireg6" 0x25C, "vstopei" 0x280, "vsatp" +0xCA0, "utid" 0x580, "stid" 0x600, "hstatus" 0x602, "hedeleg" From d33cd807fbbdb6cfd023ccb1e15e78be41bbf4fd Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 10 Jun 2024 10:52:29 +0200 Subject: [PATCH 19/25] update util, add mtid --- csrs.csv | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/csrs.csv b/csrs.csv index 1c3866c6..09d52185 100644 --- a/csrs.csv +++ b/csrs.csv @@ -90,8 +90,9 @@ 0x257, "vsireg6" 0x25C, "vstopei" 0x280, "vsatp" -0xCA0, "utid" +0x480, "utid" 0x580, "stid" +0x780, "mtid" 0x600, "hstatus" 0x602, "hedeleg" 0x603, "hideleg" From 06d6b6f603d1323fd10d8ba11f0cc41e7311afd7 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 10 Jun 2024 16:46:31 +0200 Subject: [PATCH 20/25] separate cmv from caddi --- constants.py | 1 + unratified/rv64_cheri | 5 +++-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/constants.py b/constants.py index cb3e689d..5f78577d 100644 --- a/constants.py +++ b/constants.py @@ -14,6 +14,7 @@ 'c_mv': {'c_jr'}, 'c_jalr': {'c_ebreak'}, 'c_add': {'c_ebreak', 'c_jalr'}, + 'caddi': {'cmv'} } isa_regex = \ diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index 0fd32d0c..c96138f5 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -1,8 +1,9 @@ lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 -#need to ADDIW -caddi rd rs1 imm12 14..12=2 6..2=0x06 1..0=3 +#next to ADDIW +caddi rd_n0 rs1 imm12 14..12=2 6..2=0x06 1..0=3 +cmv 11..7=0x0 rs1 imm12 14..12=2 6..2=0x06 1..0=3 #5-bit immediate and 25 says whether to shift it scbndsi rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 From 9b88c001d9c963cc51078ce1d933c0ee570f3684 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Mon, 10 Jun 2024 17:22:11 +0200 Subject: [PATCH 21/25] correctly split cmv from cadd not from caddi --- arg_lut.csv | 1 + constants.py | 2 +- unratified/rv64_cheri | 11 ++++++----- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/arg_lut.csv b/arg_lut.csv index b1436503..a118c6c6 100644 --- a/arg_lut.csv +++ b/arg_lut.csv @@ -2,6 +2,7 @@ "rt", 19, 15 "rs1", 19, 15 "rs2", 24, 20 +"rs2_n0", 24, 20 "rs3", 31, 27 "aqrl", 26, 25 "aq", 26, 26 diff --git a/constants.py b/constants.py index 5f78577d..50d3b836 100644 --- a/constants.py +++ b/constants.py @@ -14,7 +14,7 @@ 'c_mv': {'c_jr'}, 'c_jalr': {'c_ebreak'}, 'c_add': {'c_ebreak', 'c_jalr'}, - 'caddi': {'cmv'} + 'cadd': {'cmv'} } isa_regex = \ diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index c96138f5..44c118e9 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -1,14 +1,15 @@ -lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 -sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 +lc rd rs1 imm12 14..12=4 6..2=0x03 1..0=3 +sc imm12hi rs1 rs2 imm12lo 14..12=4 6..2=0x08 1..0=3 #next to ADDIW -caddi rd_n0 rs1 imm12 14..12=2 6..2=0x06 1..0=3 -cmv 11..7=0x0 rs1 imm12 14..12=2 6..2=0x06 1..0=3 +caddi rd rs1 imm12 14..12=2 6..2=0x06 1..0=3 + #5-bit immediate and 25 says whether to shift it scbndsi rd rs1 imm5 31..26=1 14..12=5 6..2=0x04 1..0=3 #if rs2=x0 decode as cmove -cadd rd rs1 rs2 31..25=6 14..12=0 6..2=0x0C 1..0=3 +cadd rd rs1 rs2_n0 31..25=6 14..12=0 6..2=0x0C 1..0=3 +cmv rd rs1 24..20=0x0 31..25=6 14..12=0 6..2=0x0C 1..0=3 scaddr rd rs1 rs2 31..25=6 14..12=1 6..2=0x0C 1..0=3 acperm rd rs1 rs2 31..25=6 14..12=2 6..2=0x0C 1..0=3 schi rd rs1 rs2 31..25=6 14..12=3 6..2=0x0C 1..0=3 From c1d327e5d9b0049749472db14b3bc0684a6463cc Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Thu, 29 Aug 2024 12:11:54 +0200 Subject: [PATCH 22/25] add gcmode, gctype --- unratified/rv64_cheri | 2 ++ 1 file changed, 2 insertions(+) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index 44c118e9..30b7c478 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -23,6 +23,8 @@ scbndsr rd rs1 rs2 31..25=7 14..12=1 6..2=0x0C 1..0=3 gctag rd rs1 31..25=8 24..20=0 14..12=0 6..2=0x0C 1..0=3 gcperm rd rs1 31..25=8 24..20=1 14..12=0 6..2=0x0C 1..0=3 +gctype rd rs1 31..25=8 24..20=2 14..12=0 6..2=0x0C 1..0=3 +gcmode rd rs1 31..25=8 24..20=3 14..12=0 6..2=0x0C 1..0=3 gchi rd rs1 31..25=8 24..20=4 14..12=0 6..2=0x0C 1..0=3 gcbase rd rs1 31..25=8 24..20=5 14..12=0 6..2=0x0C 1..0=3 gclen rd rs1 31..25=8 24..20=6 14..12=0 6..2=0x0C 1..0=3 From 6fc6c5c7f7be6384990e3865e965e92607b13a53 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Thu, 19 Sep 2024 14:44:06 +0200 Subject: [PATCH 23/25] add stval2 --- csrs.csv | 1 + 1 file changed, 1 insertion(+) diff --git a/csrs.csv b/csrs.csv index 0b02571a..e96d697c 100644 --- a/csrs.csv +++ b/csrs.csv @@ -60,6 +60,7 @@ 0x142, "scause" 0x143, "stval" 0x144, "sip" +0x14b, "stval2" 0x14D, "stimecmp" 0x14E, "sctrctl" 0x14F, "sctrstatus" From 49f4fdfb957daa899ec83d1afb51f3e427e03911 Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Thu, 19 Sep 2024 18:06:19 +0200 Subject: [PATCH 24/25] add vstval2 --- csrs.csv | 1 + 1 file changed, 1 insertion(+) diff --git a/csrs.csv b/csrs.csv index e96d697c..5716c059 100644 --- a/csrs.csv +++ b/csrs.csv @@ -84,6 +84,7 @@ 0x242, "vscause" 0x243, "vstval" 0x244, "vsip" +0x24b, "vstval2" 0x24D, "vstimecmp" 0x24E, "vsctrctl" 0x250, "vsiselect" From 8b620fada476e7da0476a8db187218d3513cb36c Mon Sep 17 00:00:00 2001 From: Tariq Kurd Date: Fri, 4 Oct 2024 16:58:32 +0200 Subject: [PATCH 25/25] update MODESW --- unratified/rv64_cheri | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/unratified/rv64_cheri b/unratified/rv64_cheri index 30b7c478..1d0af714 100644 --- a/unratified/rv64_cheri +++ b/unratified/rv64_cheri @@ -31,10 +31,8 @@ gclen rd rs1 31..25=8 24..20=6 14..12=0 6..2=0x0C 1..0=3 cram rd rs1 31..25=8 24..20=7 14..12=0 6..2=0x0C 1..0=3 sentry rd rs1 31..25=8 24..20=8 14..12=0 6..2=0x0C 1..0=3 -modesw 31..25=9 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 - -#adjacent to c.not -c.modesw 15..13=4 12..10=7 9..7=0 6..5=3 4..2=7 1..0=1 +modesw.cap 31..25=9 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 +modesw.int 31..25=10 24..15=0 14..12=1 11..7=0 6..2=0x0C 1..0=3 #adjacent to sh[123]add sh4add rd rs1 rs2 31..25=16 14..12=7 6..2=0x0C 1..0=3