diff options
author | Kevin Enderby <enderby@apple.com> | 2015-10-12 22:04:54 +0000 |
---|---|---|
committer | Kevin Enderby <enderby@apple.com> | 2015-10-12 22:04:54 +0000 |
commit | 903955451efae876b524d95c3a72b08ac977fc6d (patch) | |
tree | 2a008f087fa277865e843679792e03e2d21ee3b7 /llvm/lib/Object/Archive.cpp | |
parent | dc48412c938f39d51b8980db9f957cab30af671e (diff) | |
download | bcm5719-llvm-903955451efae876b524d95c3a72b08ac977fc6d.tar.gz bcm5719-llvm-903955451efae876b524d95c3a72b08ac977fc6d.zip |
Fixed bugs in llvm-obdump while parsing Mach-O files from malformed archives
that caused aborts. This was because of the characters of the ‘Size’ field in
the archive header did not contain decimal characters.
rdar://22983603
llvm-svn: 250117
Diffstat (limited to 'llvm/lib/Object/Archive.cpp')
-rw-r--r-- | llvm/lib/Object/Archive.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/Object/Archive.cpp b/llvm/lib/Object/Archive.cpp index 42fec39851d..b0e0881c789 100644 --- a/llvm/lib/Object/Archive.cpp +++ b/llvm/lib/Object/Archive.cpp @@ -50,6 +50,13 @@ uint32_t ArchiveMemberHeader::getSize() const { return Ret; } +bool ArchiveMemberHeader::isSizeValid() const { + uint32_t Ret; + if (llvm::StringRef(Size, sizeof(Size)).rtrim(" ").getAsInteger(10, Ret)) + return false; + return true; +} + sys::fs::perms ArchiveMemberHeader::getAccessMode() const { unsigned Ret; if (StringRef(AccessMode, sizeof(AccessMode)).rtrim(" ").getAsInteger(8, Ret)) @@ -89,6 +96,11 @@ Archive::Child::Child(const Archive *Parent, const char *Start) uint64_t Size = sizeof(ArchiveMemberHeader); Data = StringRef(Start, Size); + // Check to make sure the size is valid. + const ArchiveMemberHeader *Header = + reinterpret_cast<const ArchiveMemberHeader *>(Data.data()); + if (!Header->isSizeValid()) + return; if (!isThinMember()) { Size += getRawSize(); Data = StringRef(Start, Size); |