blob: 8ee882799e831d1adf9df0337f3e608cab47f23a [file] [log] [blame] [edit]
/*
* Copyright 2025 Intel Corporation
* SPDX-License-Identifier: MIT
*/
#if !defined(_MSC_VER)
#include <gtest/gtest.h>
#include "util/lut.h"
#define EXPECT_LUT3(value, str) \
EXPECT_STREQ(util_lut3_to_str[value], str)
TEST(lut, build3)
{
EXPECT_LUT3(UTIL_LUT3(a), "a");
EXPECT_LUT3(UTIL_LUT3(b), "b");
EXPECT_LUT3(UTIL_LUT3(c), "c");
EXPECT_LUT3(UTIL_LUT3(a & b), "a & b");
EXPECT_LUT3(UTIL_LUT3(a ^ b ^ c), "a ^ b ^ c");
EXPECT_LUT3(UTIL_LUT3(~c ^ (~a) ^ ~b), "a ^ b ^ ~c");
}
TEST(lut, build2)
{
EXPECT_LUT3(UTIL_LUT2(a), "a & ~c");
EXPECT_LUT3(UTIL_LUT2(b), "b & ~c");
EXPECT_LUT3(UTIL_LUT2(a & b), "a & b & ~c");
EXPECT_LUT3(UTIL_LUT2(~b ^ (~a)), "(a ^ b) & ~c");
}
TEST(lut, invert2)
{
EXPECT_LUT3(util_lut2_invert(UTIL_LUT2(a & b)), "(~a | ~b) & ~c");
}
TEST(lut, invert3)
{
EXPECT_LUT3(util_lut3_invert(UTIL_LUT3(a ^ b ^ c)), "a ^ b ^ ~c");
}
TEST(lut, invert_source3)
{
EXPECT_LUT3(util_lut3_invert_source(UTIL_LUT3(a | b | c), 0), "~a | b | c");
EXPECT_LUT3(util_lut3_invert_source(UTIL_LUT3(a | b | c), 1), "a | ~b | c");
EXPECT_LUT3(util_lut3_invert_source(UTIL_LUT3(a | b | c), 2), "a | b | ~c");
EXPECT_LUT3(util_lut3_invert_source(UTIL_LUT3(a & b), 0), "~a & b");
EXPECT_LUT3(util_lut3_invert_source(UTIL_LUT3(a & b), 1), "a & ~b");
EXPECT_LUT3(util_lut3_invert_source(UTIL_LUT3(a & b), 2), "a & b");
}
TEST(lut, invert_source2)
{
EXPECT_LUT3(util_lut2_invert_source(UTIL_LUT2(a & b), 0), "~a & b & ~c");
EXPECT_LUT3(util_lut2_invert_source(UTIL_LUT2(a & b), 1), "a & ~b & ~c");
}
TEST(lut, swap_sources2)
{
EXPECT_LUT3(util_lut2_swap_sources(UTIL_LUT2(a & b)), "a & b & ~c");
EXPECT_LUT3(util_lut2_swap_sources(UTIL_LUT2(a & ~b)), "~a & b & ~c");
EXPECT_LUT3(util_lut2_swap_sources(UTIL_LUT2(~a & b)), "a & ~b & ~c");
EXPECT_LUT3(util_lut2_swap_sources(UTIL_LUT2(~a | b)), "(a | ~b) & ~c");
}
TEST(lut, swap_sources3)
{
EXPECT_LUT3(util_lut3_swap_sources(UTIL_LUT3(a & b & c), 0, 2), "a & b & c");
EXPECT_LUT3(util_lut3_swap_sources(UTIL_LUT3(~a & b & c), 0, 2), "a & b & ~c");
EXPECT_LUT3(util_lut3_swap_sources(UTIL_LUT3(a | ~b | c), 0, 1), "~a | b | c");
EXPECT_LUT3(util_lut3_swap_sources(UTIL_LUT3(a | ~b | c), 0, 2), "a | ~b | c");
EXPECT_LUT3(util_lut3_swap_sources(UTIL_LUT3(a | ~b | c), 1, 2), "a | b | ~c");
}
#endif