mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
When a metadata pack is heap allocated, the pointer's LSB is set. But lldb is expecting a real pointer. So mask it off. Companion PR has a test: https://github.com/apple/llvm-project/pull/6961 rdar://110195273
24 lines
1.8 KiB
Swift
24 lines
1.8 KiB
Swift
// RUN: %target-swift-frontend -emit-ir %s -g -o - \
|
|
// RUN: -parse-as-library -module-name a | %IRGenFileCheck %s
|
|
|
|
public func foo<each T>(args: repeat each T) {
|
|
// CHECK: define {{.*}} @"$s1a3foo4argsyxxQp_tRvzlF"
|
|
// CHECK-SAME: %swift.type** %[[TYPE_PACK_ARG:.*]])
|
|
// CHECK: %[[TYPE_PACK_ALLOCA:.*]] = alloca %swift.type**
|
|
// CHECK: call void @llvm.dbg.declare(metadata %swift.type*** %[[TYPE_PACK_ALLOCA]], metadata ![[TYPE_PACK_VAR:[0-9]+]], metadata !DIExpression())
|
|
// CHECK: %[[ARGS_ALLOCA:.*]] = alloca %swift.opaque**
|
|
// CHECK-DAG: call void @llvm.dbg.declare(metadata %swift.opaque*** %[[ARGS_ALLOCA]], metadata ![[ARGS_VAR:[0-9]+]], metadata !DIExpression(DW_OP_deref))
|
|
// CHECK-DAG: %[[TYPE_PACK_ARG_INT:[^,]+]] = ptrtoint %swift.type** %[[TYPE_PACK_ARG]] to [[INT]]
|
|
// CHECK-DAG: %[[TYPE_PACK_ARG_MASKED_INT:[^,]+]] = and [[INT]] %[[TYPE_PACK_ARG_INT]], -2
|
|
// CHECK-DAG: %[[TYPE_PACK_ARG_MASKED:[^,]+]] = inttoptr [[INT]] %[[TYPE_PACK_ARG_MASKED_INT]] to %swift.type**
|
|
// CHECK-DAG: store %swift.type** %[[TYPE_PACK_ARG_MASKED]], %swift.type*** %[[TYPE_PACK_ALLOCA]]
|
|
// CHECK-DAG: store %swift.opaque** %0, %swift.opaque*** %[[ARGS_ALLOCA]]
|
|
// CHECK-DAG: ![[ARGS_VAR]] = !DILocalVariable(name: "args", arg: 1, {{.*}}line: [[@LINE-12]], type: ![[ARGS_LET_TY:[0-9]+]])
|
|
// CHECK-DAG: ![[ARGS_LET_TY]] = !DIDerivedType(tag: DW_TAG_const_type, baseType: ![[ARGS_TY:[0-9]+]])
|
|
// CHECK-DAG: ![[ARGS_TY]] = !DICompositeType({{.*}}identifier: "$sxxQp_QSiD")
|
|
// CHECK-DAG: ![[TYPE_PACK_VAR]] = !DILocalVariable(name: "$\CF\84_0_0", {{.*}}type: ![[TYPE_PACK_TYD:[0-9]+]], flags: DIFlagArtificial)
|
|
// CHECK-DAG: ![[TYPE_PACK_TYD]] = !DIDerivedType(tag: DW_TAG_typedef, name: "T", {{.*}}baseType: ![[TYPE_PACK_TY:[0-9]+]]
|
|
// CHECK-DAG: ![[TYPE_PACK_TY]] = !DIDerivedType(tag: DW_TAG_pointer_type, name: "$sBpD"
|
|
}
|
|
|