[llvm-commits] [llvm] r78443 - in /llvm/trunk: lib/Target/X86/X86Instr64bit.td test/CodeGen/X86/2009-08-08-CastError.ll

Anton Korobeynikov asl at math.spbu.ru
Fri Aug 7 16:59:21 PDT 2009


Author: asl
Date: Fri Aug  7 18:59:21 2009
New Revision: 78443

URL: http://llvm.org/viewvc/llvm-project?rev=78443&view=rev
Log:
Do not generate 32-bit call on win64 when imm does not fit

Added:
    llvm/trunk/test/CodeGen/X86/2009-08-08-CastError.ll
Modified:
    llvm/trunk/lib/Target/X86/X86Instr64bit.td

Modified: llvm/trunk/lib/Target/X86/X86Instr64bit.td
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/X86Instr64bit.td?rev=78443&r1=78442&r2=78443&view=diff

==============================================================================
--- llvm/trunk/lib/Target/X86/X86Instr64bit.td (original)
+++ llvm/trunk/lib/Target/X86/X86Instr64bit.td Fri Aug  7 18:59:21 2009
@@ -149,8 +149,8 @@
               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",

Added: llvm/trunk/test/CodeGen/X86/2009-08-08-CastError.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/2009-08-08-CastError.ll?rev=78443&view=auto

==============================================================================
--- llvm/trunk/test/CodeGen/X86/2009-08-08-CastError.ll (added)
+++ llvm/trunk/test/CodeGen/X86/2009-08-08-CastError.ll Fri Aug  7 18:59:21 2009
@@ -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
+}





More information about the llvm-commits mailing list