[ClosureLifetimeFixup] Cleanups get CleanupLocs.

This commit is contained in:
Nate Chandler
2022-12-12 12:26:17 -08:00
parent bf84d8dfe0
commit 9fbbab8045
2 changed files with 45 additions and 2 deletions

View File

@@ -1462,7 +1462,7 @@ void swift::insertDestroyOfCapturedArguments(
ApplySite site(pai); ApplySite site(pai);
SILFunctionConventions calleeConv(site.getSubstCalleeType(), SILFunctionConventions calleeConv(site.getSubstCalleeType(),
pai->getModule()); pai->getModule());
auto loc = RegularLocation::getAutoGeneratedLocation(); auto loc = CleanupLocation(RegularLocation::getAutoGeneratedLocation());
for (auto &arg : pai->getArgumentOperands()) { for (auto &arg : pai->getArgumentOperands()) {
if (!shouldInsertDestroy(arg.get())) if (!shouldInsertDestroy(arg.get()))
continue; continue;
@@ -1480,7 +1480,7 @@ void swift::insertDeallocOfCapturedArguments(
ApplySite site(pai); ApplySite site(pai);
SILFunctionConventions calleeConv(site.getSubstCalleeType(), SILFunctionConventions calleeConv(site.getSubstCalleeType(),
pai->getModule()); pai->getModule());
auto loc = RegularLocation::getAutoGeneratedLocation(); auto loc = CleanupLocation(RegularLocation::getAutoGeneratedLocation());
for (auto &arg : pai->getArgumentOperands()) { for (auto &arg : pai->getArgumentOperands()) {
unsigned calleeArgumentIndex = site.getCalleeArgIndex(arg); unsigned calleeArgumentIndex = site.getCalleeArgIndex(arg);
assert(calleeArgumentIndex >= calleeConv.getSILArgIndexOfFirstParam()); assert(calleeArgumentIndex >= calleeConv.getSILArgIndexOfFirstParam());

View File

@@ -0,0 +1,43 @@
// RUN: %target-sil-opt -enable-sil-verify-all -closure-lifetime-fixup -emit-verbose-sil %s | %FileCheck %s
import Builtin
import Swift
import SwiftShims
sil_scope 1 { loc "closure-lifetime-fixup-debuginfo.sil":12:34 parent @destroy_and_dealloc_of_capture_are_cleanups : $@convention(method) <Self where Self : Indexable> (@in Self) -> () }
sil_scope 2 { loc "closure-lifetime-fixup-debuginfo.sil":12:34 parent 1 }
protocol Indexable {
associatedtype Index
}
// Verify that the destroy_addr and dealloc_stack that are created for captured
// closure arguments are marked as cleanups.
// CHECK-LABEL: sil [ossa] @destroy_and_dealloc_of_capture_are_cleanups : {{.*}} {
// CHECK: [[CAPTURED_ADDR:%[^,]+]] = alloc_stack $Self
// CHECK: try_apply {{.*}}, normal [[SUCCESS:bb[0-9]+]]
// CHECK: [[SUCCESS]]
// CHECK: destroy_addr [[CAPTURED_ADDR]]{{.*}} // id: {{%[^,]+}}; <invalid loc>:cleanup:auto_gen
// ^^^^^^^
// CHECK: dealloc_stack [[CAPTURED_ADDR]]{{.*}} // id: {{%[^,]+}}; <invalid loc>:cleanup:auto_gen
// ^^^^^^^
// CHECK-LABEL: } // end sil function 'destroy_and_dealloc_of_capture_are_cleanups'
sil [ossa] @destroy_and_dealloc_of_capture_are_cleanups : $@convention(method) <Self where Self : Indexable> (@in Self) -> () {
bb0(%self : $*Self):
%copy = alloc_stack $Self, scope 1
copy_addr %self to [init] %copy : $*Self, scope 2
%closure = partial_apply [callee_guaranteed] undef<Self>(%copy) : $@convention(thin) <Tee where Tee : Indexable> (@in_guaranteed Tee) -> (@out Tee.Index, @error any Error), scope 2
%converted = convert_function %closure : $@callee_guaranteed () -> (@out Self.Index, @error any Error) to $@callee_guaranteed @substituted <Tee> () -> (@out Tee, @error any Error) for <Self.Index>, scope 2
%noescape = convert_escape_to_noescape [not_guaranteed] %converted : $@callee_guaranteed @substituted <Tee> () -> (@out Tee, @error any Error) for <Self.Index> to $@noescape @callee_guaranteed @substituted <Tee> () -> (@out Tee, @error any Error) for <Self.Index>, scope 2
try_apply undef<Self.Index>(%noescape) : $@convention(thin) <Tee> (@noescape @callee_guaranteed @substituted <Tee> () -> (@out Tee, @error any Error) for <Tee>) -> (@error any Error), normal bb1, error bb2, scope 2
bb1(%result : $()):
destroy_value %converted : $@callee_guaranteed @substituted <Tee> () -> (@out Tee, @error any Error) for <Self.Index>, scope 2
destroy_addr %self : $*Self, scope 2
%retval = tuple (), scope 2
dealloc_stack %copy : $*Self, scope 2
return %retval : $(), scope 2
bb2(%83 : @owned $any Error):
unreachable , scope 2
}