aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChun-Ping Chung <cpchung@pllab.cs.nthu.edu.tw>2020-11-18 14:42:30 +0800
committerAndrew Waterman <andrew@sifive.com>2021-07-28 15:13:21 -0700
commit971ff5d2486ba2678593fef3d66a644ea00f41fe (patch)
treef9a62ae24d6618ffab536d323fc7d6b55cbbcfe5
parent4b58dfb4860f1af5a21052e7128755de09ecdb9b (diff)
downloadriscv-opcodes-971ff5d2486ba2678593fef3d66a644ea00f41fe.zip
riscv-opcodes-971ff5d2486ba2678593fef3d66a644ea00f41fe.tar.gz
riscv-opcodes-971ff5d2486ba2678593fef3d66a644ea00f41fe.tar.bz2
RVP: v0.5.2 support
-rw-r--r--Makefile2
-rw-r--r--opcodes-rvp329
-rwxr-xr-xparse_opcodes9
3 files changed, 339 insertions, 1 deletions
diff --git a/Makefile b/Makefile
index acbdb71..887b3d7 100644
--- a/Makefile
+++ b/Makefile
@@ -6,7 +6,7 @@ ENV_H := ../riscv-tests/env/encoding.h
OPENOCD_H := ../riscv-openocd/src/target/riscv/encoding.h
ALL_REAL_ILEN32_OPCODES := opcodes-rv32i opcodes-rv64i opcodes-rv32m opcodes-rv64m opcodes-rv32a opcodes-rv64a opcodes-rv32h opcodes-rv64h opcodes-rv32f opcodes-rv64f opcodes-rv32d opcodes-rv64d opcodes-rv32q opcodes-rv64q opcodes-rv32b opcodes-rv64b opcodes-system opcodes-svinval opcodes-rv32zfh opcodes-rv32d-zfh opcodes-rv32q-zfh opcodes-rv64zfh opcodes-rvk opcodes-rv32k opcodes-rv64k
-ALL_REAL_OPCODES := $(ALL_REAL_ILEN32_OPCODES) opcodes-rvc opcodes-rv32c opcodes-rv64c opcodes-custom opcodes-rvv
+ALL_REAL_OPCODES := $(ALL_REAL_ILEN32_OPCODES) opcodes-rvc opcodes-rv32c opcodes-rv64c opcodes-custom opcodes-rvv opcodes-rvp
ALL_OPCODES := opcodes-pseudo $(ALL_REAL_OPCODES) opcodes-rvv-pseudo
diff --git a/opcodes-rvp b/opcodes-rvp
new file mode 100644
index 0000000..f301433
--- /dev/null
+++ b/opcodes-rvp
@@ -0,0 +1,329 @@
+add8 31..25=0b0100100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+add16 31..25=0b0100000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+add64 31..25=0b1100000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ave 31..25=0b1110000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+bitrev 31..25=0b1110011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+bitrevi 31..26=0b111010 imm6 rs1 14..12=0b000 rd 6..0=0b1111111
+bpick 31..30=0b11 rc rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+clrov 31..20=0b100000000001 19..15=0b00001 14..12=0b111 rd 6..0=0b1110011
+clrs8 31..25=0b1010111 24..20=0b00000 rs1 14..12=0b000 rd 6..0=0b1111111
+clrs16 31..25=0b1010111 24..20=0b01000 rs1 14..12=0b000 rd 6..0=0b1111111
+clrs32 31..25=0b1010111 24..20=0b11000 rs1 14..12=0b000 rd 6..0=0b1111111
+clo8 31..25=0b1010111 24..20=0b00011 rs1 14..12=0b000 rd 6..0=0b1111111
+clo16 31..25=0b1010111 24..20=0b01011 rs1 14..12=0b000 rd 6..0=0b1111111
+clo32 31..25=0b1010111 24..20=0b11011 rs1 14..12=0b000 rd 6..0=0b1111111
+clz8 31..25=0b1010111 24..20=0b00001 rs1 14..12=0b000 rd 6..0=0b1111111
+clz16 31..25=0b1010111 24..20=0b01001 rs1 14..12=0b000 rd 6..0=0b1111111
+clz32 31..25=0b1010111 24..20=0b11001 rs1 14..12=0b000 rd 6..0=0b1111111
+cmpeq8 31..25=0b0100111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+cmpeq16 31..25=0b0100110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+cras16 31..25=0b0100010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+crsa16 31..25=0b0100011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+insb 31..25=0b1010110 24..23=0b00 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+kabs8 31..25=0b1010110 24..20=0b10000 rs1 14..12=0b000 rd 6..0=0b1111111
+kabs16 31..25=0b1010110 24..20=0b10001 rs1 14..12=0b000 rd 6..0=0b1111111
+kabsw 31..25=0b1010110 24..20=0b10100 rs1 14..12=0b000 rd 6..0=0b1111111
+kadd8 31..25=0b0001100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kadd16 31..25=0b0001000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kadd64 31..25=0b1001000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kaddh 31..25=0b0000010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kaddw 31..25=0b0000000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kcras16 31..25=0b0001010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kcrsa16 31..25=0b0001011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kdmbb 31..25=0b0000101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmbt 31..25=0b0001101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmtt 31..25=0b0010101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmabb 31..25=0b1101001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmabt 31..25=0b1110001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmatt 31..25=0b1111001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+khm8 31..25=0b1000111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+khmx8 31..25=0b1001111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+khm16 31..25=0b1000011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+khmx16 31..25=0b1001011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+khmbb 31..25=0b0000110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+khmbt 31..25=0b0001110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+khmtt 31..25=0b0010110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmabb 31..25=0b0101101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmabt 31..25=0b0110101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmatt 31..25=0b0111101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmada 31..25=0b0100100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmaxda 31..25=0b0100101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmads 31..25=0b0101110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmadrs 31..25=0b0110110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmaxds 31..25=0b0111110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmar64 31..25=0b1001010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmda 31..25=0b0011100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmxda 31..25=0b0011101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmac 31..25=0b0110000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmac.u 31..25=0b0111000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawb 31..25=0b0100011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawb.u 31..25=0b0101011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawb2 31..25=0b1100111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawb2.u 31..25=0b1101111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawt 31..25=0b0110011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawt.u 31..25=0b0111011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawt2 31..25=0b1110111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmawt2.u 31..25=0b1111111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmsb 31..25=0b0100001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmsb.u 31..25=0b0101001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmwb2 31..25=0b1000111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmwb2.u 31..25=0b1001111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmwt2 31..25=0b1010111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmmwt2.u 31..25=0b1011111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmsda 31..25=0b0100110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmsxda 31..25=0b0100111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmsr64 31..25=0b1001011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ksllw 31..25=0b0010011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kslliw 31..25=0b0011011 imm5 rs1 14..12=0b001 rd 6..0=0b1111111
+ksll8 31..25=0b0110110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kslli8 31..25=0b0111110 24..23=0b01 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+ksll16 31..25=0b0110010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kslli16 31..25=0b0111010 24=0b1 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+kslra8 31..25=0b0101111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kslra8.u 31..25=0b0110111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kslra16 31..25=0b0101011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kslra16.u 31..25=0b0110011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+kslraw 31..25=0b0110111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kslraw.u 31..25=0b0111111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kstas16 31..25=0b0001010 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+kstsa16 31..25=0b0001011 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+ksub8 31..25=0b0001101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ksub16 31..25=0b0001001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ksub64 31..25=0b1001001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ksubh 31..25=0b0000011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ksubw 31..25=0b0000001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kwmmul 31..25=0b0110001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kwmmul.u 31..25=0b0111001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+maddr32 31..25=0b1100010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+maxw 31..25=0b1111001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+minw 31..25=0b1111000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+msubr32 31..25=0b1100011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+mulr64 31..25=0b1111000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+mulsr64 31..25=0b1110000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+pbsad 31..25=0b1111110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+pbsada 31..25=0b1111111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+pkbb16 31..25=0b0000111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+pkbt16 31..25=0b0001111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+pktt16 31..25=0b0010111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+pktb16 31..25=0b0011111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+radd8 31..25=0b0000100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+radd16 31..25=0b0000000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+radd64 31..25=0b1000000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+raddw 31..25=0b0010000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+rcras16 31..25=0b0000010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+rcrsa16 31..25=0b0000011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+rdov 31..20=0b100000000001 19..15=0b00000 14..12=0b010 rd 6..0=0b1110011
+rstas16 31..25=0b0000010 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+rstsa16 31..25=0b0000011 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+rsub8 31..25=0b0000101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+rsub16 31..25=0b0000001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+rsub64 31..25=0b1000001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+rsubw 31..25=0b0010001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+sclip8 31..25=0b1000110 24..23=0b00 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+sclip16 31..25=0b1000010 24=0b0 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+sclip32 31..25=0b1110010 imm5 rs1 14..12=0b000 rd 6..0=0b1111111
+scmple8 31..25=0b0001111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+scmple16 31..25=0b0001110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+scmplt8 31..25=0b0000111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+scmplt16 31..25=0b0000110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+sll8 31..25=0b0101110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+slli8 31..25=0b0111110 24..23=0b00 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+sll16 31..25=0b0101010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+slli16 31..25=0b0111010 24=0b0 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+smal 31..25=0b0101111 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smalbb 31..25=0b1000100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smalbt 31..25=0b1001100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smaltt 31..25=0b1010100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smalda 31..25=0b1000110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smalxda 31..25=0b1001110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smalds 31..25=0b1000101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smaldrs 31..25=0b1001101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smalxds 31..25=0b1010101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smar64 31..25=0b1000010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smaqa 31..25=0b1100100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smaqa.su 31..25=0b1100101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smax8 31..25=0b1000101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smax16 31..25=0b1000001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smbb16 31..25=0b0000100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smbt16 31..25=0b0001100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smtt16 31..25=0b0010100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smds 31..25=0b0101100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smdrs 31..25=0b0110100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smxds 31..25=0b0111100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smin8 31..25=0b1000100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smin16 31..25=0b1000000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smmul 31..25=0b0100000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smmul.u 31..25=0b0101000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smmwb 31..25=0b0100010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smmwb.u 31..25=0b0101010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smmwt 31..25=0b0110010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smmwt.u 31..25=0b0111010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smslda 31..25=0b1010110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smslxda 31..25=0b1011110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smsr64 31..25=0b1000011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+smul8 31..25=0b1010100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smulx8 31..25=0b1010101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smul16 31..25=0b1010000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+smulx16 31..25=0b1010001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+sra.u 31..25=0b0010010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+srai.u 31..26=0b110101 imm6 rs1 14..12=0b001 rd 6..0=0b1111111
+sra8 31..25=0b0101100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+sra8.u 31..25=0b0110100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+srai8 31..25=0b0111100 24..23=0b00 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+srai8.u 31..25=0b0111100 24..23=0b01 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+sra16 31..25=0b0101000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+sra16.u 31..25=0b0110000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+srai16 31..25=0b0111000 24=0b0 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+srai16.u 31..25=0b0111000 24=0b1 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+srl8 31..25=0b0101101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+srl8.u 31..25=0b0110101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+srli8 31..25=0b0111101 24..23=0b00 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+srli8.u 31..25=0b0111101 24..23=0b01 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+srl16 31..25=0b0101001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+srl16.u 31..25=0b0110001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+srli16 31..25=0b0111001 24=0b0 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+srli16.u 31..25=0b0111001 24=0b1 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+stas16 31..25=0b0100010 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+stsa16 31..25=0b0100011 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+sub8 31..25=0b0100101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+sub16 31..25=0b0100001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+sub64 31..25=0b1100001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+sunpkd810 31..25=0b1010110 24..20=0b01000 rs1 14..12=0b000 rd 6..0=0b1111111
+sunpkd820 31..25=0b1010110 24..20=0b01001 rs1 14..12=0b000 rd 6..0=0b1111111
+sunpkd830 31..25=0b1010110 24..20=0b01010 rs1 14..12=0b000 rd 6..0=0b1111111
+sunpkd831 31..25=0b1010110 24..20=0b01011 rs1 14..12=0b000 rd 6..0=0b1111111
+sunpkd832 31..25=0b1010110 24..20=0b10011 rs1 14..12=0b000 rd 6..0=0b1111111
+swap8 31..25=0b1010110 24..20=0b11000 rs1 14..12=0b000 rd 6..0=0b1111111
+swap16 31..25=0b1010110 24..20=0b11001 rs1 14..12=0b000 rd 6..0=0b1111111
+uclip8 31..25=0b1000110 24..23=0b10 imm3 rs1 14..12=0b000 rd 6..0=0b1111111
+uclip16 31..25=0b1000010 24=0b1 imm4 rs1 14..12=0b000 rd 6..0=0b1111111
+uclip32 31..25=0b1111010 imm5 rs1 14..12=0b000 rd 6..0=0b1111111
+ucmple8 31..25=0b0011111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ucmple16 31..25=0b0011110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ucmplt8 31..25=0b0010111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ucmplt16 31..25=0b0010110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ukadd8 31..25=0b0011100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ukadd16 31..25=0b0011000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ukadd64 31..25=0b1011000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ukaddh 31..25=0b0001010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ukaddw 31..25=0b0001000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ukcras16 31..25=0b0011010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ukcrsa16 31..25=0b0011011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ukmar64 31..25=0b1011010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ukmsr64 31..25=0b1011011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ukstas16 31..25=0b0011010 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+ukstsa16 31..25=0b0011011 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+uksub8 31..25=0b0011101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+uksub16 31..25=0b0011001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+uksub64 31..25=0b1011001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+uksubh 31..25=0b0001011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+uksubw 31..25=0b0001001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+umar64 31..25=0b1010010 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+umaqa 31..25=0b1100110 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umax8 31..25=0b1001101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umax16 31..25=0b1001001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umin8 31..25=0b1001100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umin16 31..25=0b1001000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umsr64 31..25=0b1010011 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+umul8 31..25=0b1011100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umulx8 31..25=0b1011101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umul16 31..25=0b1011000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+umulx16 31..25=0b1011001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+uradd8 31..25=0b0010100 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+uradd16 31..25=0b0010000 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+uradd64 31..25=0b1010000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+uraddw 31..25=0b0011000 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+urcras16 31..25=0b0010010 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+urcrsa16 31..25=0b0010011 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+urstas16 31..25=0b0010010 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+urstsa16 31..25=0b0010011 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+ursub8 31..25=0b0010101 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ursub16 31..25=0b0010001 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+ursub64 31..25=0b1010001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+ursubw 31..25=0b0011001 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+wexti 31..25=0b1101111 imm5 rs1 14..12=0b000 rd 6..0=0b1111111
+wext 31..25=0b1100111 rs2 rs1 14..12=0b000 rd 6..0=0b1111111
+zunpkd810 31..25=0b1010110 24..20=0b01100 rs1 14..12=0b000 rd 6..0=0b1111111
+zunpkd820 31..25=0b1010110 24..20=0b01101 rs1 14..12=0b000 rd 6..0=0b1111111
+zunpkd830 31..25=0b1010110 24..20=0b01110 rs1 14..12=0b000 rd 6..0=0b1111111
+zunpkd831 31..25=0b1010110 24..20=0b01111 rs1 14..12=0b000 rd 6..0=0b1111111
+zunpkd832 31..25=0b1010110 24..20=0b10111 rs1 14..12=0b000 rd 6..0=0b1111111
+add32 31..25=0b0100000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+cras32 31..25=0b0100010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+crsa32 31..25=0b0100011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kabs32 31..25=0b1010110 24..20=0b10010 rs1 14..12=0b000 rd 6..0=0b1111111
+kadd32 31..25=0b0001000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kcras32 31..25=0b0001010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kcrsa32 31..25=0b0001011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kdmbb16 31..25=0b1101101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmbt16 31..25=0b1110101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmtt16 31..25=0b1111101 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmabb16 31..25=0b1101100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmabt16 31..25=0b1110100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kdmatt16 31..25=0b1111100 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+khmbb16 31..25=0b1101110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+khmbt16 31..25=0b1110110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+khmtt16 31..25=0b1111110 rs2 rs1 14..12=0b001 rd 6..0=0b1111111
+kmabb32 31..25=0b0101101 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmabt32 31..25=0b0110101 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmatt32 31..25=0b0111101 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmaxda32 31..25=0b0100101 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmda32 31..25=0b0011100 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmxda32 31..25=0b0011101 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmads32 31..25=0b0101110 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmadrs32 31..25=0b0110110 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmaxds32 31..25=0b0111110 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmsda32 31..25=0b0100110 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kmsxda32 31..25=0b0100111 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+ksll32 31..25=0b0110010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kslli32 31..25=0b1000010 imm5 rs1 14..12=0b010 rd 6..0=0b1111111
+kslra32 31..25=0b0101011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kslra32.u 31..25=0b0110011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+kstas32 31..25=0b0001000 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+kstsa32 31..25=0b0001001 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+ksub32 31..25=0b0001001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+pkbb32 31..25=0b0000111 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+pkbt32 31..25=0b0001111 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+pktt32 31..25=0b0010111 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+pktb32 31..25=0b0011111 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+radd32 31..25=0b0000000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+rcras32 31..25=0b0000010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+rcrsa32 31..25=0b0000011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+rstas32 31..25=0b0000000 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+rstsa32 31..25=0b0000001 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+rsub32 31..25=0b0000001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+sll32 31..25=0b0101010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+slli32 31..25=0b0111010 imm5 rs1 14..12=0b010 rd 6..0=0b1111111
+smax32 31..25=0b1001001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+smbt32 31..25=0b0001100 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+smtt32 31..25=0b0010100 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+smds32 31..25=0b0101100 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+smdrs32 31..25=0b0110100 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+smxds32 31..25=0b0111100 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+smin32 31..25=0b1001000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+sra32 31..25=0b0101000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+sra32.u 31..25=0b0110000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+srai32 31..25=0b0111000 imm5 rs1 14..12=0b010 rd 6..0=0b1111111
+srai32.u 31..25=0b1000000 imm5 rs1 14..12=0b010 rd 6..0=0b1111111
+sraiw.u 31..25=0b0011010 imm5 rs1 14..12=0b001 rd 6..0=0b1111111
+srl32 31..25=0b0101001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+srl32.u 31..25=0b0110001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+srli32 31..25=0b0111001 imm5 rs1 14..12=0b010 rd 6..0=0b1111111
+srli32.u 31..25=0b1000001 imm5 rs1 14..12=0b010 rd 6..0=0b1111111
+stas32 31..25=0b0100000 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+stsa32 31..25=0b0100001 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+sub32 31..25=0b0100001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+ukadd32 31..25=0b0011000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+ukcras32 31..25=0b0011010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+ukcrsa32 31..25=0b0011011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+ukstas32 31..25=0b0011000 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+ukstsa32 31..25=0b0011001 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+uksub32 31..25=0b0011001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+umax32 31..25=0b1010001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+umin32 31..25=0b1010000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+uradd32 31..25=0b0010000 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+urcras32 31..25=0b0010010 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+urcrsa32 31..25=0b0010011 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
+urstas32 31..25=0b0010000 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+urstsa32 31..25=0b0010001 rs2 rs1 14..12=0b011 rd 6..0=0b1111111
+ursub32 31..25=0b0010001 rs2 rs1 14..12=0b010 rd 6..0=0b1111111
diff --git a/parse_opcodes b/parse_opcodes
index 7bb5c3a..905bc32 100755
--- a/parse_opcodes
+++ b/parse_opcodes
@@ -38,6 +38,12 @@ arglut['shamt'] = (25,20)
arglut['shamtw'] = (24,20)
arglut['bs'] = (31,30) # byte select for RV32K AES
arglut['rnum'] = (23,20) # round constant for RV64 AES
+arglut['rc'] = (29,25)
+arglut['imm2'] = (21,20)
+arglut['imm3'] = (22,20)
+arglut['imm4'] = (23,20)
+arglut['imm5'] = (24,20)
+arglut['imm6'] = (25,20)
# for vectors
arglut['vd'] = (11,7)
@@ -294,6 +300,9 @@ csrs = [
(0x33D, 'mhpmevent29'),
(0x33E, 'mhpmevent30'),
(0x33F, 'mhpmevent31'),
+
+ # rvp
+ (0x801, 'ucode'),
# Standard Machine RO
(0xF11, 'mvendorid'),