1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225
|
/*
* Copyright (C) 2019-2025 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;
static_assert(makeBitMask<1, 3, 5>() == static_cast<uint64_t>(0b101010));
static_assert(makeBitMask<0>() == static_cast<uint64_t>(0b1));
static_assert(makeBitMask<0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15>() == static_cast<uint64_t>(0xFFFF));
static_assert(makeBitMask<63, 0>() == static_cast<uint64_t>(0x8000000000000001));
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)));
}
|