diff options
author | Reid Kleckner <rnk@google.com> | 2017-03-24 17:26:38 +0000 |
---|---|---|
committer | Reid Kleckner <rnk@google.com> | 2017-03-24 17:26:38 +0000 |
commit | 5d57752c8113d443789d0b9f72d5a96bb6e60b4a (patch) | |
tree | 21b4ff9f7f351b43878c823448a89358fbb453c4 /llvm/test/tools/llvm-readobj/codeview-merging.test | |
parent | 31c04590e64b69461476c80534bb89a1a6ec7674 (diff) | |
download | bcm5719-llvm-5d57752c8113d443789d0b9f72d5a96bb6e60b4a.tar.gz bcm5719-llvm-5d57752c8113d443789d0b9f72d5a96bb6e60b4a.zip |
[PDB] Split item and type records when merging type streams
Summary: MSVC does this when producing a PDB.
Reviewers: ruiu
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D31316
llvm-svn: 298717
Diffstat (limited to 'llvm/test/tools/llvm-readobj/codeview-merging.test')
-rw-r--r-- | llvm/test/tools/llvm-readobj/codeview-merging.test | 56 |
1 files changed, 52 insertions, 4 deletions
diff --git a/llvm/test/tools/llvm-readobj/codeview-merging.test b/llvm/test/tools/llvm-readobj/codeview-merging.test index 60894eff33e..4d453e5a116 100644 --- a/llvm/test/tools/llvm-readobj/codeview-merging.test +++ b/llvm/test/tools/llvm-readobj/codeview-merging.test @@ -21,6 +21,15 @@ RUN: llvm-readobj -codeview %S/Inputs/codeview-merging-1.obj | FileCheck %s --ch RUN: llvm-readobj -codeview %S/Inputs/codeview-merging-2.obj | FileCheck %s --check-prefix=OBJ2 RUN: llvm-readobj -codeview-merged-types %S/Inputs/codeview-merging-1.obj %S/Inputs/codeview-merging-2.obj | FileCheck %s +OBJ1: Procedure ({{.*}}) { +OBJ1-NEXT: TypeLeafKind: LF_PROCEDURE (0x1008) +OBJ1-NEXT: ReturnType: int (0x74) +OBJ1-NEXT: CallingConvention: NearC (0x0) +OBJ1-NEXT: FunctionOptions [ (0x0) +OBJ1-NEXT: ] +OBJ1-NEXT: NumParameters: 1 +OBJ1-NEXT: ArgListType: (A*) (0x1002) +OBJ1-NEXT: } OBJ1: FuncId (0x100D) { OBJ1-NEXT: TypeLeafKind: LF_FUNC_ID (0x1601) OBJ1-NEXT: ParentScope: 0x0 @@ -50,16 +59,55 @@ OBJ2-NEXT: Name: g OBJ2-NEXT: } OBJ2-NOT: FuncId -CHECK: FuncId (0x100D) { +CHECK: MergedTypeStream [ +CHECK: Procedure ({{.*}}) { +CHECK-NEXT: TypeLeafKind: LF_PROCEDURE (0x1008) +CHECK-NEXT: ReturnType: int (0x74) +CHECK-NEXT: CallingConvention: NearC (0x0) +CHECK-NEXT: FunctionOptions [ (0x0) +CHECK-NEXT: ] +CHECK-NEXT: NumParameters: 1 +CHECK-NEXT: ArgListType: (A*) (0x1002) +CHECK-NEXT: } +CHECK: Struct (0x1007) { +CHECK-NEXT: TypeLeafKind: LF_STRUCTURE (0x1505) +CHECK-NEXT: MemberCount: 1 +CHECK-NEXT: Properties [ (0x200) +CHECK-NEXT: HasUniqueName (0x200) +CHECK-NEXT: ] +CHECK-NEXT: FieldList: <field list> (0x1006) +CHECK-NEXT: DerivedFrom: 0x0 +CHECK-NEXT: VShape: 0x0 +CHECK-NEXT: SizeOf: 8 +CHECK-NEXT: Name: B +CHECK-NEXT: LinkageName: .?AUB@@ +CHECK-NEXT: } +CHECK: ] + +CHECK: MergedIDStream [ +CHECK-NEXT: StringId (0x1000) { +CHECK-NEXT: TypeLeafKind: LF_STRING_ID (0x1605) +CHECK-NEXT: Id: 0x0 +CHECK-NEXT: StringData: d:\src\llvm\build\t.cpp +CHECK-NEXT: } +# Test that we contextually dump item ids and type ids from different databases. +CHECK-NEXT: UdtSourceLine (0x1001) { +CHECK-NEXT: TypeLeafKind: LF_UDT_SRC_LINE (0x1606) +CHECK-NEXT: UDT: B (0x1007) +CHECK-NEXT: SourceFile: d:\src\llvm\build\t.cpp (0x1000) +CHECK-NEXT: LineNumber: 3 +CHECK-NEXT: } +CHECK: FuncId (0x1002) { CHECK-NEXT: TypeLeafKind: LF_FUNC_ID (0x1601) CHECK-NEXT: ParentScope: 0x0 -CHECK-NEXT: FunctionType: int (B*) (0x100C) +CHECK-NEXT: FunctionType: int (B*) CHECK-NEXT: Name: g CHECK-NEXT: } -CHECK-NEXT: FuncId (0x100E) { +CHECK-NEXT: FuncId (0x1003) { CHECK-NEXT: TypeLeafKind: LF_FUNC_ID (0x1601) CHECK-NEXT: ParentScope: 0x0 -CHECK-NEXT: FunctionType: int (A*) (0x1003) +CHECK-NEXT: FunctionType: int (A*) CHECK-NEXT: Name: f CHECK-NEXT: } CHECK-NOT: FuncId +CHECK: ] |