mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-17 18:24:34 +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. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74534 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -991,13 +991,16 @@ void FPS::handleSpecialFP(MachineBasicBlock::iterator &I) {
|
|||||||
case X86::FpSET_ST0_32:
|
case X86::FpSET_ST0_32:
|
||||||
case X86::FpSET_ST0_64:
|
case X86::FpSET_ST0_64:
|
||||||
case X86::FpSET_ST0_80: {
|
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
|
// FpSET_ST0_80 is generated by copyRegToReg for both function return
|
||||||
// and inline assembly with the "st" constrain. In the latter case,
|
// and inline assembly with the "st" constrain. In the latter case,
|
||||||
// it is possible for ST(0) to be alive after this instruction.
|
// it is possible for ST(0) to be alive after this instruction.
|
||||||
if (!MI->killsRegister(X86::FP0 + RegOnTop)) {
|
if (!MI->killsRegister(X86::FP0 + Op0)) {
|
||||||
// Duplicate ST0
|
// Duplicate Op0
|
||||||
duplicateToTop(0, 7 /*temp register*/, I);
|
duplicateToTop(0, 7 /*temp register*/, I);
|
||||||
|
} else {
|
||||||
|
moveToTop(Op0, I);
|
||||||
}
|
}
|
||||||
--StackTop; // "Forget" we have something on the top of stack!
|
--StackTop; // "Forget" we have something on the top of stack!
|
||||||
break;
|
break;
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
; RUN: llvm-as < %s | llc -march=x86 > %t
|
; RUN: llvm-as < %s | llc -march=x86
|
||||||
; PR4484
|
; PR4484
|
||||||
|
|
||||||
declare x86_fp80 @ceil()
|
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
|
||||||
|
}
|
Reference in New Issue
Block a user