130 lines
5.3 KiB
C++
130 lines
5.3 KiB
C++
/*
|
|
* Copyright (C) 2017-2020 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "unit_tests/mocks/mock_device.h"
|
|
|
|
#include "core/os_interface/os_context.h"
|
|
#include "runtime/device/driver_info.h"
|
|
#include "unit_tests/mocks/mock_execution_environment.h"
|
|
#include "unit_tests/mocks/mock_memory_manager.h"
|
|
#include "unit_tests/mocks/mock_ostime.h"
|
|
#include "unit_tests/tests_configuration.h"
|
|
|
|
using namespace NEO;
|
|
|
|
bool MockDevice::createSingleDevice = true;
|
|
bool &MockClDevice::createSingleDevice = MockDevice::createSingleDevice;
|
|
|
|
decltype(&createCommandStream) MockSubDevice::createCommandStreamReceiverFunc = createCommandStream;
|
|
decltype(&createCommandStream) MockDevice::createCommandStreamReceiverFunc = createCommandStream;
|
|
decltype(&createCommandStream) &MockClDevice::createCommandStreamReceiverFunc = MockDevice::createCommandStreamReceiverFunc;
|
|
|
|
MockClDevice::MockClDevice(MockDevice *pMockDevice)
|
|
: ClDevice(*pMockDevice, platform()), device(*pMockDevice), deviceInfo(pMockDevice->deviceInfo),
|
|
executionEnvironment(pMockDevice->executionEnvironment),
|
|
subdevices(pMockDevice->subdevices), mockMemoryManager(pMockDevice->mockMemoryManager), engines(pMockDevice->engines) {
|
|
|
|
platform()->clDeviceMap.emplace(pMockDevice, this);
|
|
for (uint32_t i = 0; i < getNumAvailableDevices(); i++) {
|
|
platform()->clDeviceMap.emplace(pMockDevice->getDeviceById(i), this->getDeviceById(i));
|
|
}
|
|
}
|
|
|
|
MockDevice::MockDevice()
|
|
: MockDevice(new MockExecutionEnvironment(), 0u) {
|
|
CommandStreamReceiver *commandStreamReceiver = createCommandStream(*this->executionEnvironment, this->getRootDeviceIndex());
|
|
commandStreamReceivers.resize(1);
|
|
commandStreamReceivers[0].reset(commandStreamReceiver);
|
|
this->executionEnvironment->memoryManager = std::move(this->mockMemoryManager);
|
|
this->engines.resize(1);
|
|
this->engines[0] = {commandStreamReceiver, nullptr};
|
|
initializeCaps();
|
|
}
|
|
|
|
MockClDevice::~MockClDevice() {
|
|
if (platform()) {
|
|
platform()->clDeviceMap.erase(&device);
|
|
for (uint32_t i = 0; i < getNumAvailableDevices(); i++) {
|
|
platform()->clDeviceMap.erase(device.getDeviceById(i));
|
|
}
|
|
}
|
|
}
|
|
|
|
const char *MockDevice::getProductAbbrev() const {
|
|
return hardwarePrefix[getHardwareInfo().platform.eProductFamily];
|
|
}
|
|
|
|
MockDevice::MockDevice(ExecutionEnvironment *executionEnvironment, uint32_t rootDeviceIndex)
|
|
: RootDevice(executionEnvironment, rootDeviceIndex) {
|
|
auto &hwInfo = getHardwareInfo();
|
|
bool enableLocalMemory = HwHelper::get(hwInfo.platform.eRenderCoreFamily).getEnableLocalMemory(hwInfo);
|
|
bool aubUsage = (testMode == TestMode::AubTests) || (testMode == TestMode::AubTestsWithTbx);
|
|
this->mockMemoryManager.reset(new MemoryManagerCreate<OsAgnosticMemoryManager>(false, enableLocalMemory, aubUsage, *executionEnvironment));
|
|
this->osTime = MockOSTime::create();
|
|
executionEnvironment->setHwInfo(&hwInfo);
|
|
executionEnvironment->initializeMemoryManager();
|
|
initializeCaps();
|
|
}
|
|
|
|
bool MockDevice::createDeviceImpl() {
|
|
if (MockDevice::createSingleDevice) {
|
|
return Device::createDeviceImpl();
|
|
}
|
|
return RootDevice::createDeviceImpl();
|
|
}
|
|
|
|
void MockDevice::setOSTime(OSTime *osTime) {
|
|
this->osTime.reset(osTime);
|
|
};
|
|
|
|
void MockDevice::setDriverInfo(DriverInfo *driverInfo) {
|
|
this->driverInfo.reset(driverInfo);
|
|
};
|
|
|
|
bool MockDevice::hasDriverInfo() {
|
|
return driverInfo.get() != nullptr;
|
|
};
|
|
|
|
void MockDevice::injectMemoryManager(MemoryManager *memoryManager) {
|
|
executionEnvironment->memoryManager.reset(memoryManager);
|
|
}
|
|
|
|
void MockDevice::resetCommandStreamReceiver(CommandStreamReceiver *newCsr) {
|
|
resetCommandStreamReceiver(newCsr, defaultEngineIndex);
|
|
}
|
|
|
|
void MockDevice::resetCommandStreamReceiver(CommandStreamReceiver *newCsr, uint32_t engineIndex) {
|
|
|
|
auto osContext = this->engines[engineIndex].osContext;
|
|
auto memoryManager = executionEnvironment->memoryManager.get();
|
|
auto registeredEngine = *memoryManager->getRegisteredEngineForCsr(engines[engineIndex].commandStreamReceiver);
|
|
|
|
registeredEngine.commandStreamReceiver = newCsr;
|
|
engines[engineIndex].commandStreamReceiver = newCsr;
|
|
memoryManager->getRegisteredEngines().emplace_back(registeredEngine);
|
|
osContext->incRefInternal();
|
|
newCsr->setupContext(*osContext);
|
|
commandStreamReceivers[engineIndex].reset(newCsr);
|
|
commandStreamReceivers[engineIndex]->initializeTagAllocation();
|
|
|
|
if (preemptionMode == PreemptionMode::MidThread || isSourceLevelDebuggerActive()) {
|
|
commandStreamReceivers[engineIndex]->createPreemptionAllocation();
|
|
}
|
|
}
|
|
|
|
MockAlignedMallocManagerDevice::MockAlignedMallocManagerDevice(ExecutionEnvironment *executionEnvironment, uint32_t internalDeviceIndex) : MockDevice(executionEnvironment, internalDeviceIndex) {
|
|
this->mockMemoryManager.reset(new MockAllocSysMemAgnosticMemoryManager(*executionEnvironment));
|
|
}
|
|
FailDevice::FailDevice(ExecutionEnvironment *executionEnvironment, uint32_t deviceIndex)
|
|
: MockDevice(executionEnvironment, deviceIndex) {
|
|
this->mockMemoryManager.reset(new FailMemoryManager(*executionEnvironment));
|
|
}
|
|
FailDeviceAfterOne::FailDeviceAfterOne(ExecutionEnvironment *executionEnvironment, uint32_t deviceIndex)
|
|
: MockDevice(executionEnvironment, deviceIndex) {
|
|
this->mockMemoryManager.reset(new FailMemoryManager(1, *executionEnvironment));
|
|
}
|