/* * 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))); }