diff options
author | Sam Clegg <sbc@chromium.org> | 2017-09-20 19:03:35 +0000 |
---|---|---|
committer | Sam Clegg <sbc@chromium.org> | 2017-09-20 19:03:35 +0000 |
commit | d95ed959d8ab270808aeec8b31f06140e68834ea (patch) | |
tree | 989216a22660bb777d0fcff71cbc4540067b80ed /llvm/lib/Object/WasmObjectFile.cpp | |
parent | 01a409520b39946bd4c7e86f83bc2d01d8c839d4 (diff) | |
download | llvm-d95ed959d8ab270808aeec8b31f06140e68834ea.zip llvm-d95ed959d8ab270808aeec8b31f06140e68834ea.tar.gz llvm-d95ed959d8ab270808aeec8b31f06140e68834ea.tar.bz2 |
Reland "[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: 313795
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; |