mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Some X86ISD::CMP were created with wrong ValueType's.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30913 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -4135,40 +4135,40 @@ SDOperand X86TargetLowering::LowerSETCC(SDOperand Op, SelectionDAG &DAG, | |||||||
|   SDOperand Op1 = Op.getOperand(1); |   SDOperand Op1 = Op.getOperand(1); | ||||||
|   SDOperand CC = Op.getOperand(2); |   SDOperand CC = Op.getOperand(2); | ||||||
|   ISD::CondCode SetCCOpcode = cast<CondCodeSDNode>(CC)->get(); |   ISD::CondCode SetCCOpcode = cast<CondCodeSDNode>(CC)->get(); | ||||||
|   const MVT::ValueType *VTs = DAG.getNodeValueTypes(MVT::Other, MVT::Flag); |   const MVT::ValueType *VTs1 = DAG.getNodeValueTypes(MVT::Other, MVT::Flag); | ||||||
|  |   const MVT::ValueType *VTs2 = DAG.getNodeValueTypes(MVT::i8, MVT::Flag); | ||||||
|   bool isFP = MVT::isFloatingPoint(Op.getOperand(1).getValueType()); |   bool isFP = MVT::isFloatingPoint(Op.getOperand(1).getValueType()); | ||||||
|   unsigned X86CC; |   unsigned X86CC; | ||||||
|  |  | ||||||
|   VTs = DAG.getNodeValueTypes(MVT::i8, MVT::Flag); |  | ||||||
|   if (translateX86CC(cast<CondCodeSDNode>(CC)->get(), isFP, X86CC,  |   if (translateX86CC(cast<CondCodeSDNode>(CC)->get(), isFP, X86CC,  | ||||||
|                      Op0, Op1, DAG)) { |                      Op0, Op1, DAG)) { | ||||||
|     SDOperand Ops1[] = { Chain, Op0, Op1 }; |     SDOperand Ops1[] = { Chain, Op0, Op1 }; | ||||||
|     Cond = DAG.getNode(X86ISD::CMP, VTs, 2, Ops1, 3).getValue(1); |     Cond = DAG.getNode(X86ISD::CMP, VTs1, 2, Ops1, 3).getValue(1); | ||||||
|     SDOperand Ops2[] = { DAG.getConstant(X86CC, MVT::i8), Cond }; |     SDOperand Ops2[] = { DAG.getConstant(X86CC, MVT::i8), Cond }; | ||||||
|     return DAG.getNode(X86ISD::SETCC, VTs, 2, Ops2, 2); |     return DAG.getNode(X86ISD::SETCC, VTs2, 2, Ops2, 2); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   assert(isFP && "Illegal integer SetCC!"); |   assert(isFP && "Illegal integer SetCC!"); | ||||||
|  |  | ||||||
|   SDOperand COps[] = { Chain, Op0, Op1 }; |   SDOperand COps[] = { Chain, Op0, Op1 }; | ||||||
|   Cond = DAG.getNode(X86ISD::CMP, VTs, 2, COps, 3).getValue(1); |   Cond = DAG.getNode(X86ISD::CMP, VTs1, 2, COps, 3).getValue(1); | ||||||
|  |  | ||||||
|   switch (SetCCOpcode) { |   switch (SetCCOpcode) { | ||||||
|   default: assert(false && "Illegal floating point SetCC!"); |   default: assert(false && "Illegal floating point SetCC!"); | ||||||
|   case ISD::SETOEQ: {  // !PF & ZF |   case ISD::SETOEQ: {  // !PF & ZF | ||||||
|     SDOperand Ops1[] = { DAG.getConstant(X86ISD::COND_NP, MVT::i8), Cond }; |     SDOperand Ops1[] = { DAG.getConstant(X86ISD::COND_NP, MVT::i8), Cond }; | ||||||
|     SDOperand Tmp1 = DAG.getNode(X86ISD::SETCC, VTs, 2, Ops1, 2); |     SDOperand Tmp1 = DAG.getNode(X86ISD::SETCC, VTs2, 2, Ops1, 2); | ||||||
|     SDOperand Ops2[] = { DAG.getConstant(X86ISD::COND_E, MVT::i8), |     SDOperand Ops2[] = { DAG.getConstant(X86ISD::COND_E, MVT::i8), | ||||||
|                          Tmp1.getValue(1) }; |                          Tmp1.getValue(1) }; | ||||||
|     SDOperand Tmp2 = DAG.getNode(X86ISD::SETCC, VTs, 2, Ops2, 2); |     SDOperand Tmp2 = DAG.getNode(X86ISD::SETCC, VTs2, 2, Ops2, 2); | ||||||
|     return DAG.getNode(ISD::AND, MVT::i8, Tmp1, Tmp2); |     return DAG.getNode(ISD::AND, MVT::i8, Tmp1, Tmp2); | ||||||
|   } |   } | ||||||
|   case ISD::SETUNE: {  // PF | !ZF |   case ISD::SETUNE: {  // PF | !ZF | ||||||
|     SDOperand Ops1[] = { DAG.getConstant(X86ISD::COND_P, MVT::i8), Cond }; |     SDOperand Ops1[] = { DAG.getConstant(X86ISD::COND_P, MVT::i8), Cond }; | ||||||
|     SDOperand Tmp1 = DAG.getNode(X86ISD::SETCC, VTs, 2, Ops1, 2); |     SDOperand Tmp1 = DAG.getNode(X86ISD::SETCC, VTs2, 2, Ops1, 2); | ||||||
|     SDOperand Ops2[] = { DAG.getConstant(X86ISD::COND_NE, MVT::i8), |     SDOperand Ops2[] = { DAG.getConstant(X86ISD::COND_NE, MVT::i8), | ||||||
|                          Tmp1.getValue(1) }; |                          Tmp1.getValue(1) }; | ||||||
|     SDOperand Tmp2 = DAG.getNode(X86ISD::SETCC, VTs, 2, Ops2, 2); |     SDOperand Tmp2 = DAG.getNode(X86ISD::SETCC, VTs2, 2, Ops2, 2); | ||||||
|     return DAG.getNode(ISD::OR, MVT::i8, Tmp1, Tmp2); |     return DAG.getNode(ISD::OR, MVT::i8, Tmp1, Tmp2); | ||||||
|   } |   } | ||||||
|   } |   } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user