xref: /aosp_15_r20/external/llvm/test/MC/Mips/micromips-control-instructions.s (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker# RUN: llvm-mc %s -triple=mipsel -show-encoding -mcpu=mips32r2 -mattr=micromips \
2*9880d681SAndroid Build Coastguard Worker# RUN: | FileCheck -check-prefix=CHECK-EL %s
3*9880d681SAndroid Build Coastguard Worker# RUN: llvm-mc %s -triple=mips -show-encoding -mcpu=mips32r2 -mattr=micromips \
4*9880d681SAndroid Build Coastguard Worker# RUN: | FileCheck -check-prefix=CHECK-EB %s
5*9880d681SAndroid Build Coastguard Worker# Check that the assembler can handle the documented syntax
6*9880d681SAndroid Build Coastguard Worker# for control instructions.
7*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------
8*9880d681SAndroid Build Coastguard Worker# microMIPS Control Instructions
9*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------
10*9880d681SAndroid Build Coastguard Worker# Little endian
11*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------
12*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    sdbbp                      # encoding: [0x00,0x00,0x7c,0xdb]
13*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    sdbbp 34                   # encoding: [0x22,0x00,0x7c,0xdb]
14*9880d681SAndroid Build Coastguard Worker# CHECK-EL-NOT:    .set push
15*9880d681SAndroid Build Coastguard Worker# CHECK-EL-NOT:    .set mips32r2
16*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    rdhwr $5, $29              # encoding: [0xbd,0x00,0x3c,0x6b]
17*9880d681SAndroid Build Coastguard Worker# CHECK-EL-NOT:    .set pop
18*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    cache 1, 8($5)             # encoding: [0x25,0x20,0x08,0x60]
19*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    pref 1, 8($5)              # encoding: [0x25,0x60,0x08,0x20]
20*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    ssnop                      # encoding: [0x00,0x00,0x00,0x08]
21*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    ehb                        # encoding: [0x00,0x00,0x00,0x18]
22*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    pause                      # encoding: [0x00,0x00,0x00,0x28]
23*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    break                      # encoding: [0x00,0x00,0x07,0x00]
24*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    break 7                    # encoding: [0x07,0x00,0x07,0x00]
25*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    break 7, 5                 # encoding: [0x07,0x00,0x47,0x01]
26*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    syscall                    # encoding: [0x00,0x00,0x7c,0x8b]
27*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    syscall 396                # encoding: [0x8c,0x01,0x7c,0x8b]
28*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    eret                       # encoding: [0x00,0x00,0x7c,0xf3]
29*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    deret                      # encoding: [0x00,0x00,0x7c,0xe3]
30*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    di                         # encoding: [0x00,0x00,0x7c,0x47]
31*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    di                         # encoding: [0x00,0x00,0x7c,0x47]
32*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    di  $10                    # encoding: [0x0a,0x00,0x7c,0x47]
33*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    ei                         # encoding: [0x00,0x00,0x7c,0x57]
34*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    ei                         # encoding: [0x00,0x00,0x7c,0x57]
35*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    ei  $10                    # encoding: [0x0a,0x00,0x7c,0x57]
36*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    wait                       # encoding: [0x00,0x00,0x7c,0x93]
37*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    wait 17                    # encoding: [0x11,0x00,0x7c,0x93]
38*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    tlbp                       # encoding: [0x00,0x00,0x7c,0x03]
39*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    tlbr                       # encoding: [0x00,0x00,0x7c,0x13]
40*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    tlbwi                      # encoding: [0x00,0x00,0x7c,0x23]
41*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    tlbwr                      # encoding: [0x00,0x00,0x7c,0x33]
42*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    prefe 1, 8($5)             # encoding: [0x25,0x60,0x08,0xa4]
43*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    cachee 1, 8($5)            # encoding: [0x25,0x60,0x08,0xa6]
44*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    prefx 1, $3($5)            # encoding: [0x65,0x54,0xa0,0x09]
45*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    swre $24, 5($3)            # encoding: [0x03,0x63,0x05,0xa2]
46*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    swle $24, 5($3)            # encoding: [0x03,0x63,0x05,0xa0]
47*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    lwre $24, 5($3)            # encoding: [0x03,0x63,0x05,0x66]
48*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    lwle $24, 2($4)            # encoding: [0x04,0x63,0x02,0x64]
49*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    lle $2, 8($4)              # encoding: [0x44,0x60,0x08,0x6c]
50*9880d681SAndroid Build Coastguard Worker# CHECK-EL:    sce $2, 8($4)              # encoding: [0x44,0x60,0x08,0xac]
51*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------
52*9880d681SAndroid Build Coastguard Worker# Big endian
53*9880d681SAndroid Build Coastguard Worker#------------------------------------------------------------------------------
54*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   sdbbp                       # encoding: [0x00,0x00,0xdb,0x7c]
55*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   sdbbp 34                    # encoding: [0x00,0x22,0xdb,0x7c]
56*9880d681SAndroid Build Coastguard Worker# CHECK-EB-NOT:    .set push
57*9880d681SAndroid Build Coastguard Worker# CHECK-EB-NOT:    .set mips32r2
58*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   rdhwr $5, $29               # encoding: [0x00,0xbd,0x6b,0x3c]
59*9880d681SAndroid Build Coastguard Worker# CHECK-EB-NOT:    .set pop
60*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   cache 1, 8($5)              # encoding: [0x20,0x25,0x60,0x08]
61*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   pref 1, 8($5)               # encoding: [0x60,0x25,0x20,0x08]
62*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   ssnop                       # encoding: [0x00,0x00,0x08,0x00]
63*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   ehb                         # encoding: [0x00,0x00,0x18,0x00]
64*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   pause                       # encoding: [0x00,0x00,0x28,0x00]
65*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   break                       # encoding: [0x00,0x00,0x00,0x07]
66*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   break 7                     # encoding: [0x00,0x07,0x00,0x07]
67*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   break 7, 5                  # encoding: [0x00,0x07,0x01,0x47]
68*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   syscall                     # encoding: [0x00,0x00,0x8b,0x7c]
69*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   syscall 396                 # encoding: [0x01,0x8c,0x8b,0x7c]
70*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   eret                        # encoding: [0x00,0x00,0xf3,0x7c]
71*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   deret                       # encoding: [0x00,0x00,0xe3,0x7c]
72*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   di                          # encoding: [0x00,0x00,0x47,0x7c]
73*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   di                          # encoding: [0x00,0x00,0x47,0x7c]
74*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   di  $10                     # encoding: [0x00,0x0a,0x47,0x7c]
75*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   ei                          # encoding: [0x00,0x00,0x57,0x7c]
76*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   ei                          # encoding: [0x00,0x00,0x57,0x7c]
77*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   ei  $10                     # encoding: [0x00,0x0a,0x57,0x7c]
78*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   wait                        # encoding: [0x00,0x00,0x93,0x7c]
79*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   wait 17                     # encoding: [0x00,0x11,0x93,0x7c]
80*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   tlbp                        # encoding: [0x00,0x00,0x03,0x7c]
81*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   tlbr                        # encoding: [0x00,0x00,0x13,0x7c]
82*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   tlbwi                       # encoding: [0x00,0x00,0x23,0x7c]
83*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   tlbwr                       # encoding: [0x00,0x00,0x33,0x7c]
84*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   prefe 1, 8($5)              # encoding: [0x60,0x25,0xa4,0x08]
85*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   cachee 1, 8($5)             # encoding: [0x60,0x25,0xa6,0x08]
86*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   prefx 1, $3($5)             # encoding: [0x54,0x65,0x09,0xa0]
87*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   swre $24, 5($3)             # encoding: [0x63,0x03,0xa2,0x05]
88*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   swle $24, 5($3)             # encoding: [0x63,0x03,0xa0,0x05]
89*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   lwre $24, 5($3)             # encoding: [0x63,0x03,0x66,0x05]
90*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   lwle $24, 2($4)             # encoding: [0x63,0x04,0x64,0x02]
91*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   lle $2, 8($4)               # encoding: [0x60,0x44,0x6c,0x08]
92*9880d681SAndroid Build Coastguard Worker# CHECK-EB:   sce $2, 8($4)               # encoding: [0x60,0x44,0xac,0x08]
93*9880d681SAndroid Build Coastguard Worker
94*9880d681SAndroid Build Coastguard Worker    sdbbp
95*9880d681SAndroid Build Coastguard Worker    sdbbp 34
96*9880d681SAndroid Build Coastguard Worker    rdhwr $5, $29
97*9880d681SAndroid Build Coastguard Worker    cache 1, 8($5)
98*9880d681SAndroid Build Coastguard Worker    pref 1, 8($5)
99*9880d681SAndroid Build Coastguard Worker    ssnop
100*9880d681SAndroid Build Coastguard Worker    ehb
101*9880d681SAndroid Build Coastguard Worker    pause
102*9880d681SAndroid Build Coastguard Worker    break
103*9880d681SAndroid Build Coastguard Worker    break 7
104*9880d681SAndroid Build Coastguard Worker    break 7,5
105*9880d681SAndroid Build Coastguard Worker    syscall
106*9880d681SAndroid Build Coastguard Worker    syscall 0x18c
107*9880d681SAndroid Build Coastguard Worker    eret
108*9880d681SAndroid Build Coastguard Worker    deret
109*9880d681SAndroid Build Coastguard Worker    di
110*9880d681SAndroid Build Coastguard Worker    di $0
111*9880d681SAndroid Build Coastguard Worker    di $10
112*9880d681SAndroid Build Coastguard Worker    ei
113*9880d681SAndroid Build Coastguard Worker    ei $0
114*9880d681SAndroid Build Coastguard Worker    ei $10
115*9880d681SAndroid Build Coastguard Worker    wait
116*9880d681SAndroid Build Coastguard Worker    wait 17
117*9880d681SAndroid Build Coastguard Worker    tlbp
118*9880d681SAndroid Build Coastguard Worker    tlbr
119*9880d681SAndroid Build Coastguard Worker    tlbwi
120*9880d681SAndroid Build Coastguard Worker    tlbwr
121*9880d681SAndroid Build Coastguard Worker    prefe 1, 8($5)
122*9880d681SAndroid Build Coastguard Worker    cachee 1, 8($5)
123*9880d681SAndroid Build Coastguard Worker    prefx 1, $3($5)
124*9880d681SAndroid Build Coastguard Worker    swre $24, 5($3)
125*9880d681SAndroid Build Coastguard Worker    swle $24, 5($3)
126*9880d681SAndroid Build Coastguard Worker    lwre $24, 5($3)
127*9880d681SAndroid Build Coastguard Worker    lwle $24, 2($4)
128*9880d681SAndroid Build Coastguard Worker    lle $2, 8($4)
129*9880d681SAndroid Build Coastguard Worker    sce $2, 8($4)
130