xref: /openbmc/qemu/target/ppc/insn32.decode (revision 9c372ecfec5bd00f7ef5b6b2e9db9c2c859b408b)
1#
2# Power ISA decode for 32-bit insns (opcode space 0)
3#
4# Copyright (c) 2021 Instituto de Pesquisas Eldorado (eldorado.org.br)
5#
6# This library is free software; you can redistribute it and/or
7# modify it under the terms of the GNU Lesser General Public
8# License as published by the Free Software Foundation; either
9# version 2.1 of the License, or (at your option) any later version.
10#
11# This library is distributed in the hope that it will be useful,
12# but WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14# Lesser General Public License for more details.
15#
16# You should have received a copy of the GNU Lesser General Public
17# License along with this library; if not, see <http://www.gnu.org/licenses/>.
18#
19
20&D              rt ra si:int64_t
21@D              ...... rt:5 ra:5 si:s16                 &D
22
23&D_bf           bf l:bool ra imm
24@D_bfs          ...... bf:3 - l:1 ra:5 imm:s16          &D_bf
25@D_bfu          ...... bf:3 - l:1 ra:5 imm:16           &D_bf
26
27%ds_si          2:s14  !function=times_4
28@DS             ...... rt:5 ra:5 .............. ..      &D si=%ds_si
29
30&DX             rt d
31%dx_d           6:s10 16:5 0:1
32@DX             ...... rt:5  ..... .......... ..... .   &DX d=%dx_d
33
34&VX             vrt vra vrb
35@VX             ...... vrt:5 vra:5 vrb:5 .......... .   &VX
36
37&X              rt ra rb
38@X              ...... rt:5 ra:5 rb:5 .......... .      &X
39
40&X_bi           rt bi
41@X_bi           ...... rt:5 bi:5 ----- .......... -     &X_bi
42
43&X_bfl          bf l:bool ra rb
44@X_bfl          ...... bf:3 - l:1 ra:5 rb:5 ..........- &X_bfl
45
46### Fixed-Point Load Instructions
47
48LBZ             100010 ..... ..... ................     @D
49LBZU            100011 ..... ..... ................     @D
50LBZX            011111 ..... ..... ..... 0001010111 -   @X
51LBZUX           011111 ..... ..... ..... 0001110111 -   @X
52
53LHZ             101000 ..... ..... ................     @D
54LHZU            101001 ..... ..... ................     @D
55LHZX            011111 ..... ..... ..... 0100010111 -   @X
56LHZUX           011111 ..... ..... ..... 0100110111 -   @X
57
58LHA             101010 ..... ..... ................     @D
59LHAU            101011 ..... ..... ................     @D
60LHAX            011111 ..... ..... ..... 0101010111 -   @X
61LHAXU           011111 ..... ..... ..... 0101110111 -   @X
62
63LWZ             100000 ..... ..... ................     @D
64LWZU            100001 ..... ..... ................     @D
65LWZX            011111 ..... ..... ..... 0000010111 -   @X
66LWZUX           011111 ..... ..... ..... 0000110111 -   @X
67
68LWA             111010 ..... ..... ..............10     @DS
69LWAX            011111 ..... ..... ..... 0101010101 -   @X
70LWAUX           011111 ..... ..... ..... 0101110101 -   @X
71
72LD              111010 ..... ..... ..............00     @DS
73LDU             111010 ..... ..... ..............01     @DS
74LDX             011111 ..... ..... ..... 0000010101 -   @X
75LDUX            011111 ..... ..... ..... 0000110101 -   @X
76
77### Fixed-Point Store Instructions
78
79STB             100110 ..... ..... ................     @D
80STBU            100111 ..... ..... ................     @D
81STBX            011111 ..... ..... ..... 0011010111 -   @X
82STBUX           011111 ..... ..... ..... 0011110111 -   @X
83
84STH             101100 ..... ..... ................     @D
85STHU            101101 ..... ..... ................     @D
86STHX            011111 ..... ..... ..... 0110010111 -   @X
87STHUX           011111 ..... ..... ..... 0110110111 -   @X
88
89STW             100100 ..... ..... ................     @D
90STWU            100101 ..... ..... ................     @D
91STWX            011111 ..... ..... ..... 0010010111 -   @X
92STWUX           011111 ..... ..... ..... 0010110111 -   @X
93
94STD             111110 ..... ..... ..............00     @DS
95STDU            111110 ..... ..... ..............01     @DS
96STDX            011111 ..... ..... ..... 0010010101 -   @X
97STDUX           011111 ..... ..... ..... 0010110101 -   @X
98
99### Fixed-Point Compare Instructions
100
101CMP             011111 ... - . ..... ..... 0000000000 - @X_bfl
102CMPL            011111 ... - . ..... ..... 0000100000 - @X_bfl
103CMPI            001011 ... - . ..... ................   @D_bfs
104CMPLI           001010 ... - . ..... ................   @D_bfu
105
106### Fixed-Point Arithmetic Instructions
107
108ADDI            001110 ..... ..... ................     @D
109ADDIS           001111 ..... ..... ................     @D
110
111ADDPCIS         010011 ..... ..... .......... 00010 .   @DX
112
113## Fixed-Point Logical Instructions
114
115CFUGED          011111 ..... ..... ..... 0011011100 -   @X
116
117### Move To/From System Register Instructions
118
119SETBC           011111 ..... ..... ----- 0110000000 -   @X_bi
120SETBCR          011111 ..... ..... ----- 0110100000 -   @X_bi
121SETNBC          011111 ..... ..... ----- 0111000000 -   @X_bi
122SETNBCR         011111 ..... ..... ----- 0111100000 -   @X_bi
123
124## Vector Bit Manipulation Instruction
125
126VCFUGED         000100 ..... ..... ..... 10101001101    @VX
127