2020-08-29 02:58:33 +08:00
|
|
|
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
|
|
|
|
# RUN: llc -march=amdgcn -mcpu=gfx900 -run-pass=si-lower-sgpr-spills,prologepilog,machine-cp -verify-machineinstrs %s -o - | FileCheck -check-prefix=GCN %s
|
|
|
|
|
|
|
|
# Make sure the initial first $sgpr1 = COPY $sgpr2 copy is not deleted
|
|
|
|
# by the copy propagation after lowering the spill.
|
|
|
|
|
|
|
|
---
|
|
|
|
name: spill_sgpr128_use_subreg
|
|
|
|
tracksRegLiveness: true
|
|
|
|
machineFunctionInfo:
|
|
|
|
hasSpilledSGPRs: true
|
|
|
|
scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
|
|
|
|
stackPtrOffsetReg: $sgpr32
|
|
|
|
|
|
|
|
stack:
|
|
|
|
- { id: 0, stack-id: sgpr-spill, type: spill-slot, size: 16, alignment: 4 }
|
|
|
|
|
|
|
|
body: |
|
|
|
|
bb.0:
|
|
|
|
liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
|
|
|
|
|
|
|
|
; GCN-LABEL: name: spill_sgpr128_use_subreg
|
|
|
|
; GCN: liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $sgpr8_sgpr9 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr0, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (store 4 into %stack.1, addrspace 5)
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $exec = S_MOV_B64 killed $sgpr8_sgpr9
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: renamable $sgpr1 = COPY $sgpr2
|
2020-10-16 06:40:02 +08:00
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr0, 0, $vgpr0, implicit-def $sgpr0_sgpr1_sgpr2_sgpr3, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
2020-10-29 20:10:56 +08:00
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr1, 1, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr2, 2, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr3, 3, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: renamable $sgpr8 = COPY killed renamable $sgpr1
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $sgpr0_sgpr1 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
; GCN: $vgpr0 = BUFFER_LOAD_DWORD_OFFSET $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (load 4 from %stack.1, addrspace 5)
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $exec = S_MOV_B64 killed $sgpr0_sgpr1
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: S_ENDPGM 0, implicit $sgpr8
|
|
|
|
renamable $sgpr1 = COPY $sgpr2
|
2020-11-10 08:40:35 +08:00
|
|
|
SI_SPILL_S128_SAVE renamable $sgpr0_sgpr1_sgpr2_sgpr3, %stack.0, implicit $exec, implicit $sgpr32 :: (store 16 into %stack.0, align 4, addrspace 5)
|
2020-08-29 02:58:33 +08:00
|
|
|
renamable $sgpr8 = COPY killed renamable $sgpr1
|
|
|
|
S_ENDPGM 0, implicit $sgpr8
|
|
|
|
...
|
|
|
|
|
|
|
|
---
|
|
|
|
name: spill_sgpr128_use_kill
|
|
|
|
tracksRegLiveness: true
|
|
|
|
machineFunctionInfo:
|
|
|
|
hasSpilledSGPRs: true
|
|
|
|
scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
|
|
|
|
stackPtrOffsetReg: $sgpr32
|
|
|
|
|
|
|
|
stack:
|
|
|
|
- { id: 0, stack-id: sgpr-spill, type: spill-slot, size: 16, alignment: 4 }
|
|
|
|
|
|
|
|
body: |
|
|
|
|
bb.0:
|
|
|
|
liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
|
|
|
|
|
|
|
|
; GCN-LABEL: name: spill_sgpr128_use_kill
|
|
|
|
; GCN: liveins: $sgpr0, $sgpr1, $sgpr2, $sgpr3, $sgpr4, $sgpr5, $sgpr6, $sgpr7, $vgpr0, $vgpr1, $vgpr2, $vgpr3
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $sgpr8_sgpr9 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr0, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (store 4 into %stack.1, addrspace 5)
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $exec = S_MOV_B64 killed $sgpr8_sgpr9
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: renamable $sgpr1 = COPY $sgpr2
|
2020-10-16 06:40:02 +08:00
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr0, 0, $vgpr0, implicit-def $sgpr0_sgpr1_sgpr2_sgpr3, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
2020-10-29 20:10:56 +08:00
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr1, 1, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 $sgpr2, 2, $vgpr0, implicit $sgpr0_sgpr1_sgpr2_sgpr3
|
|
|
|
; GCN: $vgpr0 = V_WRITELANE_B32 killed $sgpr3, 3, $vgpr0, implicit killed $sgpr0_sgpr1_sgpr2_sgpr3
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $sgpr0_sgpr1 = S_OR_SAVEEXEC_B64 -1, implicit-def $exec, implicit-def $scc, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
; GCN: $vgpr0 = BUFFER_LOAD_DWORD_OFFSET $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 0, 0, 0, 0, implicit $exec :: (load 4 from %stack.1, addrspace 5)
|
2021-02-18 05:37:46 +08:00
|
|
|
; GCN: $exec = S_MOV_B64 killed $sgpr0_sgpr1
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: S_ENDPGM 0
|
|
|
|
renamable $sgpr1 = COPY $sgpr2
|
2020-11-10 08:40:35 +08:00
|
|
|
SI_SPILL_S128_SAVE renamable killed $sgpr0_sgpr1_sgpr2_sgpr3, %stack.0, implicit $exec, implicit $sgpr32 :: (store 16 into %stack.0, align 4, addrspace 5)
|
2020-08-29 02:58:33 +08:00
|
|
|
S_ENDPGM 0
|
|
|
|
...
|
|
|
|
|
|
|
|
---
|
|
|
|
name: spill_vgpr128_use_subreg
|
|
|
|
tracksRegLiveness: true
|
|
|
|
machineFunctionInfo:
|
|
|
|
scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
|
|
|
|
stackPtrOffsetReg: $sgpr32
|
|
|
|
|
|
|
|
stack:
|
|
|
|
- { id: 0, type: spill-slot, size: 16, alignment: 4 }
|
|
|
|
|
|
|
|
body: |
|
|
|
|
bb.0:
|
|
|
|
liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
|
|
|
|
|
|
|
|
; GCN-LABEL: name: spill_vgpr128_use_subreg
|
|
|
|
; GCN: liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
|
|
|
|
; GCN: renamable $vgpr1 = COPY $vgpr2
|
2021-02-09 08:36:10 +08:00
|
|
|
; 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 4 into %stack.0, addrspace 5)
|
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr1, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 4, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store 4 into %stack.0 + 4, addrspace 5)
|
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr2, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 8, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store 4 into %stack.0 + 8, addrspace 5)
|
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET $vgpr3, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 12, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store 4 into %stack.0 + 12, addrspace 5)
|
2020-10-15 06:10:54 +08:00
|
|
|
; GCN: renamable $vgpr8 = COPY killed renamable $vgpr1
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: S_ENDPGM 0, implicit $vgpr8
|
|
|
|
renamable $vgpr1 = COPY $vgpr2
|
2020-11-10 08:40:35 +08:00
|
|
|
SI_SPILL_V128_SAVE renamable $vgpr0_vgpr1_vgpr2_vgpr3, %stack.0, $sgpr32, 0, implicit $exec :: (store 16 into %stack.0, align 4, addrspace 5)
|
2020-08-29 02:58:33 +08:00
|
|
|
renamable $vgpr8 = COPY killed renamable $vgpr1
|
|
|
|
S_ENDPGM 0, implicit $vgpr8
|
|
|
|
...
|
|
|
|
|
|
|
|
---
|
|
|
|
name: spill_vgpr128_use_kill
|
|
|
|
tracksRegLiveness: true
|
|
|
|
machineFunctionInfo:
|
|
|
|
scratchRSrcReg: $sgpr100_sgpr101_sgpr102_sgpr103
|
|
|
|
stackPtrOffsetReg: $sgpr32
|
|
|
|
|
|
|
|
stack:
|
|
|
|
- { id: 0, type: spill-slot, size: 16, alignment: 4 }
|
|
|
|
|
|
|
|
body: |
|
|
|
|
bb.0:
|
|
|
|
liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
|
|
|
|
|
|
|
|
; GCN-LABEL: name: spill_vgpr128_use_kill
|
|
|
|
; GCN: liveins: $vgpr0, $vgpr1, $vgpr2, $vgpr3, $vgpr4, $vgpr5, $vgpr6, $vgpr7
|
|
|
|
; GCN: renamable $vgpr1 = COPY $vgpr2
|
2021-02-09 08:36:10 +08:00
|
|
|
; 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 4 into %stack.0, addrspace 5)
|
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr1, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 4, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store 4 into %stack.0 + 4, addrspace 5)
|
|
|
|
; GCN: BUFFER_STORE_DWORD_OFFSET killed $vgpr2, $sgpr100_sgpr101_sgpr102_sgpr103, $sgpr32, 8, 0, 0, 0, implicit $exec, implicit $vgpr0_vgpr1_vgpr2_vgpr3 :: (store 4 into %stack.0 + 8, addrspace 5)
|
|
|
|
; 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 4 into %stack.0 + 12, addrspace 5)
|
2020-08-29 02:58:33 +08:00
|
|
|
; GCN: S_ENDPGM 0
|
|
|
|
renamable $vgpr1 = COPY $vgpr2
|
2020-11-10 08:40:35 +08:00
|
|
|
SI_SPILL_V128_SAVE renamable killed $vgpr0_vgpr1_vgpr2_vgpr3, %stack.0, $sgpr32, 0, implicit $exec :: (store 16 into %stack.0, align 4, addrspace 5)
|
2020-08-29 02:58:33 +08:00
|
|
|
S_ENDPGM 0
|
|
|
|
...
|