diff options
Diffstat (limited to 'lld/wasm/InputFiles.cpp')
-rw-r--r-- | lld/wasm/InputFiles.cpp | 18 |
1 files changed, 4 insertions, 14 deletions
diff --git a/lld/wasm/InputFiles.cpp b/lld/wasm/InputFiles.cpp index 5a798c7c2e8..dee8f07b4b6 100644 --- a/lld/wasm/InputFiles.cpp +++ b/lld/wasm/InputFiles.cpp @@ -16,7 +16,6 @@ #include "lld/Common/Memory.h" #include "llvm/Object/Binary.h" #include "llvm/Object/Wasm.h" -#include "llvm/Support/LEB128.h" #include "llvm/Support/raw_ostream.h" #define DEBUG_TYPE "lld" @@ -43,12 +42,6 @@ Optional<MemoryBufferRef> lld::wasm::readFile(StringRef Path) { return MBRef; } -static size_t getFunctionCodeOffset(ArrayRef<uint8_t> FunctionBody) { - unsigned Count; - llvm::decodeULEB128(FunctionBody.data(), &Count); - return Count; -} - void ObjFile::dumpInfo() const { log("info for: " + getName() + "\n Symbols : " + Twine(Symbols.size()) + @@ -105,10 +98,8 @@ uint32_t ObjFile::calcExpectedValue(const WasmRelocation &Reloc) const { } case R_WEBASSEMBLY_FUNCTION_OFFSET_I32: if (auto *Sym = dyn_cast<DefinedFunction>(getFunctionSymbol(Reloc.Index))) { - size_t FunctionCodeOffset = - getFunctionCodeOffset(Sym->Function->getFunctionBody()); - return Sym->Function->getFunctionInputOffset() + FunctionCodeOffset + - Reloc.Addend; + return Sym->Function->getFunctionInputOffset() + + Sym->Function->getFunctionCodeOffset() + Reloc.Addend; } return 0; case R_WEBASSEMBLY_SECTION_OFFSET_I32: @@ -145,9 +136,8 @@ uint32_t ObjFile::calcNewValue(const WasmRelocation &Reloc) const { return getGlobalSymbol(Reloc.Index)->getGlobalIndex(); case R_WEBASSEMBLY_FUNCTION_OFFSET_I32: if (auto *Sym = dyn_cast<DefinedFunction>(getFunctionSymbol(Reloc.Index))) { - size_t FunctionCodeOffset = - getFunctionCodeOffset(Sym->Function->getFunctionBody()); - return Sym->Function->OutputOffset + FunctionCodeOffset + Reloc.Addend; + return Sym->Function->OutputOffset + + Sym->Function->getFunctionCodeOffset() + Reloc.Addend; } return 0; case R_WEBASSEMBLY_SECTION_OFFSET_I32: |