|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | extra times. NFC
llvm-svn: 248140 | 
| | 
| 
| 
| 
| 
| 
| | This function can actually fail since the symbol contains an index to the
section and that can be invalid.
llvm-svn: 244375 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Previously we kept going on partly corrupted input, which might result
in garbage being printed, or even worse, random crashes.
Rafael mentioned that this is the GNU behavior as well, but after some
discussion we both agreed it's probably better to emit a reasonable
error message and exit. As a side-effect of this commit, now we don't
rely on global state for error codes anymore. objdump was the last tool
in the toolchain which needed to be converted. Hopefully the old behavior
won't sneak into the tree again.
llvm-svn: 244019 | 
| | 
| 
| 
| 
| 
| 
| | It can fail trying to get the section on ELF and COFF. This makes sure the
error is handled.
llvm-svn: 241366 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This function can really fail since the string table offset can be out of
bounds.
Using ErrorOr makes sure the error is checked.
Hopefully a lot of the boilerplate code in tools/* can go away once we have
a diagnostic manager in Object.
llvm-svn: 241297 | 
| | 
| 
| 
| | llvm-svn: 241021 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | make_error_code(object_error) is slow because object::object_category()
uses a ManagedStatic variable. But the real problem is that the function is
called too frequently. This patch uses std::error_code() instead of
object_error::success. In most cases, we return "success", so this patch
reduces number of function calls to that function.
http://reviews.llvm.org/D10333
llvm-svn: 239409 | 
| | 
| 
| 
| | llvm-svn: 218916 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds support for reading the "bigobj" variant of COFF produced by
cl's /bigobj and mingw's -mbig-obj.
The most significant difference that bigobj brings is more than 2**16
sections to COFF.
bigobj brings a few interesting differences with it:
- It doesn't have a Characteristics field in the file header.
- It doesn't have a SizeOfOptionalHeader field in the file header (it's
  only used in executable files).
- Auxiliary symbol records have the same width as a symbol table entry.
  Since symbol table entries are bigger, so are auxiliary symbol
  records.
Write support will come soon.
Differential Revision: http://reviews.llvm.org/D5259
llvm-svn: 217496 | 
| | 
| 
| 
| | llvm-svn: 210876 | 
| | 
| 
| 
| | llvm-svn: 210866 | 
| | 
| 
| 
| 
| 
| 
| | This is a minimal change to remove the header. I will remove the occurrences
of "using std::error_code" in a followup patch.
llvm-svn: 210803 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | it work with range-based for loops.
Reviewers: ruiu
Reviewed By: ruiu
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D3097
llvm-svn: 204120 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Reviewers: rafael
Reviewed By: rafael
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D3077
llvm-svn: 203927 | 
| | 
| 
| 
| | llvm-svn: 203023 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Unwind info contents were indented at the same level as function table
contents. That's a bit confusing because the unwind info is pointed by
function table. In other places we usually increment indentation depth
by one when dereferncing a pointer.
This patch also removes extraneous newlines between function tables.
llvm-svn: 202879 | 
| | 
| 
| 
| | llvm-svn: 202875 | 
| | 
| 
| 
| | llvm-svn: 202787 | 
| | 
| 
| 
| | llvm-svn: 202786 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The original code does not work correctly on executable files because the
code is written in such a way that only object files are assumed to be given
to llvm-objdump.
Contents of RuntimeFunction are different between executables and objects. In
executables, fields in RuntimeFunction have actual addresses to unwind info
structures. On the other hand, in object files, the fields have zero value,
but instead there are relocations pointing to the fields, so that Linker will
fill them at link-time.
So, when we are reading an object file, we need to use relocation info to
find the location of unwind info. When executable, we should just look at the
values in RuntimeFunction.
llvm-svn: 202785 | 
| | 
| 
| 
| 
| 
| | No functionality change.
llvm-svn: 202781 | 
| | 
| 
| 
| | llvm-svn: 202772 | 
| | 
| 
| 
| 
| 
| | This is a small cleanup before making a bit larger change to this function.
llvm-svn: 202770 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The current COFF unwind printer tries to print SEH handler function names,
assuming that it can always find function names in string table. It crashes
if file being read has no symbol table (i.e. executable).
With this patch, llvm-objdump prints SEH handler's RVA if there's no symbol
table entry for that RVA.
llvm-svn: 202466 | 
| | 
| 
| 
| | llvm-svn: 202465 | 
| | 
| 
| 
| | llvm-svn: 202445 | 
| | 
| 
| 
| | llvm-svn: 201883 | 
| | 
| 
| 
| 
| 
| 
| | SEH table addresses are VA in COFF file. In this patch we convert VA to RVA
before printing it, because dumpbin prints them as RVAs.
llvm-svn: 201760 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Load Configuration Table may contain a pointer to SEH table. This patch is to
print the offset to the table. Printing SEH table contents is a TODO.
The layout of Layout Configuration Table is described in Microsoft PE/COFF
Object File Format Spec, but the table's offset/size descriptions seems to be
totally wrong, at least in revision 8.3 of the spec. I believe the table in
this patch is the correct one.
llvm-svn: 201638 | 
| | 
| 
| 
| | llvm-svn: 201108 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | None of the object file formats reported error on iterator increment. In
retrospect, that is not too surprising: no object format stores symbols or
sections in a linked list or other structure that requires chasing pointers.
As a consequence, all error checking can be done on begin() and end().
This reduces the text segment of bin/llvm-readobj in my machine from 521233 to
518526 bytes.
llvm-svn: 200442 | 
| | 
| 
| 
| 
| 
| 
| | Sweep the codebase for common typos. Includes some changes to visible function
names that were misspelt.
llvm-svn: 200018 | 
| | 
| 
| 
| | llvm-svn: 199518 | 
| | 
| 
| 
| | llvm-svn: 199423 | 
| | 
| 
| 
| | llvm-svn: 199422 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch adds the capability to dump export table contents. An example
output is this:
  Export Table:
   Ordinal      RVA  Name
         5   0x2008  exportfn1
         6   0x2010  exportfn2
By adding this feature to llvm-objdump, we will be able to use it to check
export table contents in LLD's tests. Currently we are doing binary
comparison in the tests, which is fragile and not readable to humans.
llvm-svn: 199358 | 
| | 
| 
| 
| 
| 
| 
| 
| | If a binary does not depend on any DLL, it does not contain import table at
all. Printing the section title without contents looks wrong, so we shouldn't
print it in that case.
llvm-svn: 199340 | 
| | 
| 
| 
| 
| 
| 
| | It is mentioned in the LLVM coding standard that _begin() and _end() suffixes
should be used.
llvm-svn: 191569 | 
| | 
| 
| 
| 
| | llvm-objdump: Dump COFF import table if -private-headers option is given.
llvm-svn: 191557 | 
| | 
| 
| 
| 
| 
| 
| 
| | given."
This reverts commit r191472 because it's failing on BE machine.
llvm-svn: 191480 | 
| | 
| 
| 
| | llvm-svn: 191474 | 
| | 
| 
| 
| | llvm-svn: 191473 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is a patch to add capability to llvm-objdump to dump COFF Import Table
entries, so that we can write tests for LLD checking Import Table contents.
llvm-objdump did not print anything but just file name if the format is COFF
and -private-headers option is given. This is a patch adds capability for
dumping DLL Import Table, which is specific to the COFF format.
In this patch I defined a new iterator to iterate over import table entries.
Also added a few functions to COFFObjectFile.cpp to access fields of the entry.
Differential Revision: http://llvm-reviews.chandlerc.com/D1719
llvm-svn: 191472 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | These records are mandatory for executables and are used by the loader.
Reviewers: rafael
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D939
llvm-svn: 183852 | 
| | 
| 
| 
| 
| 
| 
| 
| | In ELF (as in MachO), not all relocations point to symbols. Represent this
properly by using a symbol_iterator instead of a SymbolRef. Update llvm-readobj
ELF's dumper to handle relocatios without symbols.
llvm-svn: 183284 | 
| | 
| 
| 
| | llvm-svn: 171363 | 
| | 
| 
| 
| 
| 
| | these offsets are guaranteed to be correct by Endian.h.
llvm-svn: 169438 | 
|  | The new command line option -unwind-info dumps the Win64 EH unwind
data to the console. This is a nice feature if you need to debug
generated EH data (e.g. from LLVM). Includes a test case.
Initial patch by João Matos, extensions and rework by Kai Nacke.
llvm-svn: 169415 |