mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
I am doing this separately from the actual change to eliminate the option to make it easier to review.
1014 lines
54 KiB
Plaintext
1014 lines
54 KiB
Plaintext
// RUN: %target-sil-opt -enable-objc-interop -enable-sil-verify-all -enable-expand-all -inline -function-signature-opts %s | %FileCheck %s
|
|
|
|
import Builtin
|
|
|
|
/////////////////////
|
|
// Data Structures //
|
|
/////////////////////
|
|
|
|
struct S0 {
|
|
var f : Builtin.Int16
|
|
}
|
|
|
|
struct S1 {
|
|
var f1 : Builtin.Int16
|
|
var f2 : Builtin.Int32
|
|
}
|
|
|
|
sil @i16_user : $@convention(thin) (Builtin.Int16) -> ()
|
|
sil @i32_user : $@convention(thin) (Builtin.Int32) -> ()
|
|
|
|
sil @s1_user : $@convention(thin) (S1) -> ()
|
|
sil @s1_ptr_user : $@convention(thin) (@in S1) -> ()
|
|
|
|
struct S2 {
|
|
var f1 : S1
|
|
var f2 : Builtin.Int64
|
|
}
|
|
|
|
struct S3 {
|
|
var f1 : S2
|
|
var f2 : S1
|
|
}
|
|
|
|
sil @s2_user : $@convention(thin) (S2) -> ()
|
|
|
|
class C1 {
|
|
var f1 : Builtin.Int32
|
|
|
|
init()
|
|
deinit
|
|
}
|
|
|
|
sil @c1_user : $@convention(thin) (C1) -> ()
|
|
|
|
class C2 {
|
|
var f1 : S3
|
|
var f2 : C1
|
|
|
|
init()
|
|
deinit
|
|
}
|
|
|
|
struct S4 {
|
|
var f1 : Builtin.NativeObject
|
|
}
|
|
|
|
struct S5 {
|
|
var f1 : S4
|
|
var f2 : S1
|
|
}
|
|
|
|
sil @s5_user : $@convention(thin) (S5) -> ()
|
|
|
|
struct S6 {
|
|
var f1 : S1
|
|
var f2 : S1
|
|
var f3 : (Builtin.Int32, Builtin.Int16, S1)
|
|
}
|
|
|
|
struct FakeStaticString {
|
|
var f1 : Builtin.RawPointer
|
|
var f2 : Builtin.Word
|
|
var f3 : Builtin.Word
|
|
}
|
|
|
|
sil @fakestaticstring_user : $@convention(thin) (FakeStaticString) -> ()
|
|
|
|
@objc protocol FakeAnyObject {}
|
|
struct FakeOpaquePointer {
|
|
var rawValue : Builtin.RawPointer
|
|
}
|
|
enum FakeOptional<T> {
|
|
case none
|
|
case some(T)
|
|
}
|
|
struct FakeUWord {
|
|
var value: Builtin.Word
|
|
}
|
|
|
|
struct FakeStringCore {
|
|
var baseAddress : FakeOpaquePointer
|
|
var countAndFlags : FakeUWord
|
|
var owner : FakeOptional<FakeAnyObject>
|
|
}
|
|
|
|
struct FakeString {
|
|
var core : FakeStringCore
|
|
}
|
|
sil @fakestring_user : $@convention(thin) (FakeString) -> ()
|
|
|
|
sil @tuple_user : $@convention(thin) ((Builtin.Int32, Builtin.Int16, S1)) -> ()
|
|
|
|
struct EightFieldStruct {
|
|
var a1 : Builtin.Int32
|
|
var a2 : Builtin.Int32
|
|
var a3 : Builtin.Int32
|
|
var a4 : Builtin.Int32
|
|
var a5 : Builtin.Int32
|
|
var a6 : Builtin.Int32
|
|
var a7 : Builtin.Int32
|
|
var a8 : Builtin.Int32
|
|
}
|
|
|
|
struct ThirtySixFieldStruct {
|
|
var b1 : EightFieldStruct
|
|
var b2 : EightFieldStruct
|
|
var b3 : EightFieldStruct
|
|
var b4 : EightFieldStruct
|
|
var b5 : EightFieldStruct
|
|
}
|
|
|
|
struct SingleFieldLvl1 {
|
|
var s2: SingleFieldLvl2
|
|
}
|
|
struct SingleFieldLvl2 {
|
|
var s3: SingleFieldLvl3
|
|
}
|
|
struct SingleFieldLvl3 {
|
|
var s4: Builtin.Int16
|
|
}
|
|
|
|
|
|
///////////
|
|
// Tests //
|
|
///////////
|
|
|
|
/// This checks the case where we have a single level hierarchy and the root is
|
|
/// dead.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @single_level_dead_root_callee : $@convention(thin) (S1) -> Builtin.Int32 {
|
|
// CHECK: bb0([[INPUT:%[0-9]+]] : $S1):
|
|
// CHECK: [[FN:%[0-9]+]] = function_ref @$s29single_level_dead_root_calleeTfq4x_n : $@convention(thin) (Builtin.Int32) -> Builtin.Int32
|
|
// CHECK: [[ARG:%.*]] = struct_extract [[INPUT]] : $S1, #S1.f2
|
|
// CHECK: apply [[FN]]([[ARG]])
|
|
sil [serialized] @single_level_dead_root_callee : $@convention(thin) (S1) -> Builtin.Int32 {
|
|
bb0(%0 : $S1):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%1 = struct_extract %0 : $S1, #S1.f2
|
|
return %1 : $Builtin.Int32
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @single_level_dead_root_caller : $@convention(thin) (S1) -> () {
|
|
// CHECK: bb0([[INPUT:%[0-9]+]] : $S1):
|
|
// CHECK: [[FN:%[0-9]+]] = function_ref @$s29single_level_dead_root_calleeTfq4x_n
|
|
sil [serialized] @single_level_dead_root_caller : $@convention(thin) (S1) -> () {
|
|
bb0(%0 : $S1):
|
|
%1 = function_ref @single_level_dead_root_callee : $@convention(thin) (S1) -> Builtin.Int32
|
|
%2 = apply %1(%0) : $@convention(thin) (S1) -> Builtin.Int32
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @single_level_live_root_callee : $@convention(thin) (S1) -> Builtin.Int32 {
|
|
// CHECK: bb0([[INPUT:%[0-9]+]] : $S1):
|
|
// CHECK: [[FN:%[0-9]+]] = function_ref @$s29single_level_live_root_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> Builtin.Int32
|
|
// CHECK: [[ARG2:%.*]] = struct_extract [[INPUT]] : $S1, #S1.f2
|
|
// CHECK: [[ARG1:%.*]] = struct_extract [[INPUT]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[ARG1]], [[ARG2]])
|
|
sil [serialized] @single_level_live_root_callee : $@convention(thin) (S1) -> Builtin.Int32 {
|
|
bb0(%0 : $S1):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%1 = struct_extract %0 : $S1, #S1.f2
|
|
%2 = function_ref @s1_user : $@convention(thin) (S1) -> ()
|
|
apply %2(%0) : $@convention(thin) (S1) -> ()
|
|
return %1 : $Builtin.Int32
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @single_level_live_root_caller : $@convention(thin) (S1) -> () {
|
|
// CHECK: bb0([[INPUT:%[0-9]+]] : $S1):
|
|
// CHECK: [[FN:%[0-9]+]] = function_ref @$s29single_level_live_root_calleeTfq4x_n
|
|
sil [serialized] @single_level_live_root_caller : $@convention(thin) (S1) -> () {
|
|
bb0(%0 : $S1):
|
|
%1 = function_ref @single_level_live_root_callee : $@convention(thin) (S1) -> Builtin.Int32
|
|
%2 = apply %1(%0) : $@convention(thin) (S1) -> Builtin.Int32
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test checks where we have a multiple level hierarchy, the root is dead,
|
|
// but the root has all fields used. This means that we should extract
|
|
// everything, but we should not "reform" the aggregate.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @multiple_level_all_root_fields_used_callee : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64) {
|
|
// CHECK: bb0([[INPUT:%.*]] : $S2):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s42multiple_level_all_root_fields_used_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[INPUT]] : $S2, #S2.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[INPUT]] : $S2, #S2.f1
|
|
// CHECK: [[EXT3:%.*]] = struct_extract [[EXT2]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT3]], [[EXT1]])
|
|
sil [serialized] @multiple_level_all_root_fields_used_callee : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64) {
|
|
bb0(%0 : $S2):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
debug_value %0 : $S2 // debug_value should not prevent function signature optimization
|
|
%1 = struct_extract %0 : $S2, #S2.f1
|
|
debug_value %1 : $S1 // debug_value should not prevent function signature optimization
|
|
%2 = struct_extract %1 : $S1, #S1.f1
|
|
%3 = struct_extract %0 : $S2, #S2.f2
|
|
%4 = tuple(%2 : $Builtin.Int16, %3 : $Builtin.Int64)
|
|
return %4 : $(Builtin.Int16, Builtin.Int64)
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @multiple_level_all_root_fields_used_caller : $@convention(thin) (S2) -> () {
|
|
// CHECK: bb0([[INPUT:%.*]] : $S2):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s42multiple_level_all_root_fields_used_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[INPUT]] : $S2, #S2.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[INPUT]] : $S2, #S2.f1
|
|
// CHECK: [[EXT3:%.*]] = struct_extract [[EXT2]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT3]], [[EXT1]])
|
|
sil [serialized] @multiple_level_all_root_fields_used_caller : $@convention(thin) (S2) -> () {
|
|
bb0(%0 : $S2):
|
|
%1 = function_ref @multiple_level_all_root_fields_used_callee : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64)
|
|
%2 = apply %1(%0) : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64)
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
/// This test checks a multiple level hierarchy where the root has no fields used.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @multiple_level_no_root_fields_have_direct_uses_callee : $@convention(thin) (S3) -> (Builtin.Int16, Builtin.Int64) {
|
|
// CHECK: bb0([[IN:%.*]] : $S3):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s53multiple_level_no_root_fields_have_direct_uses_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S3, #S3.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S3, #S3.f1
|
|
// CHECK: [[EXT3:%.*]] = struct_extract [[EXT2]] : $S2, #S2.f2
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT2]] : $S2, #S2.f1
|
|
// CHECK: [[EXT5:%.*]] = struct_extract [[EXT4]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT5]], [[EXT3]])
|
|
sil [serialized] @multiple_level_no_root_fields_have_direct_uses_callee : $@convention(thin) (S3) -> (Builtin.Int16, Builtin.Int64) {
|
|
bb0(%0 : $S3):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
debug_value %0 : $S3
|
|
%1 = struct_extract %0 : $S3, #S3.f1
|
|
%2 = struct_extract %1 : $S2, #S2.f1
|
|
%3 = struct_extract %2 : $S1, #S1.f1
|
|
%4 = struct_extract %1 : $S2, #S2.f2
|
|
%5 = tuple(%3 : $Builtin.Int16, %4 : $Builtin.Int64)
|
|
return %5 : $(Builtin.Int16, Builtin.Int64)
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @multiple_level_no_root_fields_have_direct_uses_caller : $@convention(thin) (S3) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $S3):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s53multiple_level_no_root_fields_have_direct_uses_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S3, #S3.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S3, #S3.f1
|
|
// CHECK: [[EXT3:%.*]] = struct_extract [[EXT2]] : $S2, #S2.f2
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT2]] : $S2, #S2.f1
|
|
// CHECK: [[EXT5:%.*]] = struct_extract [[EXT4]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT5]], [[EXT3]])
|
|
sil [serialized] @multiple_level_no_root_fields_have_direct_uses_caller : $@convention(thin) (S3) -> () {
|
|
bb0(%0 : $S3):
|
|
%1 = function_ref @multiple_level_no_root_fields_have_direct_uses_callee : $@convention(thin) (S3) -> (Builtin.Int16, Builtin.Int64)
|
|
%2 = apply %1(%0) : $@convention(thin) (S3) -> (Builtin.Int16, Builtin.Int64)
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test checks a multiple level hierarchy where the root has its own use
|
|
// and needs to be reformed via a struct.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @multiple_level_root_must_be_reformed_callee : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64) {
|
|
// CHECK: bb0([[IN:%.*]] : $S2):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s43multiple_level_root_must_be_reformed_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S2, #S2.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S2, #S2.f1
|
|
// CHECK: [[EXT3:%.*]] = struct_extract [[EXT2]] : $S1, #S1.f2
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT2]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT4]], [[EXT3]], [[EXT1]])
|
|
sil [serialized] @multiple_level_root_must_be_reformed_callee : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64) {
|
|
bb0(%0 : $S2):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%2 = struct_extract %0 : $S2, #S2.f1
|
|
%3 = struct_extract %2 : $S1, #S1.f1
|
|
%4 = struct_extract %0 : $S2, #S2.f2
|
|
%5 = tuple(%3 : $Builtin.Int16, %4 : $Builtin.Int64)
|
|
%6 = function_ref @s2_user : $@convention(thin) (S2) -> ()
|
|
apply %6(%0) : $@convention(thin) (S2) -> ()
|
|
return %5 : $(Builtin.Int16, Builtin.Int64)
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @multiple_level_root_must_be_reformed_caller : $@convention(thin) (S2) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $S2):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s43multiple_level_root_must_be_reformed_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S2, #S2.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S2, #S2.f1
|
|
// CHECK: [[EXT3:%.*]] = struct_extract [[EXT2]] : $S1, #S1.f2
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT2]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT4]], [[EXT3]], [[EXT1]])
|
|
sil [serialized] @multiple_level_root_must_be_reformed_caller : $@convention(thin) (S2) -> () {
|
|
bb0(%0 : $S2):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%1 = function_ref @multiple_level_root_must_be_reformed_callee : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64)
|
|
%2 = apply %1(%0) : $@convention(thin) (S2) -> (Builtin.Int16, Builtin.Int64)
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test checks if we can handle @owned structs correctly
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @owned_struct_1_callee : $@convention(thin) (@owned S5, @owned S5) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32) {
|
|
// CHECK: bb0([[IN1:%.*]] : $S5, [[IN2:%.*]] : $S5):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s21owned_struct_1_calleeTfq4dgX_n : $@convention(thin) (@guaranteed S4, Builtin.Int16, Builtin.Int32) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN2]] : $S5, #S5.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN2]] : $S5, #S5.f1
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f2
|
|
// CHECK: [[EXT5:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT2]], [[EXT5]], [[EXT4]]) : $@convention(thin) (@guaranteed S4, Builtin.Int16, Builtin.Int32) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
// CHECK: release_value [[IN]] : $S5
|
|
sil [serialized] @owned_struct_1_callee : $@convention(thin) (@owned S5, @owned S5) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32) {
|
|
bb0(%0 : $S5, %1 : $S5):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%2 = struct_extract %0 : $S5, #S5.f2
|
|
%3 = struct_extract %2 : $S1, #S1.f1
|
|
%4 = struct_extract %2 : $S1, #S1.f2
|
|
%5 = struct_extract %1 : $S5, #S5.f2
|
|
%6 = struct_extract %5 : $S1, #S1.f1
|
|
%7 = struct_extract %5 : $S1, #S1.f2
|
|
release_value %1 : $S5
|
|
release_value %0 : $S5
|
|
release_value %1 : $S5
|
|
%8 = tuple(%6 : $Builtin.Int16, %7 : $Builtin.Int32, %6 : $Builtin.Int16, %7 : $Builtin.Int32)
|
|
return %8 : $(Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @owned_struct_1_caller : $@convention(thin) (S5) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $S5):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s21owned_struct_1_calleeTfq4dgX_n : $@convention(thin) (@guaranteed S4, Builtin.Int16, Builtin.Int32) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S5, #S5.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S5, #S5.f1
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f2
|
|
// CHECK: [[EXT5:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT2]], [[EXT5]], [[EXT4]]) : $@convention(thin) (@guaranteed S4, Builtin.Int16, Builtin.Int32) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
// CHECK: release_value [[IN]] : $S5
|
|
sil [serialized] @owned_struct_1_caller : $@convention(thin) (S5) -> () {
|
|
bb0(%0 : $S5):
|
|
%1 = function_ref @owned_struct_1_callee : $@convention(thin) (@owned S5, @owned S5) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
%2 = apply %1(%0, %0) : $@convention(thin) (@owned S5, @owned S5) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test checks if we can properly insert arguments in between dead arguments.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @owned_struct_2_callee : $@convention(thin) (Builtin.Int256, Builtin.Int256, @owned S5, Builtin.Int128, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128) {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int256, [[IN2:%.*]] : $Builtin.Int256, [[IN3:%.*]] : $S5, [[IN4:%.*]] : $Builtin.Int128, [[IN5:%.*]] : $Builtin.Int128):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s21owned_struct_2_calleeTfq4ndgXdn_n : $@convention(thin) (Builtin.Int256, @guaranteed S4, Builtin.Int16, Builtin.Int32, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN3]] : $S5, #S5.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN3]] : $S5, #S5.f1
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f2
|
|
// CHECK: [[EXT5:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[IN1]], [[EXT2]], [[EXT5]], [[EXT4]], [[IN5]]) : $@convention(thin) (Builtin.Int256, @guaranteed S4, Builtin.Int16, Builtin.Int32, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
sil [serialized] @owned_struct_2_callee : $@convention(thin) (Builtin.Int256, Builtin.Int256, @owned S5, Builtin.Int128, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128) {
|
|
bb0(%0 : $Builtin.Int256, %1 : $Builtin.Int256, %2 : $S5, %3 : $Builtin.Int128, %4 : $Builtin.Int128):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%5 = struct_extract %2 : $S5, #S5.f2
|
|
%6 = struct_extract %5 : $S1, #S1.f1
|
|
%7 = struct_extract %5 : $S1, #S1.f2
|
|
%11 = function_ref @s5_user : $@convention(thin) (S5) -> ()
|
|
%12 = apply %11(%2) : $@convention(thin) (S5) -> ()
|
|
release_value %2 : $S5
|
|
%13 = tuple(%0 : $Builtin.Int256, %6 : $Builtin.Int16, %7 : $Builtin.Int32, %4 : $Builtin.Int128)
|
|
return %13 : $(Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
}
|
|
|
|
|
|
// CHECK-LABEL: sil [serialized] @owned_struct_2_caller : $@convention(thin) (Builtin.Int256, S5, Builtin.Int128) -> () {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int256, [[IN2:%.*]] : $S5, [[IN3:%.*]] : $Builtin.Int128):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s21owned_struct_2_calleeTfq4ndgXdn_n : $@convention(thin) (Builtin.Int256, @guaranteed S4, Builtin.Int16, Builtin.Int32, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN2]] : $S5, #S5.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN2]] : $S5, #S5.f1
|
|
// CHECK: [[EXT4:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f2
|
|
// CHECK: [[EXT5:%.*]] = struct_extract [[EXT1]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[IN1]], [[EXT2]], [[EXT5]], [[EXT4]], [[IN3]]) : $@convention(thin) (Builtin.Int256, @guaranteed S4, Builtin.Int16, Builtin.Int32, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
sil [serialized] @owned_struct_2_caller : $@convention(thin) (Builtin.Int256, S5, Builtin.Int128) -> () {
|
|
bb0(%0 : $Builtin.Int256, %1 : $S5, %2 : $Builtin.Int128):
|
|
%3 = function_ref @owned_struct_2_callee : $@convention(thin) (Builtin.Int256, Builtin.Int256, @owned S5, Builtin.Int128, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
%4 = apply %3(%0, %0, %1, %2, %2) : $@convention(thin) (Builtin.Int256, Builtin.Int256, @owned S5, Builtin.Int128, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
/// This test makes sure that we ignore pointer arguments for now.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @ignore_ptrs_callee : $@convention(thin) (@in S1, S1, S1) -> (Builtin.Int16, Builtin.Int16) {
|
|
// CHECK: bb0([[IN1:%.*]] : $*S1, [[IN2:%.*]] : $S1, [[IN3:%.*]] : $S1):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s18ignore_ptrs_calleeTfq4nxx_n : $@convention(thin) (@in S1, Builtin.Int16, Builtin.Int16) -> (Builtin.Int16, Builtin.Int16)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN2]] : $S1, #S1.f1
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN3]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[IN1]], [[EXT1]], [[EXT2]]) : $@convention(thin) (@in S1, Builtin.Int16, Builtin.Int16) -> (Builtin.Int16, Builtin.Int16)
|
|
sil [serialized] @ignore_ptrs_callee : $@convention(thin) (@in S1, S1, S1) -> (Builtin.Int16, Builtin.Int16) {
|
|
bb0(%0 : $*S1, %1 : $S1, %2 : $S1):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
debug_value %1 : $S1
|
|
debug_value %2 : $S1
|
|
%3 = function_ref @s1_ptr_user : $@convention(thin) (@in S1) -> ()
|
|
%4 = apply %3(%0) : $@convention(thin) (@in S1) -> ()
|
|
%5 = struct_extract %1 : $S1, #S1.f1
|
|
%6 = struct_extract %2 : $S1, #S1.f1
|
|
%7 = tuple(%5 : $Builtin.Int16, %6 : $Builtin.Int16)
|
|
return %7 : $(Builtin.Int16, Builtin.Int16)
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @ignore_ptrs_caller : $@convention(thin) (@in S1, S1, S1) -> () {
|
|
// CHECK: bb0([[IN1:%.*]] : $*S1, [[IN2:%.*]] : $S1, [[IN3:%.*]] : $S1):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s18ignore_ptrs_calleeTfq4nxx_n : $@convention(thin) (@in S1, Builtin.Int16, Builtin.Int16) -> (Builtin.Int16, Builtin.Int16)
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN2]] : $S1, #S1.f1
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN3]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[IN1]], [[EXT1]], [[EXT2]]) : $@convention(thin) (@in S1, Builtin.Int16, Builtin.Int16) -> (Builtin.Int16, Builtin.Int16)
|
|
sil [serialized] @ignore_ptrs_caller : $@convention(thin) (@in S1, S1, S1) -> () {
|
|
bb0(%0 : $*S1, %1 : $S1, %2 : $S1):
|
|
%3 = function_ref @ignore_ptrs_callee : $@convention(thin) (@in S1, S1, S1) -> (Builtin.Int16, Builtin.Int16)
|
|
%4 = apply %3(%0, %1, %2) : $@convention(thin) (@in S1, S1, S1) -> (Builtin.Int16, Builtin.Int16)
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test makes sure that we can handle multiple SROA arguments.
|
|
// CHECK-LABEL: sil [serialized] @multiple_sroa_callee : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> () {
|
|
// CHECK: bb0([[IN1:%.*]] : $FakeStaticString, [[IN2:%.*]] : $FakeString, [[IN3:%.*]] : $FakeStaticString):
|
|
// CHECK: [[FN:%.*]] = function_ref @fakestaticstring_user : $@convention(thin) (FakeStaticString) -> ()
|
|
// CHECK: apply [[FN]]([[IN1]]) : $@convention(thin) (FakeStaticString) -> ()
|
|
sil [serialized] @multiple_sroa_callee : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> () {
|
|
bb0(%0 : $FakeStaticString, %1 : $FakeString, %2 : $FakeStaticString):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%3 = function_ref @fakestaticstring_user : $@convention(thin) (FakeStaticString) -> ()
|
|
%4 = function_ref @fakestring_user : $@convention(thin) (FakeString) -> ()
|
|
apply %3(%0) : $@convention(thin) (FakeStaticString) -> ()
|
|
apply %4(%1) : $@convention(thin) (FakeString) -> ()
|
|
apply %3(%2) : $@convention(thin) (FakeStaticString) -> ()
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @multiple_sroa_caller : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> () {
|
|
// CHECK: bb0([[IN1:%.*]] : $FakeStaticString, [[IN2:%.*]] : $FakeString, [[IN3:%.*]] : $FakeStaticString):
|
|
// CHECK: [[FN:%.*]] = function_ref @multiple_sroa_callee : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> ()
|
|
sil [serialized] @multiple_sroa_caller : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> () {
|
|
bb0(%0 : $FakeStaticString, %1 : $FakeString, %2 : $FakeStaticString):
|
|
%3 = function_ref @multiple_sroa_callee : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> ()
|
|
%4 = apply %3(%0, %1, %2) : $@convention(thin) (FakeStaticString, @owned FakeString, FakeStaticString) -> ()
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test makes sure that we handle cases where the callee has field uses
|
|
// that are processed in a different order than the fields are layed out in the
|
|
// structure.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @check_out_of_order_uses_callee : $@convention(thin) (S1) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $S1):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s30check_out_of_order_uses_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> ()
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S1, #S1.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT2]], [[EXT1]]) : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> ()
|
|
sil [serialized] @check_out_of_order_uses_callee : $@convention(thin) (S1) -> () {
|
|
bb0(%0 : $S1):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
debug_value %0 : $S1
|
|
%1 = struct_extract %0 : $S1, #S1.f2
|
|
%2 = function_ref @i32_user : $@convention(thin) (Builtin.Int32) -> ()
|
|
apply %2(%1) : $@convention(thin) (Builtin.Int32) -> ()
|
|
%3 = struct_extract %0 : $S1, #S1.f1
|
|
%4 = function_ref @i16_user : $@convention(thin) (Builtin.Int16) -> ()
|
|
apply %4(%3) : $@convention(thin) (Builtin.Int16) -> ()
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @check_out_of_order_uses_caller : $@convention(thin) (S1) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $S1):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s30check_out_of_order_uses_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> ()
|
|
// CHECK: [[EXT1:%.*]] = struct_extract [[IN]] : $S1, #S1.f2
|
|
// CHECK: [[EXT2:%.*]] = struct_extract [[IN]] : $S1, #S1.f1
|
|
// CHECK: apply [[FN]]([[EXT2]], [[EXT1]]) : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> ()
|
|
sil [serialized] @check_out_of_order_uses_caller : $@convention(thin) (S1) -> () {
|
|
bb0(%0 : $S1):
|
|
%1 = function_ref @check_out_of_order_uses_callee : $@convention(thin) (S1) -> ()
|
|
apply %1(%0) : $@convention(thin) (S1) -> ()
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// Make sure that we do not SROA classes.
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @class_callee_1 : $@convention(thin) (@owned C1, Builtin.Int32) -> Builtin.Int32 {
|
|
// CHECK: bb0([[IN1:%.*]] : $C1, [[IN2:%.*]] : $Builtin.Int32):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s14class_callee_1Tfq4gn_n : $@convention(thin) (@guaranteed C1, Builtin.Int32) -> Builtin.Int32
|
|
// CHECK: apply [[FN]]([[IN1]], [[IN2]]) : $@convention(thin) (@guaranteed C1, Builtin.Int32) -> Builtin.Int32
|
|
// CHECK: release_value [[IN1]]
|
|
sil [serialized] @class_callee_1 : $@convention(thin) (@owned C1, Builtin.Int32) -> Builtin.Int32 {
|
|
bb0(%0 : $C1, %1 : $Builtin.Int32):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
// This use is needed so that we do not perform dead arg + owned -> guaranteed.
|
|
strong_retain %0 : $C1
|
|
%2 = function_ref @c1_user : $@convention(thin) (C1) -> ()
|
|
apply %2(%0) : $@convention(thin) (C1) -> ()
|
|
strong_release %0 : $C1
|
|
return %1 : $Builtin.Int32
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @class_caller_1 : $@convention(thin) (@owned C1, Builtin.Int32) -> Builtin.Int32 {
|
|
// CHECK: bb0([[IN1:%.*]] : $C1, [[IN2:%.*]] : $Builtin.Int32):
|
|
// CHECK: [[FN:%.*]] = function_ref @$s14class_callee_1Tfq4gn_n : $@convention(thin) (@guaranteed C1, Builtin.Int32) -> Builtin.Int32
|
|
// CHECK: apply [[FN]]([[IN1]], [[IN2]]) : $@convention(thin) (@guaranteed C1, Builtin.Int32) -> Builtin.Int32
|
|
// CHECK: release_value [[IN1]]
|
|
sil [serialized] @class_caller_1 : $@convention(thin) (@owned C1, Builtin.Int32) -> Builtin.Int32 {
|
|
bb0(%0 : $C1, %1 : $Builtin.Int32):
|
|
%2 = function_ref @class_callee_1 : $@convention(thin) (@owned C1, Builtin.Int32) -> Builtin.Int32
|
|
%3 = apply %2(%0, %1) : $@convention(thin) (@owned C1, Builtin.Int32) -> Builtin.Int32
|
|
return %3 : $Builtin.Int32
|
|
}
|
|
|
|
// Make sure we don't clone this despite the projection tree able to
|
|
// explode S0 if it was a loadable value.
|
|
// CHECK-LABEL: sil [serialized] @inarg_callee : $@convention(thin) (@in S1) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $*S1):
|
|
// CHECK: function_ref s1_ptr_user
|
|
// CHECK: [[FN:%.*]] = function_ref @s1_ptr_user : $@convention(thin) (@in S1) -> ()
|
|
// CHECK: apply [[FN]]
|
|
// CHECK: tuple
|
|
// CHECK: return
|
|
sil [serialized] @inarg_callee : $@convention(thin) (@in S1) -> () {
|
|
bb0(%0 : $*S1):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%1 = function_ref @s1_ptr_user : $@convention(thin) (@in S1) -> ()
|
|
%2 = apply %1(%0) : $@convention(thin) (@in S1) -> ()
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @inarg_caller : $@convention(thin) (@in S1) -> () {
|
|
// CHECK: bb0([[IN:%.*]] : $*S1):
|
|
// CHECK-NEXT: function_ref inarg_callee
|
|
// CHECK-NEXT: [[FN:%.*]] = function_ref @inarg_callee : $@convention(thin) (@in S1) -> ()
|
|
// CHECK-NEXT: apply [[FN]]
|
|
// CHECK-NEXT: tuple
|
|
// CHECK-NEXT: return
|
|
sil [serialized] @inarg_caller : $@convention(thin) (@in S1) -> () {
|
|
bb0(%0 : $*S1):
|
|
%1 = function_ref @inarg_callee : $@convention(thin) (@in S1) -> ()
|
|
%2 = apply %1(%0) : $@convention(thin) (@in S1) -> ()
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// This test makes sure we can handle functions with more than 32 fields
|
|
// (including each subtype's field in that count). This fixes a bug where we
|
|
// were not handling the possibility of an std::vector resize invalidated
|
|
// references. This cause the this pointer to become invalidated and other
|
|
// shenanigans. So just make sure we don't crash
|
|
// CHECK-LABEL: sil [serialized] @more_than_32_type_sized_caller : $@convention(thin) (ThirtySixFieldStruct) -> () {
|
|
sil [serialized] @more_than_32_type_sized_caller : $@convention(thin) (ThirtySixFieldStruct) -> () {
|
|
bb0(%0 : $ThirtySixFieldStruct):
|
|
%1 = function_ref @more_than_32_type_sized_callee : $@convention(thin) (ThirtySixFieldStruct) -> Builtin.Int32
|
|
%2 = apply %1(%0) : $@convention(thin) (ThirtySixFieldStruct) -> Builtin.Int32
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] [signature_optimized_thunk] [always_inline] @more_than_32_type_sized_callee : $@convention(thin) (ThirtySixFieldStruct) -> Builtin.Int32 {
|
|
sil [serialized] @more_than_32_type_sized_callee : $@convention(thin) (ThirtySixFieldStruct) -> Builtin.Int32 {
|
|
bb0(%0 : $ThirtySixFieldStruct):
|
|
// make it a non-trivial function
|
|
%c1 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c2 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c3 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c4 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c5 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c6 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c7 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c8 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c9 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c10 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c11 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c12 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c13 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c14 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c15 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c16 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c17 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c18 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c19 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c20 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c21 = builtin "assert_configuration"() : $Builtin.Int32
|
|
%c22 = builtin "assert_configuration"() : $Builtin.Int32
|
|
|
|
%1 = struct_extract %0 : $ThirtySixFieldStruct, #ThirtySixFieldStruct.b1
|
|
%2 = struct_extract %1 : $EightFieldStruct, #EightFieldStruct.a1
|
|
return %2 : $Builtin.Int32
|
|
}
|
|
|
|
// We should not specialize this since SingleFieldLvl1 is a struct that is layout compatible with its only leaf node, %0.s2.s3.s4
|
|
// CHECK-LABEL: sil [serialized] @multiple_level_all_single_field_struct_callee : $@convention(thin) (SingleFieldLvl1) -> Builtin.Int16 {
|
|
sil [serialized] @multiple_level_all_single_field_struct_callee : $@convention(thin) (SingleFieldLvl1) -> Builtin.Int16 {
|
|
bb0(%0 : $SingleFieldLvl1):
|
|
%1 = struct_extract %0 : $SingleFieldLvl1, #SingleFieldLvl1.s2
|
|
%2 = struct_extract %1 : $SingleFieldLvl2, #SingleFieldLvl2.s3
|
|
%3 = struct_extract %2 : $SingleFieldLvl3, #SingleFieldLvl3.s4
|
|
return %3 : $Builtin.Int16
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] @multiple_level_all_single_field_struct_caller : $@convention(thin) (SingleFieldLvl1) -> Builtin.Int16 {
|
|
sil [serialized] @multiple_level_all_single_field_struct_caller : $@convention(thin) (SingleFieldLvl1) -> Builtin.Int16 {
|
|
bb0(%0 : $SingleFieldLvl1):
|
|
%1 = function_ref @multiple_level_all_single_field_struct_callee : $@convention(thin) (SingleFieldLvl1) -> Builtin.Int16
|
|
%2 = apply %1(%0) : $@convention(thin) (SingleFieldLvl1) -> Builtin.Int16
|
|
return %2 : $Builtin.Int16
|
|
}
|
|
|
|
// Check Statements for generated code.
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s29single_level_dead_root_calleeTfq4x_n : $@convention(thin) (Builtin.Int32) -> Builtin.Int32 {
|
|
// CHECK: bb0([[IN:%.*]] : $Builtin.Int32):
|
|
// CHECK: [[UN:%.*]] = struct $S1 (undef : $Builtin.Int16, [[IN]] : $Builtin.Int32)
|
|
// CHECK: struct_extract [[UN]] : $S1, #S1.f2
|
|
// CHECK: return [[IN]] : $Builtin.Int32
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s29single_level_live_root_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> Builtin.Int32 {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int16, [[IN2:%.*]] : $Builtin.Int32):
|
|
// CHECK: [[STRUCT:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT2:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int32)
|
|
// CHECK: struct_extract [[STRUCT2]] : $S1, #S1.f2
|
|
// CHECK: [[FN:%.*]] = function_ref @s1_user : $@convention(thin) (S1) -> ()
|
|
// CHECK: apply [[FN]]([[STRUCT]])
|
|
// CHECK: return [[IN2]]
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s42multiple_level_all_root_fields_used_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64) {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int16, [[IN2:%.*]] : $Builtin.Int64):
|
|
// CHECK: [[STRUCT1:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, undef : $Builtin.Int32)
|
|
// CHECK: [[STRUCT2:%.*]] = struct $S2 (%2 : $S1, [[IN2]] : $Builtin.Int64)
|
|
// CHECK: debug_value [[STRUCT2]] : $S2
|
|
// CHECK: [[STRUCT3:%.*]] = struct_extract [[STRUCT2]] : $S2, #S2.f1
|
|
// CHECK: debug_value [[STRUCT3]] : $S1
|
|
// CHECK: [[OUT:%.*]] = tuple ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int64)
|
|
// CHECK: return [[OUT]]
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s53multiple_level_no_root_fields_have_direct_uses_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64) {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int16, [[IN2:%.*]] : $Builtin.Int64):
|
|
// CHECK: [[STRUCT1:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, undef : $Builtin.Int32)
|
|
// CHECK: [[STRUCT2:%.*]] = struct $S2 ([[STRUCT1]] : $S1, [[IN2]] : $Builtin.Int64)
|
|
// CHECK: [[STRUCT4:%.*]] = struct $S3 ([[STRUCT2]] : $S2, undef : $S1)
|
|
// CHECK: debug_value [[STRUCT4]]
|
|
// CHECK: [[OUT:%.*]] = tuple ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int64)
|
|
// CHECK: return [[OUT]]
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s43multiple_level_root_must_be_reformed_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32, Builtin.Int64) -> (Builtin.Int16, Builtin.Int64) {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int16, [[IN2:%.*]] : $Builtin.Int32, [[IN3:%.*]] : $Builtin.Int64):
|
|
// CHECK: [[STRUCT1:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT3:%.*]] = struct $S2 ([[STRUCT1]] : $S1, [[IN3]] : $Builtin.Int64)
|
|
// CHECK: [[STRUCT4:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT5:%.*]] = struct $S2 ([[STRUCT4]] : $S1, [[IN3]] : $Builtin.Int64)
|
|
// CHECK: struct_extract [[STRUCT5]] : $S2, #S2.f1
|
|
// CHECK: [[OUT:%.*]] = tuple ([[IN1]] : $Builtin.Int16, [[IN3]] : $Builtin.Int64)
|
|
// CHECK: [[FN:%.*]] = function_ref @s2_user : $@convention(thin) (S2) -> ()
|
|
// CHECK: apply [[FN]]([[STRUCT3]]) : $@convention(thin) (S2) -> ()
|
|
// CHECK: return [[OUT]] : $(Builtin.Int16, Builtin.Int64)
|
|
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s21owned_struct_1_calleeTfq4dgX_n : $@convention(thin) (@guaranteed S4, Builtin.Int16, Builtin.Int32) -> (Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32) {
|
|
// CHECK: bb0([[IN1:%.*]] : $S4, [[IN2:%.*]] : $Builtin.Int16, [[IN3:%.*]] : $Builtin.Int32):
|
|
// CHECK: [[STRUCT1:%.*]] = struct $S1 ([[IN2]] : $Builtin.Int16, [[IN3]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT3:%.*]] = struct $S5 ([[IN1]] : $S4, [[STRUCT1]] : $S1)
|
|
// CHECK: [[STRUCT5:%.*]] = struct $S1 ([[IN2]] : $Builtin.Int16, [[IN3]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT6:%.*]] = struct $S5 ([[IN1]] : $S4, [[STRUCT5]] : $S1)
|
|
// CHECK: struct_extract [[STRUCT6]] : $S5, #S5.f2
|
|
// CHECK: [[OUT:%.*]] = tuple ([[IN2]] : $Builtin.Int16, [[IN3]] : $Builtin.Int32, [[IN2]] : $Builtin.Int16, [[IN3]] : $Builtin.Int32)
|
|
// CHECK: return [[OUT]] : $(Builtin.Int16, Builtin.Int32, Builtin.Int16, Builtin.Int32)
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s21owned_struct_2_calleeTfq4ndgXdn_n : $@convention(thin) (Builtin.Int256, @guaranteed S4, Builtin.Int16, Builtin.Int32, Builtin.Int128) -> (Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128) {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int256, [[IN2:%.*]] : $S4, [[IN3:%.*]] : $Builtin.Int16, [[IN4:%.*]] : $Builtin.Int32, [[IN5:%.*]] : $Builtin.Int128):
|
|
// CHECK: [[STRUCT1:%.*]] = struct $S1 ([[IN3]] : $Builtin.Int16, [[IN4]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT3:%.*]] = struct $S5 ([[IN2]] : $S4, [[STRUCT1]] : $S1)
|
|
// CHECK: [[STRUCT5:%.*]] = struct $S1 ([[IN3]] : $Builtin.Int16, [[IN4]] : $Builtin.Int32)
|
|
// CHECK: [[STRUCT6:%.*]] = struct $S5 ([[IN2]] : $S4, [[STRUCT5]] : $S1)
|
|
// CHECK: struct_extract [[STRUCT6]] : $S5, #S5.f2
|
|
// CHECK: [[FN:%.*]] = function_ref @s5_user : $@convention(thin) (S5) -> ()
|
|
// CHECK: apply [[FN]]([[STRUCT3]]) : $@convention(thin) (S5) -> ()
|
|
// CHECK: [[OUT:%.*]] = tuple ([[IN1]] : $Builtin.Int256, [[IN3]] : $Builtin.Int16, [[IN4]] : $Builtin.Int32, [[IN5]] : $Builtin.Int128)
|
|
// CHECK: [[OUT]] : $(Builtin.Int256, Builtin.Int16, Builtin.Int32, Builtin.Int128)
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s18ignore_ptrs_calleeTfq4nxx_n : $@convention(thin) (@in S1, Builtin.Int16, Builtin.Int16) -> (Builtin.Int16, Builtin.Int16) {
|
|
// CHECK: bb0([[IN1:%.*]] : $*S1, [[IN2:%.*]] : $Builtin.Int16, [[IN3:%.*]] : $Builtin.Int16):
|
|
// CHECK: [[STRUCT2:%.*]] = struct $S1 ([[IN2]] : $Builtin.Int16, undef : $Builtin.Int32)
|
|
// CHECK: [[STRUCT1:%.*]] = struct $S1 ([[IN3]] : $Builtin.Int16, undef : $Builtin.Int32)
|
|
// CHECK: debug_value [[STRUCT2]]
|
|
// CHECK: debug_value [[STRUCT1]]
|
|
// CHECK: [[FN:%.*]] = function_ref @s1_ptr_user : $@convention(thin) (@in S1) -> ()
|
|
// CHECK: apply [[FN]]([[IN1]]) : $@convention(thin) (@in S1) -> ()
|
|
// CHECK: struct_extract [[STRUCT2]] : $S1, #S1.f1
|
|
// CHECK: struct_extract [[STRUCT1]] : $S1, #S1.f1
|
|
// CHECK: [[OUT:%.*]] = tuple ([[IN2]] : $Builtin.Int16, [[IN3]] : $Builtin.Int16)
|
|
// CHECK: return [[OUT]] : $(Builtin.Int16, Builtin.Int16)
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s30check_out_of_order_uses_calleeTfq4x_n : $@convention(thin) (Builtin.Int16, Builtin.Int32) -> () {
|
|
// CHECK: bb0([[IN1:%.*]] : $Builtin.Int16, [[IN2:%.*]] : $Builtin.Int32):
|
|
// CHECK: [[STRUCT0:%.*]] = struct $S1 ([[IN1]] : $Builtin.Int16, [[IN2]] : $Builtin.Int32)
|
|
// CHECK: debug_value [[STRUCT0]]
|
|
// CHECK: struct_extract [[STRUCT0]] : $S1, #S1.f2
|
|
// CHECK: [[FN1:%.*]] = function_ref @i32_user : $@convention(thin) (Builtin.Int32) -> ()
|
|
// CHECK: apply [[FN1]]([[IN2]]) : $@convention(thin) (Builtin.Int32) -> ()
|
|
// CHECK: struct_extract [[STRUCT0]] : $S1, #S1.f1
|
|
// CHECK: [[FN2:%.*]] = function_ref @i16_user : $@convention(thin) (Builtin.Int16) -> ()
|
|
// CHECK: apply [[FN2]]([[IN1]]) : $@convention(thin) (Builtin.Int16) -> ()
|
|
|
|
|
|
// CHECK-LABEL: sil shared [serialized] @$s14class_callee_1Tfq4gn_n : $@convention(thin) (@guaranteed C1, Builtin.Int32) -> Builtin.Int32 {
|
|
// CHECK: bb0({{%.*}} : $C1, [[IN:%.*]] : $Builtin.Int32):
|
|
// CHECK: return [[IN]] : $Builtin.Int32
|