diff options
author | Nico Weber <thakis@chromium.org> | 2020-06-05 17:00:20 -0400 |
---|---|---|
committer | Nico Weber <thakis@chromium.org> | 2020-06-05 17:00:20 -0400 |
commit | 38f3ba591e3a64fa5bbe684b3171c7bda6c5b527 (patch) | |
tree | 47432f5326845411dd0ccd181d4cfd1bd626e37c /llvm/lib/Object/COFFObjectFile.cpp | |
parent | ad4e7b9dc82b13d124071f0add09cb541b495a0e (diff) | |
download | llvm-38f3ba591e3a64fa5bbe684b3171c7bda6c5b527.zip llvm-38f3ba591e3a64fa5bbe684b3171c7bda6c5b527.tar.gz llvm-38f3ba591e3a64fa5bbe684b3171c7bda6c5b527.tar.bz2 |
Revert "Migrate Binary::checkOffset from error_code to Error, NFC"
This reverts commit 74bd98829d82312676a60c5c2d142e20691b2f13.
Breaks LLVM::section-headers.test everywhere, see e.g.
http://lab.llvm.org:8011/builders/clang-x86_64-debian-fast/builds/29940/steps/test-check-all/logs/FAIL%3A%20LLVM%3A%3Asection-headers.test
Diffstat (limited to 'llvm/lib/Object/COFFObjectFile.cpp')
-rw-r--r-- | llvm/lib/Object/COFFObjectFile.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/llvm/lib/Object/COFFObjectFile.cpp b/llvm/lib/Object/COFFObjectFile.cpp index 3d12959..78bcfb1 100644 --- a/llvm/lib/Object/COFFObjectFile.cpp +++ b/llvm/lib/Object/COFFObjectFile.cpp @@ -59,8 +59,8 @@ static std::error_code getObject(const T *&Obj, MemoryBufferRef M, const void *Ptr, const uint64_t Size = sizeof(T)) { uintptr_t Addr = uintptr_t(Ptr); - if (Error E = Binary::checkOffset(M, Addr, Size)) - return errorToErrorCode(std::move(E)); + if (std::error_code EC = Binary::checkOffset(M, Addr, Size)) + return EC; Obj = reinterpret_cast<const T *>(Addr); return std::error_code(); } @@ -374,11 +374,9 @@ getFirstReloc(const coff_section *Sec, MemoryBufferRef M, const uint8_t *Base) { // relocations. begin++; } - if (auto E = Binary::checkOffset(M, uintptr_t(begin), - sizeof(coff_relocation) * NumRelocs)) { - consumeError(std::move(E)); + if (Binary::checkOffset(M, uintptr_t(begin), + sizeof(coff_relocation) * NumRelocs)) return nullptr; - } return begin; } @@ -557,8 +555,8 @@ std::error_code COFFObjectFile::initImportTablePtr() { uintptr_t IntPtr = 0; if (std::error_code EC = getRvaPtr(ImportTableRva, IntPtr)) return EC; - if (Error E = checkOffset(Data, IntPtr, DataEntry->Size)) - return errorToErrorCode(std::move(E)); + if (std::error_code EC = checkOffset(Data, IntPtr, DataEntry->Size)) + return EC; ImportDirectory = reinterpret_cast< const coff_import_directory_table_entry *>(IntPtr); return std::error_code(); @@ -1095,8 +1093,8 @@ Error COFFObjectFile::getSectionContents(const coff_section *Sec, // data, as there's nothing that says that is not allowed. uintptr_t ConStart = uintptr_t(base()) + Sec->PointerToRawData; uint32_t SectionSize = getSectionSize(Sec); - if (Error E = checkOffset(Data, ConStart, SectionSize)) - return E; + if (checkOffset(Data, ConStart, SectionSize)) + return make_error<BinaryError>(); Res = makeArrayRef(reinterpret_cast<const uint8_t *>(ConStart), SectionSize); return Error::success(); } |