1# RUN: llvm-mc %s -triple=mips-unknown-linux -show-encoding -mcpu=mips32r2 | \
2# RUN:   FileCheck %s
3# RUN: llvm-mc %s -triple=mips-unknown-linux -show-encoding -mcpu=mips32r6 | \
4# RUN:   FileCheck %s
5# RUN: llvm-mc %s -triple=mips64-unknown-linux -show-encoding -mcpu=mips64r2 -target-abi=n32 | \
6# RUN:   FileCheck %s
7# RUN: llvm-mc %s -triple=mips64-unknown-linux -show-encoding -mcpu=mips64r6 -target-abi=n32 | \
8# RUN:   FileCheck %s
9
10# N64 should be acceptable too but we cannot convert la to dla yet.
11
12la $5, 0x00000001 # CHECK: addiu $5, $zero, 1      # encoding: [0x24,0x05,0x00,0x01]
13la $5, 0x00000002 # CHECK: addiu $5, $zero, 2      # encoding: [0x24,0x05,0x00,0x02]
14la $5, 0x00004000 # CHECK: addiu $5, $zero, 16384  # encoding: [0x24,0x05,0x40,0x00]
15la $5, 0x00008000 # CHECK: ori   $5, $zero, 32768  # encoding: [0x34,0x05,0x80,0x00]
16la $5, 0xffffffff # CHECK: addiu $5, $zero, -1     # encoding: [0x24,0x05,0xff,0xff]
17la $5, 0xfffffffe # CHECK: addiu $5, $zero, -2     # encoding: [0x24,0x05,0xff,0xfe]
18la $5, 0xffffc000 # CHECK: addiu $5, $zero, -16384 # encoding: [0x24,0x05,0xc0,0x00]
19la $5, 0xffff8000 # CHECK: addiu $5, $zero, -32768 # encoding: [0x24,0x05,0x80,0x00]
20
21la $5, 0x00010000 # CHECK: lui $5, 1      # encoding: [0x3c,0x05,0x00,0x01]
22la $5, 0x00020000 # CHECK: lui $5, 2      # encoding: [0x3c,0x05,0x00,0x02]
23la $5, 0x40000000 # CHECK: lui $5, 16384  # encoding: [0x3c,0x05,0x40,0x00]
24la $5, 0x80000000 # CHECK: lui $5, 32768  # encoding: [0x3c,0x05,0x80,0x00]
25la $5, 0xffff0000 # CHECK: lui $5, 65535  # encoding: [0x3c,0x05,0xff,0xff]
26la $5, 0xfffe0000 # CHECK: lui $5, 65534  # encoding: [0x3c,0x05,0xff,0xfe]
27la $5, 0xc0000000 # CHECK: lui $5, 49152  # encoding: [0x3c,0x05,0xc0,0x00]
28la $5, 0x80000000 # CHECK: lui $5, 32768  # encoding: [0x3c,0x05,0x80,0x00]
29
30la $5, 0x00010001 # CHECK: lui $5, 1        # encoding: [0x3c,0x05,0x00,0x01]
31                  # CHECK: ori $5, $5, 1    # encoding: [0x34,0xa5,0x00,0x01]
32la $5, 0x00020001 # CHECK: lui $5, 2        # encoding: [0x3c,0x05,0x00,0x02]
33                  # CHECK: ori $5, $5, 1    # encoding: [0x34,0xa5,0x00,0x01]
34la $5, 0x40000001 # CHECK: lui $5, 16384    # encoding: [0x3c,0x05,0x40,0x00]
35                  # CHECK: ori $5, $5, 1    # encoding: [0x34,0xa5,0x00,0x01]
36la $5, 0x80000001 # CHECK: lui $5, 32768    # encoding: [0x3c,0x05,0x80,0x00]
37                  # CHECK: ori $5, $5, 1    # encoding: [0x34,0xa5,0x00,0x01]
38la $5, 0x00010002 # CHECK: lui $5, 1        # encoding: [0x3c,0x05,0x00,0x01]
39                  # CHECK: ori $5, $5, 2    # encoding: [0x34,0xa5,0x00,0x02]
40la $5, 0x00020002 # CHECK: lui $5, 2        # encoding: [0x3c,0x05,0x00,0x02]
41                  # CHECK: ori $5, $5, 2    # encoding: [0x34,0xa5,0x00,0x02]
42la $5, 0x40000002 # CHECK: lui $5, 16384    # encoding: [0x3c,0x05,0x40,0x00]
43                  # CHECK: ori $5, $5, 2    # encoding: [0x34,0xa5,0x00,0x02]
44la $5, 0x80000002 # CHECK: lui $5, 32768    # encoding: [0x3c,0x05,0x80,0x00]
45                  # CHECK: ori $5, $5, 2    # encoding: [0x34,0xa5,0x00,0x02]
46la $5, 0x00014000 # CHECK: lui $5, 1        # encoding: [0x3c,0x05,0x00,0x01]
47                  # CHECK: ori $5, $5, 16384    # encoding: [0x34,0xa5,0x40,0x00]
48la $5, 0x00024000 # CHECK: lui $5, 2            # encoding: [0x3c,0x05,0x00,0x02]
49                  # CHECK: ori $5, $5, 16384    # encoding: [0x34,0xa5,0x40,0x00]
50la $5, 0x40004000 # CHECK: lui $5, 16384        # encoding: [0x3c,0x05,0x40,0x00]
51                  # CHECK: ori $5, $5, 16384    # encoding: [0x34,0xa5,0x40,0x00]
52la $5, 0x80004000 # CHECK: lui $5, 32768        # encoding: [0x3c,0x05,0x80,0x00]
53                  # CHECK: ori $5, $5, 16384    # encoding: [0x34,0xa5,0x40,0x00]
54la $5, 0x00018000 # CHECK: lui $5, 1            # encoding: [0x3c,0x05,0x00,0x01]
55                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
56la $5, 0x00028000 # CHECK: lui $5, 2            # encoding: [0x3c,0x05,0x00,0x02]
57                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
58la $5, 0x40008000 # CHECK: lui $5, 16384        # encoding: [0x3c,0x05,0x40,0x00]
59                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
60la $5, 0x80008000 # CHECK: lui $5, 32768        # encoding: [0x3c,0x05,0x80,0x00]
61                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
62la $5, 0xffff4000 # CHECK: lui $5, 65535        # encoding: [0x3c,0x05,0xff,0xff]
63                  # CHECK: ori $5, $5, 16384    # encoding: [0x34,0xa5,0x40,0x00]
64la $5, 0xfffe8000 # CHECK: lui $5, 65534        # encoding: [0x3c,0x05,0xff,0xfe]
65                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
66la $5, 0xc0008000 # CHECK: lui $5, 49152        # encoding: [0x3c,0x05,0xc0,0x00]
67                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
68la $5, 0x80008000 # CHECK: lui $5, 32768        # encoding: [0x3c,0x05,0x80,0x00]
69                  # CHECK: ori $5, $5, 32768    # encoding: [0x34,0xa5,0x80,0x00]
70
71la $5, 0x00000001($6) # CHECK: addiu $5, $6, 1         # encoding: [0x24,0xc5,0x00,0x01]
72la $5, 0x00000002($6) # CHECK: addiu $5, $6, 2         # encoding: [0x24,0xc5,0x00,0x02]
73la $5, 0x00004000($6) # CHECK: addiu $5, $6, 16384     # encoding: [0x24,0xc5,0x40,0x00]
74la $5, 0x00008000($6) # CHECK: ori   $5, $zero, 32768  # encoding: [0x34,0x05,0x80,0x00]
75                      # CHECK: addu $5, $5, $6         # encoding: [0x00,0xa6,0x28,0x21]
76la $5, 0xffffffff($6) # CHECK: addiu $5, $6, -1        # encoding: [0x24,0xc5,0xff,0xff]
77la $5, 0xfffffffe($6) # CHECK: addiu $5, $6, -2        # encoding: [0x24,0xc5,0xff,0xfe]
78la $5, 0xffffc000($6) # CHECK: addiu $5, $6, -16384    # encoding: [0x24,0xc5,0xc0,0x00]
79la $5, 0xffff8000($6) # CHECK: addiu $5, $6, -32768    # encoding: [0x24,0xc5,0x80,0x00]
80
81la $5, 0x00010000($6) # CHECK: lui $5, 1       # encoding: [0x3c,0x05,0x00,0x01]
82                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
83la $5, 0x00020000($6) # CHECK: lui $5, 2       # encoding: [0x3c,0x05,0x00,0x02]
84                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
85la $5, 0x40000000($6) # CHECK: lui $5, 16384   # encoding: [0x3c,0x05,0x40,0x00]
86                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
87la $5, 0x80000000($6) # CHECK: lui $5, 32768   # encoding: [0x3c,0x05,0x80,0x00]
88                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
89la $5, 0xffff0000($6) # CHECK: lui $5, 65535   # encoding: [0x3c,0x05,0xff,0xff]
90                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
91la $5, 0xfffe0000($6) # CHECK: lui $5, 65534   # encoding: [0x3c,0x05,0xff,0xfe]
92                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
93la $5, 0xc0000000($6) # CHECK: lui $5, 49152   # encoding: [0x3c,0x05,0xc0,0x00]
94                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
95la $5, 0x80000000($6) # CHECK: lui $5, 32768   # encoding: [0x3c,0x05,0x80,0x00]
96                      # CHECK: addu $5, $5, $6 # encoding: [0x00,0xa6,0x28,0x21]
97
98la $5, 0x00010001($6) # CHECK: lui $5, 1         # encoding: [0x3c,0x05,0x00,0x01]
99                      # CHECK: ori $5, $5, 1     # encoding: [0x34,0xa5,0x00,0x01]
100                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
101la $5, 0x00020001($6) # CHECK: lui $5, 2         # encoding: [0x3c,0x05,0x00,0x02]
102                      # CHECK: ori $5, $5, 1     # encoding: [0x34,0xa5,0x00,0x01]
103                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
104la $5, 0x40000001($6) # CHECK: lui $5, 16384     # encoding: [0x3c,0x05,0x40,0x00]
105                      # CHECK: ori $5, $5, 1     # encoding: [0x34,0xa5,0x00,0x01]
106                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
107la $5, 0x80000001($6) # CHECK: lui $5, 32768     # encoding: [0x3c,0x05,0x80,0x00]
108                      # CHECK: ori $5, $5, 1     # encoding: [0x34,0xa5,0x00,0x01]
109                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
110la $5, 0x00010002($6) # CHECK: lui $5, 1         # encoding: [0x3c,0x05,0x00,0x01]
111                      # CHECK: ori $5, $5, 2     # encoding: [0x34,0xa5,0x00,0x02]
112                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
113la $5, 0x00020002($6) # CHECK: lui $5, 2         # encoding: [0x3c,0x05,0x00,0x02]
114                      # CHECK: ori $5, $5, 2     # encoding: [0x34,0xa5,0x00,0x02]
115                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
116la $5, 0x40000002($6) # CHECK: lui $5, 16384     # encoding: [0x3c,0x05,0x40,0x00]
117                      # CHECK: ori $5, $5, 2     # encoding: [0x34,0xa5,0x00,0x02]
118                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
119la $5, 0x80000002($6) # CHECK: lui $5, 32768     # encoding: [0x3c,0x05,0x80,0x00]
120                      # CHECK: ori $5, $5, 2     # encoding: [0x34,0xa5,0x00,0x02]
121                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
122la $5, 0x00014000($6) # CHECK: lui $5, 1         # encoding: [0x3c,0x05,0x00,0x01]
123                      # CHECK: ori $5, $5, 16384 # encoding: [0x34,0xa5,0x40,0x00]
124                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
125la $5, 0x00024000($6) # CHECK: lui $5, 2         # encoding: [0x3c,0x05,0x00,0x02]
126                      # CHECK: ori $5, $5, 16384 # encoding: [0x34,0xa5,0x40,0x00]
127                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
128la $5, 0x40004000($6) # CHECK: lui $5, 16384     # encoding: [0x3c,0x05,0x40,0x00]
129                      # CHECK: ori $5, $5, 16384 # encoding: [0x34,0xa5,0x40,0x00]
130                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
131la $5, 0x80004000($6) # CHECK: lui $5, 32768     # encoding: [0x3c,0x05,0x80,0x00]
132                      # CHECK: ori $5, $5, 16384 # encoding: [0x34,0xa5,0x40,0x00]
133                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
134la $5, 0x00018000($6) # CHECK: lui $5, 1         # encoding: [0x3c,0x05,0x00,0x01]
135                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
136                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
137la $5, 0x00028000($6) # CHECK: lui $5, 2         # encoding: [0x3c,0x05,0x00,0x02]
138                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
139                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
140la $5, 0x40008000($6) # CHECK: lui $5, 16384     # encoding: [0x3c,0x05,0x40,0x00]
141                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
142                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
143la $5, 0x80008000($6) # CHECK: lui $5, 32768     # encoding: [0x3c,0x05,0x80,0x00]
144                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
145                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
146la $5, 0xffff4000($6) # CHECK: lui $5, 65535     # encoding: [0x3c,0x05,0xff,0xff]
147                      # CHECK: ori $5, $5, 16384 # encoding: [0x34,0xa5,0x40,0x00]
148                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
149la $5, 0xfffe8000($6) # CHECK: lui $5, 65534     # encoding: [0x3c,0x05,0xff,0xfe]
150                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
151                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
152la $5, 0xc0008000($6) # CHECK: lui $5, 49152     # encoding: [0x3c,0x05,0xc0,0x00]
153                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
154                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
155la $5, 0x80008000($6) # CHECK: lui $5, 32768     # encoding: [0x3c,0x05,0x80,0x00]
156                      # CHECK: ori $5, $5, 32768 # encoding: [0x34,0xa5,0x80,0x00]
157                      # CHECK: addu $5, $5, $6   # encoding: [0x00,0xa6,0x28,0x21]
158
159la $6, 0x00000001($6) # CHECK: addiu $6, $6, 1         # encoding: [0x24,0xc6,0x00,0x01]
160la $6, 0x00000002($6) # CHECK: addiu $6, $6, 2         # encoding: [0x24,0xc6,0x00,0x02]
161la $6, 0x00004000($6) # CHECK: addiu $6, $6, 16384     # encoding: [0x24,0xc6,0x40,0x00]
162la $6, 0x00008000($6) # CHECK: ori   $1, $zero, 32768  # encoding: [0x34,0x01,0x80,0x00]
163                      # CHECK: addu $6, $1, $6         # encoding: [0x00,0x26,0x30,0x21]
164la $6, 0xffffffff($6) # CHECK: addiu $6, $6, -1        # encoding: [0x24,0xc6,0xff,0xff]
165la $6, 0xfffffffe($6) # CHECK: addiu $6, $6, -2        # encoding: [0x24,0xc6,0xff,0xfe]
166la $6, 0xffffc000($6) # CHECK: addiu $6, $6, -16384    # encoding: [0x24,0xc6,0xc0,0x00]
167la $6, 0xffff8000($6) # CHECK: addiu $6, $6, -32768    # encoding: [0x24,0xc6,0x80,0x00]
168
169la $6, 0x00010000($6) # CHECK: lui $1, 1       # encoding: [0x3c,0x01,0x00,0x01]
170                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
171la $6, 0x00020000($6) # CHECK: lui $1, 2       # encoding: [0x3c,0x01,0x00,0x02]
172                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
173la $6, 0x40000000($6) # CHECK: lui $1, 16384   # encoding: [0x3c,0x01,0x40,0x00]
174                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
175la $6, 0x80000000($6) # CHECK: lui $1, 32768   # encoding: [0x3c,0x01,0x80,0x00]
176                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
177la $6, 0xffff0000($6) # CHECK: lui $1, 65535   # encoding: [0x3c,0x01,0xff,0xff]
178                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
179la $6, 0xfffe0000($6) # CHECK: lui $1, 65534   # encoding: [0x3c,0x01,0xff,0xfe]
180                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
181la $6, 0xc0000000($6) # CHECK: lui $1, 49152   # encoding: [0x3c,0x01,0xc0,0x00]
182                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
183la $6, 0x80000000($6) # CHECK: lui $1, 32768   # encoding: [0x3c,0x01,0x80,0x00]
184                      # CHECK: addu $6, $1, $6 # encoding: [0x00,0x26,0x30,0x21]
185
186la $6, 0x00010001($6) # CHECK: lui $1, 1         # encoding: [0x3c,0x01,0x00,0x01]
187                      # CHECK: ori $1, $1, 1     # encoding: [0x34,0x21,0x00,0x01]
188                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
189la $6, 0x00020001($6) # CHECK: lui $1, 2         # encoding: [0x3c,0x01,0x00,0x02]
190                      # CHECK: ori $1, $1, 1     # encoding: [0x34,0x21,0x00,0x01]
191                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
192la $6, 0x40000001($6) # CHECK: lui $1, 16384     # encoding: [0x3c,0x01,0x40,0x00]
193                      # CHECK: ori $1, $1, 1     # encoding: [0x34,0x21,0x00,0x01]
194                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
195la $6, 0x80000001($6) # CHECK: lui $1, 32768     # encoding: [0x3c,0x01,0x80,0x00]
196                      # CHECK: ori $1, $1, 1     # encoding: [0x34,0x21,0x00,0x01]
197                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
198la $6, 0x00010002($6) # CHECK: lui $1, 1         # encoding: [0x3c,0x01,0x00,0x01]
199                      # CHECK: ori $1, $1, 2     # encoding: [0x34,0x21,0x00,0x02]
200                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
201la $6, 0x00020002($6) # CHECK: lui $1, 2         # encoding: [0x3c,0x01,0x00,0x02]
202                      # CHECK: ori $1, $1, 2     # encoding: [0x34,0x21,0x00,0x02]
203                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
204la $6, 0x40000002($6) # CHECK: lui $1, 16384     # encoding: [0x3c,0x01,0x40,0x00]
205                      # CHECK: ori $1, $1, 2     # encoding: [0x34,0x21,0x00,0x02]
206                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
207la $6, 0x80000002($6) # CHECK: lui $1, 32768     # encoding: [0x3c,0x01,0x80,0x00]
208                      # CHECK: ori $1, $1, 2     # encoding: [0x34,0x21,0x00,0x02]
209                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
210la $6, 0x00014000($6) # CHECK: lui $1, 1         # encoding: [0x3c,0x01,0x00,0x01]
211                      # CHECK: ori $1, $1, 16384 # encoding: [0x34,0x21,0x40,0x00]
212                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
213la $6, 0x00024000($6) # CHECK: lui $1, 2         # encoding: [0x3c,0x01,0x00,0x02]
214                      # CHECK: ori $1, $1, 16384 # encoding: [0x34,0x21,0x40,0x00]
215                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
216la $6, 0x40004000($6) # CHECK: lui $1, 16384     # encoding: [0x3c,0x01,0x40,0x00]
217                      # CHECK: ori $1, $1, 16384 # encoding: [0x34,0x21,0x40,0x00]
218                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
219la $6, 0x80004000($6) # CHECK: lui $1, 32768     # encoding: [0x3c,0x01,0x80,0x00]
220                      # CHECK: ori $1, $1, 16384 # encoding: [0x34,0x21,0x40,0x00]
221                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
222la $6, 0x00018000($6) # CHECK: lui $1, 1         # encoding: [0x3c,0x01,0x00,0x01]
223                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
224                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
225la $6, 0x00028000($6) # CHECK: lui $1, 2         # encoding: [0x3c,0x01,0x00,0x02]
226                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
227                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
228la $6, 0x40008000($6) # CHECK: lui $1, 16384     # encoding: [0x3c,0x01,0x40,0x00]
229                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
230                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
231la $6, 0x80008000($6) # CHECK: lui $1, 32768     # encoding: [0x3c,0x01,0x80,0x00]
232                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
233                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
234la $6, 0xffff4000($6) # CHECK: lui $1, 65535     # encoding: [0x3c,0x01,0xff,0xff]
235                      # CHECK: ori $1, $1, 16384 # encoding: [0x34,0x21,0x40,0x00]
236                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
237la $6, 0xfffe8000($6) # CHECK: lui $1, 65534     # encoding: [0x3c,0x01,0xff,0xfe]
238                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
239                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
240la $6, 0xc0008000($6) # CHECK: lui $1, 49152     # encoding: [0x3c,0x01,0xc0,0x00]
241                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
242                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
243la $6, 0x80008000($6) # CHECK: lui $1, 32768     # encoding: [0x3c,0x01,0x80,0x00]
244                      # CHECK: ori $1, $1, 32768 # encoding: [0x34,0x21,0x80,0x00]
245                      # CHECK: addu $6, $1, $6   # encoding: [0x00,0x26,0x30,0x21]
246
247la $5, symbol         # CHECK: lui $5, %hi(symbol)       # encoding: [0x3c,0x05,A,A]
248                      # CHECK:                           #   fixup A - offset: 0, value: %hi(symbol), kind: fixup_Mips_HI16
249                      # CHECK: addiu $5, $5, %lo(symbol) # encoding: [0x24,0xa5,A,A]
250                      # CHECK:                           #   fixup A - offset: 0, value: %lo(symbol), kind: fixup_Mips_LO16
251la $5, symbol($6)     # CHECK: lui $5, %hi(symbol)       # encoding: [0x3c,0x05,A,A]
252                      # CHECK:                           #   fixup A - offset: 0, value: %hi(symbol), kind: fixup_Mips_HI16
253                      # CHECK: addiu $5, $5, %lo(symbol) # encoding: [0x24,0xa5,A,A]
254                      # CHECK:                           #   fixup A - offset: 0, value: %lo(symbol), kind: fixup_Mips_LO16
255                      # CHECK: addu $5, $5, $6           # encoding: [0x00,0xa6,0x28,0x21]
256la $6, symbol($6)     # CHECK: lui $1, %hi(symbol)       # encoding: [0x3c,0x01,A,A]
257                      # CHECK:                           #   fixup A - offset: 0, value: %hi(symbol), kind: fixup_Mips_HI16
258                      # CHECK: addiu $1, $1, %lo(symbol) # encoding: [0x24,0x21,A,A]
259                      # CHECK:                           #   fixup A - offset: 0, value: %lo(symbol), kind: fixup_Mips_LO16
260                      # CHECK: addu $6, $1, $6           # encoding: [0x00,0x26,0x30,0x21]
261la $5, symbol+8       # CHECK: lui $5, %hi(symbol+8)       # encoding: [0x3c,0x05,A,A]
262                      # CHECK:                             #   fixup A - offset: 0, value: %hi(symbol+8), kind: fixup_Mips_HI16
263                      # CHECK: addiu $5, $5, %lo(symbol+8) # encoding: [0x24,0xa5,A,A]
264                      # CHECK:                             #   fixup A - offset: 0, value: %lo(symbol+8), kind: fixup_Mips_LO16
265la $5, symbol+8($6)   # CHECK: lui $5, %hi(symbol+8)       # encoding: [0x3c,0x05,A,A]
266                      # CHECK:                             #   fixup A - offset: 0, value: %hi(symbol+8), kind: fixup_Mips_HI16
267                      # CHECK: addiu $5, $5, %lo(symbol+8) # encoding: [0x24,0xa5,A,A]
268                      # CHECK:                             #   fixup A - offset: 0, value: %lo(symbol+8), kind: fixup_Mips_LO16
269                      # CHECK: addu $5, $5, $6             # encoding: [0x00,0xa6,0x28,0x21]
270la $6, symbol+8($6)   # CHECK: lui $1, %hi(symbol+8)       # encoding: [0x3c,0x01,A,A]
271                      # CHECK:                             #   fixup A - offset: 0, value: %hi(symbol+8), kind: fixup_Mips_HI16
272                      # CHECK: addiu $1, $1, %lo(symbol+8) # encoding: [0x24,0x21,A,A]
273                      # CHECK:                             #   fixup A - offset: 0, value: %lo(symbol+8), kind: fixup_Mips_LO16
274                      # CHECK: addu $6, $1, $6             # encoding: [0x00,0x26,0x30,0x21]
275la $5, 1f             # CHECK: lui $5, %hi($tmp0)          # encoding: [0x3c,0x05,A,A]
276                      # CHECK:                             #   fixup A - offset: 0, value: %hi($tmp0), kind: fixup_Mips_HI16
277                      # CHECK: addiu $5, $5, %lo($tmp0)    # encoding: [0x24,0xa5,A,A]
278                      # CHECK:                             #   fixup A - offset: 0, value: %lo($tmp0), kind: fixup_Mips_LO16
2791:
280