Skip to content

Commit fe7a044

Browse files
committed
Add test (which shows the issue)
1 parent 3c83102 commit fe7a044

File tree

1 file changed

+47
-0
lines changed

1 file changed

+47
-0
lines changed

llvm/test/CodeGen/AArch64/sme-streaming-mode-changing-call-disable-stackslot-scavenging.ll

Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,53 @@ define void @test_no_stackslot_scavenging(float %f) #0 {
4545
ret void
4646
}
4747

48+
define void @test_no_stackslot_scavenging_with_fp(float %f, i64 %n) #0 "frame-pointer"="all" {
49+
; CHECK-LABEL: test_no_stackslot_scavenging_with_fp:
50+
; CHECK: // %bb.0:
51+
; CHECK-NEXT: stp d15, d14, [sp, #-128]! // 16-byte Folded Spill
52+
; CHECK-NEXT: cntd x9
53+
; CHECK-NEXT: stp d13, d12, [sp, #16] // 16-byte Folded Spill
54+
; CHECK-NEXT: stp d11, d10, [sp, #32] // 16-byte Folded Spill
55+
; CHECK-NEXT: stp d9, d8, [sp, #48] // 16-byte Folded Spill
56+
; CHECK-NEXT: stp x29, x30, [sp, #64] // 16-byte Folded Spill
57+
; CHECK-NEXT: add x29, sp, #64
58+
; CHECK-NEXT: str x9, [sp, #80] // 8-byte Folded Spill
59+
; CHECK-NEXT: stp x28, x25, [sp, #96] // 16-byte Folded Spill
60+
; CHECK-NEXT: stp x24, x19, [sp, #112] // 16-byte Folded Spill
61+
; CHECK-NEXT: addvl sp, sp, #-1
62+
; CHECK-NEXT: lsl x9, x0, #3
63+
; CHECK-NEXT: mov x19, sp
64+
; CHECK-NEXT: addvl x8, x19, #1
65+
; CHECK-NEXT: add x9, x9, #15
66+
; CHECK-NEXT: str s0, [x8, #92] // 4-byte Folded Spill
67+
; CHECK-NEXT: mov x8, sp
68+
; CHECK-NEXT: and x9, x9, #0xfffffffffffffff0
69+
; CHECK-NEXT: sub x8, x8, x9
70+
; CHECK-NEXT: mov sp, x8
71+
; CHECK-NEXT: //APP
72+
; CHECK-NEXT: //NO_APP
73+
; CHECK-NEXT: smstop sm
74+
; CHECK-NEXT: addvl x8, x19, #1
75+
; CHECK-NEXT: ldr s0, [x8, #92] // 4-byte Folded Reload
76+
; CHECK-NEXT: bl use_f
77+
; CHECK-NEXT: smstart sm
78+
; CHECK-NEXT: sub sp, x29, #64
79+
; CHECK-NEXT: ldp x24, x19, [sp, #112] // 16-byte Folded Reload
80+
; CHECK-NEXT: ldp x28, x25, [sp, #96] // 16-byte Folded Reload
81+
; CHECK-NEXT: ldp x29, x30, [sp, #64] // 16-byte Folded Reload
82+
; CHECK-NEXT: ldp d9, d8, [sp, #48] // 16-byte Folded Reload
83+
; CHECK-NEXT: ldp d11, d10, [sp, #32] // 16-byte Folded Reload
84+
; CHECK-NEXT: ldp d13, d12, [sp, #16] // 16-byte Folded Reload
85+
; CHECK-NEXT: ldp d15, d14, [sp], #128 // 16-byte Folded Reload
86+
; CHECK-NEXT: ret
87+
%ptr2 = alloca i64, i64 %n, align 8
88+
%ptr = alloca <vscale x 16 x i8>
89+
call void asm sideeffect "", "~{x24},~{x25}"() nounwind
90+
call void @use_f(float %f)
91+
ret void
92+
}
93+
4894
declare void @use_f(float)
95+
declare void @use_f_and_ptr(float, ptr)
4996

5097
attributes #0 = { nounwind "target-features"="+sve,+sme" "aarch64_pstate_sm_enabled" }

0 commit comments

Comments
 (0)