diff options
author | Sam Clegg <sbc@chromium.org> | 2017-09-19 23:00:57 +0000 |
---|---|---|
committer | Sam Clegg <sbc@chromium.org> | 2017-09-19 23:00:57 +0000 |
commit | b292c259665df700442f47f430d0e4b4edd818cb (patch) | |
tree | 9f1cdf736c1460806311eca8b11e7bd436192b4a /llvm/lib/Object/WasmObjectFile.cpp | |
parent | 15fccf00097dd5b07710539fb4e3ff68c50f44de (diff) | |
download | llvm-b292c259665df700442f47f430d0e4b4edd818cb.zip llvm-b292c259665df700442f47f430d0e4b4edd818cb.tar.gz llvm-b292c259665df700442f47f430d0e4b4edd818cb.tar.bz2 |
[WebAssembly] Add support for naming wasm data segments
Add adds support for naming data segments. This is useful
useful linkers so that they can merge similar sections.
Differential Revision: https://reviews.llvm.org/D37886
llvm-svn: 313692
Diffstat (limited to 'llvm/lib/Object/WasmObjectFile.cpp')
-rw-r--r-- | llvm/lib/Object/WasmObjectFile.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/Object/WasmObjectFile.cpp b/llvm/lib/Object/WasmObjectFile.cpp index bd51fbd..d2d3aba 100644 --- a/llvm/lib/Object/WasmObjectFile.cpp +++ b/llvm/lib/Object/WasmObjectFile.cpp @@ -396,6 +396,15 @@ Error WasmObjectFile::parseLinkingSection(const uint8_t *Ptr, case wasm::WASM_DATA_ALIGNMENT: LinkingData.DataAlignment = readVaruint32(Ptr); break; + case wasm::WASM_SEGMENT_NAMES: { + uint32_t Count = readVaruint32(Ptr); + if (Count > DataSegments.size()) + return make_error<GenericBinaryError>("Too many segment names", + object_error::parse_failed); + for (uint32_t i = 0; i < Count; i++) + DataSegments[i].Data.Name = readString(Ptr); + break; + } case wasm::WASM_STACK_POINTER: default: Ptr += Size; |