forked from OSchip/llvm-project
Misc accumulated tweaks to legalization logic for various targets.
llvm-svn: 73476
This commit is contained in:
parent
e531f048f8
commit
48021d15d6
|
@ -249,6 +249,25 @@ SPUTargetLowering::SPUTargetLowering(SPUTargetMachine &TM)
|
||||||
setOperationAction(ISD::MUL, MVT::i32, Legal);
|
setOperationAction(ISD::MUL, MVT::i32, Legal);
|
||||||
setOperationAction(ISD::MUL, MVT::i64, Legal);
|
setOperationAction(ISD::MUL, MVT::i64, Legal);
|
||||||
|
|
||||||
|
// Expand double-width multiplication
|
||||||
|
// FIXME: It would probably be reasonable to support some of these operations
|
||||||
|
setOperationAction(ISD::UMUL_LOHI, MVT::i8, Expand);
|
||||||
|
setOperationAction(ISD::SMUL_LOHI, MVT::i8, Expand);
|
||||||
|
setOperationAction(ISD::MULHU, MVT::i8, Expand);
|
||||||
|
setOperationAction(ISD::MULHS, MVT::i8, Expand);
|
||||||
|
setOperationAction(ISD::UMUL_LOHI, MVT::i16, Expand);
|
||||||
|
setOperationAction(ISD::SMUL_LOHI, MVT::i16, Expand);
|
||||||
|
setOperationAction(ISD::MULHU, MVT::i16, Expand);
|
||||||
|
setOperationAction(ISD::MULHS, MVT::i16, Expand);
|
||||||
|
setOperationAction(ISD::UMUL_LOHI, MVT::i32, Expand);
|
||||||
|
setOperationAction(ISD::SMUL_LOHI, MVT::i32, Expand);
|
||||||
|
setOperationAction(ISD::MULHU, MVT::i32, Expand);
|
||||||
|
setOperationAction(ISD::MULHS, MVT::i32, Expand);
|
||||||
|
setOperationAction(ISD::UMUL_LOHI, MVT::i64, Expand);
|
||||||
|
setOperationAction(ISD::SMUL_LOHI, MVT::i64, Expand);
|
||||||
|
setOperationAction(ISD::MULHU, MVT::i64, Expand);
|
||||||
|
setOperationAction(ISD::MULHS, MVT::i64, Expand);
|
||||||
|
|
||||||
// Need to custom handle (some) common i8, i64 math ops
|
// Need to custom handle (some) common i8, i64 math ops
|
||||||
setOperationAction(ISD::ADD, MVT::i8, Custom);
|
setOperationAction(ISD::ADD, MVT::i8, Custom);
|
||||||
setOperationAction(ISD::ADD, MVT::i64, Legal);
|
setOperationAction(ISD::ADD, MVT::i64, Legal);
|
||||||
|
|
|
@ -107,6 +107,10 @@ IA64TargetLowering::IA64TargetLowering(TargetMachine &TM)
|
||||||
// VASTART needs to be custom lowered to use the VarArgsFrameIndex
|
// VASTART needs to be custom lowered to use the VarArgsFrameIndex
|
||||||
setOperationAction(ISD::VAARG , MVT::Other, Custom);
|
setOperationAction(ISD::VAARG , MVT::Other, Custom);
|
||||||
setOperationAction(ISD::VASTART , MVT::Other, Custom);
|
setOperationAction(ISD::VASTART , MVT::Other, Custom);
|
||||||
|
|
||||||
|
// FIXME: These should be legal
|
||||||
|
setOperationAction(ISD::BIT_CONVERT, MVT::i64, Expand);
|
||||||
|
setOperationAction(ISD::BIT_CONVERT, MVT::f64, Expand);
|
||||||
|
|
||||||
// Use the default implementation.
|
// Use the default implementation.
|
||||||
setOperationAction(ISD::VACOPY , MVT::Other, Expand);
|
setOperationAction(ISD::VACOPY , MVT::Other, Expand);
|
||||||
|
|
|
@ -95,6 +95,7 @@ MipsTargetLowering(MipsTargetMachine &TM): TargetLowering(TM)
|
||||||
setOperationAction(ISD::JumpTable, MVT::i32, Custom);
|
setOperationAction(ISD::JumpTable, MVT::i32, Custom);
|
||||||
setOperationAction(ISD::ConstantPool, MVT::i32, Custom);
|
setOperationAction(ISD::ConstantPool, MVT::i32, Custom);
|
||||||
setOperationAction(ISD::SELECT, MVT::f32, Custom);
|
setOperationAction(ISD::SELECT, MVT::f32, Custom);
|
||||||
|
setOperationAction(ISD::SELECT, MVT::f64, Custom);
|
||||||
setOperationAction(ISD::SELECT, MVT::i32, Custom);
|
setOperationAction(ISD::SELECT, MVT::i32, Custom);
|
||||||
setOperationAction(ISD::SETCC, MVT::f32, Custom);
|
setOperationAction(ISD::SETCC, MVT::f32, Custom);
|
||||||
setOperationAction(ISD::SETCC, MVT::f64, Custom);
|
setOperationAction(ISD::SETCC, MVT::f64, Custom);
|
||||||
|
@ -122,6 +123,7 @@ MipsTargetLowering(MipsTargetMachine &TM): TargetLowering(TM)
|
||||||
setOperationAction(ISD::SRA_PARTS, MVT::i32, Expand);
|
setOperationAction(ISD::SRA_PARTS, MVT::i32, Expand);
|
||||||
setOperationAction(ISD::SRL_PARTS, MVT::i32, Expand);
|
setOperationAction(ISD::SRL_PARTS, MVT::i32, Expand);
|
||||||
setOperationAction(ISD::FCOPYSIGN, MVT::f32, Expand);
|
setOperationAction(ISD::FCOPYSIGN, MVT::f32, Expand);
|
||||||
|
setOperationAction(ISD::FCOPYSIGN, MVT::f64, Expand);
|
||||||
|
|
||||||
// We don't have line number support yet.
|
// We don't have line number support yet.
|
||||||
setOperationAction(ISD::DBG_STOPPOINT, MVT::Other, Expand);
|
setOperationAction(ISD::DBG_STOPPOINT, MVT::Other, Expand);
|
||||||
|
|
|
@ -788,8 +788,6 @@ X86TargetLowering::X86TargetLowering(X86TargetMachine &TM)
|
||||||
setOperationAction(ISD::USUBO, MVT::i64, Custom);
|
setOperationAction(ISD::USUBO, MVT::i64, Custom);
|
||||||
setOperationAction(ISD::SMULO, MVT::i32, Custom);
|
setOperationAction(ISD::SMULO, MVT::i32, Custom);
|
||||||
setOperationAction(ISD::SMULO, MVT::i64, Custom);
|
setOperationAction(ISD::SMULO, MVT::i64, Custom);
|
||||||
setOperationAction(ISD::UMULO, MVT::i32, Custom);
|
|
||||||
setOperationAction(ISD::UMULO, MVT::i64, Custom);
|
|
||||||
|
|
||||||
if (!Subtarget->is64Bit()) {
|
if (!Subtarget->is64Bit()) {
|
||||||
// These libcalls are not available in 32-bit.
|
// These libcalls are not available in 32-bit.
|
||||||
|
|
Loading…
Reference in New Issue