From 13f080fbebab4708afdaef542fda308d7a26a9c6 Mon Sep 17 00:00:00 2001 From: Derek Schuff Date: Wed, 15 Mar 2017 19:36:02 +0000 Subject: [PATCH] [WebAssembly] Update format of 'names' section. This change updates to the format of the 'names' sectionin the generated wasm binary to match the latest changesto the design and 'wabt'. Differential Revision: https://reviews.llvm.org/D30950 Patch by Sam Clegg llvm-svn: 297877 --- llvm/include/llvm/Support/Wasm.h | 5 +++++ llvm/lib/MC/WasmObjectWriter.cpp | 17 +++++++++++------ 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/llvm/include/llvm/Support/Wasm.h b/llvm/include/llvm/Support/Wasm.h index cd15e21d0234..553ed721870b 100644 --- a/llvm/include/llvm/Support/Wasm.h +++ b/llvm/include/llvm/Support/Wasm.h @@ -81,6 +81,11 @@ enum : unsigned { WASM_OPCODE_F64_CONST = 0x44, }; +enum : unsigned { + WASM_NAMES_FUNCTION = 0x1, + WASM_NAMES_LOCAL = 0x2, +}; + // Subset of types that a value can have enum class ValType { I32 = WASM_TYPE_I32, diff --git a/llvm/lib/MC/WasmObjectWriter.cpp b/llvm/lib/MC/WasmObjectWriter.cpp index 20ace61825b3..39ddc30eb7d8 100644 --- a/llvm/lib/MC/WasmObjectWriter.cpp +++ b/llvm/lib/MC/WasmObjectWriter.cpp @@ -982,25 +982,30 @@ void WasmObjectWriter::writeObject(MCAssembler &Asm, } // === Name Section ========================================================== - if (NumFuncImports != 0 || !Functions.empty()) { + uint32_t TotalFunctions = NumFuncImports + Functions.size(); + if (TotalFunctions != 0) { startSection(Section, wasm::WASM_SEC_CUSTOM, "name"); + SectionBookkeeping SubSection; + startSection(SubSection, wasm::WASM_NAMES_FUNCTION); - encodeULEB128(NumFuncImports + Functions.size(), getStream()); + encodeULEB128(TotalFunctions, getStream()); + uint32_t Index = 0; for (const WasmImport &Import : Imports) { if (Import.Kind == wasm::WASM_EXTERNAL_FUNCTION) { + encodeULEB128(Index, getStream()); encodeULEB128(Import.FieldName.size(), getStream()); writeBytes(Import.FieldName); - encodeULEB128(0, getStream()); // local count, meaningless for imports + ++Index; } } for (const WasmFunction &Func : Functions) { + encodeULEB128(Index, getStream()); encodeULEB128(Func.Sym->getName().size(), getStream()); writeBytes(Func.Sym->getName()); - - // TODO: Local names. - encodeULEB128(0, getStream()); // local count + ++Index; } + endSection(SubSection); endSection(Section); }