forked from OSchip/llvm-project
Temporarily revert r299221 to fix nondeterminism in ThinLTO builder.
llvm-svn: 300783
This commit is contained in:
parent
0d98ada0d4
commit
2cc97d92ce
|
@ -2967,7 +2967,7 @@ unsigned SelectionDAG::ComputeNumSignBits(SDValue Op, const APInt &DemandedElts,
|
|||
return std::max(Tmp, Tmp2);
|
||||
|
||||
case ISD::SRA:
|
||||
Tmp = ComputeNumSignBits(Op.getOperand(0), DemandedElts, Depth+1);
|
||||
Tmp = ComputeNumSignBits(Op.getOperand(0), Depth+1);
|
||||
// SRA X, C -> adds C sign bits.
|
||||
if (ConstantSDNode *C = isConstOrConstSplat(Op.getOperand(1))) {
|
||||
APInt ShiftVal = C->getAPIntValue();
|
||||
|
@ -3130,40 +3130,6 @@ unsigned SelectionDAG::ComputeNumSignBits(SDValue Op, const APInt &DemandedElts,
|
|||
// result. Otherwise it gives either negative or > bitwidth result
|
||||
return std::max(std::min(KnownSign - rIndex * BitWidth, BitWidth), 0);
|
||||
}
|
||||
case ISD::INSERT_VECTOR_ELT: {
|
||||
SDValue InVec = Op.getOperand(0);
|
||||
SDValue InVal = Op.getOperand(1);
|
||||
SDValue EltNo = Op.getOperand(2);
|
||||
unsigned NumElts = InVec.getValueType().getVectorNumElements();
|
||||
|
||||
ConstantSDNode *CEltNo = dyn_cast<ConstantSDNode>(EltNo);
|
||||
if (CEltNo && CEltNo->getAPIntValue().ult(NumElts)) {
|
||||
// If we know the element index, split the demand between the
|
||||
// source vector and the inserted element.
|
||||
unsigned EltIdx = CEltNo->getZExtValue();
|
||||
|
||||
// If we demand the inserted element then get its sign bits.
|
||||
Tmp = UINT_MAX;
|
||||
if (DemandedElts[EltIdx])
|
||||
Tmp = ComputeNumSignBits(InVal, Depth + 1);
|
||||
|
||||
// If we demand the source vector then get its sign bits, and determine
|
||||
// the minimum.
|
||||
APInt VectorElts = DemandedElts;
|
||||
VectorElts.clearBit(EltIdx);
|
||||
if (!!VectorElts) {
|
||||
Tmp2 = ComputeNumSignBits(InVec, VectorElts, Depth + 1);
|
||||
Tmp = std::min(Tmp, Tmp2);
|
||||
}
|
||||
} else {
|
||||
// Unknown element index, so ignore DemandedElts and demand them all.
|
||||
Tmp = ComputeNumSignBits(InVec, Depth + 1);
|
||||
Tmp2 = ComputeNumSignBits(InVal, Depth + 1);
|
||||
Tmp = std::min(Tmp, Tmp2);
|
||||
}
|
||||
assert(Tmp <= VTBits && "Failed to determine minimum sign bits");
|
||||
return Tmp;
|
||||
}
|
||||
case ISD::EXTRACT_VECTOR_ELT: {
|
||||
SDValue InVec = Op.getOperand(0);
|
||||
SDValue EltNo = Op.getOperand(1);
|
||||
|
|
|
@ -100,21 +100,27 @@ define float @signbits_ashr_extract_sitofp(<2 x i64> %a0) nounwind {
|
|||
define float @signbits_ashr_insert_ashr_extract_sitofp(i64 %a0, i64 %a1) nounwind {
|
||||
; X32-LABEL: signbits_ashr_insert_ashr_extract_sitofp:
|
||||
; X32: # BB#0:
|
||||
; X32-NEXT: pushl %eax
|
||||
; X32-NEXT: movl {{[0-9]+}}(%esp), %eax
|
||||
; X32-NEXT: movl {{[0-9]+}}(%esp), %ecx
|
||||
; X32-NEXT: pushl %ebp
|
||||
; X32-NEXT: movl %esp, %ebp
|
||||
; X32-NEXT: andl $-8, %esp
|
||||
; X32-NEXT: subl $16, %esp
|
||||
; X32-NEXT: movl 8(%ebp), %eax
|
||||
; X32-NEXT: movl 12(%ebp), %ecx
|
||||
; X32-NEXT: shrdl $30, %ecx, %eax
|
||||
; X32-NEXT: sarl $30, %ecx
|
||||
; X32-NEXT: vmovd %eax, %xmm0
|
||||
; X32-NEXT: vpinsrd $1, %ecx, %xmm0, %xmm0
|
||||
; X32-NEXT: vpinsrd $2, {{[0-9]+}}(%esp), %xmm0, %xmm0
|
||||
; X32-NEXT: vpinsrd $3, {{[0-9]+}}(%esp), %xmm0, %xmm0
|
||||
; X32-NEXT: vpinsrd $2, 16(%ebp), %xmm0, %xmm0
|
||||
; X32-NEXT: vpinsrd $3, 20(%ebp), %xmm0, %xmm0
|
||||
; X32-NEXT: vpsrad $3, %xmm0, %xmm1
|
||||
; X32-NEXT: vpsrlq $3, %xmm0, %xmm0
|
||||
; X32-NEXT: vmovd %xmm0, %eax
|
||||
; X32-NEXT: vcvtsi2ssl %eax, %xmm1, %xmm0
|
||||
; X32-NEXT: vmovss %xmm0, (%esp)
|
||||
; X32-NEXT: flds (%esp)
|
||||
; X32-NEXT: popl %eax
|
||||
; X32-NEXT: vpblendw {{.*#+}} xmm0 = xmm0[0,1],xmm1[2,3],xmm0[4,5],xmm1[6,7]
|
||||
; X32-NEXT: vmovq %xmm0, {{[0-9]+}}(%esp)
|
||||
; X32-NEXT: fildll {{[0-9]+}}(%esp)
|
||||
; X32-NEXT: fstps {{[0-9]+}}(%esp)
|
||||
; X32-NEXT: flds {{[0-9]+}}(%esp)
|
||||
; X32-NEXT: movl %ebp, %esp
|
||||
; X32-NEXT: popl %ebp
|
||||
; X32-NEXT: retl
|
||||
;
|
||||
; X64-LABEL: signbits_ashr_insert_ashr_extract_sitofp:
|
||||
|
@ -127,7 +133,7 @@ define float @signbits_ashr_insert_ashr_extract_sitofp(i64 %a0, i64 %a1) nounwin
|
|||
; X64-NEXT: vpsrlq $3, %xmm0, %xmm0
|
||||
; X64-NEXT: vpblendw {{.*#+}} xmm0 = xmm0[0,1],xmm1[2,3],xmm0[4,5],xmm1[6,7]
|
||||
; X64-NEXT: vmovq %xmm0, %rax
|
||||
; X64-NEXT: vcvtsi2ssl %eax, %xmm2, %xmm0
|
||||
; X64-NEXT: vcvtsi2ssq %rax, %xmm2, %xmm0
|
||||
; X64-NEXT: retq
|
||||
%1 = ashr i64 %a0, 30
|
||||
%2 = insertelement <2 x i64> undef, i64 %1, i32 0
|
||||
|
|
Loading…
Reference in New Issue