Index: wasm/InputChunks.h =================================================================== --- wasm/InputChunks.h +++ wasm/InputChunks.h @@ -136,6 +136,7 @@ uint32_t getComdat() const override { return Function->Comdat; } const ArrayRef getFunctionBody() const { return Function->Body; } uint32_t getFunctionInputOffset() const { return getInputSectionOffset(); } + uint32_t getFunctionCodeOffset() const { return Function->CodeOffset; } uint32_t getFunctionIndex() const { return FunctionIndex.getValue(); } bool hasFunctionIndex() const { return FunctionIndex.hasValue(); } void setFunctionIndex(uint32_t Index); Index: wasm/InputFiles.cpp =================================================================== --- wasm/InputFiles.cpp +++ 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 @@ return MBRef; } -static size_t getFunctionCodeOffset(ArrayRef 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 @@ } case R_WEBASSEMBLY_FUNCTION_OFFSET_I32: if (auto *Sym = dyn_cast(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 @@ return getGlobalSymbol(Reloc.Index)->getGlobalIndex(); case R_WEBASSEMBLY_FUNCTION_OFFSET_I32: if (auto *Sym = dyn_cast(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: