2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2020-01-14 21:32:11 +08:00
|
|
|
* Copyright (C) 2017-2020 Intel Corporation
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-02-24 08:01:38 +08:00
|
|
|
#include "shared/test/unit_test/helpers/debug_manager_state_restore.h"
|
2020-02-24 17:22:30 +08:00
|
|
|
|
2020-02-23 05:50:57 +08:00
|
|
|
#include "opencl/source/device_queue/device_queue.h"
|
2020-02-23 22:20:22 +08:00
|
|
|
#include "opencl/test/unit_test/command_queue/command_queue_fixture.h"
|
|
|
|
#include "opencl/test/unit_test/fixtures/execution_model_kernel_fixture.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
2020-04-28 19:00:33 +08:00
|
|
|
#include "opencl/test/unit_test/test_macros/test_checks_ocl.h"
|
2020-02-22 16:28:27 +08:00
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
class DeviceQueueFixture {
|
|
|
|
public:
|
2020-01-14 21:32:11 +08:00
|
|
|
void SetUp(Context *context, ClDevice *device) {
|
2020-04-28 19:00:33 +08:00
|
|
|
REQUIRE_DEVICE_ENQUEUE_OR_SKIP(device);
|
2017-12-21 07:45:38 +08:00
|
|
|
cl_int errcodeRet = 0;
|
|
|
|
cl_queue_properties properties[3];
|
|
|
|
|
|
|
|
properties[0] = CL_QUEUE_PROPERTIES;
|
|
|
|
properties[1] = CL_QUEUE_ON_DEVICE | CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE;
|
|
|
|
properties[2] = 0;
|
|
|
|
|
|
|
|
ASSERT_NE(nullptr, context);
|
|
|
|
ASSERT_NE(nullptr, device);
|
|
|
|
|
|
|
|
pDevQueue = DeviceQueue::create(context, device,
|
|
|
|
properties[0],
|
|
|
|
errcodeRet);
|
|
|
|
|
|
|
|
ASSERT_NE(nullptr, pDevQueue);
|
|
|
|
|
|
|
|
auto devQueue = context->getDefaultDeviceQueue();
|
|
|
|
|
|
|
|
ASSERT_NE(nullptr, devQueue);
|
|
|
|
EXPECT_EQ(pDevQueue, devQueue);
|
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() {
|
|
|
|
delete pDevQueue;
|
|
|
|
}
|
|
|
|
|
2020-03-13 21:59:00 +08:00
|
|
|
DeviceQueue *pDevQueue = nullptr;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class ExecutionModelKernelTest : public ExecutionModelKernelFixture,
|
|
|
|
public CommandQueueHwFixture,
|
|
|
|
public DeviceQueueFixture {
|
|
|
|
public:
|
|
|
|
void SetUp() override {
|
2019-02-21 23:59:10 +08:00
|
|
|
DebugManager.flags.EnableTimestampPacket.set(0);
|
2017-12-21 07:45:38 +08:00
|
|
|
ExecutionModelKernelFixture::SetUp();
|
2020-01-14 21:32:11 +08:00
|
|
|
CommandQueueHwFixture::SetUp(pClDevice, 0);
|
|
|
|
DeviceQueueFixture::SetUp(context, pClDevice);
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override {
|
|
|
|
|
|
|
|
DeviceQueueFixture::TearDown();
|
|
|
|
CommandQueueHwFixture::TearDown();
|
|
|
|
ExecutionModelKernelFixture::TearDown();
|
|
|
|
}
|
2019-07-19 03:15:50 +08:00
|
|
|
|
|
|
|
std::unique_ptr<KernelOperation> createBlockedCommandsData(CommandQueue &commandQueue) {
|
|
|
|
auto commandStream = new LinearStream();
|
|
|
|
|
|
|
|
auto &gpgpuCsr = commandQueue.getGpgpuCommandStreamReceiver();
|
|
|
|
gpgpuCsr.ensureCommandBufferAllocation(*commandStream, 1, 1);
|
|
|
|
|
|
|
|
return std::make_unique<KernelOperation>(commandStream, *gpgpuCsr.getInternalAllocationStorage());
|
|
|
|
}
|
|
|
|
|
2019-02-21 23:59:10 +08:00
|
|
|
DebugManagerStateRestore dbgRestore;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class ExecutionModelSchedulerTest : public DeviceFixture,
|
|
|
|
public CommandQueueHwFixture,
|
|
|
|
public DeviceQueueFixture {
|
|
|
|
public:
|
|
|
|
void SetUp() override {
|
|
|
|
DeviceFixture::SetUp();
|
2020-01-14 21:32:11 +08:00
|
|
|
CommandQueueHwFixture::SetUp(pClDevice, 0);
|
|
|
|
DeviceQueueFixture::SetUp(context, pClDevice);
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-07-30 20:13:37 +08:00
|
|
|
parentKernel = MockParentKernel::create(*context);
|
2017-12-21 07:45:38 +08:00
|
|
|
ASSERT_NE(nullptr, parentKernel);
|
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override {
|
2019-02-04 20:08:47 +08:00
|
|
|
parentKernel->release();
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
DeviceQueueFixture::TearDown();
|
|
|
|
CommandQueueHwFixture::TearDown();
|
|
|
|
DeviceFixture::TearDown();
|
|
|
|
}
|
|
|
|
|
2020-03-13 21:59:00 +08:00
|
|
|
MockParentKernel *parentKernel = nullptr;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct ParentKernelCommandQueueFixture : public CommandQueueHwFixture,
|
|
|
|
testing::Test {
|
2018-07-30 20:13:37 +08:00
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
void SetUp() override {
|
2020-01-14 21:32:11 +08:00
|
|
|
device = new MockClDevice{MockDevice::createWithNewExecutionEnvironment<MockDevice>(nullptr)};
|
2017-12-21 07:45:38 +08:00
|
|
|
CommandQueueHwFixture::SetUp(device, 0);
|
|
|
|
}
|
|
|
|
void TearDown() override {
|
|
|
|
CommandQueueHwFixture::TearDown();
|
|
|
|
delete device;
|
|
|
|
}
|
2019-07-19 03:15:50 +08:00
|
|
|
|
|
|
|
std::unique_ptr<KernelOperation> createBlockedCommandsData(CommandQueue &commandQueue) {
|
|
|
|
auto commandStream = new LinearStream();
|
|
|
|
|
|
|
|
auto &gpgpuCsr = commandQueue.getGpgpuCommandStreamReceiver();
|
|
|
|
gpgpuCsr.ensureCommandBufferAllocation(*commandStream, 1, 1);
|
|
|
|
|
|
|
|
return std::make_unique<KernelOperation>(commandStream, *gpgpuCsr.getInternalAllocationStorage());
|
|
|
|
}
|
|
|
|
|
2020-03-13 21:59:00 +08:00
|
|
|
MockClDevice *device = nullptr;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|