mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-25 03:55:25 +00:00
Make log, log2, log10, exp, exp2 use Expand by
default. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56471 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bbeeb2a61e
commit
0bb41608e9
@ -430,6 +430,18 @@ TargetLowering::TargetLowering(TargetMachine &tm)
|
|||||||
setOperationAction(ISD::ConstantFP, MVT::f64, Expand);
|
setOperationAction(ISD::ConstantFP, MVT::f64, Expand);
|
||||||
setOperationAction(ISD::ConstantFP, MVT::f80, Expand);
|
setOperationAction(ISD::ConstantFP, MVT::f80, Expand);
|
||||||
|
|
||||||
|
// These library functions default to expand.
|
||||||
|
setOperationAction(ISD::FLOG , MVT::f64, Expand);
|
||||||
|
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
||||||
|
setOperationAction(ISD::FLOG10,MVT::f64, Expand);
|
||||||
|
setOperationAction(ISD::FEXP , MVT::f64, Expand);
|
||||||
|
setOperationAction(ISD::FEXP2, MVT::f64, Expand);
|
||||||
|
setOperationAction(ISD::FLOG , MVT::f32, Expand);
|
||||||
|
setOperationAction(ISD::FLOG2, MVT::f32, Expand);
|
||||||
|
setOperationAction(ISD::FLOG10,MVT::f32, Expand);
|
||||||
|
setOperationAction(ISD::FEXP , MVT::f32, Expand);
|
||||||
|
setOperationAction(ISD::FEXP2, MVT::f32, Expand);
|
||||||
|
|
||||||
// Default ISD::TRAP to expand (which turns it into abort).
|
// Default ISD::TRAP to expand (which turns it into abort).
|
||||||
setOperationAction(ISD::TRAP, MVT::Other, Expand);
|
setOperationAction(ISD::TRAP, MVT::Other, Expand);
|
||||||
|
|
||||||
|
@ -243,16 +243,6 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM)
|
|||||||
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FREM , MVT::f64, Expand);
|
setOperationAction(ISD::FREM , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FREM , MVT::f32, Expand);
|
setOperationAction(ISD::FREM , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2 , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2 , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10 , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10 , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2 , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2 , MVT::f32, Expand);
|
|
||||||
if (!UseSoftFloat && Subtarget->hasVFP2() && !Subtarget->isThumb()) {
|
if (!UseSoftFloat && Subtarget->hasVFP2() && !Subtarget->isThumb()) {
|
||||||
setOperationAction(ISD::FCOPYSIGN, MVT::f64, Custom);
|
setOperationAction(ISD::FCOPYSIGN, MVT::f64, Custom);
|
||||||
setOperationAction(ISD::FCOPYSIGN, MVT::f32, Custom);
|
setOperationAction(ISD::FCOPYSIGN, MVT::f32, Custom);
|
||||||
|
@ -99,17 +99,6 @@ AlphaTargetLowering::AlphaTargetLowering(TargetMachine &TM) : TargetLowering(TM)
|
|||||||
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
||||||
|
|
||||||
setOperationAction(ISD::FLOG, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f64, Expand);
|
|
||||||
|
|
||||||
setOperationAction(ISD::SETCC, MVT::f32, Promote);
|
setOperationAction(ISD::SETCC, MVT::f32, Promote);
|
||||||
|
|
||||||
setOperationAction(ISD::BIT_CONVERT, MVT::f32, Promote);
|
setOperationAction(ISD::BIT_CONVERT, MVT::f32, Promote);
|
||||||
|
@ -189,19 +189,9 @@ SPUTargetLowering::SPUTargetLowering(SPUTargetMachine &TM)
|
|||||||
setOperationAction(ISD::FSIN , MVT::f64, Expand);
|
setOperationAction(ISD::FSIN , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FREM , MVT::f64, Expand);
|
setOperationAction(ISD::FREM , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10,MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FSIN , MVT::f32, Expand);
|
setOperationAction(ISD::FSIN , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FCOS , MVT::f32, Expand);
|
setOperationAction(ISD::FCOS , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FREM , MVT::f32, Expand);
|
setOperationAction(ISD::FREM , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10,MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f32, Expand);
|
|
||||||
|
|
||||||
// If we're enabling GP optimizations, use hardware square root
|
// If we're enabling GP optimizations, use hardware square root
|
||||||
setOperationAction(ISD::FSQRT, MVT::f64, Expand);
|
setOperationAction(ISD::FSQRT, MVT::f64, Expand);
|
||||||
|
@ -75,20 +75,10 @@ IA64TargetLowering::IA64TargetLowering(TargetMachine &TM)
|
|||||||
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FSQRT, MVT::f64, Expand);
|
setOperationAction(ISD::FSQRT, MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10,MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FSIN , MVT::f32, Expand);
|
setOperationAction(ISD::FSIN , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FCOS , MVT::f32, Expand);
|
setOperationAction(ISD::FCOS , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FSQRT, MVT::f32, Expand);
|
setOperationAction(ISD::FSQRT, MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10,MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f32, Expand);
|
|
||||||
|
|
||||||
setOperationAction(ISD::SIGN_EXTEND_INREG, MVT::i1 , Expand);
|
setOperationAction(ISD::SIGN_EXTEND_INREG, MVT::i1 , Expand);
|
||||||
|
|
||||||
|
@ -99,20 +99,10 @@ PPCTargetLowering::PPCTargetLowering(PPCTargetMachine &TM)
|
|||||||
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
setOperationAction(ISD::FCOS , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FREM , MVT::f64, Expand);
|
setOperationAction(ISD::FREM , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10,MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP ,MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2 ,MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FSIN , MVT::f32, Expand);
|
setOperationAction(ISD::FSIN , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FCOS , MVT::f32, Expand);
|
setOperationAction(ISD::FCOS , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FREM , MVT::f32, Expand);
|
setOperationAction(ISD::FREM , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2 ,MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10,MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP ,MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2 ,MVT::f32, Expand);
|
|
||||||
|
|
||||||
setOperationAction(ISD::FLT_ROUNDS_, MVT::i32, Custom);
|
setOperationAction(ISD::FLT_ROUNDS_, MVT::i32, Custom);
|
||||||
|
|
||||||
|
@ -587,16 +587,6 @@ SparcTargetLowering::SparcTargetLowering(TargetMachine &TM)
|
|||||||
setOperationAction(ISD::FCOPYSIGN, MVT::f32, Expand);
|
setOperationAction(ISD::FCOPYSIGN, MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
setOperationAction(ISD::FPOW , MVT::f64, Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
setOperationAction(ISD::FPOW , MVT::f32, Expand);
|
||||||
setOperationAction(ISD::FLOG , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP , MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f32, Expand);
|
|
||||||
|
|
||||||
setOperationAction(ISD::SHL_PARTS, MVT::i32, Expand);
|
setOperationAction(ISD::SHL_PARTS, MVT::i32, Expand);
|
||||||
setOperationAction(ISD::SRA_PARTS, MVT::i32, Expand);
|
setOperationAction(ISD::SRA_PARTS, MVT::i32, Expand);
|
||||||
|
@ -494,20 +494,10 @@ X86TargetLowering::X86TargetLowering(X86TargetMachine &TM)
|
|||||||
setOperationAction(ISD::FPOW , MVT::f64 , Expand);
|
setOperationAction(ISD::FPOW , MVT::f64 , Expand);
|
||||||
setOperationAction(ISD::FPOW , MVT::f80 , Expand);
|
setOperationAction(ISD::FPOW , MVT::f80 , Expand);
|
||||||
|
|
||||||
setOperationAction(ISD::FLOG, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG, MVT::f80, Expand);
|
setOperationAction(ISD::FLOG, MVT::f80, Expand);
|
||||||
setOperationAction(ISD::FLOG2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG2, MVT::f80, Expand);
|
setOperationAction(ISD::FLOG2, MVT::f80, Expand);
|
||||||
setOperationAction(ISD::FLOG10, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FLOG10, MVT::f80, Expand);
|
setOperationAction(ISD::FLOG10, MVT::f80, Expand);
|
||||||
setOperationAction(ISD::FEXP, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP, MVT::f80, Expand);
|
setOperationAction(ISD::FEXP, MVT::f80, Expand);
|
||||||
setOperationAction(ISD::FEXP2, MVT::f32, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f64, Expand);
|
|
||||||
setOperationAction(ISD::FEXP2, MVT::f80, Expand);
|
setOperationAction(ISD::FEXP2, MVT::f80, Expand);
|
||||||
|
|
||||||
// First set operation action for all vector types to expand. Then we
|
// First set operation action for all vector types to expand. Then we
|
||||||
|
Loading…
x
Reference in New Issue
Block a user