forked from OSchip/llvm-project
				
			Fix a problem with fast-isel return values introduced in r134018.
We would put the return value from long double functions in the wrong register. This fixes gcc.c-torture/execute/conversion.c llvm-svn: 134205
This commit is contained in:
		
							parent
							
								
									e9cc901814
								
							
						
					
					
						commit
						d0e2352b65
					
				| 
						 | 
				
			
			@ -1849,9 +1849,10 @@ bool X86FastISel::DoSelectCall(const Instruction *I, const char *MemIntName) {
 | 
			
		|||
    // out as F80 and use a truncate to move it from fp stack reg to xmm reg.
 | 
			
		||||
    if ((RVLocs[i].getLocReg() == X86::ST0 ||
 | 
			
		||||
         RVLocs[i].getLocReg() == X86::ST1)) {
 | 
			
		||||
      if (isScalarFPTypeInSSEReg(RVLocs[i].getValVT()))
 | 
			
		||||
      if (isScalarFPTypeInSSEReg(RVLocs[i].getValVT())) {
 | 
			
		||||
        CopyVT = MVT::f80;
 | 
			
		||||
        CopyReg = createResultReg(X86::RFP80RegisterClass);
 | 
			
		||||
      }
 | 
			
		||||
      BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, TII.get(X86::FpPOP_RETVAL),
 | 
			
		||||
              CopyReg);
 | 
			
		||||
    } else {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,24 @@
 | 
			
		|||
; RUN: llc < %s -O0 | FileCheck %s
 | 
			
		||||
target triple = "x86_64-apple-macosx"
 | 
			
		||||
 | 
			
		||||
declare x86_fp80 @x1(i32) nounwind
 | 
			
		||||
declare i32 @x2(x86_fp80, x86_fp80) nounwind
 | 
			
		||||
 | 
			
		||||
; Keep track of the return value.
 | 
			
		||||
; CHECK: test1
 | 
			
		||||
; CHECK: x1
 | 
			
		||||
; Pass arguments on the stack.
 | 
			
		||||
; CHECK-NEXT: movq %rsp, [[RCX:%r..]]
 | 
			
		||||
; Copy constant-pool value.
 | 
			
		||||
; CHECK-NEXT: fldt LCPI
 | 
			
		||||
; CHECK-NEXT: fstpt 16([[RCX]])
 | 
			
		||||
; Copy x1 return value.
 | 
			
		||||
; CHECK-NEXT: fstpt ([[RCX]])
 | 
			
		||||
; CHECK-NEXT: x2
 | 
			
		||||
define i32 @test1() nounwind uwtable ssp {
 | 
			
		||||
entry:
 | 
			
		||||
  %call = call x86_fp80 (...)* bitcast (x86_fp80 (i32)* @x1 to x86_fp80 (...)*)(i32 -1)
 | 
			
		||||
  %call1 = call i32 @x2(x86_fp80 %call, x86_fp80 0xK401EFFFFFFFF00000000)
 | 
			
		||||
  ret i32 %call1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue