2019-12-19 21:02:05 +08:00
|
|
|
/*
|
2021-12-16 10:13:00 +08:00
|
|
|
* Copyright (C) 2019-2022 Intel Corporation
|
2019-12-19 21:02:05 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2021-04-16 00:14:04 +08:00
|
|
|
#include "shared/source/os_interface/device_factory.h"
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/os_interface/os_context.h"
|
2021-04-16 00:14:04 +08:00
|
|
|
#include "shared/test/common/helpers/debug_manager_state_restore.h"
|
|
|
|
#include "shared/test/common/helpers/default_hw_info.h"
|
2021-08-12 01:36:00 +08:00
|
|
|
#include "shared/test/common/helpers/engine_descriptor_helper.h"
|
2021-04-16 00:14:04 +08:00
|
|
|
#include "shared/test/common/mocks/mock_device.h"
|
2019-12-19 21:02:05 +08:00
|
|
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
using namespace NEO;
|
|
|
|
|
|
|
|
TEST(OSContext, whenCreatingDefaultOsContextThenExpectInitializedAlways) {
|
2021-08-12 01:36:00 +08:00
|
|
|
OsContext *osContext = OsContext::create(nullptr, 0, EngineDescriptorHelper::getDefaultDescriptor());
|
2020-03-04 06:33:31 +08:00
|
|
|
EXPECT_FALSE(osContext->isLowPriority());
|
|
|
|
EXPECT_FALSE(osContext->isInternalEngine());
|
|
|
|
EXPECT_FALSE(osContext->isRootDevice());
|
|
|
|
delete osContext;
|
|
|
|
}
|
|
|
|
|
2021-03-09 02:50:32 +08:00
|
|
|
TEST(OSContext, givenInternalAndRootDeviceAreTrueWhenCreatingDefaultOsContextThenExpectGettersTrue) {
|
2021-08-12 01:36:00 +08:00
|
|
|
auto descriptor = EngineDescriptorHelper::getDefaultDescriptor({aub_stream::ENGINE_RCS, EngineUsage::Internal});
|
|
|
|
descriptor.isRootDevice = true;
|
|
|
|
|
|
|
|
OsContext *osContext = OsContext::create(nullptr, 0, descriptor);
|
2021-03-09 02:50:32 +08:00
|
|
|
EXPECT_FALSE(osContext->isLowPriority());
|
2020-03-04 06:33:31 +08:00
|
|
|
EXPECT_TRUE(osContext->isInternalEngine());
|
|
|
|
EXPECT_TRUE(osContext->isRootDevice());
|
2019-12-19 21:02:05 +08:00
|
|
|
delete osContext;
|
|
|
|
}
|
2020-03-07 02:02:24 +08:00
|
|
|
|
2021-03-09 02:50:32 +08:00
|
|
|
TEST(OSContext, givenLowPriorityAndRootDeviceAreTrueWhenCreatingDefaultOsContextThenExpectGettersTrue) {
|
2021-08-12 01:36:00 +08:00
|
|
|
auto descriptor = EngineDescriptorHelper::getDefaultDescriptor({aub_stream::ENGINE_RCS, EngineUsage::LowPriority});
|
|
|
|
descriptor.isRootDevice = true;
|
|
|
|
|
|
|
|
OsContext *osContext = OsContext::create(nullptr, 0, descriptor);
|
2021-03-09 02:50:32 +08:00
|
|
|
EXPECT_TRUE(osContext->isLowPriority());
|
|
|
|
EXPECT_FALSE(osContext->isInternalEngine());
|
|
|
|
EXPECT_TRUE(osContext->isRootDevice());
|
|
|
|
delete osContext;
|
|
|
|
}
|
|
|
|
|
2020-03-07 02:02:24 +08:00
|
|
|
TEST(OSContext, givenOsContextCreatedDefaultIsFalseWhenSettingTrueThenFlagTrueReturned) {
|
2021-08-12 01:36:00 +08:00
|
|
|
OsContext *osContext = OsContext::create(nullptr, 0, EngineDescriptorHelper::getDefaultDescriptor());
|
2020-03-07 02:02:24 +08:00
|
|
|
EXPECT_FALSE(osContext->isDefaultContext());
|
|
|
|
osContext->setDefaultContext(true);
|
|
|
|
EXPECT_TRUE(osContext->isDefaultContext());
|
|
|
|
delete osContext;
|
|
|
|
}
|
2021-04-16 00:14:04 +08:00
|
|
|
|
2021-11-30 22:38:41 +08:00
|
|
|
TEST(OSContext, givenCooperativeEngineWhenIsCooperativeEngineIsCalledThenReturnTrue) {
|
|
|
|
auto engineDescriptor = EngineDescriptorHelper::getDefaultDescriptor();
|
|
|
|
engineDescriptor.engineTypeUsage.second = EngineUsage::Cooperative;
|
|
|
|
auto pOsContext = OsContext::create(nullptr, 0, engineDescriptor);
|
|
|
|
EXPECT_FALSE(pOsContext->isRegular());
|
|
|
|
EXPECT_FALSE(pOsContext->isLowPriority());
|
|
|
|
EXPECT_FALSE(pOsContext->isInternalEngine());
|
|
|
|
EXPECT_TRUE(pOsContext->isCooperativeEngine());
|
|
|
|
delete pOsContext;
|
|
|
|
}
|
|
|
|
|
2021-12-16 10:13:00 +08:00
|
|
|
TEST(OSContext, givenReinitializeContextWhenContextIsInitThenContextIsStillIinitializedAfter) {
|
|
|
|
auto engineDescriptor = EngineDescriptorHelper::getDefaultDescriptor();
|
|
|
|
auto pOsContext = OsContext::create(nullptr, 0, engineDescriptor);
|
|
|
|
EXPECT_NO_THROW(pOsContext->reInitializeContext());
|
|
|
|
EXPECT_NO_THROW(pOsContext->ensureContextInitialized());
|
|
|
|
delete pOsContext;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(OSContext, givenSetPowerHintThenGetPowerHintShowsTheSameValue) {
|
|
|
|
auto engineDescriptor = EngineDescriptorHelper::getDefaultDescriptor();
|
|
|
|
auto pOsContext = OsContext::create(nullptr, 0, engineDescriptor);
|
|
|
|
pOsContext->setUmdPowerHintValue(1);
|
|
|
|
EXPECT_EQ(1, pOsContext->getUmdPowerHintValue());
|
|
|
|
delete pOsContext;
|
|
|
|
}
|
|
|
|
|
2021-04-16 00:14:04 +08:00
|
|
|
struct DeferredOsContextCreationTests : ::testing::Test {
|
|
|
|
void SetUp() override {
|
|
|
|
device = std::unique_ptr<MockDevice>{MockDevice::createWithNewExecutionEnvironment<MockDevice>(defaultHwInfo.get())};
|
|
|
|
DeviceFactory::prepareDeviceEnvironments(*device->getExecutionEnvironment());
|
|
|
|
}
|
|
|
|
|
2021-05-17 23:22:49 +08:00
|
|
|
std::unique_ptr<OsContext> createOsContext(EngineTypeUsage engineTypeUsage, bool defaultEngine) {
|
2021-04-16 00:14:04 +08:00
|
|
|
OSInterface *osInterface = device->getRootDeviceEnvironment().osInterface.get();
|
2021-08-12 01:36:00 +08:00
|
|
|
std::unique_ptr<OsContext> osContext{OsContext::create(osInterface, 0, EngineDescriptorHelper::getDefaultDescriptor(engineTypeUsage))};
|
2021-04-16 00:14:04 +08:00
|
|
|
EXPECT_FALSE(osContext->isInitialized());
|
2021-05-17 23:22:49 +08:00
|
|
|
return osContext;
|
|
|
|
}
|
2021-04-16 00:14:04 +08:00
|
|
|
|
2021-05-17 23:22:49 +08:00
|
|
|
void expectContextCreation(EngineTypeUsage engineTypeUsage, bool defaultEngine, bool expectedImmediate) {
|
|
|
|
auto osContext = createOsContext(engineTypeUsage, defaultEngine);
|
2021-04-16 00:14:04 +08:00
|
|
|
const bool immediate = osContext->isImmediateContextInitializationEnabled(defaultEngine);
|
|
|
|
EXPECT_EQ(expectedImmediate, immediate);
|
|
|
|
if (immediate) {
|
|
|
|
osContext->ensureContextInitialized();
|
|
|
|
EXPECT_TRUE(osContext->isInitialized());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void expectDeferredContextCreation(EngineTypeUsage engineTypeUsage, bool defaultEngine) {
|
|
|
|
expectContextCreation(engineTypeUsage, defaultEngine, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
void expectImmediateContextCreation(EngineTypeUsage engineTypeUsage, bool defaultEngine) {
|
|
|
|
expectContextCreation(engineTypeUsage, defaultEngine, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
std::unique_ptr<MockDevice> device;
|
|
|
|
static inline const EngineTypeUsage engineTypeUsageRegular{aub_stream::ENGINE_RCS, EngineUsage::Regular};
|
|
|
|
static inline const EngineTypeUsage engineTypeUsageInternal{aub_stream::ENGINE_RCS, EngineUsage::Internal};
|
2021-06-02 02:07:49 +08:00
|
|
|
static inline const EngineTypeUsage engineTypeUsageBlitter{aub_stream::ENGINE_BCS, EngineUsage::Regular};
|
2021-04-16 00:14:04 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(DeferredOsContextCreationTests, givenRegularEngineWhenCreatingOsContextThenOsContextIsInitializedDeferred) {
|
|
|
|
DebugManagerStateRestore restore{};
|
|
|
|
|
2021-05-13 19:41:36 +08:00
|
|
|
expectDeferredContextCreation(engineTypeUsageRegular, false);
|
2021-04-16 00:14:04 +08:00
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(1);
|
|
|
|
expectDeferredContextCreation(engineTypeUsageRegular, false);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(0);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageRegular, false);
|
|
|
|
}
|
|
|
|
|
2021-05-13 19:41:36 +08:00
|
|
|
TEST_F(DeferredOsContextCreationTests, givenDefaultEngineWhenCreatingOsContextThenOsContextIsInitializedImmediately) {
|
2021-04-16 00:14:04 +08:00
|
|
|
DebugManagerStateRestore restore{};
|
|
|
|
|
|
|
|
expectImmediateContextCreation(engineTypeUsageRegular, true);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(1);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageRegular, true);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(0);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageRegular, true);
|
|
|
|
}
|
|
|
|
|
2021-05-13 19:41:36 +08:00
|
|
|
TEST_F(DeferredOsContextCreationTests, givenInternalEngineWhenCreatingOsContextThenOsContextIsInitializedImmediately) {
|
2021-04-16 00:14:04 +08:00
|
|
|
DebugManagerStateRestore restore{};
|
|
|
|
|
|
|
|
expectImmediateContextCreation(engineTypeUsageInternal, false);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(1);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageInternal, false);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(0);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageInternal, false);
|
|
|
|
}
|
|
|
|
|
2021-06-02 02:07:49 +08:00
|
|
|
TEST_F(DeferredOsContextCreationTests, givenBlitterEngineWhenCreatingOsContextThenOsContextIsInitializedImmediately) {
|
|
|
|
DebugManagerStateRestore restore{};
|
|
|
|
|
|
|
|
expectImmediateContextCreation(engineTypeUsageBlitter, false);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(1);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageBlitter, false);
|
|
|
|
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(0);
|
|
|
|
expectImmediateContextCreation(engineTypeUsageBlitter, false);
|
|
|
|
}
|
|
|
|
|
2021-04-16 00:14:04 +08:00
|
|
|
TEST_F(DeferredOsContextCreationTests, givenEnsureContextInitializeCalledMultipleTimesWhenOsContextIsCreatedThenInitializeOnlyOnce) {
|
|
|
|
struct MyOsContext : OsContext {
|
|
|
|
MyOsContext(uint32_t contextId,
|
2021-08-12 01:36:00 +08:00
|
|
|
const EngineDescriptor &engineDescriptor) : OsContext(contextId, engineDescriptor) {}
|
2021-04-16 00:14:04 +08:00
|
|
|
|
2021-04-20 17:24:15 +08:00
|
|
|
void initializeContext() override {
|
2021-04-16 00:14:04 +08:00
|
|
|
initializeContextCalled++;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t initializeContextCalled = 0u;
|
|
|
|
};
|
|
|
|
|
2021-08-12 01:36:00 +08:00
|
|
|
MyOsContext osContext{0, EngineDescriptorHelper::getDefaultDescriptor(engineTypeUsageRegular)};
|
2021-04-16 00:14:04 +08:00
|
|
|
EXPECT_FALSE(osContext.isInitialized());
|
|
|
|
|
|
|
|
osContext.ensureContextInitialized();
|
|
|
|
EXPECT_TRUE(osContext.isInitialized());
|
|
|
|
EXPECT_EQ(1u, osContext.initializeContextCalled);
|
|
|
|
|
|
|
|
osContext.ensureContextInitialized();
|
|
|
|
EXPECT_TRUE(osContext.isInitialized());
|
|
|
|
EXPECT_EQ(1u, osContext.initializeContextCalled);
|
|
|
|
}
|
2021-05-17 23:22:49 +08:00
|
|
|
|
|
|
|
TEST_F(DeferredOsContextCreationTests, givenPrintOsContextInitializationsIsSetWhenOsContextItIsInitializedThenInfoIsLoggedToStdout) {
|
|
|
|
DebugManagerStateRestore restore{};
|
|
|
|
DebugManager.flags.DeferOsContextInitialization.set(1);
|
|
|
|
DebugManager.flags.PrintOsContextInitializations.set(1);
|
|
|
|
testing::internal::CaptureStdout();
|
|
|
|
|
|
|
|
auto osContext = createOsContext(engineTypeUsageRegular, false);
|
|
|
|
EXPECT_EQ(std::string{}, testing::internal::GetCapturedStdout());
|
|
|
|
|
|
|
|
testing::internal::CaptureStdout();
|
|
|
|
osContext->ensureContextInitialized();
|
|
|
|
std::string expectedMessage = "OsContext initialization: contextId=0 usage=Regular type=RCS isRootDevice=0\n";
|
|
|
|
EXPECT_EQ(expectedMessage, testing::internal::GetCapturedStdout());
|
|
|
|
}
|