2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2021-05-17 02:51:16 +08:00
|
|
|
* Copyright (C) 2018-2021 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
|
|
|
|
|
2021-01-21 20:10:13 +08:00
|
|
|
#include "shared/test/common/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,
|
2020-12-02 20:43:54 +08:00
|
|
|
public DeviceQueueFixture,
|
|
|
|
public ::testing::WithParamInterface<std::tuple<const char *, const char *>> {
|
2017-12-21 07:45:38 +08:00
|
|
|
public:
|
|
|
|
void SetUp() override {
|
2020-10-07 19:37:34 +08:00
|
|
|
REQUIRE_DEVICE_ENQUEUE_OR_SKIP(defaultHwInfo);
|
|
|
|
|
2019-02-21 23:59:10 +08:00
|
|
|
DebugManager.flags.EnableTimestampPacket.set(0);
|
2020-12-02 20:43:54 +08:00
|
|
|
ExecutionModelKernelFixture::SetUp(std::get<0>(GetParam()), std::get<1>(GetParam()));
|
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 {
|
2020-10-07 19:37:34 +08:00
|
|
|
if (!IsSkipped()) {
|
|
|
|
DeviceQueueFixture::TearDown();
|
|
|
|
CommandQueueHwFixture::TearDown();
|
|
|
|
ExecutionModelKernelFixture::TearDown();
|
|
|
|
}
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
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
|
|
|
};
|
|
|
|
|
2020-05-28 20:05:12 +08:00
|
|
|
class ExecutionModelSchedulerTest : public ClDeviceFixture,
|
2017-12-21 07:45:38 +08:00
|
|
|
public CommandQueueHwFixture,
|
|
|
|
public DeviceQueueFixture {
|
|
|
|
public:
|
|
|
|
void SetUp() override {
|
2020-05-28 20:05:12 +08:00
|
|
|
ClDeviceFixture::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);
|
2021-03-22 23:26:03 +08:00
|
|
|
kernelInfos = MockKernel::toKernelInfoContainer(parentKernel->getKernelInfo(), rootDeviceIndex);
|
|
|
|
pMultiDeviceKernel = new MockMultiDeviceKernel(MockMultiDeviceKernel::toKernelVector(parentKernel), kernelInfos);
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override {
|
2021-03-09 18:30:21 +08:00
|
|
|
pMultiDeviceKernel->release();
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
DeviceQueueFixture::TearDown();
|
|
|
|
CommandQueueHwFixture::TearDown();
|
2020-05-28 20:05:12 +08:00
|
|
|
ClDeviceFixture::TearDown();
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
2021-03-22 23:26:03 +08:00
|
|
|
KernelInfoContainer kernelInfos;
|
2021-03-09 18:30:21 +08:00
|
|
|
MockMultiDeviceKernel *pMultiDeviceKernel = nullptr;
|
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-11-24 02:01:38 +08:00
|
|
|
device = new MockClDevice{MockDevice::createWithNewExecutionEnvironment<MockDevice>(nullptr, rootDeviceIndex)};
|
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-11-24 02:01:38 +08:00
|
|
|
const uint32_t rootDeviceIndex = 0u;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|