mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-25 00:24:26 +00:00
expand count-leading/trailing-zeros; the test 2005-05-11-Popcount-ffs-fls.c
should now pass (the "LLVM" and "REF" results should be identical) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21866 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -1132,27 +1132,40 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||||||
Result = Tmp1;
|
Result = Tmp1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case ISD::CTTZ:
|
case ISD::CTLZ: {
|
||||||
/* This should be used for targets that support ctpop:
|
/* for now, we do this:
|
||||||
int nlz5(unsigned x) {
|
x = x | (x >> 1);
|
||||||
int pop(unsigned x);
|
x = x | (x >> 2);
|
||||||
|
...
|
||||||
x = x | (x >> 1);
|
x = x | (x >>16);
|
||||||
x = x | (x >> 2);
|
x = x | (x >>32); // for 64-bit input
|
||||||
x = x | (x >> 4);
|
return popcount(~x);
|
||||||
x = x | (x >> 8);
|
|
||||||
x = x | (x >>16);
|
but see also: http://www.hackersdelight.org/HDcode/nlz.cc */
|
||||||
return ctpop(~x);
|
MVT::ValueType VT = Tmp1.getValueType();
|
||||||
}
|
MVT::ValueType ShVT = TLI.getShiftAmountTy();
|
||||||
See also: http://www.hackersdelight.org/HDcode/nlz.cc
|
unsigned len = getSizeInBits(VT);
|
||||||
*/
|
for (unsigned i = 0; (1U << i) <= (len / 2); ++i) {
|
||||||
|
Tmp3 = DAG.getConstant(1ULL << i, ShVT);
|
||||||
assert(0 && "Cannot expand this yet!");
|
Tmp1 = DAG.getNode(ISD::OR, VT, Tmp1,
|
||||||
|
DAG.getNode(ISD::SRL, VT, Tmp1, Tmp3));
|
||||||
|
}
|
||||||
|
Tmp3 = DAG.getNode(ISD::XOR, VT, Tmp1, DAG.getConstant(~0ULL, VT));
|
||||||
|
Result = DAG.getNode(ISD::CTPOP, VT, Tmp3);
|
||||||
break;
|
break;
|
||||||
case ISD::CTLZ:
|
}
|
||||||
// See Also: http://www.hackersdelight.org/HDcode/ntz.cc
|
case ISD::CTTZ: {
|
||||||
assert(0 && "Cannot expand this yet!");
|
// for now, we use: { return popcount(~x & (x - 1)); }
|
||||||
|
// but see also http://www.hackersdelight.org/HDcode/ntz.cc )
|
||||||
|
MVT::ValueType VT = Tmp1.getValueType();
|
||||||
|
Tmp2 = DAG.getConstant(~0ULL, VT);
|
||||||
|
Tmp3 = DAG.getNode(ISD::AND, VT,
|
||||||
|
DAG.getNode(ISD::XOR, VT, Tmp1, Tmp2),
|
||||||
|
DAG.getNode(ISD::SUB, VT, Tmp1,
|
||||||
|
DAG.getConstant(1, VT)));
|
||||||
|
Result = DAG.getNode(ISD::CTPOP, VT, Tmp3);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
assert(0 && "Cannot expand this yet!");
|
assert(0 && "Cannot expand this yet!");
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user