mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-13 23:18:51 +00:00
When in v9 mode, emit fabsd/fnegd/fmovd
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25810 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
76afdc9a80
commit
b34d3fd4cf
@ -25,6 +25,11 @@ include "SparcV8InstrFormats.td"
|
|||||||
// instructions. Note that the machine may be running in 32-bit mode.
|
// instructions. Note that the machine may be running in 32-bit mode.
|
||||||
def HasV9 : Predicate<"Subtarget.isV9()">;
|
def HasV9 : Predicate<"Subtarget.isV9()">;
|
||||||
|
|
||||||
|
// HasNoV9 - This predicate is true when the target doesn't have V9
|
||||||
|
// instructions. Use of this is just a hack for the isel not having proper
|
||||||
|
// costs for V8 instructions that are more expensive than their V9 ones.
|
||||||
|
def HasNoV9 : Predicate<"!Subtarget.isV9()">;
|
||||||
|
|
||||||
// HasVIS - This is true when the target processor has VIS extensions.
|
// HasVIS - This is true when the target processor has VIS extensions.
|
||||||
def HasVIS : Predicate<"Subtarget.isVIS()">;
|
def HasVIS : Predicate<"Subtarget.isVIS()">;
|
||||||
|
|
||||||
@ -140,14 +145,16 @@ def IMPLICIT_DEF_DFP : Pseudo<(ops DFPRegs:$dst), "!IMPLICIT_DEF $dst",
|
|||||||
|
|
||||||
// FpMOVD/FpNEGD/FpABSD - These are lowered to single-precision ops by the
|
// FpMOVD/FpNEGD/FpABSD - These are lowered to single-precision ops by the
|
||||||
// fpmover pass.
|
// fpmover pass.
|
||||||
def FpMOVD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
let Predicates = [HasNoV9] in { // Only emit these in V8 mode.
|
||||||
"!FpMOVD $src, $dst", []>; // pseudo 64-bit double move
|
def FpMOVD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
def FpNEGD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
"!FpMOVD $src, $dst", []>;
|
||||||
"!FpNEGD $src, $dst",
|
def FpNEGD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
[(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
|
"!FpNEGD $src, $dst",
|
||||||
def FpABSD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
[(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
|
||||||
"!FpABSD $src, $dst",
|
def FpABSD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
[(set DFPRegs:$dst, (fabs DFPRegs:$src))]>;
|
"!FpABSD $src, $dst",
|
||||||
|
[(set DFPRegs:$dst, (fabs DFPRegs:$src))]>;
|
||||||
|
}
|
||||||
|
|
||||||
// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded by the
|
// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded by the
|
||||||
// scheduler into a branch sequence. This has to handle all permutations of
|
// scheduler into a branch sequence. This has to handle all permutations of
|
||||||
@ -742,6 +749,21 @@ let Predicates = [HasV9], isTwoAddress = 1 in {
|
|||||||
(V8selecticc IntRegs:$F, IntRegs:$T, 17, ICC))]>;
|
(V8selecticc IntRegs:$F, IntRegs:$T, 17, ICC))]>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Floating-Point Move Instructions, p. 164 of the V9 manual.
|
||||||
|
let Predicates = [HasV9] in {
|
||||||
|
def FMOVD : F3_3<2, 0b110100, 0b000000010,
|
||||||
|
(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
|
"fmovd $src, $dst", []>;
|
||||||
|
def FNEGD : F3_3<2, 0b110100, 0b000000110,
|
||||||
|
(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
|
"fnegd $src, $dst",
|
||||||
|
[(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
|
||||||
|
def FABSD : F3_3<2, 0b110100, 0b000001010,
|
||||||
|
(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
|
"fabsd $src, $dst",
|
||||||
|
[(set DFPRegs:$dst, (fabs DFPRegs:$src))]>;
|
||||||
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Non-Instruction Patterns
|
// Non-Instruction Patterns
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
@ -25,6 +25,11 @@ include "SparcV8InstrFormats.td"
|
|||||||
// instructions. Note that the machine may be running in 32-bit mode.
|
// instructions. Note that the machine may be running in 32-bit mode.
|
||||||
def HasV9 : Predicate<"Subtarget.isV9()">;
|
def HasV9 : Predicate<"Subtarget.isV9()">;
|
||||||
|
|
||||||
|
// HasNoV9 - This predicate is true when the target doesn't have V9
|
||||||
|
// instructions. Use of this is just a hack for the isel not having proper
|
||||||
|
// costs for V8 instructions that are more expensive than their V9 ones.
|
||||||
|
def HasNoV9 : Predicate<"!Subtarget.isV9()">;
|
||||||
|
|
||||||
// HasVIS - This is true when the target processor has VIS extensions.
|
// HasVIS - This is true when the target processor has VIS extensions.
|
||||||
def HasVIS : Predicate<"Subtarget.isVIS()">;
|
def HasVIS : Predicate<"Subtarget.isVIS()">;
|
||||||
|
|
||||||
@ -140,14 +145,16 @@ def IMPLICIT_DEF_DFP : Pseudo<(ops DFPRegs:$dst), "!IMPLICIT_DEF $dst",
|
|||||||
|
|
||||||
// FpMOVD/FpNEGD/FpABSD - These are lowered to single-precision ops by the
|
// FpMOVD/FpNEGD/FpABSD - These are lowered to single-precision ops by the
|
||||||
// fpmover pass.
|
// fpmover pass.
|
||||||
def FpMOVD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
let Predicates = [HasNoV9] in { // Only emit these in V8 mode.
|
||||||
"!FpMOVD $src, $dst", []>; // pseudo 64-bit double move
|
def FpMOVD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
def FpNEGD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
"!FpMOVD $src, $dst", []>;
|
||||||
"!FpNEGD $src, $dst",
|
def FpNEGD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
[(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
|
"!FpNEGD $src, $dst",
|
||||||
def FpABSD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
[(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
|
||||||
"!FpABSD $src, $dst",
|
def FpABSD : Pseudo<(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
[(set DFPRegs:$dst, (fabs DFPRegs:$src))]>;
|
"!FpABSD $src, $dst",
|
||||||
|
[(set DFPRegs:$dst, (fabs DFPRegs:$src))]>;
|
||||||
|
}
|
||||||
|
|
||||||
// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded by the
|
// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded by the
|
||||||
// scheduler into a branch sequence. This has to handle all permutations of
|
// scheduler into a branch sequence. This has to handle all permutations of
|
||||||
@ -742,6 +749,21 @@ let Predicates = [HasV9], isTwoAddress = 1 in {
|
|||||||
(V8selecticc IntRegs:$F, IntRegs:$T, 17, ICC))]>;
|
(V8selecticc IntRegs:$F, IntRegs:$T, 17, ICC))]>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Floating-Point Move Instructions, p. 164 of the V9 manual.
|
||||||
|
let Predicates = [HasV9] in {
|
||||||
|
def FMOVD : F3_3<2, 0b110100, 0b000000010,
|
||||||
|
(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
|
"fmovd $src, $dst", []>;
|
||||||
|
def FNEGD : F3_3<2, 0b110100, 0b000000110,
|
||||||
|
(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
|
"fnegd $src, $dst",
|
||||||
|
[(set DFPRegs:$dst, (fneg DFPRegs:$src))]>;
|
||||||
|
def FABSD : F3_3<2, 0b110100, 0b000001010,
|
||||||
|
(ops DFPRegs:$dst, DFPRegs:$src),
|
||||||
|
"fabsd $src, $dst",
|
||||||
|
[(set DFPRegs:$dst, (fabs DFPRegs:$src))]>;
|
||||||
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Non-Instruction Patterns
|
// Non-Instruction Patterns
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
Loading…
Reference in New Issue
Block a user