compute-runtime/opencl/test/unit_test/command_queue/command_queue_fixture.cpp

128 lines
3.5 KiB
C++

/*
* Copyright (C) 2018-2021 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "opencl/test/unit_test/command_queue/command_queue_fixture.h"
#include "shared/source/device/device.h"
#include "shared/test/common/mocks/mock_device.h"
#include "shared/test/common/mocks/mock_gmm.h"
#include "opencl/source/command_queue/command_queue_hw.h"
#include "opencl/source/context/context.h"
#include "opencl/test/unit_test/mocks/mock_cl_device.h"
#include "opencl/test/unit_test/mocks/mock_command_queue.h"
#include "gtest/gtest.h"
namespace NEO {
// Global table of create functions
extern CommandQueueCreateFunc commandQueueFactory[IGFX_MAX_CORE];
CommandQueue *CommandQueueHwFixture::createCommandQueue(
ClDevice *pDevice,
cl_command_queue_properties properties) {
const cl_queue_properties props[3] = {CL_QUEUE_PROPERTIES, properties, 0};
return createCommandQueue(pDevice, props);
}
CommandQueue *CommandQueueHwFixture::createCommandQueue(
ClDevice *pDevice,
const cl_command_queue_properties *properties) {
if (pDevice == nullptr) {
if (this->device == nullptr) {
this->device = new MockClDevice{MockClDevice::createWithNewExecutionEnvironment<MockDevice>(nullptr)};
createdDevice = true;
}
pDevice = this->device;
}
if (!context) {
context = new MockContext(pDevice);
}
return createCommandQueue(pDevice, properties, context);
}
CommandQueue *CommandQueueHwFixture::createCommandQueue(
ClDevice *pDevice,
const cl_command_queue_properties *properties,
Context *pContext) {
auto funcCreate = commandQueueFactory[pDevice->getRenderCoreFamily()];
assert(nullptr != funcCreate);
return funcCreate(pContext, pDevice, properties, false);
}
void CommandQueueHwFixture::forceMapBufferOnGpu(Buffer &buffer) {
ClDevice *clDevice = buffer.getContext()->getDevice(0);
buffer.setSharingHandler(new SharingHandler());
auto gfxAllocation = buffer.getGraphicsAllocation(clDevice->getRootDeviceIndex());
for (auto handleId = 0u; handleId < gfxAllocation->getNumGmms(); handleId++) {
gfxAllocation->setGmm(new MockGmm(clDevice->getGmmClientContext()), handleId);
}
}
void CommandQueueHwFixture::SetUp() {
ASSERT_NE(nullptr, pCmdQ);
context = new MockContext();
}
void CommandQueueHwFixture::SetUp(
ClDevice *pDevice,
cl_command_queue_properties properties) {
ASSERT_NE(nullptr, pDevice);
context = new MockContext(pDevice);
pCmdQ = createCommandQueue(pDevice, properties);
ASSERT_NE(nullptr, pCmdQ);
}
void CommandQueueHwFixture::TearDown() {
//resolve event dependencies
if (pCmdQ) {
auto blocked = pCmdQ->isQueueBlocked();
UNRECOVERABLE_IF(blocked);
pCmdQ->release();
}
if (context) {
context->release();
}
if (createdDevice) {
delete device;
}
}
CommandQueue *CommandQueueFixture::createCommandQueue(
Context *context,
ClDevice *device,
cl_command_queue_properties properties,
bool internalUsage) {
const cl_queue_properties props[3] = {CL_QUEUE_PROPERTIES, properties, 0};
return new MockCommandQueue(
context,
device,
props,
internalUsage);
}
void CommandQueueFixture::SetUp(
Context *context,
ClDevice *device,
cl_command_queue_properties properties) {
pCmdQ = createCommandQueue(
context,
device,
properties,
false);
}
void CommandQueueFixture::TearDown() {
delete pCmdQ;
pCmdQ = nullptr;
}
} // namespace NEO