From 9d0136274b28cf15540d19e7cd0cd5b8eb0bf51b Mon Sep 17 00:00:00 2001 From: Eric Christopher Date: Fri, 1 Oct 2010 21:33:12 +0000 Subject: Direct calls only for arm fast isel for now. llvm-svn: 115350 --- llvm/lib/Target/ARM/ARMFastISel.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'llvm/lib/Target/ARM') diff --git a/llvm/lib/Target/ARM/ARMFastISel.cpp b/llvm/lib/Target/ARM/ARMFastISel.cpp index 9c35d0a2b4c..2d38aff416e 100644 --- a/llvm/lib/Target/ARM/ARMFastISel.cpp +++ b/llvm/lib/Target/ARM/ARMFastISel.cpp @@ -1291,9 +1291,10 @@ bool ARMFastISel::SelectCall(const Instruction *I) { // Can't handle inline asm or worry about intrinsics yet. if (isa(Callee) || isa(CI)) return false; - // Only handle global variable Callees + // Only handle global variable Callees that are direct calls. const GlobalValue *GV = dyn_cast(Callee); - if (!GV) return false; + if (!GV || Subtarget->GVIsIndirectSymbol(GV, TM.getRelocationModel())) + return false; // Check the calling convention. ImmutableCallSite CS(CI); -- cgit v1.2.3