From: Dan Gohman Date: Mon, 23 Feb 2009 22:03:08 +0000 (+0000) Subject: Fast-isel can't do TLS yet, so it should fall back to SDISel X-Git-Tag: android-x86-6.0-r1~1003^2~22297 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=e9865945ad8286a007d8b8465703c5b242f94caa;p=android-x86%2Fexternal-llvm.git Fast-isel can't do TLS yet, so it should fall back to SDISel if it sees TLS addresses. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65341 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/X86FastISel.cpp b/lib/Target/X86/X86FastISel.cpp index e00697cecb4..e7b70b17ef8 100644 --- a/lib/Target/X86/X86FastISel.cpp +++ b/lib/Target/X86/X86FastISel.cpp @@ -21,6 +21,7 @@ #include "X86TargetMachine.h" #include "llvm/CallingConv.h" #include "llvm/DerivedTypes.h" +#include "llvm/GlobalVariable.h" #include "llvm/Instructions.h" #include "llvm/Intrinsics.h" #include "llvm/CodeGen/FastISel.h" @@ -433,6 +434,11 @@ bool X86FastISel::X86SelectAddress(Value *V, X86AddressMode &AM, bool isCall) { (AM.Base.Reg != 0 || AM.IndexReg != 0)) return false; + // Can't handle TLS yet. + if (GlobalVariable *GVar = dyn_cast(GV)) + if (GVar->isThreadLocal()) + return false; + // Set up the basic address. AM.GV = GV; if (!isCall && diff --git a/test/CodeGen/X86/fast-isel-tls.ll b/test/CodeGen/X86/fast-isel-tls.ll new file mode 100644 index 00000000000..4dd14e6b216 --- /dev/null +++ b/test/CodeGen/X86/fast-isel-tls.ll @@ -0,0 +1,10 @@ +; RUN: llvm-as < %s | llc -march=x86 -relocation-model=pic -mtriple=i686-unknown-linux-gnu -fast-isel | grep __tls_get_addr +; PR3654 + +@v = thread_local global i32 0 +define i32 @f() nounwind { +entry: + %t = load i32* @v + %s = add i32 %t, 1 + ret i32 %s +}