summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam Clegg <sbc@chromium.org>2017-08-31 23:22:44 +0000
committerSam Clegg <sbc@chromium.org>2017-08-31 23:22:44 +0000
commitb09cfa51040a5ab4980d83984c33d7cf459d9a0a (patch)
tree2b15edb1a9d786e6f300d060bdfd083ead2cc5ae
parent5372fb8cc1abe6e6b1619beb8722b4596a61200e (diff)
downloadbcm5719-llvm-b09cfa51040a5ab4980d83984c33d7cf459d9a0a.tar.gz
bcm5719-llvm-b09cfa51040a5ab4980d83984c33d7cf459d9a0a.zip
[WebAssembly] Fix getSymbolValue() for data symbols
This is mostly a fix for the output of `llvm-nm` See Bug 34392: https://bugs.llvm.org//show_bug.cgi?id=34392 Differential Revision: https://reviews.llvm.org/D37359 llvm-svn: 312294
-rw-r--r--llvm/lib/Object/WasmObjectFile.cpp7
-rw-r--r--llvm/test/Object/nm-trivial-object.test2
-rw-r--r--llvm/test/tools/llvm-nm/wasm/exports.yaml2
-rw-r--r--llvm/test/tools/llvm-nm/wasm/weak-symbols.yaml2
-rw-r--r--llvm/test/tools/llvm-objdump/WebAssembly/symbol-table.test2
5 files changed, 10 insertions, 5 deletions
diff --git a/llvm/lib/Object/WasmObjectFile.cpp b/llvm/lib/Object/WasmObjectFile.cpp
index 8a2fb38f58a..ad8c2b706de 100644
--- a/llvm/lib/Object/WasmObjectFile.cpp
+++ b/llvm/lib/Object/WasmObjectFile.cpp
@@ -786,8 +786,13 @@ uint64_t WasmObjectFile::getSymbolValueImpl(DataRefImpl Symb) const {
case WasmSymbol::SymbolType::GLOBAL_IMPORT:
return 0;
case WasmSymbol::SymbolType::FUNCTION_EXPORT:
- case WasmSymbol::SymbolType::GLOBAL_EXPORT:
return Exports[Sym.ElementIndex].Index;
+ case WasmSymbol::SymbolType::GLOBAL_EXPORT: {
+ uint32_t GlobalIndex = Exports[Sym.ElementIndex].Index;
+ assert(GlobalIndex < Globals.size());
+ const wasm::WasmGlobal& Global = Globals[GlobalIndex];
+ return Global.InitExpr.Value.Int32;
+ }
case WasmSymbol::SymbolType::DEBUG_FUNCTION_NAME:
return Sym.ElementIndex;
}
diff --git a/llvm/test/Object/nm-trivial-object.test b/llvm/test/Object/nm-trivial-object.test
index f1aadd5cccf..0be998e8605 100644
--- a/llvm/test/Object/nm-trivial-object.test
+++ b/llvm/test/Object/nm-trivial-object.test
@@ -62,7 +62,7 @@ COFF32-NEXT: U _puts
WASM: U SomeOtherFunction
WASM-NEXT: 00000002 T main
WASM-NEXT: U puts
-WASM-NEXT: 00000001 D var
+WASM-NEXT: 00000010 D var
COFF64: 00000000 d .data
COFF64-NEXT: 00000000 t .text
diff --git a/llvm/test/tools/llvm-nm/wasm/exports.yaml b/llvm/test/tools/llvm-nm/wasm/exports.yaml
index 6d2f12d1feb..420cc2f5dbb 100644
--- a/llvm/test/tools/llvm-nm/wasm/exports.yaml
+++ b/llvm/test/tools/llvm-nm/wasm/exports.yaml
@@ -40,5 +40,5 @@ Sections:
Kind: GLOBAL
Index: 0x00000002
-# CHECK: 00000002 D bar
+# CHECK: 00000400 D bar
# CHECK: 00000004 T foo
diff --git a/llvm/test/tools/llvm-nm/wasm/weak-symbols.yaml b/llvm/test/tools/llvm-nm/wasm/weak-symbols.yaml
index b0796d607e5..91c4dd6262a 100644
--- a/llvm/test/tools/llvm-nm/wasm/weak-symbols.yaml
+++ b/llvm/test/tools/llvm-nm/wasm/weak-symbols.yaml
@@ -64,7 +64,7 @@ Sections:
- Name: weak_import_data
Flags: 1
-# CHECK: 00000002 W weak_global_data
+# CHECK: 00000400 W weak_global_data
# CHECK: 00000004 W weak_global_func
# CHECK: w weak_import_data
# CHECK: w weak_import_func
diff --git a/llvm/test/tools/llvm-objdump/WebAssembly/symbol-table.test b/llvm/test/tools/llvm-objdump/WebAssembly/symbol-table.test
index 2c49d5d65c5..f64088f9ecf 100644
--- a/llvm/test/tools/llvm-objdump/WebAssembly/symbol-table.test
+++ b/llvm/test/tools/llvm-objdump/WebAssembly/symbol-table.test
@@ -4,7 +4,7 @@ CHECK: SYMBOL TABLE:
CHECK-NEXT: 00000000 l F IMPORT puts
CHECK-NEXT: 00000000 l F IMPORT SomeOtherFunction
CHECK-NEXT: 00000002 g F EXPORT main
-CHECK-NEXT: 00000001 g EXPORT var
+CHECK-NEXT: 00000010 g EXPORT var
CHECK-NEXT: 00000000 l F name puts
CHECK-NEXT: 00000001 l F name SomeOtherFunction
CHECK-NEXT: 00000002 l F name main
OpenPOWER on IntegriCloud