From da2ce114078b0fb6c548f5efc174773873b3a5f8 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 16 Jan 2005 07:34:08 +0000 Subject: [PATCH] * Adjust to changes in TargetLowering interfaces. * Remove custom promotion for bool and byte select ops. Legalize now promotes them for us. * Allow folding ConstantPoolIndexes into EXTLOAD's, useful for float immediates. * Declare which operations are not supported better. * Add some hacky code for TRUNCSTORE to pretend that we have truncstore for i16 types. This is useful for testing promotion code because I can just remove 16-bit registers all together and verify that programs work. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19614 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/X86/X86ISelPattern.cpp | 95 +++++++++++++++++-------------- 1 file changed, 52 insertions(+), 43 deletions(-) diff --git a/lib/Target/X86/X86ISelPattern.cpp b/lib/Target/X86/X86ISelPattern.cpp index a6932faea0d..ba359de12e1 100644 --- a/lib/Target/X86/X86ISelPattern.cpp +++ b/lib/Target/X86/X86ISelPattern.cpp @@ -46,16 +46,23 @@ namespace { // FIXME: Eliminate these two classes when legalize can handle promotions // well. - addRegisterClass(MVT::i1, X86::R8RegisterClass); - addRegisterClass(MVT::f32, X86::RFPRegisterClass); +/**/ addRegisterClass(MVT::i1, X86::R8RegisterClass); +/**/ //addRegisterClass(MVT::f32, X86::RFPRegisterClass); + + setOperationAction(ISD::MEMMOVE , MVT::Other, Expand); + setOperationAction(ISD::SIGN_EXTEND_INREG, MVT::i16 , Expand); + setOperationAction(ISD::ZERO_EXTEND_INREG, MVT::i16 , Expand); + setOperationAction(ISD::SIGN_EXTEND_INREG, MVT::i1 , Expand); + setOperationAction(ISD::ZERO_EXTEND_INREG, MVT::i1 , Expand); + setOperationAction(ISD::FP_ROUND_INREG , MVT::f32 , Expand); + setOperationAction(ISD::SEXTLOAD , MVT::i1 , Expand); + setOperationAction(ISD::SREM , MVT::f64 , Expand); + + // These should be promoted to a larger select which is supported. +/**/ setOperationAction(ISD::SELECT , MVT::i1 , Promote); + setOperationAction(ISD::SELECT , MVT::i8 , Promote); computeRegisterProperties(); - - setOperationUnsupported(ISD::MEMMOVE, MVT::Other); - - //setOperationUnsupported(ISD::SEXTLOAD, MVT::i1); - setOperationUnsupported(ISD::SELECT, MVT::i1); - setOperationUnsupported(ISD::SELECT, MVT::i8); addLegalFPImmediate(+0.0); // FLD0 addLegalFPImmediate(+1.0); // FLD1 @@ -1698,42 +1705,23 @@ unsigned ISel::SelectExpr(SDOperand N) { return Result; } case ISD::SELECT: - if (N.getValueType() != MVT::i1 && N.getValueType() != MVT::i8) { - if (getRegPressure(N.getOperand(1)) > getRegPressure(N.getOperand(2))) { - Tmp2 = SelectExpr(N.getOperand(1)); - Tmp3 = SelectExpr(N.getOperand(2)); - } else { - Tmp3 = SelectExpr(N.getOperand(2)); - Tmp2 = SelectExpr(N.getOperand(1)); - } - EmitSelectCC(N.getOperand(0), N.getValueType(), Tmp2, Tmp3, Result); - return Result; + if (getRegPressure(N.getOperand(1)) > getRegPressure(N.getOperand(2))) { + Tmp2 = SelectExpr(N.getOperand(1)); + Tmp3 = SelectExpr(N.getOperand(2)); } else { - // FIXME: This should not be implemented here, it should be in the generic - // code! - if (getRegPressure(N.getOperand(1)) > getRegPressure(N.getOperand(2))) { - Tmp2 = SelectExpr(CurDAG->getNode(ISD::ZERO_EXTEND, MVT::i16, - N.getOperand(1))); - Tmp3 = SelectExpr(CurDAG->getNode(ISD::ZERO_EXTEND, MVT::i16, - N.getOperand(2))); - } else { - Tmp3 = SelectExpr(CurDAG->getNode(ISD::ZERO_EXTEND, MVT::i16, - N.getOperand(2))); - Tmp2 = SelectExpr(CurDAG->getNode(ISD::ZERO_EXTEND, MVT::i16, - N.getOperand(1))); - } - unsigned TmpReg = MakeReg(MVT::i16); - EmitSelectCC(N.getOperand(0), MVT::i16, Tmp2, Tmp3, TmpReg); - // FIXME: need subregs to do better than this! - BuildMI(BB, X86::MOV16rr, 1, X86::AX).addReg(TmpReg); - BuildMI(BB, X86::MOV8rr, 1, Result).addReg(X86::AL); - return Result; + Tmp3 = SelectExpr(N.getOperand(2)); + Tmp2 = SelectExpr(N.getOperand(1)); } + EmitSelectCC(N.getOperand(0), N.getValueType(), Tmp2, Tmp3, Result); + return Result; case ISD::SDIV: case ISD::UDIV: case ISD::SREM: case ISD::UREM: { + assert((N.getOpcode() != ISD::SREM || MVT::isInteger(N.getValueType())) && + "We don't support this operator!"); + if (N.getOpcode() == ISD::SDIV) if (ConstantSDNode *CN = dyn_cast(N.getOperand(1))) { // FIXME: These special cases should be handled by the lowering impl! @@ -1823,10 +1811,7 @@ unsigned ISel::SelectExpr(SDOperand N) { case MVT::i64: assert(0 && "FIXME: implement i64 DIV/REM libcalls!"); case MVT::f32: case MVT::f64: - if (N.getOpcode() == ISD::SDIV) - BuildMI(BB, X86::FpDIV, 2, Result).addReg(Tmp1).addReg(Tmp2); - else - assert(0 && "FIXME: Emit frem libcall to fmod!"); + BuildMI(BB, X86::FpDIV, 2, Result).addReg(Tmp1).addReg(Tmp2); return Result; } @@ -2002,6 +1987,15 @@ unsigned ISel::SelectExpr(SDOperand N) { else Result = ExprMap[N.getValue(0)] = MakeReg(N.getValue(0).getValueType()); + if (ConstantPoolSDNode *CP = dyn_cast(N.getOperand(1))) + if (Node->getValueType(0) == MVT::f64) { + assert(cast(Node)->getExtraValueType() == MVT::f32 && + "Bad EXTLOAD!"); + addConstantPoolReference(BuildMI(BB, X86::FLD32m, 4, Result), + CP->getIndex()); + return Result; + } + X86AddressMode AM; if (getRegPressure(Node->getOperand(0)) > getRegPressure(Node->getOperand(1))) { @@ -2322,8 +2316,23 @@ void ISel::Select(SDOperand N) { // On X86, we can represent all types except for Bool and Float natively. X86AddressMode AM; MVT::ValueType StoredTy = cast(Node)->getExtraValueType(); - assert((StoredTy == MVT::i1 || StoredTy == MVT::f32) && - "Unsupported TRUNCSTORE for this target!"); + assert((StoredTy == MVT::i1 || StoredTy == MVT::f32 || + StoredTy == MVT::i16 /*FIXME: THIS IS JUST FOR TESTING!*/) + && "Unsupported TRUNCSTORE for this target!"); + + if (StoredTy == MVT::i16) { + // FIXME: This is here just to allow testing. X86 doesn't really have a + // TRUNCSTORE i16 operation, but this is required for targets that do not + // have 16-bit integer registers. We occasionally disable 16-bit integer + // registers to test the promotion code. + Select(N.getOperand(0)); + Tmp1 = SelectExpr(N.getOperand(1)); + SelectAddress(N.getOperand(2), AM); + + BuildMI(BB, X86::MOV32rr, 1, X86::EAX).addReg(Tmp1); + addFullAddress(BuildMI(BB, X86::MOV16mr, 5), AM).addReg(X86::AX); + return; + } // Store of constant bool? if (ConstantSDNode *CN = dyn_cast(N.getOperand(1))) {