@@ -45,6 +45,51 @@ 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 x8, sp
64
+ ; CHECK-NEXT: mov x19, sp
65
+ ; CHECK-NEXT: str s0, [x29, #28] // 4-byte Folded Spill
66
+ ; CHECK-NEXT: add x9, x9, #15
67
+ ; CHECK-NEXT: and x9, x9, #0xfffffffffffffff0
68
+ ; CHECK-NEXT: sub x8, x8, x9
69
+ ; CHECK-NEXT: mov sp, x8
70
+ ; CHECK-NEXT: //APP
71
+ ; CHECK-NEXT: //NO_APP
72
+ ; CHECK-NEXT: smstop sm
73
+ ; CHECK-NEXT: ldr s0, [x29, #28] // 4-byte Folded Reload
74
+ ; CHECK-NEXT: bl use_f
75
+ ; CHECK-NEXT: smstart sm
76
+ ; CHECK-NEXT: sub sp, x29, #64
77
+ ; CHECK-NEXT: ldp x24, x19, [sp, #112] // 16-byte Folded Reload
78
+ ; CHECK-NEXT: ldp x28, x25, [sp, #96] // 16-byte Folded Reload
79
+ ; CHECK-NEXT: ldp x29, x30, [sp, #64] // 16-byte Folded Reload
80
+ ; CHECK-NEXT: ldp d9, d8, [sp, #48] // 16-byte Folded Reload
81
+ ; CHECK-NEXT: ldp d11, d10, [sp, #32] // 16-byte Folded Reload
82
+ ; CHECK-NEXT: ldp d13, d12, [sp, #16] // 16-byte Folded Reload
83
+ ; CHECK-NEXT: ldp d15, d14, [sp], #128 // 16-byte Folded Reload
84
+ ; CHECK-NEXT: ret
85
+ %ptr2 = alloca i64 , i64 %n , align 8
86
+ %ptr = alloca <vscale x 16 x i8 >
87
+ call void asm sideeffect "" , "~{x24},~{x25}" () nounwind
88
+ call void @use_f (float %f )
89
+ ret void
90
+ }
91
+
48
92
declare void @use_f (float )
93
+ declare void @use_f_and_ptr (float , ptr )
49
94
50
95
attributes #0 = { nounwind "target-features" ="+sve,+sme" "aarch64_pstate_sm_enabled" }
0 commit comments