xref: /openbmc/qemu/target/riscv/insn16.decode (revision 92ec7805190313c9e628f8fc4eb4f932c15247bd)
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