[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / spill-reg-tuple-super-reg-use.mir
blobae4000149e28476b549121e00c87c3d913b9ee19
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -march=amdgcn -mcpu=gfx900 -run-pass=si-lower-sgpr-spills,prologepilog,machine-cp -verify-machineinstrs %s -o - | FileCheck -check-prefix=GCN %s
4 # Make sure the initial first $sgpr1 = COPY $sgpr2 copy is not deleted
5 # by the copy propagation after lowering the spill.
7 ---
8 name: spill_sgpr128_use_subreg
9 tracksRegLiveness: true
10 machineFunctionInfo:
11   hasSpilledSGPRs: true
12   scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
13   stackPtrOffsetReg: $sgpr32
15 stack:
16   - { id: 0, stack-id: sgpr-spill, type: spill-slot, size: 16, alignment: 4 }
18 body:             |
19   bb.0:
20     liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
22     ; GCN-LABEL: name: spill_sgpr128_use_subreg
23     ; GCN: liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
24     ; GCN: $sgpr8_sgpr9 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
25     ; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr0, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (store (s32) into %stack.1, addrspace 5)
26     ; GCN: $exec = S_MOV_B64 killed $sgpr8_sgpr9
27     ; GCN: renamable $sgpr1 = COPY $sgpr2
28     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr0, 0, $vgpr0, implicit-def $sgpr0_sgpr1_sgpr2_sgpr3, implicit $sgpr0_sgpr1_sgpr2_sgpr3
29     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr1, 1, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
30     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr2, 2, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
31     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr3, 3, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
32     ; GCN: renamable $sgpr8 = COPY killed renamable $sgpr1
33     ; GCN: $sgpr0_sgpr1 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
34     ; GCN: $vgpr0 = BUFFER_LOAD_DWORD_OFFSET $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (load (s32) from %stack.1, addrspace 5)
35     ; GCN: $exec = S_MOV_B64 killed $sgpr0_sgpr1
36     ; GCN: S_ENDPGM 0, implicit $sgpr8
37     renamable $sgpr1 = COPY $sgpr2
38     SI_SPILL_S128_SAVE renamable $sgpr0_sgpr1_sgpr2_sgpr3, %stack.0, implicit $exec, implicit $sgpr32 :: (store (s128) into %stack.0, align 4, addrspace 5)
39     renamable $sgpr8 = COPY killed renamable $sgpr1
40     S_ENDPGM 0, implicit $sgpr8
41 ...
43 ---
44 name: spill_sgpr128_use_kill
45 tracksRegLiveness: true
46 machineFunctionInfo:
47   hasSpilledSGPRs: true
48   scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
49   stackPtrOffsetReg: $sgpr32
51 stack:
52   - { id: 0, stack-id: sgpr-spill, type: spill-slot, size: 16, alignment: 4 }
54 body:             |
55   bb.0:
56     liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
58     ; GCN-LABEL: name: spill_sgpr128_use_kill
59     ; GCN: liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
60     ; GCN: $sgpr8_sgpr9 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
61     ; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr0, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (store (s32) into %stack.1, addrspace 5)
62     ; GCN: $exec = S_MOV_B64 killed $sgpr8_sgpr9
63     ; GCN: renamable $sgpr1 = COPY $sgpr2
64     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr0, 0, $vgpr0, implicit-def $sgpr0_sgpr1_sgpr2_sgpr3, implicit $sgpr0_sgpr1_sgpr2_sgpr3
65     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr1, 1, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
66     ; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr2, 2, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
67     ; GCN: $vgpr0 = V_WRITELANE_B32 killed $sgpr3, 3, $vgpr0, implicit killed $sgpr0_sgpr1_sgpr2_sgpr3
68     ; GCN: $sgpr0_sgpr1 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
69     ; GCN: $vgpr0 = BUFFER_LOAD_DWORD_OFFSET $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (load (s32) from %stack.1, addrspace 5)
70     ; GCN: $exec = S_MOV_B64 killed $sgpr0_sgpr1
71     ; GCN: S_ENDPGM 0
72     renamable $sgpr1 = COPY $sgpr2
73     SI_SPILL_S128_SAVE renamable killed $sgpr0_sgpr1_sgpr2_sgpr3, %stack.0, implicit $exec, implicit $sgpr32 :: (store (s128) into %stack.0, align 4, addrspace 5)
74     S_ENDPGM 0
75 ...
77 ---
78 name: spill_vgpr128_use_subreg
79 tracksRegLiveness: true
80 machineFunctionInfo:
81   scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
82   stackPtrOffsetReg: $sgpr32
84 stack:
85   - { id: 0, type: spill-slot, size: 16, alignment: 4 }
87 body:             |
88   bb.0:
89     liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
91     ; GCN-LABEL: name: spill_vgpr128_use_subreg
92     ; GCN: liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
93     ; GCN: renamable $vgpr1 = COPY $vgpr2
94     ; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr0, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec, implicit-def $vgpr0_vgpr1_vgpr2_vgpr3, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0, addrspace 5)
95     ; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr1, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 4, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0 + 4, addrspace 5)
96     ; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr2, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 8, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0 + 8, addrspace 5)
97     ; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr3, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 12, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0 + 12, addrspace 5)
98     ; GCN: renamable $vgpr8 = COPY killed renamable $vgpr1
99     ; GCN: S_ENDPGM 0, implicit $vgpr8
100     renamable $vgpr1 = COPY $vgpr2
101     SI_SPILL_V128_SAVE renamable $vgpr0_vgpr1_vgpr2_vgpr3, %stack.0, $sgpr32, 0, implicit $exec :: (store (s128) into %stack.0, align 4, addrspace 5)
102     renamable $vgpr8 = COPY killed renamable $vgpr1
103     S_ENDPGM 0, implicit $vgpr8
107 name: spill_vgpr128_use_kill
108 tracksRegLiveness: true
109 machineFunctionInfo:
110   scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
111   stackPtrOffsetReg: $sgpr32
113 stack:
114   - { id: 0, type: spill-slot, size: 16, alignment: 4 }
116 body:             |
117   bb.0:
118     liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
120     ; GCN-LABEL: name: spill_vgpr128_use_kill
121     ; GCN: liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
122     ; GCN: renamable $vgpr1 = COPY $vgpr2
123     ; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr0, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec, implicit-def $vgpr0_vgpr1_vgpr2_vgpr3, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0, addrspace 5)
124     ; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr1, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 4, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0 + 4, addrspace 5)
125     ; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr2, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 8, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0 + 8, addrspace 5)
126     ; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr3, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 12, 0, 0, 0, implicit $exec, implicit killed $vgpr0_vgpr1_vgpr2_vgpr3 :: (store (s32) into %stack.0 + 12, addrspace 5)
127     ; GCN: S_ENDPGM 0
128     renamable $vgpr1 = COPY $vgpr2
129     SI_SPILL_V128_SAVE renamable killed $vgpr0_vgpr1_vgpr2_vgpr3, %stack.0, $sgpr32, 0, implicit $exec :: (store (s128) into %stack.0, align 4, addrspace 5)
130     S_ENDPGM 0