forked from OSchip/llvm-project
parent
177be32334
commit
1be6286028
|
@ -980,6 +980,7 @@ X86TargetLowering::X86TargetLowering(X86TargetMachine &TM)
|
|||
setTargetDAGCombine(ISD::SRL);
|
||||
setTargetDAGCombine(ISD::STORE);
|
||||
setTargetDAGCombine(ISD::MEMBARRIER);
|
||||
setTargetDAGCombine(ISD::ZERO_EXTEND);
|
||||
if (Subtarget->is64Bit())
|
||||
setTargetDAGCombine(ISD::MUL);
|
||||
|
||||
|
@ -5752,14 +5753,11 @@ SDValue X86TargetLowering::LowerSETCC(SDValue Op, SelectionDAG &DAG) {
|
|||
SDValue Cond = EmitCmp(Op0, Op1, X86CC, DAG);
|
||||
|
||||
// Use sbb x, x to materialize carry bit into a GPR.
|
||||
// FIXME: Temporarily disabled since it breaks self-hosting. It's apparently
|
||||
// miscompiling ARMISelDAGToDAG.cpp.
|
||||
if (0 && !isFP && X86CC == X86::COND_B) {
|
||||
if (X86CC == X86::COND_B)
|
||||
return DAG.getNode(ISD::AND, dl, MVT::i8,
|
||||
DAG.getNode(X86ISD::SETCC_CARRY, dl, MVT::i8,
|
||||
DAG.getConstant(X86CC, MVT::i8), Cond),
|
||||
DAG.getConstant(1, MVT::i8));
|
||||
}
|
||||
|
||||
return DAG.getNode(X86ISD::SETCC, dl, MVT::i8,
|
||||
DAG.getConstant(X86CC, MVT::i8), Cond);
|
||||
|
@ -9349,6 +9347,32 @@ static SDValue PerformMEMBARRIERCombine(SDNode* N, SelectionDAG &DAG) {
|
|||
}
|
||||
}
|
||||
|
||||
static SDValue PerformZExtCombine(SDNode *N, SelectionDAG &DAG) {
|
||||
// (i32 zext (and (i8 x86isd::setcc_carry), 1)) ->
|
||||
// (and (i32 x86isd::setcc_carry), 1)
|
||||
// This eliminates the zext. This transformation is necessary because
|
||||
// ISD::SETCC is always legalized to i8.
|
||||
DebugLoc dl = N->getDebugLoc();
|
||||
SDValue N0 = N->getOperand(0);
|
||||
EVT VT = N->getValueType(0);
|
||||
if (N0.getOpcode() == ISD::AND &&
|
||||
N0.hasOneUse() &&
|
||||
N0.getOperand(0).hasOneUse()) {
|
||||
SDValue N00 = N0.getOperand(0);
|
||||
if (N00.getOpcode() != X86ISD::SETCC_CARRY)
|
||||
return SDValue();
|
||||
ConstantSDNode *C = dyn_cast<ConstantSDNode>(N0.getOperand(1));
|
||||
if (!C || C->getZExtValue() != 1)
|
||||
return SDValue();
|
||||
return DAG.getNode(ISD::AND, dl, VT,
|
||||
DAG.getNode(X86ISD::SETCC_CARRY, dl, VT,
|
||||
N00.getOperand(0), N00.getOperand(1)),
|
||||
DAG.getConstant(1, VT));
|
||||
}
|
||||
|
||||
return SDValue();
|
||||
}
|
||||
|
||||
SDValue X86TargetLowering::PerformDAGCombine(SDNode *N,
|
||||
DAGCombinerInfo &DCI) const {
|
||||
SelectionDAG &DAG = DCI.DAG;
|
||||
|
@ -9368,6 +9392,7 @@ SDValue X86TargetLowering::PerformDAGCombine(SDNode *N,
|
|||
case X86ISD::BT: return PerformBTCombine(N, DAG, DCI);
|
||||
case X86ISD::VZEXT_MOVL: return PerformVZEXT_MOVLCombine(N, DAG);
|
||||
case ISD::MEMBARRIER: return PerformMEMBARRIERCombine(N, DAG);
|
||||
case ISD::ZERO_EXTEND: return PerformZExtCombine(N, DAG);
|
||||
}
|
||||
|
||||
return SDValue();
|
||||
|
|
|
@ -1337,9 +1337,9 @@ def CMOVNO64rm : RI<0x41, MRMSrcMem, // if !overflow, GR64 = [mem64]
|
|||
let Defs = [EFLAGS], Uses = [EFLAGS], isCodeGenOnly = 1 in
|
||||
def SETB_C64r : RI<0x19, MRMInitReg, (outs GR64:$dst), (ins),
|
||||
"sbb{q}\t$dst, $dst",
|
||||
[(set GR64:$dst, (zext (X86setcc_c X86_COND_B, EFLAGS)))]>;
|
||||
[(set GR64:$dst, (X86setcc_c X86_COND_B, EFLAGS))]>;
|
||||
|
||||
def : Pat<(i64 (anyext (X86setcc_c X86_COND_B, EFLAGS))),
|
||||
def : Pat<(i64 (anyext (i8 (X86setcc_c X86_COND_B, EFLAGS)))),
|
||||
(SETB_C64r)>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
|
@ -41,6 +41,9 @@ def SDTX86BrCond : SDTypeProfile<0, 3,
|
|||
def SDTX86SetCC : SDTypeProfile<1, 2,
|
||||
[SDTCisVT<0, i8>,
|
||||
SDTCisVT<1, i8>, SDTCisVT<2, i32>]>;
|
||||
def SDTX86SetCC_C : SDTypeProfile<1, 2,
|
||||
[SDTCisInt<0>,
|
||||
SDTCisVT<1, i8>, SDTCisVT<2, i32>]>;
|
||||
|
||||
def SDTX86cas : SDTypeProfile<0, 3, [SDTCisPtrTy<0>, SDTCisInt<1>,
|
||||
SDTCisVT<2, i8>]>;
|
||||
|
@ -87,7 +90,7 @@ def X86cmov : SDNode<"X86ISD::CMOV", SDTX86Cmov>;
|
|||
def X86brcond : SDNode<"X86ISD::BRCOND", SDTX86BrCond,
|
||||
[SDNPHasChain]>;
|
||||
def X86setcc : SDNode<"X86ISD::SETCC", SDTX86SetCC>;
|
||||
def X86setcc_c : SDNode<"X86ISD::SETCC_CARRY", SDTX86SetCC>;
|
||||
def X86setcc_c : SDNode<"X86ISD::SETCC_CARRY", SDTX86SetCC_C>;
|
||||
|
||||
def X86cas : SDNode<"X86ISD::LCMPXCHG_DAG", SDTX86cas,
|
||||
[SDNPHasChain, SDNPInFlag, SDNPOutFlag, SDNPMayStore,
|
||||
|
@ -3068,11 +3071,11 @@ def SETB_C8r : I<0x18, MRMInitReg, (outs GR8:$dst), (ins),
|
|||
[(set GR8:$dst, (X86setcc_c X86_COND_B, EFLAGS))]>;
|
||||
def SETB_C16r : I<0x19, MRMInitReg, (outs GR16:$dst), (ins),
|
||||
"sbb{w}\t$dst, $dst",
|
||||
[(set GR16:$dst, (zext (X86setcc_c X86_COND_B, EFLAGS)))]>,
|
||||
[(set GR16:$dst, (X86setcc_c X86_COND_B, EFLAGS))]>,
|
||||
OpSize;
|
||||
def SETB_C32r : I<0x19, MRMInitReg, (outs GR32:$dst), (ins),
|
||||
"sbb{l}\t$dst, $dst",
|
||||
[(set GR32:$dst, (zext (X86setcc_c X86_COND_B, EFLAGS)))]>;
|
||||
[(set GR32:$dst, (X86setcc_c X86_COND_B, EFLAGS))]>;
|
||||
} // isCodeGenOnly
|
||||
|
||||
def SETEr : I<0x94, MRM0r,
|
||||
|
@ -4185,10 +4188,10 @@ def : Pat<(store (shld (loadi16 addr:$dst), (i8 imm:$amt1),
|
|||
GR16:$src2, (i8 imm:$amt2)), addr:$dst),
|
||||
(SHLD16mri8 addr:$dst, GR16:$src2, (i8 imm:$amt1))>;
|
||||
|
||||
// (anyext (setcc_carry)) -> (zext (setcc_carry))
|
||||
def : Pat<(i16 (anyext (X86setcc_c X86_COND_B, EFLAGS))),
|
||||
// (anyext (setcc_carry)) -> (setcc_carry)
|
||||
def : Pat<(i16 (anyext (i8 (X86setcc_c X86_COND_B, EFLAGS)))),
|
||||
(SETB_C16r)>;
|
||||
def : Pat<(i32 (anyext (X86setcc_c X86_COND_B, EFLAGS))),
|
||||
def : Pat<(i32 (anyext (i8 (X86setcc_c X86_COND_B, EFLAGS)))),
|
||||
(SETB_C32r)>;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
; RUN: llc < %s -mtriple=x86_64-apple-darwin | FileCheck %s
|
||||
; XFAIL: *
|
||||
; rdar://7329206
|
||||
|
||||
; Use sbb x, x to materialize carry bit in a GPR. The value is either
|
||||
|
|
Loading…
Reference in New Issue