diff --git a/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp b/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp --- a/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp @@ -2372,7 +2372,8 @@ // friends in the past, but modern versions do not. } } else if (auto *Composite = dyn_cast(Element)) { - Info.NestedTypes.push_back(Composite); + if (!Composite->getIdentifier().contains("@HasNested@@") !11 = !{!12} !12 = !DIEnumerator(name: "InnerEnumerator", value: 2) -!13 = !DICompositeType(tag: DW_TAG_structure_type, name: "InnerStruct", scope: !6, file: !3, line: 5, flags: DIFlagFwdDecl, identifier: ".?AUInnerStruct@HasNested@@") -!14 = !{!15} -!15 = !DIEnumerator(name: "_BUF_SIZE", value: 1) -!16 = !{!0} -!17 = !{i32 2, !"CodeView", i32 1} -!18 = !{i32 2, !"Debug Info Version", i32 3} -!19 = !{i32 1, !"wchar_size", i32 2} -!20 = !{i32 7, !"PIC Level", i32 2} -!21 = !{!"clang version 6.0.0 "} +!13 = !DICompositeType(tag: DW_TAG_structure_type, name: "InnerStruct", scope: !6, file: !3, line: 5, size: 8, flags: DIFlagFwdDecl, identifier: ".?AUInnerStruct@HasNested@@") +!14 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "", scope: !6, file: !3, line: 6, size: 32, flags: DIFlagTypePassByValue, elements: !15, identifier: ".?AU@HasNested@@") +!15 = !{!16} +!16 = !DIDerivedType(tag: DW_TAG_member, name: "i1", scope: !14, file: !3, line: 7, baseType: !9, size: 32) +!17 = !DIDerivedType(tag: DW_TAG_member, name: "unnamed_struct", scope: !6, file: !3, line: 8, baseType: !14, size: 32) +!18 = distinct !DICompositeType(tag: DW_TAG_structure_type, scope: !6, file: !3, line: 9, size: 32, flags: DIFlagExportSymbols | DIFlagTypePassByValue, elements: !19, identifier: ".?AU@HasNested@@") +!19 = !{!20} +!20 = !DIDerivedType(tag: DW_TAG_member, name: "i2", scope: !18, file: !3, line: 10, baseType: !9, size: 32) +!21 = !DIDerivedType(tag: DW_TAG_member, scope: !6, file: !3, line: 9, baseType: !18, size: 32, offset: 32) +!22 = distinct !DICompositeType(tag: DW_TAG_union_type, name: "", scope: !6, file: !3, line: 12, size: 32, flags: DIFlagTypePassByValue, elements: !23, identifier: ".?AT@HasNested@@") +!23 = !{!24} +!24 = !DIDerivedType(tag: DW_TAG_member, name: "i3", scope: !22, file: !3, line: 13, baseType: !9, size: 32) +!25 = !DIDerivedType(tag: DW_TAG_member, name: "unnamed_union", scope: !6, file: !3, line: 14, baseType: !22, size: 32, offset: 64) +!26 = distinct !DICompositeType(tag: DW_TAG_union_type, scope: !6, file: !3, line: 15, size: 32, flags: DIFlagExportSymbols | DIFlagTypePassByValue, elements: !27, identifier: ".?AT@HasNested@@") +!27 = !{!28} +!28 = !DIDerivedType(tag: DW_TAG_member, name: "i4", scope: !26, file: !3, line: 16, baseType: !9, size: 32) +!29 = !DIDerivedType(tag: DW_TAG_member, scope: !6, file: !3, line: 15, baseType: !26, size: 32, offset: 96) +!30 = !{!31} +!31 = !DIEnumerator(name: "_BUF_SIZE", value: 1) +!32 = !{!0} +!33 = !{!"/DEFAULTLIB:libcmt.lib"} +!34 = !{!"/DEFAULTLIB:oldnames.lib"} +!35 = !{i32 2, !"CodeView", i32 1} +!36 = !{i32 2, !"Debug Info Version", i32 3} +!37 = !{i32 1, !"wchar_size", i32 2} +!38 = !{i32 8, !"PIC Level", i32 2} +!39 = !{i32 7, !"uwtable", i32 2} +!40 = !{!"clang version 16.0.0"} + + +; CHECK: Struct ({{0x.*}}) { +; CHECK: LinkageName: .?AUHasNested@@ + +; CHECK: Struct ([[UNNAMED_STRUCT_FORWARD:0x.*]]) { +; CHECK-NEXT: TypeLeafKind: LF_STRUCTURE (0x1505) +; CHECK-NEXT: MemberCount: 0 +; CHECK-NEXT: Properties [ (0x288) +; CHECK-NEXT: ForwardReference (0x80) +; CHECK-NEXT: HasUniqueName (0x200) +; CHECK-NEXT: Nested (0x8) +; CHECK-NEXT: ] +; CHECK-NEXT: FieldList: 0x0 +; CHECK-NEXT: DerivedFrom: 0x0 +; CHECK-NEXT: VShape: 0x0 +; CHECK-NEXT: SizeOf: 0 +; CHECK-NEXT: Name: HasNested:: +; CHECK-NEXT: LinkageName: .?AU@HasNested@@ +; CHECK-NEXT: } + +; CHECK: Union ([[UNNAMED_UNION_FORWARD:0x.*]]) { +; CHECK-NEXT: TypeLeafKind: LF_UNION (0x1506) +; CHECK-NEXT: MemberCount: 0 +; CHECK-NEXT: Properties [ (0x288) +; CHECK-NEXT: ForwardReference (0x80) +; CHECK-NEXT: HasUniqueName (0x200) +; CHECK-NEXT: Nested (0x8) +; CHECK-NEXT: ] +; CHECK-NEXT: FieldList: 0x0 +; CHECK-NEXT: SizeOf: 0 +; CHECK-NEXT: Name: HasNested:: +; CHECK-NEXT: LinkageName: .?AT@HasNested@@ +; CHECK-NEXT: } ; InnerEnum: @@ -113,6 +183,34 @@ ; CHECK: FieldList ([[HASNESTED_MEMBERS:0x.*]]) { ; CHECK-NEXT: TypeLeafKind: LF_FIELDLIST (0x1203) +; CHECK-NEXT: DataMember { +; CHECK-NEXT: TypeLeafKind: LF_MEMBER (0x150D) +; CHECK-NEXT: AccessSpecifier: Public (0x3) +; CHECK-NEXT: Type: HasNested:: ([[UNNAMED_STRUCT_FORWARD]]) +; CHECK-NEXT: FieldOffset: 0x0 +; CHECK-NEXT: Name: unnamed_struct +; CHECK-NEXT: } +; CHECK-NEXT: DataMember { +; CHECK-NEXT: TypeLeafKind: LF_MEMBER (0x150D) +; CHECK-NEXT: AccessSpecifier: Public (0x3) +; CHECK-NEXT: Type: int (0x74) +; CHECK-NEXT: FieldOffset: 0x4 +; CHECK-NEXT: Name: i2 +; CHECK-NEXT: } +; CHECK-NEXT: DataMember { +; CHECK-NEXT: TypeLeafKind: LF_MEMBER (0x150D) +; CHECK-NEXT: AccessSpecifier: Public (0x3) +; CHECK-NEXT: Type: HasNested:: ([[UNNAMED_UNION_FORWARD]]) +; CHECK-NEXT: FieldOffset: 0x8 +; CHECK-NEXT: Name: unnamed_union +; CHECK-NEXT: } +; CHECK-NEXT: DataMember { +; CHECK-NEXT: TypeLeafKind: LF_MEMBER (0x150D) +; CHECK-NEXT: AccessSpecifier: Public (0x3) +; CHECK-NEXT: Type: int (0x74) +; CHECK-NEXT: FieldOffset: 0xC +; CHECK-NEXT: Name: i4 +; CHECK-NEXT: } ; CHECK-NEXT: NestedType { ; CHECK-NEXT: TypeLeafKind: LF_NESTTYPE (0x1510) ; CHECK-NEXT: Type: HasNested::InnerEnum ([[INNERENUM]]) @@ -137,7 +235,7 @@ ; ; CHECK: Struct (0x{{.*}}) { ; CHECK-NEXT: TypeLeafKind: LF_STRUCTURE (0x1505) -; CHECK-NEXT: MemberCount: 4 +; CHECK-NEXT: MemberCount: 8 ; CHECK-NEXT: Properties [ (0x210) ; CHECK-NEXT: ContainsNestedClass (0x10) ; CHECK-NEXT: HasUniqueName (0x200) @@ -145,7 +243,58 @@ ; CHECK-NEXT: FieldList: ([[HASNESTED_MEMBERS]]) ; CHECK-NEXT: DerivedFrom: 0x0 ; CHECK-NEXT: VShape: 0x0 -; CHECK-NEXT: SizeOf: 1 +; CHECK-NEXT: SizeOf: 16 ; CHECK-NEXT: Name: HasNested ; CHECK-NEXT: LinkageName: .?AUHasNested@@ ; CHECK-NEXT: } + +; CHECK: FieldList ([[UNNAMED_STRUCT_MEMBERS:0x.*]]) { +; CHECK-NEXT: TypeLeafKind: LF_FIELDLIST (0x1203) +; CHECK-NEXT: DataMember { +; CHECK-NEXT: TypeLeafKind: LF_MEMBER (0x150D) +; CHECK-NEXT: AccessSpecifier: Public (0x3) +; CHECK-NEXT: Type: int (0x74) +; CHECK-NEXT: FieldOffset: 0x0 +; CHECK-NEXT: Name: i1 +; CHECK-NEXT: } +; CHECK-NEXT: } + +; CHECK: Struct (0x{{.*}}) { +; CHECK-NEXT: TypeLeafKind: LF_STRUCTURE (0x1505) +; CHECK-NEXT: MemberCount: 1 +; CHECK-NEXT: Properties [ (0x208) +; CHECK-NEXT: HasUniqueName (0x200) +; CHECK-NEXT: Nested (0x8) +; CHECK-NEXT: ] +; CHECK-NEXT: FieldList: ([[UNNAMED_STRUCT_MEMBERS]]) +; CHECK-NEXT: DerivedFrom: 0x0 +; CHECK-NEXT: VShape: 0x0 +; CHECK-NEXT: SizeOf: 4 +; CHECK-NEXT: Name: HasNested:: +; CHECK-NEXT: LinkageName: .?AU@HasNested@@ +; CHECK-NEXT: } + +; CHECK: FieldList ([[UNNAMED_UNION_MEMBERS:0x.*]]) { +; CHECK-NEXT: TypeLeafKind: LF_FIELDLIST (0x1203) +; CHECK-NEXT: DataMember { +; CHECK-NEXT: TypeLeafKind: LF_MEMBER (0x150D) +; CHECK-NEXT: AccessSpecifier: Public (0x3) +; CHECK-NEXT: Type: int (0x74) +; CHECK-NEXT: FieldOffset: 0x0 +; CHECK-NEXT: Name: i3 +; CHECK-NEXT: } +; CHECK-NEXT: } + +; CHECK: Union (0x{{.*}}) { +; CHECK-NEXT: TypeLeafKind: LF_UNION (0x1506) +; CHECK-NEXT: MemberCount: 1 +; CHECK-NEXT: Properties [ (0x608) +; CHECK-NEXT: HasUniqueName (0x200) +; CHECK-NEXT: Nested (0x8) +; CHECK-NEXT: Sealed (0x400) +; CHECK-NEXT: ] +; CHECK-NEXT: FieldList: ([[UNNAMED_UNION_MEMBERS]]) +; CHECK-NEXT: SizeOf: 4 +; CHECK-NEXT: Name: HasNested:: +; CHECK-NEXT: LinkageName: .?AT@HasNested@@ +; CHECK-NEXT: }