diff options
author | Anton Korobeynikov <asl@math.spbu.ru> | 2009-08-07 23:59:21 +0000 |
---|---|---|
committer | Anton Korobeynikov <asl@math.spbu.ru> | 2009-08-07 23:59:21 +0000 |
commit | 941222eea05cb5e0bf6b1789c3d6beb4e66cc375 (patch) | |
tree | 8785528e3992dee9b1275486046ba93bdd1df2f1 | |
parent | ce0e9abef37bc8d4a2ed452bf495ebf7daf61332 (diff) | |
download | external_llvm-941222eea05cb5e0bf6b1789c3d6beb4e66cc375.tar.gz external_llvm-941222eea05cb5e0bf6b1789c3d6beb4e66cc375.tar.bz2 external_llvm-941222eea05cb5e0bf6b1789c3d6beb4e66cc375.zip |
Do not generate 32-bit call on win64 when imm does not fit
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78443 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/X86/X86Instr64bit.td | 4 | ||||
-rw-r--r-- | test/CodeGen/X86/2009-08-08-CastError.ll | 9 |
2 files changed, 11 insertions, 2 deletions
diff --git a/lib/Target/X86/X86Instr64bit.td b/lib/Target/X86/X86Instr64bit.td index 11a9c190fc..a4decbb93a 100644 --- a/lib/Target/X86/X86Instr64bit.td +++ b/lib/Target/X86/X86Instr64bit.td @@ -149,8 +149,8 @@ let isCall = 1 in XMM0, XMM1, XMM2, XMM3, XMM4, XMM5, EFLAGS], Uses = [RSP] in { def WINCALL64pcrel32 : I<0xE8, RawFrm, - (outs), (ins i64i32imm:$dst, variable_ops), - "call\t${dst:call}", [(X86call imm:$dst)]>, + (outs), (ins i64i32imm_pcrel:$dst, variable_ops), + "call\t$dst", []>, Requires<[IsWin64]>; def WINCALL64r : I<0xFF, MRM2r, (outs), (ins GR64:$dst, variable_ops), "call\t{*}$dst", diff --git a/test/CodeGen/X86/2009-08-08-CastError.ll b/test/CodeGen/X86/2009-08-08-CastError.ll new file mode 100644 index 0000000000..2cddf02697 --- /dev/null +++ b/test/CodeGen/X86/2009-08-08-CastError.ll @@ -0,0 +1,9 @@ +; RUN: llvm-as < %s | llc -mtriple=x86_64-mingw | grep movabsq + +target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128" + +define <4 x float> @RecursiveTestFunc1(i8*) { +EntryBlock: + %1 = call <4 x float> inttoptr (i64 5367207198 to <4 x float> (i8*, float, float, float, float)*)(i8* %0, float 8.000000e+00, float 5.000000e+00, float 3.000000e+00, float 4.000000e+00) ; <<4 x float>> [#uses=1] + ret <4 x float> %1 +} |