1036 lines
89 KiB
C++
1036 lines
89 KiB
C++
/*
|
|
* Copyright (C) 2017-2020 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
#include "shared/source/helpers/hw_cmds.h"
|
|
#include "shared/source/helpers/hw_info.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
#include "igfxfmid.h"
|
|
#include "test_mode.h"
|
|
|
|
#include <cstdint>
|
|
#include <memory>
|
|
#include <unordered_set>
|
|
|
|
extern PRODUCT_FAMILY productFamily;
|
|
extern GFXCORE_FAMILY renderCoreFamily;
|
|
|
|
#ifdef TESTS_GEN8
|
|
#define BDW_TYPED_TEST(method) method<typename NEO::GfxFamilyMapper<IGFX_GEN8_CORE>::GfxFamily>();
|
|
#define BDW_SUPPORTED_TEST(cmdSetBase) NEO::GfxFamilyMapper<IGFX_GEN8_CORE>::GfxFamily::supportsCmdSet(cmdSetBase)
|
|
#else
|
|
#define BDW_TYPED_TEST(method)
|
|
#define BDW_SUPPORTED_TEST(cmdSetBase) false
|
|
#endif
|
|
#ifdef TESTS_GEN9
|
|
#define SKL_TYPED_TEST(method) method<typename NEO::GfxFamilyMapper<IGFX_GEN9_CORE>::GfxFamily>();
|
|
#define SKL_SUPPORTED_TEST(cmdSetBase) NEO::GfxFamilyMapper<IGFX_GEN9_CORE>::GfxFamily::supportsCmdSet(cmdSetBase)
|
|
#else
|
|
#define SKL_TYPED_TEST(method)
|
|
#define SKL_SUPPORTED_TEST(cmdSetBase) false
|
|
#endif
|
|
#ifdef TESTS_GEN11
|
|
#define ICL_TYPED_TEST(method) method<typename NEO::GfxFamilyMapper<IGFX_GEN11_CORE>::GfxFamily>();
|
|
#define ICL_SUPPORTED_TEST(cmdSetBase) NEO::GfxFamilyMapper<IGFX_GEN11_CORE>::GfxFamily::supportsCmdSet(cmdSetBase)
|
|
#else
|
|
#define ICL_TYPED_TEST(method)
|
|
#define ICL_SUPPORTED_TEST(cmdSetBase) false
|
|
#endif
|
|
#ifdef TESTS_GEN12LP
|
|
#define TGLLP_TYPED_TEST(method) method<typename NEO::GfxFamilyMapper<IGFX_GEN12LP_CORE>::GfxFamily>();
|
|
#define TGLLP_SUPPORTED_TEST(cmdSetBase) NEO::GfxFamilyMapper<IGFX_GEN12LP_CORE>::GfxFamily::supportsCmdSet(cmdSetBase)
|
|
#else
|
|
#define TGLLP_TYPED_TEST(method)
|
|
#define TGLLP_SUPPORTED_TEST(cmdSetBase) false
|
|
#endif
|
|
|
|
#define FAMILY_SELECTOR(family, methodName) \
|
|
switch (family) { \
|
|
case IGFX_GEN8_CORE: \
|
|
BDW_TYPED_TEST(methodName) \
|
|
break; \
|
|
case IGFX_GEN9_CORE: \
|
|
SKL_TYPED_TEST(methodName) \
|
|
break; \
|
|
case IGFX_GEN11_CORE: \
|
|
ICL_TYPED_TEST(methodName) \
|
|
break; \
|
|
case IGFX_GEN12LP_CORE: \
|
|
TGLLP_TYPED_TEST(methodName) \
|
|
break; \
|
|
default: \
|
|
ASSERT_TRUE((false && "Unknown hardware family")); \
|
|
break; \
|
|
}
|
|
|
|
#define TO_STR2(x) #x
|
|
#define TO_STR(x) TO_STR2(x)
|
|
|
|
#define TEST_MAX_LENGTH 140
|
|
#define CHECK_TEST_NAME_LENGTH_WITH_MAX(test_fixture, test_name, max_length) \
|
|
static_assert((NEO::defaultTestMode != NEO::TestMode::AubTests && NEO::defaultTestMode != NEO::TestMode::AubTestsWithTbx) || (sizeof(#test_fixture) + sizeof(#test_name) <= max_length), "Test and fixture names length exceeds max allowed size: " TO_STR(max_length));
|
|
#define CHECK_TEST_NAME_LENGTH(test_fixture, test_name) \
|
|
CHECK_TEST_NAME_LENGTH_WITH_MAX(test_fixture, test_name, TEST_MAX_LENGTH)
|
|
|
|
#ifdef TEST_F
|
|
#undef TEST_F
|
|
#endif
|
|
|
|
// Taken from gtest.h
|
|
#define TEST_F(test_fixture, test_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_fixture, test_name) \
|
|
GTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>())
|
|
|
|
#ifdef TEST_P
|
|
#undef TEST_P
|
|
#endif
|
|
|
|
// Taken from gtest.h
|
|
#define TEST_P(test_suite_name, test_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_fixture, test_name) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
: public test_suite_name { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
void TestBody() override; \
|
|
\
|
|
private: \
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance()->parameterized_test_registry().GetTestCasePatternHolder<test_suite_name>( \
|
|
#test_suite_name, ::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern( \
|
|
#test_suite_name, \
|
|
#test_name, \
|
|
new ::testing::internal::TestMetaFactory< \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody()
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use FamilyType in the test -- equivalent to SKLFamily
|
|
#define HWTEST_TEST_(test_suite_name, test_name, parent_class, parent_id, SetUpT_name, TearDownT_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name) { \
|
|
public: \
|
|
static std::unique_ptr<std::unordered_set<uint32_t>> &getExcludes() { \
|
|
static std::unique_ptr<std::unordered_set<uint32_t>> excludes; \
|
|
return excludes; \
|
|
} \
|
|
static void addExclude(uint32_t product) { \
|
|
auto &excludes = getExcludes(); \
|
|
if (excludes == nullptr) { \
|
|
excludes = std::make_unique<std::unordered_set<uint32_t>>(); \
|
|
} \
|
|
excludes->insert(product); \
|
|
} \
|
|
}; \
|
|
\
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
\
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
bool notExcluded() const { \
|
|
using ExcludesT = PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name); \
|
|
auto &excludes = ExcludesT::getExcludes(); \
|
|
if (excludes == nullptr) { \
|
|
return true; \
|
|
} \
|
|
return excludes->count(::productFamily) == 0; \
|
|
} \
|
|
template <typename T> \
|
|
void emptyFcn() {} \
|
|
void SetUp() override { \
|
|
if (notExcluded()) { \
|
|
parent_class::SetUp(); \
|
|
FAMILY_SELECTOR(::renderCoreFamily, SetUpT_name) \
|
|
} \
|
|
} \
|
|
void TearDown() override { \
|
|
if (notExcluded()) { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, TearDownT_name) \
|
|
parent_class::TearDown(); \
|
|
} \
|
|
} \
|
|
\
|
|
void TestBody() override { \
|
|
if (notExcluded()) { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, testBodyHw) \
|
|
} \
|
|
} \
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define HWTEST_F(test_fixture, test_name) \
|
|
HWTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), emptyFcn, emptyFcn)
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use productFamily, gfxCoreFamily and FamilyType in the test
|
|
#define HWTEST2_TEST_(test_suite_name, test_name, parent_class, parent_id, test_matcher) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
\
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
using ContainerType = SupportedProductFamilies; \
|
|
using MatcherType = test_matcher; \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void matchBody(); \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
void matched() { \
|
|
const GFXCORE_FAMILY gfxCoreFamily = \
|
|
static_cast<GFXCORE_FAMILY>(NEO::HwMapper<productFamily>::gfxFamily); \
|
|
using FamilyType = typename NEO::GfxFamilyMapper<gfxCoreFamily>::GfxFamily; \
|
|
matchBody<productFamily, gfxCoreFamily, FamilyType>(); \
|
|
} \
|
|
\
|
|
struct MatcherFalse { \
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
static void matched() {} \
|
|
}; \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void checkForMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
bool checkMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
void SetUp() override { \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
parent_class::SetUp(); \
|
|
} \
|
|
} \
|
|
void TearDown() override { \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
parent_class::TearDown(); \
|
|
} \
|
|
} \
|
|
void TestBody() override; \
|
|
\
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver<parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver<parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)>); \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} else { \
|
|
checkForMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch<0u>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} \
|
|
} \
|
|
template <unsigned int matcherOrdinal> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return checkMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch<0>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return false; \
|
|
} \
|
|
} \
|
|
\
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody() { \
|
|
checkForMatch<SupportedProductFamilies::size - 1u>(::productFamily); \
|
|
} \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::matchBody()
|
|
|
|
#define HWTEST2_F(test_fixture, test_name, test_matcher) \
|
|
HWTEST2_TEST_(test_fixture, test_name##_##test_matcher, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), test_matcher)
|
|
|
|
#define HWTEST_TEMPLATED_F(test_fixture, test_name) \
|
|
HWTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), SetUpT, TearDownT)
|
|
|
|
#define PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name) \
|
|
PLATFORM_EXCLUDES_##test_suite_name##test_name
|
|
|
|
#define CALL_IF_SUPPORTED(cmdSetBase, expression) \
|
|
{ \
|
|
bool supported = false; \
|
|
switch (::renderCoreFamily) { \
|
|
case IGFX_GEN8_CORE: \
|
|
supported = BDW_SUPPORTED_TEST(cmdSetBase); \
|
|
break; \
|
|
case IGFX_GEN9_CORE: \
|
|
supported = SKL_SUPPORTED_TEST(cmdSetBase); \
|
|
break; \
|
|
case IGFX_GEN11_CORE: \
|
|
supported = ICL_SUPPORTED_TEST(cmdSetBase); \
|
|
break; \
|
|
case IGFX_GEN12LP_CORE: \
|
|
supported = TGLLP_SUPPORTED_TEST(cmdSetBase); \
|
|
break; \
|
|
default: \
|
|
ASSERT_TRUE((false && "Unknown hardware family")); \
|
|
break; \
|
|
} \
|
|
if (supported) { \
|
|
expression; \
|
|
} \
|
|
}
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use FamilyType in the test -- equivalent to SKLFamily
|
|
#define HWCMDTEST_TEST_(cmdset_gen_base, test_suite_name, test_name, parent_class, parent_id) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name) { \
|
|
public: \
|
|
static std::unique_ptr<std::unordered_set<uint32_t>> &getExcludes() { \
|
|
static std::unique_ptr<std::unordered_set<uint32_t>> excludes; \
|
|
return excludes; \
|
|
} \
|
|
static void addExclude(uint32_t product) { \
|
|
auto &excludes = getExcludes(); \
|
|
if (excludes == nullptr) { \
|
|
excludes = std::make_unique<std::unordered_set<uint32_t>>(); \
|
|
} \
|
|
excludes->insert(product); \
|
|
} \
|
|
}; \
|
|
\
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<ShouldBeTested>::type { \
|
|
if (notExcluded()) { \
|
|
testBodyHw<FamilyType>(); \
|
|
} \
|
|
} \
|
|
\
|
|
bool notExcluded() const { \
|
|
using ExcludesT = PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name); \
|
|
auto &excludes = ExcludesT::getExcludes(); \
|
|
if (excludes == nullptr) { \
|
|
return true; \
|
|
} \
|
|
return excludes->count(::productFamily) == 0; \
|
|
} \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<false == ShouldBeTested>::type { \
|
|
/* do nothing */ \
|
|
} \
|
|
\
|
|
void TestBody() override { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, runCmdTestHwIfSupported) \
|
|
} \
|
|
void SetUp() override { \
|
|
if (notExcluded()) { \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, parent_class::SetUp()); \
|
|
} \
|
|
} \
|
|
void TearDown() override { \
|
|
if (notExcluded()) { \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, parent_class::TearDown()); \
|
|
} \
|
|
} \
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define HWCMDTEST_EXCLUDE_FAMILY(test_suite_name, test_name, family) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name) { \
|
|
public: \
|
|
static std::unique_ptr<std::unordered_set<uint32_t>> &getExcludes() { \
|
|
static std::unique_ptr<std::unordered_set<uint32_t>> excludes; \
|
|
return excludes; \
|
|
} \
|
|
static void addExclude(uint32_t product) { \
|
|
auto &excludes = getExcludes(); \
|
|
if (excludes == nullptr) { \
|
|
excludes = std::make_unique<std::unordered_set<uint32_t>>(); \
|
|
} \
|
|
excludes->insert(product); \
|
|
} \
|
|
}; \
|
|
\
|
|
struct test_suite_name##test_name##_PLATFORM_EXCLUDES_EXCLUDE_##family { \
|
|
test_suite_name##test_name##_PLATFORM_EXCLUDES_EXCLUDE_##family() { \
|
|
PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name)::addExclude(family); \
|
|
} \
|
|
} test_suite_name##test_name##_PLATFORM_EXCLUDES_EXCLUDE_##family##_init;
|
|
|
|
#define HWCMDTEST_EXCLUDE_ADDITIONAL_FAMILY(test_suite_name, test_name, family) \
|
|
struct test_suite_name##test_name##_PLATFORM_EXCLUDES_EXCLUDE_##family { \
|
|
test_suite_name##test_name##_PLATFORM_EXCLUDES_EXCLUDE_##family() { \
|
|
PLATFORM_EXCLUDES_CLASS_NAME(test_suite_name, test_name)::addExclude(family); \
|
|
} \
|
|
} test_suite_name##test_name##_PLATFORM_EXCLUDES_EXCLUDE_##family##_init;
|
|
|
|
#define HWCMDTEST_F(cmdset_gen_base, test_fixture, test_name) \
|
|
HWCMDTEST_TEST_(cmdset_gen_base, test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>())
|
|
|
|
#define CALL_IF_MATCH(match_core, match_product, expr) \
|
|
auto matchCore = match_core; \
|
|
auto matchProduct = match_product; \
|
|
if ((::renderCoreFamily == matchCore) && \
|
|
(IGFX_MAX_PRODUCT == matchProduct || ::productFamily == matchProduct)) { \
|
|
expr; \
|
|
}
|
|
|
|
#define FAMILYTEST_TEST_(test_suite_name, test_name, parent_class, parent_id, match_core, match_product) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
void TestBody() override { \
|
|
CALL_IF_MATCH(match_core, match_product, \
|
|
testBodyHw<typename NEO::GfxFamilyMapper<match_core>::GfxFamily>()) \
|
|
} \
|
|
void SetUp() override { \
|
|
CALL_IF_MATCH(match_core, match_product, parent_class::SetUp()) \
|
|
} \
|
|
void TearDown() override { \
|
|
CALL_IF_MATCH(match_core, match_product, parent_class::TearDown()) \
|
|
} \
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
// Equivalent Hw specific macro for permuted tests
|
|
// Test can use FamilyType in the test -- equivalent to SKLFamily
|
|
#define HWTEST_P(test_suite_name, test_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
void TestBody() override { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, testBodyHw) \
|
|
} \
|
|
\
|
|
private: \
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance()->parameterized_test_registry().GetTestCasePatternHolder<test_suite_name>( \
|
|
#test_suite_name, ::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern( \
|
|
#test_suite_name, \
|
|
#test_name, \
|
|
new ::testing::internal::TestMetaFactory< \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define HWCMDTEST_P(cmdset_gen_base, test_suite_name, test_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<ShouldBeTested>::type { \
|
|
testBodyHw<FamilyType>(); \
|
|
} \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<false == ShouldBeTested>::type { \
|
|
/* do nothing */ \
|
|
} \
|
|
\
|
|
void TestBody() override { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, runCmdTestHwIfSupported) \
|
|
} \
|
|
void SetUp() override { \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, test_suite_name::SetUp()); \
|
|
} \
|
|
void TearDown() override { \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, test_suite_name::TearDown()); \
|
|
} \
|
|
\
|
|
private: \
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance()->parameterized_test_registry().GetTestCasePatternHolder<test_suite_name>( \
|
|
#test_suite_name, ::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern( \
|
|
#test_suite_name, \
|
|
#test_name, \
|
|
new ::testing::internal::TestMetaFactory< \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use productFamily, gfxCoreFamily and FamilyType in the test
|
|
#define HWTEST2_P(test_suite_name, test_name, test_matcher) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
\
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void matchBody(); \
|
|
\
|
|
private: \
|
|
using ContainerType = SupportedProductFamilies; \
|
|
using MatcherType = test_matcher; \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
void matched() { \
|
|
const GFXCORE_FAMILY gfxCoreFamily = \
|
|
static_cast<GFXCORE_FAMILY>(NEO::HwMapper<productFamily>::gfxFamily); \
|
|
using FamilyType = typename NEO::GfxFamilyMapper<gfxCoreFamily>::GfxFamily; \
|
|
matchBody<productFamily, gfxCoreFamily, FamilyType>(); \
|
|
} \
|
|
\
|
|
struct MatcherFalse { \
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
static void matched() {} \
|
|
}; \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void checkForMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
bool checkMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
void SetUp() override { \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
test_suite_name::SetUp(); \
|
|
} \
|
|
} \
|
|
void TearDown() override { \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
test_suite_name::TearDown(); \
|
|
} \
|
|
} \
|
|
\
|
|
void TestBody() override; \
|
|
\
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance() \
|
|
->parameterized_test_registry() \
|
|
.GetTestCasePatternHolder<test_suite_name>(#test_suite_name, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern(#test_suite_name, #test_name, \
|
|
new ::testing::internal::TestMetaFactory<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} else { \
|
|
checkForMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch<0u>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} \
|
|
} \
|
|
template <unsigned int matcherOrdinal> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return checkMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch<0>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return false; \
|
|
} \
|
|
} \
|
|
\
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody() { \
|
|
checkForMatch<SupportedProductFamilies::size - 1u>(::productFamily); \
|
|
} \
|
|
\
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::matchBody()
|
|
|
|
#define FAMILYTEST_TEST_P(test_suite_name, test_name, match_core, match_product) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
void TestBody() override { \
|
|
CALL_IF_MATCH(match_core, match_product, \
|
|
testBodyHw<typename NEO::GfxFamilyMapper<match_core>::GfxFamily>()) \
|
|
} \
|
|
void SetUp() override { \
|
|
CALL_IF_MATCH(match_core, match_product, test_suite_name::SetUp()) \
|
|
} \
|
|
void TearDown() override { \
|
|
CALL_IF_MATCH(match_core, match_product, test_suite_name::TearDown()) \
|
|
} \
|
|
\
|
|
private: \
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance()->parameterized_test_registry().GetTestCasePatternHolder<test_suite_name>( \
|
|
#test_suite_name, ::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern( \
|
|
#test_suite_name, \
|
|
#test_name, \
|
|
new ::testing::internal::TestMetaFactory< \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define GENTEST_F(gfx_core, test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
gfx_core, IGFX_MAX_PRODUCT)
|
|
|
|
#define GENTEST_P(gfx_core, test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, gfx_core, IGFX_MAX_PRODUCT)
|
|
|
|
#ifdef TESTS_GEN8
|
|
#define GEN8TEST_F(test_fixture, test_name) GENTEST_F(IGFX_GEN8_CORE, test_fixture, test_name)
|
|
#define GEN8TEST_P(test_fixture, test_name) GENTEST_P(IGFX_GEN8_CORE, test_fixture, test_name)
|
|
#endif
|
|
#ifdef TESTS_GEN9
|
|
#define GEN9TEST_F(test_fixture, test_name) GENTEST_F(IGFX_GEN9_CORE, test_fixture, test_name)
|
|
#define GEN9TEST_P(test_fixture, test_name) GENTEST_P(IGFX_GEN9_CORE, test_fixture, test_name)
|
|
#endif
|
|
#ifdef TESTS_GEN11
|
|
#define GEN11TEST_F(test_fixture, test_name) GENTEST_F(IGFX_GEN11_CORE, test_fixture, test_name)
|
|
#define GEN11TEST_P(test_fixture, test_name) GENTEST_P(IGFX_GEN11_CORE, test_fixture, test_name)
|
|
#endif
|
|
#ifdef TESTS_GEN12LP
|
|
#define GEN12LPTEST_F(test_fixture, test_name) GENTEST_F(IGFX_GEN12LP_CORE, test_fixture, test_name)
|
|
#define GEN12LPTEST_P(test_fixture, test_name) GENTEST_P(IGFX_GEN12LP_CORE, test_fixture, test_name)
|
|
#endif
|
|
#ifdef TESTS_GEN8
|
|
#define BDWTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN8_CORE, IGFX_BROADWELL)
|
|
#define BDWTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN8_CORE, \
|
|
IGFX_BROADWELL)
|
|
#endif
|
|
#ifdef TESTS_SKL
|
|
#define SKLTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN9_CORE, IGFX_SKYLAKE)
|
|
#define SKLTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN9_CORE, \
|
|
IGFX_SKYLAKE)
|
|
#endif
|
|
#ifdef TESTS_KBL
|
|
#define KBLTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN9_CORE, IGFX_KABYLAKE)
|
|
#define KBLTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN9_CORE, \
|
|
IGFX_KABYLAKE)
|
|
#endif
|
|
#ifdef TESTS_GLK
|
|
#define GLKTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN9_CORE, IGFX_GEMINILAKE)
|
|
#define GLKTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN9_CORE, \
|
|
IGFX_GEMINILAKE)
|
|
#endif
|
|
#ifdef TESTS_BXT
|
|
#define BXTTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN9_CORE, IGFX_BROXTON)
|
|
#define BXTTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN9_CORE, \
|
|
IGFX_BROXTON)
|
|
#endif
|
|
#ifdef TESTS_CFL
|
|
#define CFLTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN9_CORE, IGFX_COFFEELAKE)
|
|
#define CFLTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN9_CORE, \
|
|
IGFX_COFFEELAKE)
|
|
#endif
|
|
#ifdef TESTS_ICLLP
|
|
#define ICLLPTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN11_CORE, IGFX_ICELAKE_LP)
|
|
#define ICLLPTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN11_CORE, \
|
|
IGFX_ICELAKE_LP)
|
|
#endif
|
|
#ifdef TESTS_LKF
|
|
#define LKFTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN11_CORE, IGFX_LAKEFIELD)
|
|
#define LKFTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN11_CORE, \
|
|
IGFX_LAKEFIELD)
|
|
#endif
|
|
#ifdef TESTS_EHL
|
|
#define EHLTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN11_CORE, IGFX_ELKHARTLAKE)
|
|
#define EHLTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN11_CORE, \
|
|
IGFX_ELKHARTLAKE)
|
|
#endif
|
|
#ifdef TESTS_TGLLP
|
|
#define TGLLPTEST_F(test_fixture, test_name) \
|
|
FAMILYTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), \
|
|
IGFX_GEN12LP_CORE, IGFX_TIGERLAKE_LP)
|
|
#define TGLLPTEST_P(test_suite_name, test_name) \
|
|
FAMILYTEST_TEST_P(test_suite_name, test_name, \
|
|
IGFX_GEN12LP_CORE, \
|
|
IGFX_TIGERLAKE_LP)
|
|
#endif
|
|
#define HWTEST_TYPED_TEST(CaseName, TestName) \
|
|
CHECK_TEST_NAME_LENGTH(CaseName, TestName) \
|
|
template <typename gtest_TypeParam_> \
|
|
class GTEST_TEST_CLASS_NAME_(CaseName, TestName) : public CaseName<gtest_TypeParam_> { \
|
|
private: \
|
|
typedef CaseName<gtest_TypeParam_> TestFixture; \
|
|
typedef gtest_TypeParam_ TypeParam; \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
void TestBody() override { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, testBodyHw) \
|
|
} \
|
|
}; \
|
|
bool gtest_##CaseName##_##TestName##_registered_ GTEST_ATTRIBUTE_UNUSED_ = \
|
|
::testing::internal::TypeParameterizedTest< \
|
|
CaseName, \
|
|
::testing::internal::TemplateSel< \
|
|
GTEST_TEST_CLASS_NAME_(CaseName, TestName)>, \
|
|
GTEST_TYPE_PARAMS_(CaseName)>::Register("", ::testing::internal::CodeLocation(__FILE__, __LINE__), \
|
|
#CaseName, #TestName, 0); \
|
|
template <typename gtest_TypeParam_> \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(CaseName, TestName)<gtest_TypeParam_>::testBodyHw()
|
|
|
|
template <typename Fixture>
|
|
struct Test
|
|
: public Fixture,
|
|
public ::testing::Test {
|
|
|
|
void SetUp() override {
|
|
Fixture::SetUp();
|
|
}
|
|
|
|
void TearDown() override {
|
|
Fixture::TearDown();
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY... args>
|
|
struct SupportedProductFamilyContainer {
|
|
using BaseClass = SupportedProductFamilyContainer<args...>;
|
|
static const PRODUCT_FAMILY productFamily = IGFX_UNKNOWN;
|
|
};
|
|
|
|
template <PRODUCT_FAMILY p, PRODUCT_FAMILY... args>
|
|
struct SupportedProductFamilyContainer<p, args...> : SupportedProductFamilyContainer<args...> {
|
|
using BaseClass = SupportedProductFamilyContainer<args...>;
|
|
|
|
static const PRODUCT_FAMILY productFamily = p;
|
|
static const std::size_t size = sizeof...(args) + 1;
|
|
};
|
|
|
|
using SupportedProductFamilies =
|
|
SupportedProductFamilyContainer<SUPPORTED_TEST_PRODUCT_FAMILIES>;
|
|
|
|
// Static container accessor
|
|
|
|
template <typename Container, int index>
|
|
struct At {
|
|
static const PRODUCT_FAMILY productFamily =
|
|
At<typename Container::BaseClass, index - 1>::productFamily;
|
|
};
|
|
|
|
template <typename Container>
|
|
struct At<Container, 0> {
|
|
static const PRODUCT_FAMILY productFamily = Container::productFamily;
|
|
};
|
|
|
|
// HWTEST2_F matchers
|
|
template <GFXCORE_FAMILY gfxCoreFamily>
|
|
struct IsGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() == gfxCoreFamily;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY product>
|
|
struct IsProduct {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily == product;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMax>
|
|
struct IsAtMostProduct {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily <= productFamilyMax;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMin>
|
|
struct IsAtLeastProduct {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily >= productFamilyMin;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMin, PRODUCT_FAMILY productFamilyMax>
|
|
struct IsWithinProducts {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily >= productFamilyMin && productFamily <= productFamilyMax;
|
|
}
|
|
};
|
|
|
|
struct MatchAny {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() { return true; }
|
|
};
|
|
|
|
// Common matchers
|
|
using IsGen9 = IsGfxCore<IGFX_GEN9_CORE>;
|
|
using IsGen11HP = IsGfxCore<IGFX_GEN11_CORE>;
|
|
using IsGen11LP = IsGfxCore<IGFX_GEN11LP_CORE>;
|
|
using IsGen12LP = IsGfxCore<IGFX_GEN12LP_CORE>;
|
|
|
|
using IsBXT = IsProduct<IGFX_BROXTON>;
|
|
using IsCFL = IsProduct<IGFX_COFFEELAKE>;
|
|
using IsEHL = IsProduct<IGFX_ELKHARTLAKE>;
|
|
using IsGLK = IsProduct<IGFX_GEMINILAKE>;
|
|
using IsICLLP = IsProduct<IGFX_ICELAKE_LP>;
|
|
using IsKBL = IsProduct<IGFX_KABYLAKE>;
|
|
using IsLKF = IsProduct<IGFX_LAKEFIELD>;
|
|
using IsSKL = IsProduct<IGFX_SKYLAKE>;
|
|
using IsTGLLP = IsProduct<IGFX_TIGERLAKE_LP>;
|