compute-runtime/shared/source/helpers/bit_helpers.h

45 lines
1.0 KiB
C++

/*
* Copyright (C) 2019-2020 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#pragma once
#include <cassert>
#include <cstdint>
#include <limits>
namespace NEO {
constexpr bool isBitSet(uint64_t field, uint64_t bitPosition) {
assert(bitPosition < std::numeric_limits<uint64_t>::digits); // undefined behavior
return (field & (1ull << bitPosition));
}
constexpr bool isAnyBitSet(uint64_t field, uint64_t checkedBits) {
return ((field & checkedBits) != 0);
}
constexpr bool isValueSet(uint64_t field, uint64_t value) {
assert(value != 0);
return ((field & value) == value);
}
constexpr bool isFieldValid(uint64_t field, uint64_t acceptedBits) {
return ((field & (~acceptedBits)) == 0);
}
constexpr uint64_t setBits(uint64_t field, bool newValue, uint64_t bitsToModify) {
if (newValue) {
return (field | bitsToModify);
}
return (field & (~bitsToModify));
}
constexpr uint64_t shiftLeftBy(uint64_t bitPosition) {
return (1ull << bitPosition);
}
} // namespace NEO