[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / frame-index.mir
blob31bc2b04dde8c1384b6e090c3d9b185e810a21a3
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=kaveri -verify-machineinstrs -run-pass=prologepilog -o - %s | FileCheck -check-prefix=GCN %s
4 ---
5 name: func_add_constant_to_fi_divergent_i32
6 tracksRegLiveness: true
7 stack:
8   - { id: 0, type: default, offset: 0, size: 8, alignment: 4,
9       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
10       local-offset: 0, debug-info-variable: '', debug-info-expression: '',
11       debug-info-location: '' }
12 machineFunctionInfo:
13   stackPtrOffsetReg: '$sgpr32'
15 body:             |
16   bb.0:
17     liveins: $vgpr31, $sgpr30_sgpr31
19     ; GCN-LABEL: name: func_add_constant_to_fi_divergent_i32
20     ; GCN: liveins: $vgpr31, $sgpr30_sgpr31
21     ; GCN-NEXT: {{  $}}
22     ; GCN-NEXT: renamable $vgpr0 = V_AND_B32_e32 1023, killed $vgpr31, implicit $exec
23     ; GCN-NEXT: renamable $vgpr0 = V_LSHLREV_B32_e32 2, killed $vgpr0, implicit $exec
24     ; GCN-NEXT: $vgpr1 = V_LSHRREV_B32_e64 6, $sgpr32, implicit $exec
25     ; GCN-NEXT: renamable $vgpr0 = V_ADD_CO_U32_e32 killed $vgpr1, killed $vgpr0, implicit-def dead $vcc, implicit $exec
26     ; GCN-NEXT: renamable $vgpr0, dead renamable $vcc = nuw V_ADD_CO_U32_e64 4, killed $vgpr0, 0, implicit $exec
27     ; GCN-NEXT: $m0 = S_MOV_B32 -1
28     ; GCN-NEXT: DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
29     ; GCN-NEXT: S_SETPC_B64_return killed renamable $sgpr30_sgpr31
30     renamable $vgpr0 = V_AND_B32_e32 1023, killed $vgpr31, implicit $exec
31     renamable $vgpr0 = V_LSHLREV_B32_e32 2, killed $vgpr0, implicit $exec
32     renamable $vgpr0 = V_ADD_CO_U32_e32 %stack.0, killed $vgpr0, implicit-def dead $vcc, implicit $exec
33     renamable $vgpr0, dead renamable $vcc = nuw V_ADD_CO_U32_e64 4, killed $vgpr0, 0, implicit $exec
34     $m0 = S_MOV_B32 -1
35     DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
36     S_SETPC_B64_return killed renamable $sgpr30_sgpr31
38 ...
39 ---
40 name: func_add_constant_to_fi_uniform_i32
41 tracksRegLiveness: true
42 stack:
43   - { id: 0, type: default, offset: 0, size: 8, alignment: 4,
44       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
45       local-offset: 0, debug-info-variable: '', debug-info-expression: '',
46       debug-info-location: '' }
47 machineFunctionInfo:
48   stackPtrOffsetReg: '$sgpr32'
49 body:             |
50   bb.0:
51     liveins: $sgpr30_sgpr31
53     ; GCN-LABEL: name: func_add_constant_to_fi_uniform_i32
54     ; GCN: liveins: $sgpr30_sgpr31
55     ; GCN-NEXT: {{  $}}
56     ; GCN-NEXT: $sgpr0 = S_LSHR_B32 6, $sgpr32, implicit-def dead $scc
57     ; GCN-NEXT: renamable $sgpr4 = nuw S_ADD_I32 killed $sgpr0, 4, implicit-def dead $scc
58     ; GCN-NEXT: renamable $vgpr0 = COPY killed renamable $sgpr4, implicit $exec
59     ; GCN-NEXT: $m0 = S_MOV_B32 -1
60     ; GCN-NEXT: DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
61     ; GCN-NEXT: S_SETPC_B64_return killed renamable $sgpr30_sgpr31
62     renamable $sgpr4 = nuw S_ADD_I32 %stack.0, 4, implicit-def dead $scc
63     renamable $vgpr0 = COPY killed renamable $sgpr4, implicit $exec
64     $m0 = S_MOV_B32 -1
65     DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
66     S_SETPC_B64_return killed renamable $sgpr30_sgpr31
68 ...
69 ---
70 name: func_add_constant_to_fi_uniform_SCC_clobber_i32
71 tracksRegLiveness: true
72 stack:
73   - { id: 0, type: default, offset: 0, size: 8, alignment: 4,
74       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
75       local-offset: 0, debug-info-variable: '', debug-info-expression: '',
76       debug-info-location: '' }
77   - { id: 1, type: default, offset: 0, size: 32, alignment: 4,
78       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
79       local-offset: 512, debug-info-variable: '', debug-info-expression: '',
80       debug-info-location: '' }
82 machineFunctionInfo:
84   stackPtrOffsetReg: '$sgpr32'
85 body:             |
86   bb.0:
87     liveins: $sgpr30_sgpr31
89     ; GCN-LABEL: name: func_add_constant_to_fi_uniform_SCC_clobber_i32
90     ; GCN: liveins: $sgpr30_sgpr31
91     ; GCN-NEXT: {{  $}}
92     ; GCN-NEXT: $sgpr0 = S_LSHR_B32 6, $sgpr32, implicit-def dead $scc
93     ; GCN-NEXT: renamable $sgpr4 = nuw S_ADD_U32 killed $sgpr0, 4, implicit-def $scc
94     ; GCN-NEXT: renamable $sgpr5 = S_ADDC_U32 $sgpr4, 1234567, implicit-def $scc, implicit $scc
95     ; GCN-NEXT: $sgpr0 = S_LSHR_B32 $sgpr32, 6, implicit-def $scc
96     ; GCN-NEXT: $sgpr0 = S_ADD_I32 killed $sgpr0, 8, implicit-def $scc
97     ; GCN-NEXT: renamable $sgpr6 = S_MUL_I32 killed $sgpr0, $sgpr5
98     ; GCN-NEXT: renamable $vgpr0 = COPY killed renamable $sgpr6, implicit $exec
99     ; GCN-NEXT: $m0 = S_MOV_B32 -1
100     ; GCN-NEXT: DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
101     ; GCN-NEXT: S_SETPC_B64_return killed renamable $sgpr30_sgpr31
102     renamable $sgpr4 = nuw S_ADD_U32 %stack.0, 4, implicit-def $scc
103     renamable $sgpr5 = S_ADDC_U32 $sgpr4, 1234567, implicit-def $scc, implicit $scc
104     renamable $sgpr6 = S_MUL_I32 %stack.1, $sgpr5
105     renamable $vgpr0 = COPY killed renamable $sgpr6, implicit $exec
106     $m0 = S_MOV_B32 -1
107     DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
108     S_SETPC_B64_return killed renamable $sgpr30_sgpr31
112 name: func_other_fi_user_non_inline_imm_offset_i32
113 tracksRegLiveness: true
114 stack:
115   - { id: 0, type: default, offset: 0, size: 512, alignment: 4,
116       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
117       local-offset: 0, debug-info-variable: '', debug-info-expression: '',
118       debug-info-location: '' }
119   - { id: 1, type: default, offset: 0, size: 32, alignment: 4,
120       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
121       local-offset: 512, debug-info-variable: '', debug-info-expression: '',
122       debug-info-location: '' }
123 machineFunctionInfo:
124   scratchRSrcReg:  '$sgpr0_sgpr1_sgpr2_sgpr3'
125   stackPtrOffsetReg: '$sgpr32'
126 body:             |
127   bb.0:
128     liveins: $sgpr30_sgpr31
130     ; GCN-LABEL: name: func_other_fi_user_non_inline_imm_offset_i32
131     ; GCN: liveins: $sgpr30_sgpr31
132     ; GCN-NEXT: {{  $}}
133     ; GCN-NEXT: renamable $vgpr0 = V_MOV_B32_e32 7, implicit $exec
134     ; GCN-NEXT: BUFFER_STORE_DWORD_OFFSET killed renamable $vgpr0, $sgpr0_sgpr1_sgpr2_sgpr3, $sgpr32, 260, 0, 0, implicit $exec
135     ; GCN-NEXT: $sgpr5 = S_LSHR_B32 $sgpr32, 6, implicit-def $scc
136     ; GCN-NEXT: $sgpr5 = S_ADD_I32 killed $sgpr5, 512, implicit-def $scc
137     ; GCN-NEXT: renamable $sgpr4 = S_MUL_I32 killed $sgpr5, 9
138     ; GCN-NEXT: renamable $vgpr0 = COPY killed renamable $sgpr4, implicit $exec
139     ; GCN-NEXT: $m0 = S_MOV_B32 -1
140     ; GCN-NEXT: DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
141     ; GCN-NEXT: S_SETPC_B64_return killed renamable $sgpr30_sgpr31
142     renamable $vgpr0 = V_MOV_B32_e32 7, implicit $exec
143     BUFFER_STORE_DWORD_OFFEN killed renamable $vgpr0, %stack.0, $sgpr0_sgpr1_sgpr2_sgpr3, 0, 260, 0, 0, implicit $exec
144     renamable $sgpr4 = S_MUL_I32 %stack.1, 9
145     renamable $vgpr0 = COPY killed renamable $sgpr4, implicit $exec
146     $m0 = S_MOV_B32 -1
147     DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
148     S_SETPC_B64_return killed renamable $sgpr30_sgpr31
152 name: func_add_constant_to_fi_uniform_live_SCC_i32
153 tracksRegLiveness: true
154 stack:
155   - { id: 0, type: default, offset: 0, size: 8, alignment: 4,
156       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
157       local-offset: 0, debug-info-variable: '', debug-info-expression: '',
158       debug-info-location: '' }
160 machineFunctionInfo:
162   stackPtrOffsetReg: '$sgpr32'
163 body:             |
164   bb.0:
165     liveins: $sgpr30_sgpr31, $sgpr10
166     ; GCN-LABEL: name: func_add_constant_to_fi_uniform_live_SCC_i32
167     ; GCN: liveins: $sgpr10, $sgpr30_sgpr31
168     ; GCN-NEXT: {{  $}}
169     ; GCN-NEXT: renamable $sgpr4 = nuw S_ADD_U32 $sgpr10, 4, implicit-def $scc
170     ; GCN-NEXT: $vgpr0 = V_LSHRREV_B32_e64 6, $sgpr32, implicit $exec
171     ; GCN-NEXT: $sgpr0 = V_READFIRSTLANE_B32 $vgpr0, implicit $exec
172     ; GCN-NEXT: renamable $sgpr5 = S_MUL_I32 killed $sgpr0, $sgpr4
173     ; GCN-NEXT: renamable $sgpr6 = S_ADDC_U32 $sgpr5, 1234567, implicit-def dead $scc, implicit $scc
174     ; GCN-NEXT: renamable $vgpr0 = COPY killed renamable $sgpr6, implicit $exec
175     ; GCN-NEXT: $m0 = S_MOV_B32 -1
176     ; GCN-NEXT: DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
177     ; GCN-NEXT: S_SETPC_B64_return killed renamable $sgpr30_sgpr31
178     renamable $sgpr4 = nuw S_ADD_U32 $sgpr10, 4, implicit-def $scc
179     renamable $sgpr5 = S_MUL_I32 %stack.0, $sgpr4
180     renamable $sgpr6 = S_ADDC_U32 $sgpr5, 1234567, implicit-def dead $scc, implicit $scc
181     renamable $vgpr0 = COPY killed renamable $sgpr6, implicit $exec
182     $m0 = S_MOV_B32 -1
183     DS_WRITE_B32 undef renamable $vgpr0, killed renamable $vgpr0, 0, 0, implicit $m0, implicit $exec
184     S_SETPC_B64_return killed renamable $sgpr30_sgpr31
188 name: func_frame_idx_at_the_end_of_bb
189 tracksRegLiveness: true
190 stack:
191   - { id: 0, type: default, offset: 0, size: 8, alignment: 4,
192       stack-id: default, callee-saved-register: '', callee-saved-restored: true,
193       local-offset: 0, debug-info-variable: '', debug-info-expression: '',
194       debug-info-location: '' }
195 machineFunctionInfo:
196   stackPtrOffsetReg: '$sgpr32'
198 body:             |
199   bb.0:
200     liveins: $vgpr31
202     ; GCN-LABEL: name: func_frame_idx_at_the_end_of_bb
203     ; GCN: liveins: $vgpr31
204     ; GCN-NEXT: {{  $}}
205     ; GCN-NEXT: renamable $vgpr0 = V_AND_B32_e32 1023, killed $vgpr31, implicit $exec
206     ; GCN-NEXT: renamable $vgpr0 = V_LSHLREV_B32_e32 2, killed $vgpr0, implicit $exec
207     ; GCN-NEXT: $vgpr1 = V_LSHRREV_B32_e64 6, $sgpr32, implicit $exec
208     ; GCN-NEXT: renamable $vgpr0 = V_ADD_CO_U32_e32 killed $vgpr1, killed $vgpr0, implicit-def dead $vcc, implicit $exec
209     renamable $vgpr0 = V_AND_B32_e32 1023, killed $vgpr31, implicit $exec
210     renamable $vgpr0 = V_LSHLREV_B32_e32 2, killed $vgpr0, implicit $exec
211     renamable $vgpr0 = V_ADD_CO_U32_e32 %stack.0, killed $vgpr0, implicit-def dead $vcc, implicit $exec