compute-runtime/shared/test/unit_test/helpers/bit_helpers_tests.cpp

221 lines
8.0 KiB
C++

/*
* Copyright (C) 2019-2024 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/helpers/bit_helpers.h"
#include "shared/source/helpers/constants.h"
#include "gtest/gtest.h"
using namespace NEO;
TEST(IsBitSetTests, givenDifferentValuesWhenTestingIsBitSetThenCorrectValueIsReturned) {
size_t field1 = 0;
size_t field2 = 0b1;
size_t field3 = 0b1000;
size_t field4 = 0b1010;
EXPECT_FALSE(isBitSet(field1, 0));
EXPECT_FALSE(isBitSet(field1, 1));
EXPECT_FALSE(isBitSet(field1, 2));
EXPECT_FALSE(isBitSet(field1, 3));
EXPECT_TRUE(isBitSet(field2, 0));
EXPECT_FALSE(isBitSet(field2, 1));
EXPECT_FALSE(isBitSet(field2, 2));
EXPECT_FALSE(isBitSet(field2, 3));
EXPECT_FALSE(isBitSet(field3, 0));
EXPECT_FALSE(isBitSet(field3, 1));
EXPECT_FALSE(isBitSet(field3, 2));
EXPECT_TRUE(isBitSet(field3, 3));
EXPECT_FALSE(isBitSet(field4, 0));
EXPECT_TRUE(isBitSet(field4, 1));
EXPECT_FALSE(isBitSet(field4, 2));
EXPECT_TRUE(isBitSet(field4, 3));
}
TEST(IsAnyBitSetTests, givenDifferentValuesWhenTestingIsAnyBitSetThenCorrectValueIsReturned) {
EXPECT_FALSE(isAnyBitSet(0, 0));
EXPECT_FALSE(isAnyBitSet(0, 0b1));
EXPECT_FALSE(isAnyBitSet(0, 0b10));
EXPECT_FALSE(isAnyBitSet(0, 0b1000));
EXPECT_FALSE(isAnyBitSet(0, 0b1010));
EXPECT_FALSE(isAnyBitSet(0, 0b1111));
EXPECT_FALSE(isAnyBitSet(0b1, 0));
EXPECT_TRUE(isAnyBitSet(0b1, 0b1));
EXPECT_FALSE(isAnyBitSet(0b1, 0b10));
EXPECT_FALSE(isAnyBitSet(0b1, 0b1000));
EXPECT_FALSE(isAnyBitSet(0b1, 0b1010));
EXPECT_TRUE(isAnyBitSet(0b1, 0b1111));
EXPECT_FALSE(isAnyBitSet(0b10, 0));
EXPECT_FALSE(isAnyBitSet(0b10, 0b1));
EXPECT_TRUE(isAnyBitSet(0b10, 0b10));
EXPECT_FALSE(isAnyBitSet(0b10, 0b1000));
EXPECT_TRUE(isAnyBitSet(0b10, 0b1010));
EXPECT_TRUE(isAnyBitSet(0b10, 0b1111));
EXPECT_FALSE(isAnyBitSet(0b1000, 0));
EXPECT_FALSE(isAnyBitSet(0b1000, 0b1));
EXPECT_FALSE(isAnyBitSet(0b1000, 0b10));
EXPECT_TRUE(isAnyBitSet(0b1000, 0b1000));
EXPECT_TRUE(isAnyBitSet(0b1000, 0b1010));
EXPECT_TRUE(isAnyBitSet(0b1000, 0b1111));
EXPECT_FALSE(isAnyBitSet(0b1010, 0));
EXPECT_FALSE(isAnyBitSet(0b1010, 0b1));
EXPECT_TRUE(isAnyBitSet(0b1010, 0b10));
EXPECT_TRUE(isAnyBitSet(0b1010, 0b1000));
EXPECT_TRUE(isAnyBitSet(0b1010, 0b1010));
EXPECT_TRUE(isAnyBitSet(0b1010, 0b1111));
EXPECT_FALSE(isAnyBitSet(0b1111, 0));
EXPECT_TRUE(isAnyBitSet(0b1111, 0b1));
EXPECT_TRUE(isAnyBitSet(0b1111, 0b10));
EXPECT_TRUE(isAnyBitSet(0b1111, 0b1000));
EXPECT_TRUE(isAnyBitSet(0b1111, 0b1010));
EXPECT_TRUE(isAnyBitSet(0b1111, 0b1111));
}
TEST(IsValueSetTests, givenDifferentValuesWhenTestingIsValueSetThenCorrectValueIsReturned) {
size_t field1 = 0;
size_t field2 = 0b1;
size_t field3 = 0b10;
size_t field4 = 0b1000;
size_t field5 = 0b1010;
size_t field6 = 0b1111;
EXPECT_FALSE(isValueSet(field1, field2));
EXPECT_FALSE(isValueSet(field1, field3));
EXPECT_FALSE(isValueSet(field1, field4));
EXPECT_FALSE(isValueSet(field1, field5));
EXPECT_FALSE(isValueSet(field1, field6));
EXPECT_TRUE(isValueSet(field2, field2));
EXPECT_FALSE(isValueSet(field2, field3));
EXPECT_FALSE(isValueSet(field2, field4));
EXPECT_FALSE(isValueSet(field2, field5));
EXPECT_FALSE(isValueSet(field2, field6));
EXPECT_FALSE(isValueSet(field3, field2));
EXPECT_TRUE(isValueSet(field3, field3));
EXPECT_FALSE(isValueSet(field3, field4));
EXPECT_FALSE(isValueSet(field3, field5));
EXPECT_FALSE(isValueSet(field3, field6));
EXPECT_FALSE(isValueSet(field4, field2));
EXPECT_FALSE(isValueSet(field4, field3));
EXPECT_TRUE(isValueSet(field4, field4));
EXPECT_FALSE(isValueSet(field4, field5));
EXPECT_FALSE(isValueSet(field4, field6));
EXPECT_FALSE(isValueSet(field5, field2));
EXPECT_TRUE(isValueSet(field5, field3));
EXPECT_TRUE(isValueSet(field5, field4));
EXPECT_TRUE(isValueSet(field5, field5));
EXPECT_FALSE(isValueSet(field5, field6));
EXPECT_TRUE(isValueSet(field6, field2));
EXPECT_TRUE(isValueSet(field6, field3));
EXPECT_TRUE(isValueSet(field6, field4));
EXPECT_TRUE(isValueSet(field6, field5));
EXPECT_TRUE(isValueSet(field6, field6));
}
TEST(IsFieldValidTests, givenDifferentValuesWhenTestingIsFieldValidThenCorrectValueIsReturned) {
size_t field1 = 0;
size_t field2 = 0b1;
size_t field3 = 0b10;
size_t field4 = 0b1000;
size_t field5 = 0b1010;
size_t field6 = 0b1111;
EXPECT_TRUE(isFieldValid(field1, field1));
EXPECT_TRUE(isFieldValid(field1, field2));
EXPECT_TRUE(isFieldValid(field1, field3));
EXPECT_TRUE(isFieldValid(field1, field4));
EXPECT_TRUE(isFieldValid(field1, field5));
EXPECT_TRUE(isFieldValid(field1, field6));
EXPECT_FALSE(isFieldValid(field2, field1));
EXPECT_TRUE(isFieldValid(field2, field2));
EXPECT_FALSE(isFieldValid(field2, field3));
EXPECT_FALSE(isFieldValid(field2, field4));
EXPECT_FALSE(isFieldValid(field2, field5));
EXPECT_TRUE(isFieldValid(field2, field6));
EXPECT_FALSE(isFieldValid(field3, field1));
EXPECT_FALSE(isFieldValid(field3, field2));
EXPECT_TRUE(isFieldValid(field3, field3));
EXPECT_FALSE(isFieldValid(field3, field4));
EXPECT_TRUE(isFieldValid(field3, field5));
EXPECT_TRUE(isFieldValid(field3, field6));
EXPECT_FALSE(isFieldValid(field4, field1));
EXPECT_FALSE(isFieldValid(field4, field2));
EXPECT_FALSE(isFieldValid(field4, field3));
EXPECT_TRUE(isFieldValid(field4, field4));
EXPECT_TRUE(isFieldValid(field4, field5));
EXPECT_TRUE(isFieldValid(field4, field6));
EXPECT_FALSE(isFieldValid(field5, field1));
EXPECT_FALSE(isFieldValid(field5, field2));
EXPECT_FALSE(isFieldValid(field5, field3));
EXPECT_FALSE(isFieldValid(field5, field4));
EXPECT_TRUE(isFieldValid(field5, field5));
EXPECT_TRUE(isFieldValid(field5, field6));
EXPECT_FALSE(isFieldValid(field6, field1));
EXPECT_FALSE(isFieldValid(field6, field2));
EXPECT_FALSE(isFieldValid(field6, field3));
EXPECT_FALSE(isFieldValid(field6, field4));
EXPECT_FALSE(isFieldValid(field6, field5));
EXPECT_TRUE(isFieldValid(field6, field6));
}
TEST(SetBitsTests, givenDifferentValuesWhenTestingSetBitsThenCorrectValueIsReturned) {
EXPECT_EQ(0b0u, setBits(0b0, false, 0b0));
EXPECT_EQ(0b0u, setBits(0b0, false, 0b1));
EXPECT_EQ(0b1u, setBits(0b1, false, 0b0));
EXPECT_EQ(0b0u, setBits(0b1, false, 0b1));
EXPECT_EQ(0b0u, setBits(0b0, true, 0b0));
EXPECT_EQ(0b1u, setBits(0b0, true, 0b1));
EXPECT_EQ(0b1u, setBits(0b1, true, 0b0));
EXPECT_EQ(0b1u, setBits(0b1, true, 0b1));
EXPECT_EQ(0b1010u, setBits(0b1010, false, 0b101));
EXPECT_EQ(0b1111u, setBits(0b1010, true, 0b101));
EXPECT_EQ(0b101u, setBits(0b101, false, 0b1010));
EXPECT_EQ(0b1111u, setBits(0b101, true, 0b1010));
EXPECT_EQ(0b0u, setBits(0b1010, false, 0b1010));
EXPECT_EQ(0b1010u, setBits(0b1010, true, 0b1010));
}
TEST(GetMsbIndexTests, givenDifferentValuesWhenTestingGetMostSignificantSetBitIndexThenCorrectValueIsReturned) {
EXPECT_EQ(0u, getMostSignificantSetBitIndex(0b0));
EXPECT_EQ(0u, getMostSignificantSetBitIndex(0b1));
EXPECT_EQ(1u, getMostSignificantSetBitIndex(0b10));
EXPECT_EQ(2u, getMostSignificantSetBitIndex(0b100));
EXPECT_EQ(3u, getMostSignificantSetBitIndex(0b1000));
EXPECT_EQ(3u, getMostSignificantSetBitIndex(0b1001));
EXPECT_EQ(3u, getMostSignificantSetBitIndex(0b1010));
EXPECT_EQ(3u, getMostSignificantSetBitIndex(0b1100));
EXPECT_EQ(3u, getMostSignificantSetBitIndex(0b1101));
EXPECT_EQ(6u, getMostSignificantSetBitIndex(maxNBitValue(7)));
EXPECT_EQ(7u, getMostSignificantSetBitIndex(maxNBitValue(8)));
EXPECT_EQ(8u, getMostSignificantSetBitIndex(maxNBitValue(9)));
EXPECT_EQ(16u, getMostSignificantSetBitIndex(maxNBitValue(17)));
EXPECT_EQ(32u, getMostSignificantSetBitIndex(maxNBitValue(33)));
EXPECT_EQ(63u, getMostSignificantSetBitIndex(maxNBitValue(64)));
}