diff options
author | Hans Wennborg <hans@hanshq.net> | 2018-05-08 08:22:58 +0000 |
---|---|---|
committer | Hans Wennborg <hans@hanshq.net> | 2018-05-08 08:22:58 +0000 |
commit | 5e6e6cc7213616038cc781ca21d9c532beb8e220 (patch) | |
tree | 36e281f7b00df19012e8ad55471b51850381fecb /llvm/lib/Object/Archive.cpp | |
parent | 98a1cab6947a60d404e72a0ce719f52f4590ecd9 (diff) | |
download | bcm5719-llvm-5e6e6cc7213616038cc781ca21d9c532beb8e220.tar.gz bcm5719-llvm-5e6e6cc7213616038cc781ca21d9c532beb8e220.zip |
Object: Find terminator correctly when reading long filenames in GNU archives (PR37244)
The code was previously relying on there being a null terminator
somewhere in (or after) the string table, something made less likely by
r330786.
Differential Revision: https://reviews.llvm.org/D46527
llvm-svn: 331746
Diffstat (limited to 'llvm/lib/Object/Archive.cpp')
-rw-r--r-- | llvm/lib/Object/Archive.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/llvm/lib/Object/Archive.cpp b/llvm/lib/Object/Archive.cpp index b17eefd220b..8ec115a5566 100644 --- a/llvm/lib/Object/Archive.cpp +++ b/llvm/lib/Object/Archive.cpp @@ -175,15 +175,19 @@ Expected<StringRef> ArchiveMemberHeader::getName(uint64_t Size) const { "the end of the string table for archive member " "header at offset " + Twine(ArchiveOffset)); } - const char *addr = Parent->getStringTable().begin() + StringOffset; // GNU long file names end with a "/\n". if (Parent->kind() == Archive::K_GNU || Parent->kind() == Archive::K_GNU64) { - StringRef::size_type End = StringRef(addr).find('\n'); - return StringRef(addr, End - 1); + size_t End = Parent->getStringTable().find('\n', /*From=*/StringOffset); + if (End == StringRef::npos || End < 1 || + Parent->getStringTable()[End - 1] != '/') { + return malformedError("string table at long name offset " + + Twine(StringOffset) + "not terminated"); + } + return Parent->getStringTable().slice(StringOffset, End - 1); } - return addr; + return Parent->getStringTable().begin() + StringOffset; } if (Name.startswith("#1/")) { |