aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Object/WasmObjectFile.cpp
diff options
context:
space:
mode:
authorSam Clegg <sbc@chromium.org>2017-09-29 16:50:08 +0000
committerSam Clegg <sbc@chromium.org>2017-09-29 16:50:08 +0000
commit63ebb81386393c84d990e5e1bd52938eeb596f47 (patch)
tree95bacc2d0a9e8e1726c580decb1a2b55ccb65e8a /llvm/lib/Object/WasmObjectFile.cpp
parent113708b7cb30277a89a4b65d8ae4c8370b6b1841 (diff)
downloadllvm-63ebb81386393c84d990e5e1bd52938eeb596f47.zip
llvm-63ebb81386393c84d990e5e1bd52938eeb596f47.tar.gz
llvm-63ebb81386393c84d990e5e1bd52938eeb596f47.tar.bz2
[WebAssembly] Allow each data segment to specify its own alignment
Also, add a flags field as we will almost certainly be needing that soon too. Differential Revision: https://reviews.llvm.org/D38296 llvm-svn: 314534
Diffstat (limited to 'llvm/lib/Object/WasmObjectFile.cpp')
-rw-r--r--llvm/lib/Object/WasmObjectFile.cpp13
1 files changed, 7 insertions, 6 deletions
diff --git a/llvm/lib/Object/WasmObjectFile.cpp b/llvm/lib/Object/WasmObjectFile.cpp
index 1954335..15a78df 100644
--- a/llvm/lib/Object/WasmObjectFile.cpp
+++ b/llvm/lib/Object/WasmObjectFile.cpp
@@ -193,7 +193,6 @@ static Error readSection(WasmSection &Section, const uint8_t *&Ptr,
WasmObjectFile::WasmObjectFile(MemoryBufferRef Buffer, Error &Err)
: ObjectFile(Binary::ID_Wasm, Buffer) {
- LinkingData.DataAlignment = 0;
LinkingData.DataSize = 0;
ErrorAsOutParameter ErrAsOutParam(&Err);
@@ -385,16 +384,16 @@ Error WasmObjectFile::parseLinkingSection(const uint8_t *Ptr,
case wasm::WASM_DATA_SIZE:
LinkingData.DataSize = readVaruint32(Ptr);
break;
- case wasm::WASM_DATA_ALIGNMENT:
- LinkingData.DataAlignment = readVaruint32(Ptr);
- break;
- case wasm::WASM_SEGMENT_NAMES: {
+ case wasm::WASM_SEGMENT_INFO: {
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++)
+ for (uint32_t i = 0; i < Count; i++) {
DataSegments[i].Data.Name = readString(Ptr);
+ DataSegments[i].Data.Alignment = readVaruint32(Ptr);
+ DataSegments[i].Data.Flags = readVaruint32(Ptr);
+ }
break;
}
case wasm::WASM_STACK_POINTER:
@@ -734,6 +733,8 @@ Error WasmObjectFile::parseDataSection(const uint8_t *Ptr, const uint8_t *End) {
return Err;
uint32_t Size = readVaruint32(Ptr);
Segment.Data.Content = ArrayRef<uint8_t>(Ptr, Size);
+ Segment.Data.Alignment = 0;
+ Segment.Data.Flags = 0;
Segment.SectionOffset = Ptr - Start;
Ptr += Size;
DataSegments.push_back(Segment);