[PATCH] D43365: [WebAssembly] MC: Make explicit our current lack of support for relocations against unnamed temporary symbols.
Phabricator via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 16 10:10:39 PST 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rL325367: [WebAssembly] MC: Make explicit our current lack of support for relocations… (authored by sbc, committed by ).
Repository:
rL LLVM
https://reviews.llvm.org/D43365
Files:
llvm/trunk/lib/MC/WasmObjectWriter.cpp
llvm/trunk/lib/Target/WebAssembly/known_gcc_test_failures.txt
llvm/trunk/test/MC/WebAssembly/blockaddress.ll
Index: llvm/trunk/lib/Target/WebAssembly/known_gcc_test_failures.txt
===================================================================
--- llvm/trunk/lib/Target/WebAssembly/known_gcc_test_failures.txt
+++ llvm/trunk/lib/Target/WebAssembly/known_gcc_test_failures.txt
@@ -11,7 +11,8 @@
# to wasm object files (.o).
# Computed gotos are not supported (Cannot select BlockAddress/BRIND)
-20071220-1.c wasm-o,O0
+20071220-1.c wasm-o
+20071220-2.c wasm-o
20040302-1.c
20041214-1.c O0
20071210-1.c
@@ -97,9 +98,6 @@
devirt-21.C # bad main signature
devirt-23.C # bad main signature
-# Untriaged: Assertion failure in WasmObjectWriter::applyRelocations
-20071220-2.c wasm-o,O0
-
# Untriaged C++ failures
spec5.C
addr1.C
Index: llvm/trunk/lib/MC/WasmObjectWriter.cpp
===================================================================
--- llvm/trunk/lib/MC/WasmObjectWriter.cpp
+++ llvm/trunk/lib/MC/WasmObjectWriter.cpp
@@ -355,6 +355,10 @@
if (FixupSection.getSectionName().startswith(".init_array"))
return;
+ // TODO(sbc): Add support for debug sections.
+ if (FixupSection.getKind().isMetadata())
+ return;
+
if (const MCSymbolRefExpr *RefB = Target.getSymB()) {
assert(RefB->getKind() == MCSymbolRefExpr::VK_None &&
"Should not have constructed this");
@@ -423,12 +427,20 @@
WasmRelocationEntry Rec(FixupOffset, SymA, C, Type, &FixupSection);
DEBUG(dbgs() << "WasmReloc: " << Rec << "\n");
+ // Relocation other than R_WEBASSEMBLY_TYPE_INDEX_LEB are currently required
+ // to be against a named symbol.
+ // TODO(sbc): Add support for relocations against unnamed temporaries such
+ // as those generated by llvm's `blockaddress`.
+ // See: test/MC/WebAssembly/blockaddress.ll
+ if (SymA->getName().empty() && Type != wasm::R_WEBASSEMBLY_TYPE_INDEX_LEB)
+ report_fatal_error("relocations against un-named temporaries are not yet "
+ "supported by wasm");
+
if (FixupSection.isWasmData())
DataRelocations.push_back(Rec);
else if (FixupSection.getKind().isText())
CodeRelocations.push_back(Rec);
- else if (!FixupSection.getKind().isMetadata())
- // TODO(sbc): Add support for debug sections.
+ else
llvm_unreachable("unexpected section type");
}
@@ -496,6 +508,9 @@
if (!Sym->isDefined())
return 0;
+ if (!SymbolIndices.count(Sym))
+ report_fatal_error("symbol not found in function/global index space: " +
+ Sym->getName());
uint32_t GlobalIndex = SymbolIndices[Sym];
const WasmGlobal& Global = Globals[GlobalIndex - NumGlobalImports];
uint64_t Address = Global.InitialValue + RelEntry.Addend;
Index: llvm/trunk/test/MC/WebAssembly/blockaddress.ll
===================================================================
--- llvm/trunk/test/MC/WebAssembly/blockaddress.ll
+++ llvm/trunk/test/MC/WebAssembly/blockaddress.ll
@@ -0,0 +1,15 @@
+; TODO(sbc): Make this test pass by adding support for unnamed tempoaries
+; in wasm relocations.
+; RUN: not llc -filetype=obj %s
+
+target triple = "wasm32-unknown-unknown-wasm"
+
+ at foo = internal global i8* blockaddress(@bar, %addr), align 4
+
+define hidden i32 @bar() #0 {
+entry:
+ br label %addr
+
+addr:
+ ret i32 0
+}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D43365.134649.patch
Type: text/x-patch
Size: 3245 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180216/1fe4a9ee/attachment.bin>
More information about the llvm-commits
mailing list