mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-27 06:54:30 +00:00
Fix PR4485.
Avoid unnecessary duplication of operand 0 of X86::FpSET_ST0_80. This duplication would cause one register to remain on the stack at the function return. llvm-svn: 74534
This commit is contained in:
parent
5d4e95558e
commit
340632e814
@ -991,13 +991,16 @@ void FPS::handleSpecialFP(MachineBasicBlock::iterator &I) {
|
||||
case X86::FpSET_ST0_32:
|
||||
case X86::FpSET_ST0_64:
|
||||
case X86::FpSET_ST0_80: {
|
||||
unsigned RegOnTop = getStackEntry(0);
|
||||
unsigned Op0 = getFPReg(MI->getOperand(0));
|
||||
|
||||
// FpSET_ST0_80 is generated by copyRegToReg for both function return
|
||||
// and inline assembly with the "st" constrain. In the latter case,
|
||||
// it is possible for ST(0) to be alive after this instruction.
|
||||
if (!MI->killsRegister(X86::FP0 + RegOnTop)) {
|
||||
// Duplicate ST0
|
||||
if (!MI->killsRegister(X86::FP0 + Op0)) {
|
||||
// Duplicate Op0
|
||||
duplicateToTop(0, 7 /*temp register*/, I);
|
||||
} else {
|
||||
moveToTop(Op0, I);
|
||||
}
|
||||
--StackTop; // "Forget" we have something on the top of stack!
|
||||
break;
|
||||
|
@ -1,4 +1,4 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 > %t
|
||||
; RUN: llvm-as < %s | llc -march=x86
|
||||
; PR4484
|
||||
|
||||
declare x86_fp80 @ceil()
|
||||
|
15
test/CodeGen/X86/inline-asm-fpstack5.ll
Normal file
15
test/CodeGen/X86/inline-asm-fpstack5.ll
Normal file
@ -0,0 +1,15 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86
|
||||
; PR4485
|
||||
|
||||
define void @test(x86_fp80* %a) {
|
||||
entry:
|
||||
%0 = load x86_fp80* %a, align 16
|
||||
%1 = fmul x86_fp80 %0, 0xK4006B400000000000000
|
||||
%2 = fmul x86_fp80 %1, 0xK4012F424000000000000
|
||||
tail call void asm sideeffect "fistpl $0", "{st},~{st}"(x86_fp80 %2)
|
||||
%3 = load x86_fp80* %a, align 16
|
||||
%4 = fmul x86_fp80 %3, 0xK4006B400000000000000
|
||||
%5 = fmul x86_fp80 %4, 0xK4012F424000000000000
|
||||
tail call void asm sideeffect "fistpl $0", "{st},~{st}"(x86_fp80 %5)
|
||||
ret void
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user