
Previously when objcopy generated section headers, it padded the LEB that encodes the section size out to 5 bytes, matching the behavior of clang. This is correct, but results in a binary that differs from the input. This can sometimes have undesirable consequences (e.g. breaking source maps). This change makes the object reader remember the size of the LEB encoding in the section header, so that llvm-objcopy can reproduce it exactly. For sections not read from an object file (e.g. that llvm-objcopy is adding itself), pad to 5 bytes. Reviewed By: jhenderson Differential Revision: https://reviews.llvm.org/D155535
40 lines
1.4 KiB
C++
40 lines
1.4 KiB
C++
//===- WasmReader.cpp -----------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "WasmReader.h"
|
|
|
|
namespace llvm {
|
|
namespace objcopy {
|
|
namespace wasm {
|
|
|
|
using namespace object;
|
|
using namespace llvm::wasm;
|
|
|
|
Expected<std::unique_ptr<Object>> Reader::create() const {
|
|
auto Obj = std::make_unique<Object>();
|
|
Obj->Header = WasmObj.getHeader();
|
|
std::vector<Section> Sections;
|
|
Obj->Sections.reserve(WasmObj.getNumSections());
|
|
for (const SectionRef &Sec : WasmObj.sections()) {
|
|
const WasmSection &WS = WasmObj.getWasmSection(Sec);
|
|
Obj->Sections.push_back({static_cast<uint8_t>(WS.Type),
|
|
WS.HeaderSecSizeEncodingLen, WS.Name, WS.Content});
|
|
// Give known sections standard names to allow them to be selected. (Custom
|
|
// sections already have their names filled in by the parser).
|
|
Section &ReaderSec = Obj->Sections.back();
|
|
if (ReaderSec.SectionType > WASM_SEC_CUSTOM &&
|
|
ReaderSec.SectionType <= WASM_SEC_LAST_KNOWN)
|
|
ReaderSec.Name = sectionTypeToString(ReaderSec.SectionType);
|
|
}
|
|
return std::move(Obj);
|
|
}
|
|
|
|
} // end namespace wasm
|
|
} // end namespace objcopy
|
|
} // end namespace llvm
|