diff options
author | Lauro Ramos Venancio <lauro.venancio@gmail.com> | 2007-04-25 14:50:40 +0000 |
---|---|---|
committer | Lauro Ramos Venancio <lauro.venancio@gmail.com> | 2007-04-25 14:50:40 +0000 |
commit | 4ae9425bb6c49d1fde2dd3872bd5c650b1d3abd0 (patch) | |
tree | 21917110e186f87c9df1dbf961ee8342993fc355 | |
parent | e9fcbefa9a3590c8f041112d6db963e39b4adf4d (diff) | |
download | bcm5719-llvm-4ae9425bb6c49d1fde2dd3872bd5c650b1d3abd0.tar.gz bcm5719-llvm-4ae9425bb6c49d1fde2dd3872bd5c650b1d3abd0.zip |
remember to emit weak reference in one more case.
llvm-svn: 36438
-rw-r--r-- | llvm/lib/Target/ARM/ARMAsmPrinter.cpp | 7 | ||||
-rw-r--r-- | llvm/test/CodeGen/ARM/weak2.ll | 18 |
2 files changed, 24 insertions, 1 deletions
diff --git a/llvm/lib/Target/ARM/ARMAsmPrinter.cpp b/llvm/lib/Target/ARM/ARMAsmPrinter.cpp index 6822e632824..6e9a9038dc4 100644 --- a/llvm/lib/Target/ARM/ARMAsmPrinter.cpp +++ b/llvm/lib/Target/ARM/ARMAsmPrinter.cpp @@ -639,8 +639,13 @@ void ARMAsmPrinter::printCPInstOperand(const MachineInstr *MI, int OpNo, if (MCPE.isMachineConstantPoolEntry()) EmitMachineConstantPoolValue(MCPE.Val.MachineCPVal); - else + else { EmitGlobalConstant(MCPE.Val.ConstVal); + // remember to emit the weak reference + if (const GlobalValue *GV = dyn_cast<GlobalValue>(MCPE.Val.ConstVal)) + if (GV->hasExternalWeakLinkage()) + ExtWeakSymbols.insert(GV); + } } } diff --git a/llvm/test/CodeGen/ARM/weak2.ll b/llvm/test/CodeGen/ARM/weak2.ll new file mode 100644 index 00000000000..a57a76707ce --- /dev/null +++ b/llvm/test/CodeGen/ARM/weak2.ll @@ -0,0 +1,18 @@ +; RUN: llvm-as < %s | llc -march=arm | grep .weak + +define i32 @f(i32 %a) { +entry: + %tmp2 = icmp eq i32 %a, 0 ; <i1> [#uses=1] + %t.0 = select i1 %tmp2, i32 (...)* null, i32 (...)* @test_weak ; <i32 (...)*> [#uses=2] + %tmp5 = icmp eq i32 (...)* %t.0, null ; <i1> [#uses=1] + br i1 %tmp5, label %UnifiedReturnBlock, label %cond_true8 + +cond_true8: ; preds = %entry + %tmp10 = tail call i32 (...)* %t.0( ) ; <i32> [#uses=1] + ret i32 %tmp10 + +UnifiedReturnBlock: ; preds = %entry + ret i32 250 +} + +declare extern_weak i32 @test_weak(...) |