summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Object/Archive.cpp
diff options
context:
space:
mode:
authorKevin Enderby <enderby@apple.com>2015-10-12 22:04:54 +0000
committerKevin Enderby <enderby@apple.com>2015-10-12 22:04:54 +0000
commit903955451efae876b524d95c3a72b08ac977fc6d (patch)
tree2a008f087fa277865e843679792e03e2d21ee3b7 /llvm/lib/Object/Archive.cpp
parentdc48412c938f39d51b8980db9f957cab30af671e (diff)
downloadbcm5719-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.cpp12
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);
OpenPOWER on IntegriCloud