From e320cea5b9a4d474ee2dd6a67cb7dc9bf0d6b73c Mon Sep 17 00:00:00 2001 From: Sam Clegg Date: Wed, 30 Jan 2019 00:25:52 +0000 Subject: [PATCH] [WebAssembly] Fix undefined weak function symbols in LTO builds Summary: Fixes PR40219 Subscribers: dschuff, mehdi_amini, inglorion, jgravelle-google, aheejin, sunfish, steven_wu, dexonsmith, llvm-commits Differential Revision: https://reviews.llvm.org/D57420 llvm-svn: 352575 --- lld/test/wasm/lto/weak-undefined.ll | 20 ++++++++++++++++++++ lld/wasm/Driver.cpp | 8 +++++--- 2 files changed, 25 insertions(+), 3 deletions(-) create mode 100644 lld/test/wasm/lto/weak-undefined.ll diff --git a/lld/test/wasm/lto/weak-undefined.ll b/lld/test/wasm/lto/weak-undefined.ll new file mode 100644 index 0000000..54b302e --- /dev/null +++ b/lld/test/wasm/lto/weak-undefined.ll @@ -0,0 +1,20 @@ +; RUN: llvm-as %s -o %t.o +; RUN: wasm-ld %t.o -o %t.wasm +; RUN: obj2yaml %t.wasm | FileCheck %s + +; Test that undefined weak external functions are handled in the LTO case +; We had a bug where stub function generation was failing because functions +; that are in bitcode (pre-LTO) don't have signatures assigned. + +target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128" +target triple = "wasm32-unknown-unknown" + +declare extern_weak i32 @foo() + +define void @_start() #0 { +entry: + %call2 = call i32 @foo() + ret void +} + +; CHECK: Name: undefined function foo diff --git a/lld/wasm/Driver.cpp b/lld/wasm/Driver.cpp index eb32802..860d9f5 100644 --- a/lld/wasm/Driver.cpp +++ b/lld/wasm/Driver.cpp @@ -587,9 +587,6 @@ void LinkerDriver::link(ArrayRef ArgsArr) { Symbol *EntrySym = nullptr; if (!Config->Relocatable) { - // Add synthetic dummies for weak undefined functions. - handleWeakUndefines(); - if (!Config->Shared && !Config->Entry.empty()) { EntrySym = handleUndefined(Config->Entry); if (EntrySym && EntrySym->isDefined()) @@ -613,6 +610,11 @@ void LinkerDriver::link(ArrayRef ArgsArr) { if (errorCount()) return; + // Add synthetic dummies for weak undefined functions. Must happen + // after LTO otherwise functions may not yet have signatures. + if (!Config->Relocatable) + handleWeakUndefines(); + if (EntrySym) EntrySym->setHidden(false); -- 2.7.4