@@ -45,6 +45,53 @@ define void @test_no_stackslot_scavenging(float %f) #0 {
45
45
ret void
46
46
}
47
47
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
+
48
94
declare void @use_f (float )
95
+ declare void @use_f_and_ptr (float , ptr )
49
96
50
97
attributes #0 = { nounwind "target-features" ="+sve,+sme" "aarch64_pstate_sm_enabled" }
0 commit comments