helpers: Add GENMASK macro

The GENMASK is defined in multiple files (with various names such as
MASKBIT), which sets certain consecutive bits to 1 and leaves the others
to 0. To avoid duplicate macros, add GENMASK macro to helpers.h.

GENMASK(high, low) sets bits from `high` to `low` (inclusive) to 1. For
example, GENMASK(39, 21) gives us the 64-bit vector 0x000000ffffe00000.

Remove duplicate macro definitions. Also utilize GENMASK for _BF_MASK in
mmio.h.

BUG=none
TEST=make tests/commonlib/bsd/helpers-test
TEST=emerge-cherry coreboot
BRANCH=none

Change-Id: If2e7c4827d8a7d27688534593b556a72f16f0c2b
Signed-off-by: Yu-Ping Wu <yupingso@chromium.org>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/56543
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Julius Werner <jwerner@chromium.org>
This commit is contained in:
Yu-Ping Wu
2021-07-23 16:17:11 +08:00
committed by Paul Fagerburg
parent 5d71994c02
commit 941db0e55c
7 changed files with 33 additions and 19 deletions

View File

@ -8,6 +8,19 @@ static void func(void)
function_called();
}
static void test_genmask(void **state)
{
assert_int_equal(GENMASK(4, 4), 0x10);
assert_int_equal(GENMASK(4, 3), 0x18);
assert_int_equal(GENMASK(4, 0), 0x1f);
/* Edge cases */
assert_int_equal(GENMASK(0, 0), 1);
assert_int_equal(GENMASK(31, 31), 0x80000000);
assert_int_equal(GENMASK(31, 0), 0xffffffff);
assert_int_equal(GENMASK(63, 63), 0x8000000000000000);
assert_int_equal(GENMASK(63, 0), 0xffffffffffffffff);
}
static void test_retry(void **state)
{
int count;
@ -34,6 +47,7 @@ static void test_retry(void **state)
int main(void)
{
const struct CMUnitTest tests[] = {
cmocka_unit_test(test_genmask),
cmocka_unit_test(test_retry),
};