mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Explanation: There was an inconsistency between non-const and const FRT pointers. The former used Direct_Unowned the latter used Indirect calling convention. We want to use Direct_Unowned for both cases. The crash was the result of a calling convention mismatch between the SILFunctionType of a Swift closure and the SILFunctionType of the C++ function's formal parameter that is taking a function pointer. The compiler tried to insert a conversion between the two function types that does not exist and caused an assertion in debug compilers and miscompilation in production compilers. Issue: rdar://149398905 Risk: Low, the fix is targeted and we change to a well-tested behavior with non-const FRT pointers. Testing: Regression test added. Original PR: #81070 Reviewer: @j-hui
29 lines
1.0 KiB
Swift
29 lines
1.0 KiB
Swift
// RUN: %target-swift-emit-ir %s -I %S/Inputs -enable-experimental-cxx-interop -validate-tbd-against-ir=none -disable-llvm-verify -Xcc -fignore-exceptions -disable-availability-checking | %FileCheck %s
|
|
|
|
import POD
|
|
|
|
// TODO: this should not be opaque.
|
|
// CHECK: %TSo7IntPairV = type <{ %Ts5Int32V, %Ts5Int32V }>
|
|
// CHECK: %struct.IntPair = type { i32, i32 }
|
|
|
|
// CHECK-LABEL: define {{.*}}swiftcc void @"$s4main4testyyF"
|
|
|
|
// CHECK: [[X:%.*]] = alloca ptr
|
|
|
|
// CHECK: [[CREATED:%.*]] = call ptr @{{_ZN7IntPair6createEv|"\?create\@IntPair\@\@SAPEAU1\@XZ"}}()
|
|
// CHECK: store ptr [[CREATED]], ptr [[X]]
|
|
|
|
// CHECK: [[B_FIELD:%.*]] = getelementptr inbounds %TSo7IntPairV, ptr [[CREATED]], i32 0, i32 1
|
|
// CHECK: [[INT_VALUE:%.*]] = getelementptr inbounds %Ts5Int32V, ptr [[B_FIELD]], i32 0, i32 0
|
|
// CHECK: store i32 42, ptr [[INT_VALUE]], align 4
|
|
|
|
// CHECK: call i32 @{{_ZNK7IntPair4testEv|"\?test\@IntPair\@\@QEBAHXZ"}}(ptr [[CREATED]])
|
|
|
|
// CHECK: ret void
|
|
|
|
public func test() {
|
|
var x = IntPair.create()
|
|
x.b = 42
|
|
_ = x.test()
|
|
}
|