1e98d9140SBastian Koppelmann# 2e98d9140SBastian Koppelmann# RISC-V translation routines for the RVXI Base Integer Instruction Set. 3e98d9140SBastian Koppelmann# 4e98d9140SBastian Koppelmann# Copyright (c) 2018 Peer Adelt, peer.adelt@hni.uni-paderborn.de 5e98d9140SBastian Koppelmann# Bastian Koppelmann, kbastian@mail.uni-paderborn.de 6e98d9140SBastian Koppelmann# 7e98d9140SBastian Koppelmann# This program is free software; you can redistribute it and/or modify it 8e98d9140SBastian Koppelmann# under the terms and conditions of the GNU General Public License, 9e98d9140SBastian Koppelmann# version 2 or later, as published by the Free Software Foundation. 10e98d9140SBastian Koppelmann# 11e98d9140SBastian Koppelmann# This program is distributed in the hope it will be useful, but WITHOUT 12e98d9140SBastian Koppelmann# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13e98d9140SBastian Koppelmann# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 14e98d9140SBastian Koppelmann# more details. 15e98d9140SBastian Koppelmann# 16e98d9140SBastian Koppelmann# You should have received a copy of the GNU General Public License along with 17e98d9140SBastian Koppelmann# this program. If not, see <http://www.gnu.org/licenses/>. 18e98d9140SBastian Koppelmann 19e98d9140SBastian Koppelmann# Fields: 20e98d9140SBastian Koppelmann%rd 7:5 21e98d9140SBastian Koppelmann%rs1_3 7:3 !function=ex_rvc_register 22e98d9140SBastian Koppelmann%rs2_3 2:3 !function=ex_rvc_register 2397b0be81SBastian Koppelmann%rs2_5 2:5 24193eb522SWeiwei Li%r1s 7:3 !function=ex_sreg_register 25193eb522SWeiwei Li%r2s 2:3 !function=ex_sreg_register 26e98d9140SBastian Koppelmann 27e98d9140SBastian Koppelmann# Immediates: 2807b001c6SBastian Koppelmann%imm_ci 12:s1 2:5 29e98d9140SBastian Koppelmann%nzuimm_ciw 7:4 11:2 5:1 6:1 !function=ex_shift_2 30a2f827ffSFrédéric Pétrot%uimm_cl_q 10:1 5:2 11:2 !function=ex_shift_4 31e98d9140SBastian Koppelmann%uimm_cl_d 5:2 10:3 !function=ex_shift_3 32e98d9140SBastian Koppelmann%uimm_cl_w 5:1 10:3 6:1 !function=ex_shift_2 3307b001c6SBastian Koppelmann%imm_cb 12:s1 5:2 2:1 10:2 3:2 !function=ex_shift_1 3407b001c6SBastian Koppelmann%imm_cj 12:s1 8:1 9:2 6:1 7:1 2:1 11:1 3:3 !function=ex_shift_1 3507b001c6SBastian Koppelmann 3633632775SFrédéric Pétrot%shlimm_6bit 12:1 2:5 !function=ex_rvc_shiftli 3733632775SFrédéric Pétrot%shrimm_6bit 12:1 2:5 !function=ex_rvc_shiftri 38a2f827ffSFrédéric Pétrot%uimm_6bit_lq 2:4 12:1 6:1 !function=ex_shift_4 3997b0be81SBastian Koppelmann%uimm_6bit_ld 2:3 12:1 5:2 !function=ex_shift_3 4097b0be81SBastian Koppelmann%uimm_6bit_lw 2:2 12:1 4:3 !function=ex_shift_2 41a2f827ffSFrédéric Pétrot%uimm_6bit_sq 7:4 11:2 !function=ex_shift_4 4297b0be81SBastian Koppelmann%uimm_6bit_sd 7:3 10:3 !function=ex_shift_3 4397b0be81SBastian Koppelmann%uimm_6bit_sw 7:2 9:4 !function=ex_shift_2 4407b001c6SBastian Koppelmann 4507b001c6SBastian Koppelmann%imm_addi16sp 12:s1 3:2 5:1 2:1 6:1 !function=ex_shift_4 4607b001c6SBastian Koppelmann%imm_lui 12:s1 2:5 !function=ex_shift_12 4707b001c6SBastian Koppelmann 48e0a3054fSWeiwei Li%uimm_cl_b 5:1 6:1 49e0a3054fSWeiwei Li%uimm_cl_h 5:1 !function=ex_shift_1 50193eb522SWeiwei Li%spimm 2:2 !function=ex_shift_4 51193eb522SWeiwei Li%urlist 4:4 52ce3af0bbSWeiwei Li%index 2:8 53e98d9140SBastian Koppelmann 54e1d455ddSRichard Henderson# Argument sets imported from insn32.decode: 55e1d455ddSRichard Henderson&empty !extern 56e1d455ddSRichard Henderson&r rd rs1 rs2 !extern 57e1d455ddSRichard Henderson&i imm rs1 rd !extern 58e1d455ddSRichard Henderson&s imm rs1 rs2 !extern 59e1d455ddSRichard Henderson&j imm rd !extern 60e1d455ddSRichard Henderson&b imm rs2 rs1 !extern 61e1d455ddSRichard Henderson&u imm rd !extern 62e1d455ddSRichard Henderson&shift shamt rs1 rd !extern 63e0a3054fSWeiwei Li&r2 rd rs1 !extern 64193eb522SWeiwei Li&r2_s rs1 rs2 !extern 65e98d9140SBastian Koppelmann 66193eb522SWeiwei Li&cmpp urlist spimm 67ce3af0bbSWeiwei Li&cmjt index 6807b001c6SBastian Koppelmann 69e98d9140SBastian Koppelmann# Formats 16: 70e1d455ddSRichard Henderson@cr .... ..... ..... .. &r rs2=%rs2_5 rs1=%rd %rd 71e1d455ddSRichard Henderson@ci ... . ..... ..... .. &i imm=%imm_ci rs1=%rd %rd 72a2f827ffSFrédéric Pétrot@cl_q ... . ..... ..... .. &i imm=%uimm_cl_q rs1=%rs1_3 rd=%rs2_3 73e1d455ddSRichard Henderson@cl_d ... ... ... .. ... .. &i imm=%uimm_cl_d rs1=%rs1_3 rd=%rs2_3 74e1d455ddSRichard Henderson@cl_w ... ... ... .. ... .. &i imm=%uimm_cl_w rs1=%rs1_3 rd=%rs2_3 75e1d455ddSRichard Henderson@cs_2 ... ... ... .. ... .. &r rs2=%rs2_3 rs1=%rs1_3 rd=%rs1_3 76a2f827ffSFrédéric Pétrot@cs_q ... ... ... .. ... .. &s imm=%uimm_cl_q rs1=%rs1_3 rs2=%rs2_3 77e1d455ddSRichard Henderson@cs_d ... ... ... .. ... .. &s imm=%uimm_cl_d rs1=%rs1_3 rs2=%rs2_3 78e1d455ddSRichard Henderson@cs_w ... ... ... .. ... .. &s imm=%uimm_cl_w rs1=%rs1_3 rs2=%rs2_3 79e1d455ddSRichard Henderson@cj ... ........... .. &j imm=%imm_cj 80e1d455ddSRichard Henderson@cb_z ... ... ... .. ... .. &b imm=%imm_cb rs1=%rs1_3 rs2=0 81e98d9140SBastian Koppelmann 82a2f827ffSFrédéric Pétrot@c_lqsp ... . ..... ..... .. &i imm=%uimm_6bit_lq rs1=2 %rd 83e1d455ddSRichard Henderson@c_ldsp ... . ..... ..... .. &i imm=%uimm_6bit_ld rs1=2 %rd 84e1d455ddSRichard Henderson@c_lwsp ... . ..... ..... .. &i imm=%uimm_6bit_lw rs1=2 %rd 85a2f827ffSFrédéric Pétrot@c_sqsp ... . ..... ..... .. &s imm=%uimm_6bit_sq rs1=2 rs2=%rs2_5 86e1d455ddSRichard Henderson@c_sdsp ... . ..... ..... .. &s imm=%uimm_6bit_sd rs1=2 rs2=%rs2_5 87e1d455ddSRichard Henderson@c_swsp ... . ..... ..... .. &s imm=%uimm_6bit_sw rs1=2 rs2=%rs2_5 88e1d455ddSRichard Henderson@c_li ... . ..... ..... .. &i imm=%imm_ci rs1=0 %rd 89c2cfb97cSRichard Henderson@c_lui ... . ..... ..... .. &u imm=%imm_lui %rd 90c2cfb97cSRichard Henderson@c_jalr ... . ..... ..... .. &i imm=0 rs1=%rd 91c2cfb97cSRichard Henderson@c_mv ... . ..... ..... .. &i imm=0 rs1=%rs2_5 %rd 9297b0be81SBastian Koppelmann 93c2cfb97cSRichard Henderson@c_addi4spn ... . ..... ..... .. &i imm=%nzuimm_ciw rs1=2 rd=%rs2_3 94c2cfb97cSRichard Henderson@c_addi16sp ... . ..... ..... .. &i imm=%imm_addi16sp rs1=2 rd=2 9507b001c6SBastian Koppelmann 96e1d455ddSRichard Henderson@c_shift ... . .. ... ..... .. \ 9733632775SFrédéric Pétrot &shift rd=%rs1_3 rs1=%rs1_3 shamt=%shrimm_6bit 98e1d455ddSRichard Henderson@c_shift2 ... . .. ... ..... .. \ 9933632775SFrédéric Pétrot &shift rd=%rd rs1=%rd shamt=%shlimm_6bit 10007b001c6SBastian Koppelmann 101e1d455ddSRichard Henderson@c_andi ... . .. ... ..... .. &i imm=%imm_ci rs1=%rs1_3 rd=%rs1_3 102e98d9140SBastian Koppelmann 103e0a3054fSWeiwei Li@cu ... ... ... .. ... .. &r2 rs1=%rs1_3 rd=%rs1_3 104e0a3054fSWeiwei Li@cl_b ... . .. ... .. ... .. &i imm=%uimm_cl_b rs1=%rs1_3 rd=%rs2_3 105e0a3054fSWeiwei Li@cl_h ... . .. ... .. ... .. &i imm=%uimm_cl_h rs1=%rs1_3 rd=%rs2_3 106e0a3054fSWeiwei Li@cs_b ... . .. ... .. ... .. &s imm=%uimm_cl_b rs1=%rs1_3 rs2=%rs2_3 107e0a3054fSWeiwei Li@cs_h ... . .. ... .. ... .. &s imm=%uimm_cl_h rs1=%rs1_3 rs2=%rs2_3 108193eb522SWeiwei Li@cm_pp ... ... ........ .. &cmpp %urlist %spimm 109193eb522SWeiwei Li@cm_mv ... ... ... .. ... .. &r2_s rs2=%r2s rs1=%r1s 110ce3af0bbSWeiwei Li@cm_jt ... ... ........ .. &cmjt %index 111e0a3054fSWeiwei Li 1120e68e240SRichard Henderson# *** RV32/64C Standard Extension (Quadrant 0) *** 113c2cfb97cSRichard Henderson{ 114c2cfb97cSRichard Henderson # Opcode of all zeros is illegal; rd != 0, nzuimm == 0 is reserved. 115c2cfb97cSRichard Henderson illegal 000 000 000 00 --- 00 116c2cfb97cSRichard Henderson addi 000 ... ... .. ... 00 @c_addi4spn 117c2cfb97cSRichard Henderson} 118a2f827ffSFrédéric Pétrot{ 119a2f827ffSFrédéric Pétrot lq 001 ... ... .. ... 00 @cl_q 120c4935b58SWeiwei Li c_fld 001 ... ... .. ... 00 @cl_d 121a2f827ffSFrédéric Pétrot} 122e1d455ddSRichard Hendersonlw 010 ... ... .. ... 00 @cl_w 123a2f827ffSFrédéric Pétrot{ 124a2f827ffSFrédéric Pétrot sq 101 ... ... .. ... 00 @cs_q 125c4935b58SWeiwei Li c_fsd 101 ... ... .. ... 00 @cs_d 126a2f827ffSFrédéric Pétrot} 127e1d455ddSRichard Hendersonsw 110 ... ... .. ... 00 @cs_w 12807b001c6SBastian Koppelmann 1296baba30aSAlistair Francis# *** RV32C and RV64C specific Standard Extension (Quadrant 0) *** 1306baba30aSAlistair Francis{ 1316baba30aSAlistair Francis ld 011 ... ... .. ... 00 @cl_d 13230b03579SWeiwei Li c_flw 011 ... ... .. ... 00 @cl_w 1336baba30aSAlistair Francis} 1346baba30aSAlistair Francis{ 1356baba30aSAlistair Francis sd 111 ... ... .. ... 00 @cs_d 13630b03579SWeiwei Li c_fsw 111 ... ... .. ... 00 @cs_w 1376baba30aSAlistair Francis} 1386baba30aSAlistair Francis 1390e68e240SRichard Henderson# *** RV32/64C Standard Extension (Quadrant 1) *** 140e1d455ddSRichard Hendersonaddi 000 . ..... ..... 01 @ci 141e1d455ddSRichard Hendersonaddi 010 . ..... ..... 01 @c_li 142c2cfb97cSRichard Henderson{ 143*905c0324SDeepak Gupta # c.sspush x1 carving out of zcmops 144*905c0324SDeepak Gupta sspush 011 0 00001 00000 01 &r2_s rs2=1 rs1=0 145*905c0324SDeepak Gupta # c.sspopchk x5 carving out of zcmops 146*905c0324SDeepak Gupta sspopchk 011 0 00101 00000 01 &r2 rs1=5 rd=0 147197e4d29SLIU Zhiwei c_mop_n 011 0 0 n:3 1 00000 01 1484cc16b3bSRichard Henderson illegal 011 0 ----- 00000 01 # c.addi16sp and c.lui, RES nzimm=0 149c2cfb97cSRichard Henderson addi 011 . 00010 ..... 01 @c_addi16sp 150c2cfb97cSRichard Henderson lui 011 . ..... ..... 01 @c_lui 151c2cfb97cSRichard Henderson} 1526cafec92SRichard Hendersonsrli 100 . 00 ... ..... 01 @c_shift 1536cafec92SRichard Hendersonsrai 100 . 01 ... ..... 01 @c_shift 154e1d455ddSRichard Hendersonandi 100 . 10 ... ..... 01 @c_andi 155e1d455ddSRichard Hendersonsub 100 0 11 ... 00 ... 01 @cs_2 156e1d455ddSRichard Hendersonxor 100 0 11 ... 01 ... 01 @cs_2 157e1d455ddSRichard Hendersonor 100 0 11 ... 10 ... 01 @cs_2 158e1d455ddSRichard Hendersonand 100 0 11 ... 11 ... 01 @cs_2 159e1d455ddSRichard Hendersonjal 101 ........... 01 @cj rd=0 # C.J 160e1d455ddSRichard Hendersonbeq 110 ... ... ..... 01 @cb_z 161e1d455ddSRichard Hendersonbne 111 ... ... ..... 01 @cb_z 16297b0be81SBastian Koppelmann 1636baba30aSAlistair Francis# *** RV64C and RV32C specific Standard Extension (Quadrant 1) *** 1646baba30aSAlistair Francis{ 1656baba30aSAlistair Francis c64_illegal 001 - 00000 ----- 01 # c.addiw, RES rd=0 1666baba30aSAlistair Francis addiw 001 . ..... ..... 01 @ci 1676baba30aSAlistair Francis jal 001 ........... 01 @cj rd=1 # C.JAL 1686baba30aSAlistair Francis} 1696baba30aSAlistair Francissubw 100 1 11 ... 00 ... 01 @cs_2 1706baba30aSAlistair Francisaddw 100 1 11 ... 01 ... 01 @cs_2 1716baba30aSAlistair Francis 1720e68e240SRichard Henderson# *** RV32/64C Standard Extension (Quadrant 2) *** 1736cafec92SRichard Hendersonslli 000 . ..... ..... 10 @c_shift2 174a2f827ffSFrédéric Pétrot{ 175a2f827ffSFrédéric Pétrot lq 001 ... ... .. ... 10 @c_lqsp 176c4935b58SWeiwei Li c_fld 001 . ..... ..... 10 @c_ldsp 177a2f827ffSFrédéric Pétrot} 178c2cfb97cSRichard Henderson{ 1794cc16b3bSRichard Henderson illegal 010 - 00000 ----- 10 # c.lwsp, RES rd=0 1804cc16b3bSRichard Henderson lw 010 . ..... ..... 10 @c_lwsp 1814cc16b3bSRichard Henderson} 1824cc16b3bSRichard Henderson{ 1834cc16b3bSRichard Henderson illegal 100 0 00000 00000 10 # c.jr, RES rs1=0 184c2cfb97cSRichard Henderson jalr 100 0 ..... 00000 10 @c_jalr rd=0 # C.JR 185c2cfb97cSRichard Henderson addi 100 0 ..... ..... 10 @c_mv 186c2cfb97cSRichard Henderson} 187c2cfb97cSRichard Henderson{ 188c2cfb97cSRichard Henderson ebreak 100 1 00000 00000 10 189c2cfb97cSRichard Henderson jalr 100 1 ..... 00000 10 @c_jalr rd=1 # C.JALR 190c2cfb97cSRichard Henderson add 100 1 ..... ..... 10 @cr 191c2cfb97cSRichard Henderson} 192a2f827ffSFrédéric Pétrot{ 193a2f827ffSFrédéric Pétrot sq 101 ... ... .. ... 10 @c_sqsp 194c4935b58SWeiwei Li c_fsd 101 ...... ..... 10 @c_sdsp 195193eb522SWeiwei Li 196ce3af0bbSWeiwei Li # *** RV64 and RV32 Zcmp/Zcmt Extension *** 197193eb522SWeiwei Li [ 198193eb522SWeiwei Li cm_push 101 11000 .... .. 10 @cm_pp 199193eb522SWeiwei Li cm_pop 101 11010 .... .. 10 @cm_pp 200193eb522SWeiwei Li cm_popret 101 11110 .... .. 10 @cm_pp 201193eb522SWeiwei Li cm_popretz 101 11100 .... .. 10 @cm_pp 202193eb522SWeiwei Li cm_mva01s 101 011 ... 11 ... 10 @cm_mv 203193eb522SWeiwei Li cm_mvsa01 101 011 ... 01 ... 10 @cm_mv 204ce3af0bbSWeiwei Li 205ce3af0bbSWeiwei Li cm_jalt 101 000 ........ 10 @cm_jt 206193eb522SWeiwei Li ] 207a2f827ffSFrédéric Pétrot} 208e1d455ddSRichard Hendersonsw 110 . ..... ..... 10 @c_swsp 2096baba30aSAlistair Francis 2106baba30aSAlistair Francis# *** RV32C and RV64C specific Standard Extension (Quadrant 2) *** 2116baba30aSAlistair Francis{ 2126baba30aSAlistair Francis c64_illegal 011 - 00000 ----- 10 # c.ldsp, RES rd=0 2136baba30aSAlistair Francis ld 011 . ..... ..... 10 @c_ldsp 21430b03579SWeiwei Li c_flw 011 . ..... ..... 10 @c_lwsp 2156baba30aSAlistair Francis} 2166baba30aSAlistair Francis{ 2176baba30aSAlistair Francis sd 111 . ..... ..... 10 @c_sdsp 21830b03579SWeiwei Li c_fsw 111 . ..... ..... 10 @c_swsp 2196baba30aSAlistair Francis} 220e0a3054fSWeiwei Li 221e0a3054fSWeiwei Li# *** RV64 and RV32 Zcb Extension *** 222e0a3054fSWeiwei Lic_zext_b 100 111 ... 11 000 01 @cu 223e0a3054fSWeiwei Lic_sext_b 100 111 ... 11 001 01 @cu 224e0a3054fSWeiwei Lic_zext_h 100 111 ... 11 010 01 @cu 225e0a3054fSWeiwei Lic_sext_h 100 111 ... 11 011 01 @cu 226e0a3054fSWeiwei Lic_zext_w 100 111 ... 11 100 01 @cu 227e0a3054fSWeiwei Lic_not 100 111 ... 11 101 01 @cu 228e0a3054fSWeiwei Lic_mul 100 111 ... 10 ... 01 @cs_2 229e0a3054fSWeiwei Lic_lbu 100 000 ... .. ... 00 @cl_b 230e0a3054fSWeiwei Lic_lhu 100 001 ... 0. ... 00 @cl_h 231e0a3054fSWeiwei Lic_lh 100 001 ... 1. ... 00 @cl_h 232e0a3054fSWeiwei Lic_sb 100 010 ... .. ... 00 @cs_b 233e0a3054fSWeiwei Lic_sh 100 011 ... 0. ... 00 @cs_h 234