X86: Use bitset to manage a bag of bits. NFC.

Doesn't matter in terms of memory usage or perf here, but it's a neat
simplification.

llvm-svn: 229672
This commit is contained in:
Benjamin Kramer 2015-02-18 14:10:44 +00:00
parent 8874eac5e6
commit 6ca8992018
1 changed files with 3 additions and 7 deletions

View File

@ -5828,13 +5828,12 @@ static SDValue LowerBuildVectorv4x32(SDValue Op, SelectionDAG &DAG,
const X86Subtarget *Subtarget, const X86Subtarget *Subtarget,
const TargetLowering &TLI) { const TargetLowering &TLI) {
// Find all zeroable elements. // Find all zeroable elements.
bool Zeroable[4]; std::bitset<4> Zeroable;
for (int i=0; i < 4; ++i) { for (int i=0; i < 4; ++i) {
SDValue Elt = Op->getOperand(i); SDValue Elt = Op->getOperand(i);
Zeroable[i] = (Elt.getOpcode() == ISD::UNDEF || X86::isZeroNode(Elt)); Zeroable[i] = (Elt.getOpcode() == ISD::UNDEF || X86::isZeroNode(Elt));
} }
assert(std::count_if(&Zeroable[0], &Zeroable[4], assert(Zeroable.size() - Zeroable.count() > 1 &&
[](bool M) { return !M; }) > 1 &&
"We expect at least two non-zero elements!"); "We expect at least two non-zero elements!");
// We only know how to deal with build_vector nodes where elements are either // We only know how to deal with build_vector nodes where elements are either
@ -5920,10 +5919,7 @@ static SDValue LowerBuildVectorv4x32(SDValue Op, SelectionDAG &DAG,
V2 = DAG.getNode(ISD::BITCAST, SDLoc(V2), MVT::v4f32, V2); V2 = DAG.getNode(ISD::BITCAST, SDLoc(V2), MVT::v4f32, V2);
// Ok, we can emit an INSERTPS instruction. // Ok, we can emit an INSERTPS instruction.
unsigned ZMask = 0; unsigned ZMask = Zeroable.to_ulong();
for (int i = 0; i < 4; ++i)
if (Zeroable[i])
ZMask |= 1 << i;
unsigned InsertPSMask = EltMaskIdx << 6 | EltIdx << 4 | ZMask; unsigned InsertPSMask = EltMaskIdx << 6 | EltIdx << 4 | ZMask;
assert((InsertPSMask & ~0xFFu) == 0 && "Invalid mask!"); assert((InsertPSMask & ~0xFFu) == 0 && "Invalid mask!");