diff options
author | Andy Wingo <wingo@igalia.com> | 2020-10-01 17:30:58 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-01 08:30:58 -0700 |
commit | ee87440dedb4335d5ca8ec25e86b36c27a5b3368 (patch) | |
tree | 522ec9766d5da42fd8b8ba6efa0c6e74fc370748 /src/binary-reader-ir.cc | |
parent | cd63243c5b3b2fa938f365edab30139f74549b51 (diff) | |
download | wabt-ee87440dedb4335d5ca8ec25e86b36c27a5b3368.tar.gz wabt-ee87440dedb4335d5ca8ec25e86b36c27a5b3368.tar.bz2 wabt-ee87440dedb4335d5ca8ec25e86b36c27a5b3368.zip |
Add --relocatable support for tables (#1549) (#1549)
We add relocations for table numbers on each place where we reify a
table number (call_indirect, table.get, table.set...), but only if
reference types are enabled.
Also, fix symbol table generation with unnamed definitions, to allow for
relocating references to anonymous functions or tables.
As tests, add variants of the relocations and symbol-tables dump tests,
with and without all features enabled. Enabling reference types causes
relocs to be emitted. We also add --details to the relocations dump
tests, so that we can see the target symbols for the relocations.
Diffstat (limited to 'src/binary-reader-ir.cc')
-rw-r--r-- | src/binary-reader-ir.cc | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/binary-reader-ir.cc b/src/binary-reader-ir.cc index 3678438e..58636e88 100644 --- a/src/binary-reader-ir.cc +++ b/src/binary-reader-ir.cc @@ -260,6 +260,8 @@ class BinaryReaderIR : public BinaryReaderNop { Index section_index) override; Result OnEventSymbol(Index index, uint32_t flags, string_view name, Index event_index) override; + Result OnTableSymbol(Index index, uint32_t flags, string_view name, + Index table_index) override; private: Location GetLocation() const; @@ -1349,6 +1351,23 @@ Result BinaryReaderIR::OnEventSymbol(Index index, uint32_t flags, return Result::Ok; } +Result BinaryReaderIR::OnTableSymbol(Index index, uint32_t flags, + string_view name, Index table_index) { + if (name.empty()) { + return Result::Ok; + } + if (table_index >= module_->tables.size()) { + PrintError("invalid table index: %" PRIindex, table_index); + return Result::Error; + } + Table* table = module_->tables[table_index]; + std::string dollar_name = + GetUniqueName(&module_->table_bindings, MakeDollarName(name)); + table->name = dollar_name; + module_->table_bindings.emplace(dollar_name, Binding(table_index)); + return Result::Ok; +} + } // end anonymous namespace Result ReadBinaryIr(const char* filename, |