mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-21 20:12:56 +02:00
[codeview] Don't record UDTs for anonymous structs
MSVC makes up names for these anonymous structs, but we don't (yet). Eventually Clang should use getTypedefNameForAnonDecl() to put some name in the debug info, and we can update the test case when that happens. llvm-svn: 274391
This commit is contained in:
parent
96dade69b3
commit
d61604b293
@ -873,6 +873,10 @@ void CodeViewDebug::beginFunction(const MachineFunction *MF) {
|
||||
}
|
||||
|
||||
void CodeViewDebug::addToUDTs(const DIType *Ty, TypeIndex TI) {
|
||||
// Don't record empty UDTs.
|
||||
if (Ty->getName().empty())
|
||||
return;
|
||||
|
||||
SmallVector<StringRef, 5> QualifiedNameComponents;
|
||||
const DISubprogram *ClosestSubprogram = getQualifiedNameComponents(
|
||||
Ty->getScope().resolve(), QualifiedNameComponents);
|
||||
|
@ -15,6 +15,8 @@ target triple = "i686-pc-windows-msvc18.0.0"
|
||||
; p.x = s->x;
|
||||
; return p.f;
|
||||
; }
|
||||
; typedef struct { int x; } U;
|
||||
; U u;
|
||||
|
||||
; CHECK: ProcStart {
|
||||
; CHECK: DisplayName: f
|
||||
@ -43,82 +45,95 @@ target triple = "i686-pc-windows-msvc18.0.0"
|
||||
; CHECK: UDT {
|
||||
; CHECK-NEXT: Type: S (0x{{[0-9A-F]+}})
|
||||
; CHECK-NEXT: UDTName: S
|
||||
; CHECK: UDT {
|
||||
; CHECK-NEXT: Type: 0x{{[0-9A-F]+}}
|
||||
; CHECK-NEXT: UDTName: U
|
||||
; CHECK-NOT: UDT {
|
||||
|
||||
|
||||
%struct.U = type { i32 }
|
||||
%struct.S = type { i32 }
|
||||
%union.pun = type { i32 }
|
||||
|
||||
@"\01?u@@3UU@@A" = global %struct.U zeroinitializer, align 4
|
||||
|
||||
; Function Attrs: nounwind uwtable
|
||||
define void @"\01?f@@YAXXZ"() #0 !dbg !7 {
|
||||
define void @"\01?f@@YAXXZ"() #0 !dbg !14 {
|
||||
entry:
|
||||
%f = alloca i32, align 4
|
||||
call void @llvm.dbg.declare(metadata i32* %f, metadata !10, metadata !13), !dbg !14
|
||||
ret void, !dbg !15
|
||||
call void @llvm.dbg.declare(metadata i32* %f, metadata !17, metadata !19), !dbg !20
|
||||
ret void, !dbg !21
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
|
||||
|
||||
; Function Attrs: nounwind uwtable
|
||||
define float @"\01?g@@YAMPEAUS@@@Z"(%struct.S* %s) #0 !dbg !16 {
|
||||
define float @"\01?g@@YAMPEAUS@@@Z"(%struct.S* %s) #0 !dbg !22 {
|
||||
entry:
|
||||
%s.addr = alloca %struct.S*, align 8
|
||||
%p = alloca %union.pun, align 4
|
||||
store %struct.S* %s, %struct.S** %s.addr, align 8
|
||||
call void @llvm.dbg.declare(metadata %struct.S** %s.addr, metadata !24, metadata !13), !dbg !25
|
||||
call void @llvm.dbg.declare(metadata %union.pun* %p, metadata !26, metadata !13), !dbg !31
|
||||
%0 = load %struct.S*, %struct.S** %s.addr, align 8, !dbg !32
|
||||
%x = getelementptr inbounds %struct.S, %struct.S* %0, i32 0, i32 0, !dbg !33
|
||||
%1 = load i32, i32* %x, align 4, !dbg !33
|
||||
%x1 = bitcast %union.pun* %p to i32*, !dbg !34
|
||||
store i32 %1, i32* %x1, align 4, !dbg !35
|
||||
%f = bitcast %union.pun* %p to float*, !dbg !36
|
||||
%2 = load float, float* %f, align 4, !dbg !36
|
||||
ret float %2, !dbg !37
|
||||
call void @llvm.dbg.declare(metadata %struct.S** %s.addr, metadata !30, metadata !19), !dbg !31
|
||||
call void @llvm.dbg.declare(metadata %union.pun* %p, metadata !32, metadata !19), !dbg !37
|
||||
%0 = load %struct.S*, %struct.S** %s.addr, align 8, !dbg !38
|
||||
%x = getelementptr inbounds %struct.S, %struct.S* %0, i32 0, i32 0, !dbg !39
|
||||
%1 = load i32, i32* %x, align 4, !dbg !39
|
||||
%x1 = bitcast %union.pun* %p to i32*, !dbg !40
|
||||
store i32 %1, i32* %x1, align 4, !dbg !41
|
||||
%f = bitcast %union.pun* %p to float*, !dbg !42
|
||||
%2 = load float, float* %f, align 4, !dbg !42
|
||||
ret float %2, !dbg !43
|
||||
}
|
||||
|
||||
attributes #0 = { nounwind uwtable "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+fxsr,+mmx,+sse,+sse2,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" }
|
||||
attributes #1 = { nounwind readnone }
|
||||
|
||||
!llvm.dbg.cu = !{!0}
|
||||
!llvm.module.flags = !{!3, !4, !5}
|
||||
!llvm.ident = !{!6}
|
||||
!llvm.module.flags = !{!10, !11, !12}
|
||||
!llvm.ident = !{!13}
|
||||
|
||||
!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, producer: "clang version 3.9.0 (trunk 273566) (llvm/trunk 273570)", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2)
|
||||
!1 = !DIFile(filename: "t.cpp", directory: "/usr/local/google/work/llvm/build.release")
|
||||
!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, producer: "clang version 3.9.0 ", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, globals: !3)
|
||||
!1 = !DIFile(filename: "t.cpp", directory: "D:\5Csrc\5Cllvm\5Cbuild")
|
||||
!2 = !{}
|
||||
!3 = !{i32 2, !"CodeView", i32 1}
|
||||
!4 = !{i32 2, !"Debug Info Version", i32 3}
|
||||
!5 = !{i32 1, !"PIC Level", i32 2}
|
||||
!6 = !{!"clang version 3.9.0 (trunk 273566) (llvm/trunk 273570)"}
|
||||
!7 = distinct !DISubprogram(name: "f", linkageName: "\01?f@@YAXXZ", scope: !1, file: !1, line: 1, type: !8, isLocal: false, isDefinition: true, scopeLine: 1, flags: DIFlagPrototyped, isOptimized: false, unit: !0, variables: !2)
|
||||
!8 = !DISubroutineType(types: !9)
|
||||
!9 = !{null}
|
||||
!10 = !DILocalVariable(name: "f", scope: !7, file: !1, line: 3, type: !11)
|
||||
!11 = !DIDerivedType(tag: DW_TAG_typedef, name: "FOO", scope: !7, file: !1, line: 2, baseType: !12)
|
||||
!12 = !DIBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
||||
!13 = !DIExpression()
|
||||
!14 = !DILocation(line: 3, column: 7, scope: !7)
|
||||
!15 = !DILocation(line: 4, column: 1, scope: !7)
|
||||
!16 = distinct !DISubprogram(name: "g", linkageName: "\01?g@@YAMPEAUS@@@Z", scope: !1, file: !1, line: 7, type: !17, isLocal: false, isDefinition: true, scopeLine: 7, flags: DIFlagPrototyped, isOptimized: false, unit: !0, variables: !2)
|
||||
!17 = !DISubroutineType(types: !18)
|
||||
!18 = !{!19, !20}
|
||||
!19 = !DIBasicType(name: "float", size: 32, align: 32, encoding: DW_ATE_float)
|
||||
!20 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !21, size: 64, align: 64)
|
||||
!21 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "S", file: !1, line: 6, size: 32, align: 32, elements: !22, identifier: ".?AUS@@")
|
||||
!22 = !{!23}
|
||||
!23 = !DIDerivedType(tag: DW_TAG_member, name: "x", scope: !21, file: !1, line: 6, baseType: !12, size: 32, align: 32)
|
||||
!24 = !DILocalVariable(name: "s", arg: 1, scope: !16, file: !1, line: 7, type: !20)
|
||||
!25 = !DILocation(line: 7, column: 12, scope: !16)
|
||||
!26 = !DILocalVariable(name: "p", scope: !16, file: !1, line: 8, type: !27)
|
||||
!27 = distinct !DICompositeType(tag: DW_TAG_union_type, name: "pun", scope: !16, file: !1, line: 8, size: 32, align: 32, elements: !28)
|
||||
!28 = !{!29, !30}
|
||||
!29 = !DIDerivedType(tag: DW_TAG_member, name: "x", scope: !27, file: !1, line: 8, baseType: !12, size: 32, align: 32)
|
||||
!30 = !DIDerivedType(tag: DW_TAG_member, name: "f", scope: !27, file: !1, line: 8, baseType: !19, size: 32, align: 32)
|
||||
!31 = !DILocation(line: 8, column: 33, scope: !16)
|
||||
!32 = !DILocation(line: 9, column: 9, scope: !16)
|
||||
!33 = !DILocation(line: 9, column: 12, scope: !16)
|
||||
!34 = !DILocation(line: 9, column: 5, scope: !16)
|
||||
!35 = !DILocation(line: 9, column: 7, scope: !16)
|
||||
!36 = !DILocation(line: 10, column: 12, scope: !16)
|
||||
!37 = !DILocation(line: 10, column: 3, scope: !16)
|
||||
!3 = !{!4}
|
||||
!4 = distinct !DIGlobalVariable(name: "u", linkageName: "\01?u@@3UU@@A", scope: !0, file: !1, line: 13, type: !5, isLocal: false, isDefinition: true, variable: %struct.U* @"\01?u@@3UU@@A")
|
||||
!5 = !DIDerivedType(tag: DW_TAG_typedef, name: "U", file: !1, line: 12, baseType: !6)
|
||||
!6 = distinct !DICompositeType(tag: DW_TAG_structure_type, file: !1, line: 12, size: 32, align: 32, elements: !7, identifier: ".?AUU@@")
|
||||
!7 = !{!8}
|
||||
!8 = !DIDerivedType(tag: DW_TAG_member, name: "x", scope: !6, file: !1, line: 12, baseType: !9, size: 32, align: 32)
|
||||
!9 = !DIBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
||||
!10 = !{i32 2, !"CodeView", i32 1}
|
||||
!11 = !{i32 2, !"Debug Info Version", i32 3}
|
||||
!12 = !{i32 1, !"PIC Level", i32 2}
|
||||
!13 = !{!"clang version 3.9.0 "}
|
||||
!14 = distinct !DISubprogram(name: "f", linkageName: "\01?f@@YAXXZ", scope: !1, file: !1, line: 1, type: !15, isLocal: false, isDefinition: true, scopeLine: 1, flags: DIFlagPrototyped, isOptimized: false, unit: !0, variables: !2)
|
||||
!15 = !DISubroutineType(types: !16)
|
||||
!16 = !{null}
|
||||
!17 = !DILocalVariable(name: "f", scope: !14, file: !1, line: 3, type: !18)
|
||||
!18 = !DIDerivedType(tag: DW_TAG_typedef, name: "FOO", scope: !14, file: !1, line: 2, baseType: !9)
|
||||
!19 = !DIExpression()
|
||||
!20 = !DILocation(line: 3, column: 7, scope: !14)
|
||||
!21 = !DILocation(line: 4, column: 1, scope: !14)
|
||||
!22 = distinct !DISubprogram(name: "g", linkageName: "\01?g@@YAMPEAUS@@@Z", scope: !1, file: !1, line: 7, type: !23, isLocal: false, isDefinition: true, scopeLine: 7, flags: DIFlagPrototyped, isOptimized: false, unit: !0, variables: !2)
|
||||
!23 = !DISubroutineType(types: !24)
|
||||
!24 = !{!25, !26}
|
||||
!25 = !DIBasicType(name: "float", size: 32, align: 32, encoding: DW_ATE_float)
|
||||
!26 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !27, size: 64, align: 64)
|
||||
!27 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "S", file: !1, line: 6, size: 32, align: 32, elements: !28, identifier: ".?AUS@@")
|
||||
!28 = !{!29}
|
||||
!29 = !DIDerivedType(tag: DW_TAG_member, name: "x", scope: !27, file: !1, line: 6, baseType: !9, size: 32, align: 32)
|
||||
!30 = !DILocalVariable(name: "s", arg: 1, scope: !22, file: !1, line: 7, type: !26)
|
||||
!31 = !DILocation(line: 7, column: 12, scope: !22)
|
||||
!32 = !DILocalVariable(name: "p", scope: !22, file: !1, line: 8, type: !33)
|
||||
!33 = distinct !DICompositeType(tag: DW_TAG_union_type, name: "pun", scope: !22, file: !1, line: 8, size: 32, align: 32, elements: !34)
|
||||
!34 = !{!35, !36}
|
||||
!35 = !DIDerivedType(tag: DW_TAG_member, name: "x", scope: !33, file: !1, line: 8, baseType: !9, size: 32, align: 32)
|
||||
!36 = !DIDerivedType(tag: DW_TAG_member, name: "f", scope: !33, file: !1, line: 8, baseType: !25, size: 32, align: 32)
|
||||
!37 = !DILocation(line: 8, column: 33, scope: !22)
|
||||
!38 = !DILocation(line: 9, column: 9, scope: !22)
|
||||
!39 = !DILocation(line: 9, column: 12, scope: !22)
|
||||
!40 = !DILocation(line: 9, column: 5, scope: !22)
|
||||
!41 = !DILocation(line: 9, column: 7, scope: !22)
|
||||
!42 = !DILocation(line: 10, column: 12, scope: !22)
|
||||
!43 = !DILocation(line: 10, column: 3, scope: !22)
|
||||
|
Loading…
Reference in New Issue
Block a user