blob: c4a4b8ddf6016f401f94ecd2c822654af16e1011 [file] [log] [blame]
/*
* Copyright (c) 2019 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "TestHarness.h"
#include "pas_bitfield_vector.h"
#include <vector>
using namespace std;
namespace {
void testBitfieldNumWords(unsigned numFields, unsigned numBitsPerField, unsigned expectedNumWords)
{
CHECK_EQUAL(PAS_BITFIELD_VECTOR_NUM_WORDS(numFields, numBitsPerField), expectedNumWords);
CHECK_EQUAL(PAS_BITFIELD_VECTOR_NUM_BYTES(numFields, numBitsPerField), expectedNumWords * sizeof(unsigned));
}
void testBitfieldNumFields(unsigned numWords, unsigned numBitsPerField, unsigned expectedNumFields)
{
CHECK_EQUAL(PAS_BITFIELD_VECTOR_NUM_FIELDS(numWords, numBitsPerField), expectedNumFields);
}
void testBitfieldWordIndex(unsigned fieldIndex, unsigned numBitsPerField, unsigned expectedWordIndex)
{
CHECK_EQUAL(PAS_BITFIELD_VECTOR_WORD_INDEX(fieldIndex, numBitsPerField), expectedWordIndex);
}
void testBitfieldFieldIndex(unsigned wordIndex, unsigned numBitsPerField, unsigned expectedFieldIndex)
{
CHECK_EQUAL(PAS_BITFIELD_VECTOR_FIELD_INDEX(wordIndex, numBitsPerField), expectedFieldIndex);
}
void testBitfieldFieldShift(unsigned fieldIndex, unsigned numBitsPerField, unsigned expectedFieldShift)
{
CHECK_EQUAL(PAS_BITFIELD_VECTOR_FIELD_SHIFT(fieldIndex, numBitsPerField), expectedFieldShift);
}
class BitfieldVector {
public:
BitfieldVector(unsigned numFields, unsigned numBitsPerField)
: m_bits(PAS_BITFIELD_VECTOR_NUM_WORDS(numFields, numBitsPerField), 0)
, m_numBitsPerField(numBitsPerField)
{
}
unsigned get(unsigned fieldIndex) const
{
return pas_bitfield_vector_get(m_bits.data(), m_numBitsPerField, fieldIndex);
}
void set(unsigned fieldIndex, unsigned value)
{
pas_bitfield_vector_set(m_bits.data(), m_numBitsPerField, fieldIndex, value);
}
private:
vector<unsigned> m_bits;
unsigned m_numBitsPerField;
};
void testBitfieldVectorForward(unsigned numFields, unsigned numBitsPerField)
{
BitfieldVector myVector(numFields, numBitsPerField);
for (unsigned i = 0; i < numFields; ++i)
myVector.set(i, (i * 7) & PAS_BITFIELD_VECTOR_FIELD_MASK(numBitsPerField));
for (unsigned i = 0; i < numFields; ++i)
CHECK_EQUAL(myVector.get(i), (i * 7) & PAS_BITFIELD_VECTOR_FIELD_MASK(numBitsPerField));
}
void testBitfieldVectorBackward(unsigned numFields, unsigned numBitsPerField)
{
BitfieldVector myVector(numFields, numBitsPerField);
for (unsigned i = numFields; i--;)
myVector.set(i, (i * 11) & PAS_BITFIELD_VECTOR_FIELD_MASK(numBitsPerField));
for (unsigned i = numFields; i--;)
CHECK_EQUAL(myVector.get(i), (i * 11) & PAS_BITFIELD_VECTOR_FIELD_MASK(numBitsPerField));
}
} // anonymous namespace
void addBitfieldVectorTests()
{
ADD_TEST(testBitfieldNumWords(0, 1, 0));
ADD_TEST(testBitfieldNumWords(0, 2, 0));
ADD_TEST(testBitfieldNumWords(0, 4, 0));
ADD_TEST(testBitfieldNumWords(0, 8, 0));
ADD_TEST(testBitfieldNumWords(0, 16, 0));
ADD_TEST(testBitfieldNumWords(0, 32, 0));
ADD_TEST(testBitfieldNumWords(1, 1, 1));
ADD_TEST(testBitfieldNumWords(1, 2, 1));
ADD_TEST(testBitfieldNumWords(1, 4, 1));
ADD_TEST(testBitfieldNumWords(1, 8, 1));
ADD_TEST(testBitfieldNumWords(1, 16, 1));
ADD_TEST(testBitfieldNumWords(1, 32, 1));
ADD_TEST(testBitfieldNumWords(2, 1, 1));
ADD_TEST(testBitfieldNumWords(2, 2, 1));
ADD_TEST(testBitfieldNumWords(2, 4, 1));
ADD_TEST(testBitfieldNumWords(2, 8, 1));
ADD_TEST(testBitfieldNumWords(2, 16, 1));
ADD_TEST(testBitfieldNumWords(2, 32, 2));
ADD_TEST(testBitfieldNumWords(3, 1, 1));
ADD_TEST(testBitfieldNumWords(3, 2, 1));
ADD_TEST(testBitfieldNumWords(3, 4, 1));
ADD_TEST(testBitfieldNumWords(3, 8, 1));
ADD_TEST(testBitfieldNumWords(3, 16, 2));
ADD_TEST(testBitfieldNumWords(3, 32, 3));
ADD_TEST(testBitfieldNumWords(4, 1, 1));
ADD_TEST(testBitfieldNumWords(4, 2, 1));
ADD_TEST(testBitfieldNumWords(4, 4, 1));
ADD_TEST(testBitfieldNumWords(4, 8, 1));
ADD_TEST(testBitfieldNumWords(4, 16, 2));
ADD_TEST(testBitfieldNumWords(4, 32, 4));
ADD_TEST(testBitfieldNumWords(8, 1, 1));
ADD_TEST(testBitfieldNumWords(8, 2, 1));
ADD_TEST(testBitfieldNumWords(8, 4, 1));
ADD_TEST(testBitfieldNumWords(8, 8, 2));
ADD_TEST(testBitfieldNumWords(8, 16, 4));
ADD_TEST(testBitfieldNumWords(8, 32, 8));
ADD_TEST(testBitfieldNumWords(9, 1, 1));
ADD_TEST(testBitfieldNumWords(9, 2, 1));
ADD_TEST(testBitfieldNumWords(9, 4, 2));
ADD_TEST(testBitfieldNumWords(9, 8, 3));
ADD_TEST(testBitfieldNumWords(9, 16, 5));
ADD_TEST(testBitfieldNumWords(9, 32, 9));
ADD_TEST(testBitfieldNumWords(19, 1, 1));
ADD_TEST(testBitfieldNumWords(19, 2, 2));
ADD_TEST(testBitfieldNumWords(19, 4, 3));
ADD_TEST(testBitfieldNumWords(19, 8, 5));
ADD_TEST(testBitfieldNumWords(19, 16, 10));
ADD_TEST(testBitfieldNumWords(19, 32, 19));
ADD_TEST(testBitfieldNumWords(81, 1, 3));
ADD_TEST(testBitfieldNumWords(81, 2, 6));
ADD_TEST(testBitfieldNumWords(81, 4, 11));
ADD_TEST(testBitfieldNumWords(81, 8, 21));
ADD_TEST(testBitfieldNumWords(81, 16, 41));
ADD_TEST(testBitfieldNumWords(81, 32, 81));
ADD_TEST(testBitfieldNumWords(95, 1, 3));
ADD_TEST(testBitfieldNumWords(95, 2, 6));
ADD_TEST(testBitfieldNumWords(95, 4, 12));
ADD_TEST(testBitfieldNumWords(95, 8, 24));
ADD_TEST(testBitfieldNumWords(95, 16, 48));
ADD_TEST(testBitfieldNumWords(95, 32, 95));
ADD_TEST(testBitfieldNumWords(96, 1, 3));
ADD_TEST(testBitfieldNumWords(96, 2, 6));
ADD_TEST(testBitfieldNumWords(96, 4, 12));
ADD_TEST(testBitfieldNumWords(96, 8, 24));
ADD_TEST(testBitfieldNumWords(96, 16, 48));
ADD_TEST(testBitfieldNumWords(96, 32, 96));
ADD_TEST(testBitfieldNumWords(97, 1, 4));
ADD_TEST(testBitfieldNumWords(97, 2, 7));
ADD_TEST(testBitfieldNumWords(97, 4, 13));
ADD_TEST(testBitfieldNumWords(97, 8, 25));
ADD_TEST(testBitfieldNumWords(97, 16, 49));
ADD_TEST(testBitfieldNumWords(97, 32, 97));
ADD_TEST(testBitfieldNumFields(0, 1, 0));
ADD_TEST(testBitfieldNumFields(0, 2, 0));
ADD_TEST(testBitfieldNumFields(0, 4, 0));
ADD_TEST(testBitfieldNumFields(0, 8, 0));
ADD_TEST(testBitfieldNumFields(0, 16, 0));
ADD_TEST(testBitfieldNumFields(0, 32, 0));
ADD_TEST(testBitfieldNumFields(1, 1, 32));
ADD_TEST(testBitfieldNumFields(1, 2, 16));
ADD_TEST(testBitfieldNumFields(1, 4, 8));
ADD_TEST(testBitfieldNumFields(1, 8, 4));
ADD_TEST(testBitfieldNumFields(1, 16, 2));
ADD_TEST(testBitfieldNumFields(1, 32, 1));
ADD_TEST(testBitfieldNumFields(3, 1, 96));
ADD_TEST(testBitfieldNumFields(3, 2, 48));
ADD_TEST(testBitfieldNumFields(3, 4, 24));
ADD_TEST(testBitfieldNumFields(3, 8, 12));
ADD_TEST(testBitfieldNumFields(3, 16, 6));
ADD_TEST(testBitfieldNumFields(3, 32, 3));
ADD_TEST(testBitfieldWordIndex(0, 1, 0));
ADD_TEST(testBitfieldWordIndex(0, 2, 0));
ADD_TEST(testBitfieldWordIndex(0, 4, 0));
ADD_TEST(testBitfieldWordIndex(0, 8, 0));
ADD_TEST(testBitfieldWordIndex(0, 16, 0));
ADD_TEST(testBitfieldWordIndex(0, 32, 0));
ADD_TEST(testBitfieldWordIndex(1, 1, 0));
ADD_TEST(testBitfieldWordIndex(1, 2, 0));
ADD_TEST(testBitfieldWordIndex(1, 4, 0));
ADD_TEST(testBitfieldWordIndex(1, 8, 0));
ADD_TEST(testBitfieldWordIndex(1, 16, 0));
ADD_TEST(testBitfieldWordIndex(1, 32, 1));
ADD_TEST(testBitfieldWordIndex(2, 1, 0));
ADD_TEST(testBitfieldWordIndex(2, 2, 0));
ADD_TEST(testBitfieldWordIndex(2, 4, 0));
ADD_TEST(testBitfieldWordIndex(2, 8, 0));
ADD_TEST(testBitfieldWordIndex(2, 16, 1));
ADD_TEST(testBitfieldWordIndex(2, 32, 2));
ADD_TEST(testBitfieldWordIndex(3, 1, 0));
ADD_TEST(testBitfieldWordIndex(3, 2, 0));
ADD_TEST(testBitfieldWordIndex(3, 4, 0));
ADD_TEST(testBitfieldWordIndex(3, 8, 0));
ADD_TEST(testBitfieldWordIndex(3, 16, 1));
ADD_TEST(testBitfieldWordIndex(3, 32, 3));
ADD_TEST(testBitfieldWordIndex(4, 1, 0));
ADD_TEST(testBitfieldWordIndex(4, 2, 0));
ADD_TEST(testBitfieldWordIndex(4, 4, 0));
ADD_TEST(testBitfieldWordIndex(4, 8, 1));
ADD_TEST(testBitfieldWordIndex(4, 16, 2));
ADD_TEST(testBitfieldWordIndex(4, 32, 4));
ADD_TEST(testBitfieldWordIndex(95, 1, 2));
ADD_TEST(testBitfieldWordIndex(95, 2, 5));
ADD_TEST(testBitfieldWordIndex(95, 4, 11));
ADD_TEST(testBitfieldWordIndex(95, 8, 23));
ADD_TEST(testBitfieldWordIndex(95, 16, 47));
ADD_TEST(testBitfieldWordIndex(95, 32, 95));
ADD_TEST(testBitfieldWordIndex(96, 1, 3));
ADD_TEST(testBitfieldWordIndex(96, 2, 6));
ADD_TEST(testBitfieldWordIndex(96, 4, 12));
ADD_TEST(testBitfieldWordIndex(96, 8, 24));
ADD_TEST(testBitfieldWordIndex(96, 16, 48));
ADD_TEST(testBitfieldWordIndex(96, 32, 96));
ADD_TEST(testBitfieldWordIndex(97, 1, 3));
ADD_TEST(testBitfieldWordIndex(97, 2, 6));
ADD_TEST(testBitfieldWordIndex(97, 4, 12));
ADD_TEST(testBitfieldWordIndex(97, 8, 24));
ADD_TEST(testBitfieldWordIndex(97, 16, 48));
ADD_TEST(testBitfieldWordIndex(97, 32, 97));
ADD_TEST(testBitfieldFieldIndex(0, 1, 0));
ADD_TEST(testBitfieldFieldIndex(0, 2, 0));
ADD_TEST(testBitfieldFieldIndex(0, 4, 0));
ADD_TEST(testBitfieldFieldIndex(0, 8, 0));
ADD_TEST(testBitfieldFieldIndex(0, 16, 0));
ADD_TEST(testBitfieldFieldIndex(0, 32, 0));
ADD_TEST(testBitfieldFieldIndex(1, 1, 32));
ADD_TEST(testBitfieldFieldIndex(1, 2, 16));
ADD_TEST(testBitfieldFieldIndex(1, 4, 8));
ADD_TEST(testBitfieldFieldIndex(1, 8, 4));
ADD_TEST(testBitfieldFieldIndex(1, 16, 2));
ADD_TEST(testBitfieldFieldIndex(1, 32, 1));
ADD_TEST(testBitfieldFieldIndex(3, 1, 96));
ADD_TEST(testBitfieldFieldIndex(3, 2, 48));
ADD_TEST(testBitfieldFieldIndex(3, 4, 24));
ADD_TEST(testBitfieldFieldIndex(3, 8, 12));
ADD_TEST(testBitfieldFieldIndex(3, 16, 6));
ADD_TEST(testBitfieldFieldIndex(3, 32, 3));
ADD_TEST(testBitfieldFieldShift(0, 1, 0));
ADD_TEST(testBitfieldFieldShift(0, 2, 0));
ADD_TEST(testBitfieldFieldShift(0, 4, 0));
ADD_TEST(testBitfieldFieldShift(0, 8, 0));
ADD_TEST(testBitfieldFieldShift(0, 16, 0));
ADD_TEST(testBitfieldFieldShift(0, 32, 0));
ADD_TEST(testBitfieldFieldShift(1, 1, 1));
ADD_TEST(testBitfieldFieldShift(1, 2, 2));
ADD_TEST(testBitfieldFieldShift(1, 4, 4));
ADD_TEST(testBitfieldFieldShift(1, 8, 8));
ADD_TEST(testBitfieldFieldShift(1, 16, 16));
ADD_TEST(testBitfieldFieldShift(1, 32, 0));
ADD_TEST(testBitfieldFieldShift(2, 1, 2));
ADD_TEST(testBitfieldFieldShift(2, 2, 4));
ADD_TEST(testBitfieldFieldShift(2, 4, 8));
ADD_TEST(testBitfieldFieldShift(2, 8, 16));
ADD_TEST(testBitfieldFieldShift(2, 16, 0));
ADD_TEST(testBitfieldFieldShift(2, 32, 0));
ADD_TEST(testBitfieldFieldShift(3, 1, 3));
ADD_TEST(testBitfieldFieldShift(3, 2, 6));
ADD_TEST(testBitfieldFieldShift(3, 4, 12));
ADD_TEST(testBitfieldFieldShift(3, 8, 24));
ADD_TEST(testBitfieldFieldShift(3, 16, 16));
ADD_TEST(testBitfieldFieldShift(3, 32, 0));
ADD_TEST(testBitfieldFieldShift(4, 1, 4));
ADD_TEST(testBitfieldFieldShift(4, 2, 8));
ADD_TEST(testBitfieldFieldShift(4, 4, 16));
ADD_TEST(testBitfieldFieldShift(4, 8, 0));
ADD_TEST(testBitfieldFieldShift(4, 16, 0));
ADD_TEST(testBitfieldFieldShift(4, 32, 0));
ADD_TEST(testBitfieldFieldShift(95, 1, 31));
ADD_TEST(testBitfieldFieldShift(95, 2, 30));
ADD_TEST(testBitfieldFieldShift(95, 4, 28));
ADD_TEST(testBitfieldFieldShift(95, 8, 24));
ADD_TEST(testBitfieldFieldShift(95, 16, 16));
ADD_TEST(testBitfieldFieldShift(95, 32, 0));
ADD_TEST(testBitfieldFieldShift(96, 1, 0));
ADD_TEST(testBitfieldFieldShift(96, 2, 0));
ADD_TEST(testBitfieldFieldShift(96, 4, 0));
ADD_TEST(testBitfieldFieldShift(96, 8, 0));
ADD_TEST(testBitfieldFieldShift(96, 16, 0));
ADD_TEST(testBitfieldFieldShift(96, 32, 0));
ADD_TEST(testBitfieldFieldShift(97, 1, 1));
ADD_TEST(testBitfieldFieldShift(97, 2, 2));
ADD_TEST(testBitfieldFieldShift(97, 4, 4));
ADD_TEST(testBitfieldFieldShift(97, 8, 8));
ADD_TEST(testBitfieldFieldShift(97, 16, 16));
ADD_TEST(testBitfieldFieldShift(97, 32, 0));
ADD_TEST(testBitfieldVectorForward(95, 1));
ADD_TEST(testBitfieldVectorForward(95, 2));
ADD_TEST(testBitfieldVectorForward(95, 4));
ADD_TEST(testBitfieldVectorForward(95, 8));
ADD_TEST(testBitfieldVectorForward(95, 16));
ADD_TEST(testBitfieldVectorForward(95, 32));
ADD_TEST(testBitfieldVectorBackward(95, 1));
ADD_TEST(testBitfieldVectorBackward(95, 2));
ADD_TEST(testBitfieldVectorBackward(95, 4));
ADD_TEST(testBitfieldVectorBackward(95, 8));
ADD_TEST(testBitfieldVectorBackward(95, 16));
ADD_TEST(testBitfieldVectorBackward(95, 32));
}