blob: 807ce31381efbf4e37e9e4a53594a52042c53dc7 [file] [log] [blame] [edit]
//===- llvm/unittest/Support/KnownBitsTest.h - KnownBits tests ------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// This file implements helpers for KnownBits and DemandedBits unit tests.
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_UNITTESTS_SUPPORT_KNOWNBITSTEST_H
#define LLVM_UNITTESTS_SUPPORT_KNOWNBITSTEST_H
#include "llvm/Support/KnownBits.h"
namespace {
using namespace llvm;
template <typename FnTy> void ForeachKnownBits(unsigned Bits, FnTy Fn) {
unsigned Max = 1 << Bits;
KnownBits Known(Bits);
for (unsigned Zero = 0; Zero < Max; ++Zero) {
for (unsigned One = 0; One < Max; ++One) {
Known.Zero = Zero;
Known.One = One;
Fn(Known);
}
}
}
template <typename FnTy>
void ForeachNumInKnownBits(const KnownBits &Known, FnTy Fn) {
unsigned Bits = Known.getBitWidth();
assert(Bits < 32);
unsigned Max = 1u << Bits;
unsigned Zero = Known.Zero.getZExtValue();
unsigned One = Known.One.getZExtValue();
if (Zero & One) {
// Known has a conflict. No values will satisfy it.
return;
}
for (unsigned N = 0; N < Max; ++N) {
if ((N & Zero) == 0 && (~N & One) == 0)
Fn(APInt(Bits, N));
}
}
} // end anonymous namespace
#endif