diff options
| author | Zachary Turner <zturner@google.com> | 2018-03-29 16:28:20 +0000 |
|---|---|---|
| committer | Zachary Turner <zturner@google.com> | 2018-03-29 16:28:20 +0000 |
| commit | ea40f40e1b024598fb1dbd56211c2f24cb703df2 (patch) | |
| tree | 9229b61a4aa5ff8bab244758d5845b0b05b11484 /llvm/test | |
| parent | c7cc87922e7e28487fd93b010d6de9ec7c0ef318 (diff) | |
| download | bcm5719-llvm-ea40f40e1b024598fb1dbd56211c2f24cb703df2.tar.gz bcm5719-llvm-ea40f40e1b024598fb1dbd56211c2f24cb703df2.zip | |
[PDB] Add an explain subcommand.
When investigating various things, we often have a file offset
and what to know what's in the PDB at that address. For example
we may be doing a binary comparison of two LLD-generated PDBs
to look for sources of non-determinism, or we may wish to compare
an LLD-generated PDB with a Microsoft generated PDB for sources
of byte-for-byte incompatibility. In these cases, we can do a
binary diff of the two files, and once we find a mismatched byte
we can use explain to figure out what that byte is, immediately
honining in on the problem.
This patch implements this by trying to narrow the meaning of
a particular file offset down as much as possible.
Differential Revision: https://reviews.llvm.org/D44959
llvm-svn: 328799
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/tools/llvm-pdbdump/explain.test | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/llvm/test/tools/llvm-pdbdump/explain.test b/llvm/test/tools/llvm-pdbdump/explain.test new file mode 100644 index 00000000000..9926eb01e35 --- /dev/null +++ b/llvm/test/tools/llvm-pdbdump/explain.test @@ -0,0 +1,83 @@ +; RUN: llvm-pdbutil explain -offset=0 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=ZERO %s +; RUN: llvm-pdbutil explain -offset=40 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=FORTY %s +; RUN: llvm-pdbutil explain -offset=60 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=SIXTY %s + +; RUN: llvm-pdbutil explain -offset=0x1000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=FPM1 %s +; RUN: llvm-pdbutil explain -offset=0x1100 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=EXTRANEOUSFPM %s +; RUN: llvm-pdbutil explain -offset=0x2000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=FPM2 %s + +; RUN: llvm-pdbutil explain -offset=0x3000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=UNALLOCATED %s + +; RUN: llvm-pdbutil explain -offset=0x7000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=STREAM %s + +; RUN: llvm-pdbutil explain -offset=0x1A000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=STREAMDIR %s + +; RUN: llvm-pdbutil explain -offset=0x1B000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=DIRBLOCKLIST %s + +; RUN: llvm-pdbutil explain -offset=0x1D000 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=INVALIDFILEOFFSET %s + +; RUN: llvm-pdbutil explain -offset=0xA100 %p/Inputs/InjectedSource.pdb \ +; RUN: | FileCheck --check-prefix=UNUSED %s + + +ZERO: Block:Offset = 0:0000. +ZERO-NEXT: Address is in block 0 (allocated). +ZERO-NEXT: This corresponds to offset 0 of MSF super block, +ZERO-NEXT: which is part of the MSF file magic. + +FORTY: Block:Offset = 0:0028. +FORTY-NEXT: Address is in block 0 (allocated). +FORTY-NEXT: This corresponds to offset 40 of MSF super block, +FORTY-NEXT: which contains the number of bytes in the stream directory. + +SIXTY: Block:Offset = 0:003C. +SIXTY-NEXT: Address is in block 0 (allocated). +SIXTY-NEXT: This corresponds to offset 60 of MSF super block, +SIXTY-NEXT: which is outside the range of valid data for the super block. + +FPM1: Block:Offset = 1:0000. +FPM1-NEXT: Address is in block 1 (allocated). +FPM1-NEXT: Address is in FPM1 (Alt FPM) +FPM1-NEXT: Address describes the allocation status of blocks [0,8) + +EXTRANEOUSFPM: Block:Offset = 1:0100. +EXTRANEOUSFPM-NEXT: Address is in block 1 (allocated). +EXTRANEOUSFPM-NEXT: Address is in FPM1 (Alt FPM) +EXTRANEOUSFPM-NEXT: Address is in extraneous FPM space. + +FPM2: Block:Offset = 2:0000. +FPM2-NEXT: Address is in block 2 (allocated). +FPM2-NEXT: Address is in FPM2 (Main FPM) +FPM2-NEXT: Address describes the allocation status of blocks [0,8) + +UNALLOCATED: Block:Offset = 3:0000. +UNALLOCATED-NEXT: Address is in block 3 (unallocated). + +STREAM: Block:Offset = 7:0000. +STREAM-NEXT: Address is in block 7 (allocated). +STREAM-NEXT: Address is at offset 0/684 of Stream 12 (Module "* Linker *"). + +STREAMDIR: Block:Offset = 1A:0000. +STREAMDIR-NEXT: Address is in block 26 (allocated). +STREAMDIR-NEXT: Address is at offset 0/156 of Stream Directory. + +DIRBLOCKLIST: Block:Offset = 1B:0000. +DIRBLOCKLIST-NEXT: Address is in block 27 (allocated). +DIRBLOCKLIST-NEXT: Address is at offset 0 of the directory block list + +INVALIDFILEOFFSET: Address 118784 is not in the file (file size = 118784). + +UNUSED: Block:Offset = A:0100. +UNUSED-NEXT: Address is in block 10 (allocated). +UNUSED-NEXT: Address is at offset 256/120 of Stream 11 (Section Header Data) in unused space. |

