Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / GlobalISel / select-memop-scalar-x32.mir
blob00b797416fd94418463c67ea027a5ef96c8a49c6
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=i386-linux-gnu  -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
4 --- |
5   define i8 @test_load_i8(ptr %p1) {
6     %r = load i8, ptr %p1
7     ret i8 %r
8   }
10   define i16 @test_load_i16(ptr %p1) {
11     %r = load i16, ptr %p1
12     ret i16 %r
13   }
15   define i32 @test_load_i32(ptr %p1) {
16     %r = load i32, ptr %p1
17     ret i32 %r
18   }
20   define ptr @test_store_i8(i8 %val, ptr %p1) {
21     store i8 %val, ptr %p1
22     ret ptr %p1
23   }
25   define ptr @test_store_i16(i16 %val, ptr %p1) {
26     store i16 %val, ptr %p1
27     ret ptr %p1
28   }
30   define ptr @test_store_i32(i32 %val, ptr %p1) {
31     store i32 %val, ptr %p1
32     ret ptr %p1
33   }
35   define ptr @test_load_ptr(ptr %ptr1) {
36     %p = load ptr, ptr %ptr1
37     ret ptr %p
38   }
40   define void @test_store_ptr(ptr %ptr1, ptr %a) {
41     store ptr %a, ptr %ptr1
42     ret void
43   }
45 ...
46 ---
47 name:            test_load_i8
48 alignment:       16
49 legalized:       true
50 regBankSelected: true
51 registers:
52   - { id: 0, class: gpr }
53   - { id: 1, class: gpr }
54   - { id: 2, class: gpr }
55 fixedStack:
56   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
57 body:             |
58   bb.1 (%ir-block.0):
59     ; ALL-LABEL: name: test_load_i8
60     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.0, align 16)
61     ; ALL: [[MOV8rm:%[0-9]+]]:gr8 = MOV8rm [[MOV32rm]], 1, $noreg, 0, $noreg :: (load (s8) from %ir.p1)
62     ; ALL: $al = COPY [[MOV8rm]]
63     ; ALL: RET 0, implicit $al
64     %1(p0) = G_FRAME_INDEX %fixed-stack.0
65     %0(p0) = G_LOAD %1(p0) :: (invariant load (p0) from %fixed-stack.0, align 16)
66     %2(s8) = G_LOAD %0(p0) :: (load (s8) from %ir.p1)
67     $al = COPY %2(s8)
68     RET 0, implicit $al
70 ...
71 ---
72 name:            test_load_i16
73 alignment:       16
74 legalized:       true
75 regBankSelected: true
76 registers:
77   - { id: 0, class: gpr }
78   - { id: 1, class: gpr }
79   - { id: 2, class: gpr }
80 fixedStack:
81   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
82 body:             |
83   bb.1 (%ir-block.0):
84     ; ALL-LABEL: name: test_load_i16
85     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.0, align 16)
86     ; ALL: [[MOV16rm:%[0-9]+]]:gr16 = MOV16rm [[MOV32rm]], 1, $noreg, 0, $noreg :: (load (s16) from %ir.p1)
87     ; ALL: $ax = COPY [[MOV16rm]]
88     ; ALL: RET 0, implicit $ax
89     %1(p0) = G_FRAME_INDEX %fixed-stack.0
90     %0(p0) = G_LOAD %1(p0) :: (invariant load (p0) from %fixed-stack.0, align 16)
91     %2(s16) = G_LOAD %0(p0) :: (load (s16) from %ir.p1)
92     $ax = COPY %2(s16)
93     RET 0, implicit $ax
95 ...
96 ---
97 name:            test_load_i32
98 alignment:       16
99 legalized:       true
100 regBankSelected: true
101 registers:
102   - { id: 0, class: gpr }
103   - { id: 1, class: gpr }
104   - { id: 2, class: gpr }
105 fixedStack:
106   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
107 body:             |
108   bb.1 (%ir-block.0):
109     ; ALL-LABEL: name: test_load_i32
110     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.0, align 16)
111     ; ALL: [[MOV32rm1:%[0-9]+]]:gr32 = MOV32rm [[MOV32rm]], 1, $noreg, 0, $noreg :: (load (s32) from %ir.p1)
112     ; ALL: $eax = COPY [[MOV32rm1]]
113     ; ALL: RET 0, implicit $eax
114     %1(p0) = G_FRAME_INDEX %fixed-stack.0
115     %0(p0) = G_LOAD %1(p0) :: (invariant load (p0) from %fixed-stack.0, align 16)
116     %2(s32) = G_LOAD %0(p0) :: (load (s32) from %ir.p1)
117     $eax = COPY %2(s32)
118     RET 0, implicit $eax
122 name:            test_store_i8
123 alignment:       16
124 legalized:       true
125 regBankSelected: true
126 registers:
127   - { id: 0, class: gpr }
128   - { id: 1, class: gpr }
129   - { id: 2, class: gpr }
130   - { id: 3, class: gpr }
131 fixedStack:
132   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
133   - { id: 1, offset: 0, size: 1, alignment: 16, isImmutable: true, isAliased: false }
134 body:             |
135   bb.1 (%ir-block.0):
136     ; ALL-LABEL: name: test_store_i8
137     ; ALL: [[MOV8rm:%[0-9]+]]:gr8 = MOV8rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (s8) from %fixed-stack.0, align 16)
138     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.1, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.1)
139     ; ALL: MOV8mr [[MOV32rm]], 1, $noreg, 0, $noreg, [[MOV8rm]] :: (store (s8) into %ir.p1)
140     ; ALL: $eax = COPY [[MOV32rm]]
141     ; ALL: RET 0, implicit $eax
142     %2(p0) = G_FRAME_INDEX %fixed-stack.1
143     %0(s8) = G_LOAD %2(p0) :: (invariant load (s8) from %fixed-stack.1, align 16)
144     %3(p0) = G_FRAME_INDEX %fixed-stack.0
145     %1(p0) = G_LOAD %3(p0) :: (invariant load (p0) from %fixed-stack.0, align 4)
146     G_STORE %0(s8), %1(p0) :: (store (s8) into %ir.p1)
147     $eax = COPY %1(p0)
148     RET 0, implicit $eax
152 name:            test_store_i16
153 alignment:       16
154 legalized:       true
155 regBankSelected: true
156 registers:
157   - { id: 0, class: gpr }
158   - { id: 1, class: gpr }
159   - { id: 2, class: gpr }
160   - { id: 3, class: gpr }
161 fixedStack:
162   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
163   - { id: 1, offset: 0, size: 2, alignment: 16, isImmutable: true, isAliased: false }
164 body:             |
165   bb.1 (%ir-block.0):
166     ; ALL-LABEL: name: test_store_i16
167     ; ALL: [[MOV16rm:%[0-9]+]]:gr16 = MOV16rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (s16) from %fixed-stack.0, align 16)
168     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.1, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.1)
169     ; ALL: MOV16mr [[MOV32rm]], 1, $noreg, 0, $noreg, [[MOV16rm]] :: (store (s16) into %ir.p1)
170     ; ALL: $eax = COPY [[MOV32rm]]
171     ; ALL: RET 0, implicit $eax
172     %2(p0) = G_FRAME_INDEX %fixed-stack.1
173     %0(s16) = G_LOAD %2(p0) :: (invariant load (s16) from %fixed-stack.1, align 16)
174     %3(p0) = G_FRAME_INDEX %fixed-stack.0
175     %1(p0) = G_LOAD %3(p0) :: (invariant load (p0) from %fixed-stack.0, align 4)
176     G_STORE %0(s16), %1(p0) :: (store (s16) into %ir.p1)
177     $eax = COPY %1(p0)
178     RET 0, implicit $eax
182 name:            test_store_i32
183 alignment:       16
184 legalized:       true
185 regBankSelected: true
186 registers:
187   - { id: 0, class: gpr }
188   - { id: 1, class: gpr }
189   - { id: 2, class: gpr }
190   - { id: 3, class: gpr }
191 fixedStack:
192   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
193   - { id: 1, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
194 body:             |
195   bb.1 (%ir-block.0):
196     ; ALL-LABEL: name: test_store_i32
197     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (s32) from %fixed-stack.0, align 16)
198     ; ALL: [[MOV32rm1:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.1, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.1)
199     ; ALL: MOV32mr [[MOV32rm1]], 1, $noreg, 0, $noreg, [[MOV32rm]] :: (store (s32) into %ir.p1)
200     ; ALL: $eax = COPY [[MOV32rm1]]
201     ; ALL: RET 0, implicit $eax
202     %2(p0) = G_FRAME_INDEX %fixed-stack.1
203     %0(s32) = G_LOAD %2(p0) :: (invariant load (s32) from %fixed-stack.1, align 16)
204     %3(p0) = G_FRAME_INDEX %fixed-stack.0
205     %1(p0) = G_LOAD %3(p0) :: (invariant load (p0) from %fixed-stack.0, align 4)
206     G_STORE %0(s32), %1(p0) :: (store (s32) into %ir.p1)
207     $eax = COPY %1(p0)
208     RET 0, implicit $eax
212 name:            test_load_ptr
213 alignment:       16
214 legalized:       true
215 regBankSelected: true
216 registers:
217   - { id: 0, class: gpr }
218   - { id: 1, class: gpr }
219   - { id: 2, class: gpr }
220 fixedStack:
221   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
222 body:             |
223   bb.1 (%ir-block.0):
224     ; ALL-LABEL: name: test_load_ptr
225     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.0, align 16)
226     ; ALL: [[MOV32rm1:%[0-9]+]]:gr32 = MOV32rm [[MOV32rm]], 1, $noreg, 0, $noreg :: (load (p0) from %ir.ptr1)
227     ; ALL: $eax = COPY [[MOV32rm1]]
228     ; ALL: RET 0, implicit $eax
229     %1(p0) = G_FRAME_INDEX %fixed-stack.0
230     %0(p0) = G_LOAD %1(p0) :: (invariant load (p0) from %fixed-stack.0, align 16)
231     %2(p0) = G_LOAD %0(p0) :: (load (p0) from %ir.ptr1)
232     $eax = COPY %2(p0)
233     RET 0, implicit $eax
237 name:            test_store_ptr
238 alignment:       16
239 legalized:       true
240 regBankSelected: true
241 registers:
242   - { id: 0, class: gpr }
243   - { id: 1, class: gpr }
244   - { id: 2, class: gpr }
245   - { id: 3, class: gpr }
246 fixedStack:
247   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
248   - { id: 1, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
249 body:             |
250   bb.1 (%ir-block.0):
251     ; ALL-LABEL: name: test_store_ptr
252     ; ALL: [[MOV32rm:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.0, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.0, align 16)
253     ; ALL: [[MOV32rm1:%[0-9]+]]:gr32 = MOV32rm %fixed-stack.1, 1, $noreg, 0, $noreg :: (invariant load (p0) from %fixed-stack.1)
254     ; ALL: MOV32mr [[MOV32rm]], 1, $noreg, 0, $noreg, [[MOV32rm1]] :: (store (p0) into %ir.ptr1)
255     ; ALL: RET 0
256     %2(p0) = G_FRAME_INDEX %fixed-stack.1
257     %0(p0) = G_LOAD %2(p0) :: (invariant load (p0) from %fixed-stack.1, align 16)
258     %3(p0) = G_FRAME_INDEX %fixed-stack.0
259     %1(p0) = G_LOAD %3(p0) :: (invariant load (p0) from %fixed-stack.0, align 4)
260     G_STORE %1(p0), %0(p0) :: (store (p0) into %ir.ptr1)
261     RET 0