2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2023-01-09 21:30:43 +08:00
|
|
|
* Copyright (C) 2018-2023 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
|
2022-02-03 00:30:03 +08:00
|
|
|
#include "shared/test/common/helpers/debug_manager_state_restore.h"
|
|
|
|
#include "shared/test/common/test_macros/test_checks_shared.h"
|
|
|
|
|
|
|
|
#include "opencl/test/unit_test/fixtures/cl_device_fixture.h"
|
|
|
|
#include "opencl/test/unit_test/fixtures/context_fixture.h"
|
2023-01-13 03:31:00 +08:00
|
|
|
#include "opencl/test/unit_test/mocks/mock_cl_device.h"
|
2020-02-23 22:20:22 +08:00
|
|
|
#include "opencl/test/unit_test/mocks/mock_context.h"
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "CL/cl.h"
|
2022-11-16 22:01:52 +08:00
|
|
|
#include "gtest/gtest.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2017-12-21 07:45:38 +08:00
|
|
|
class Device;
|
|
|
|
|
|
|
|
struct CommandQueueHwFixture {
|
2020-01-14 21:32:11 +08:00
|
|
|
CommandQueue *createCommandQueue(ClDevice *device) {
|
2019-02-11 00:50:54 +08:00
|
|
|
return createCommandQueue(device, cl_command_queue_properties{0});
|
|
|
|
}
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
CommandQueue *createCommandQueue(
|
2020-01-14 21:32:11 +08:00
|
|
|
ClDevice *device,
|
2017-12-21 07:45:38 +08:00
|
|
|
cl_command_queue_properties properties);
|
|
|
|
|
2019-02-11 00:50:54 +08:00
|
|
|
CommandQueue *createCommandQueue(
|
2020-01-14 21:32:11 +08:00
|
|
|
ClDevice *device,
|
2019-02-11 00:50:54 +08:00
|
|
|
const cl_command_queue_properties *properties);
|
|
|
|
|
2021-07-02 00:00:22 +08:00
|
|
|
CommandQueue *createCommandQueue(
|
|
|
|
ClDevice *device,
|
|
|
|
const cl_command_queue_properties *properties,
|
|
|
|
Context *context);
|
|
|
|
|
2021-10-18 23:07:01 +08:00
|
|
|
static void forceMapBufferOnGpu(Buffer &buffer);
|
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
void setUp();
|
|
|
|
void setUp(ClDevice *pDevice, cl_command_queue_properties properties);
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
void tearDown();
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2019-02-11 00:50:54 +08:00
|
|
|
CommandQueue *pCmdQ = nullptr;
|
2020-11-16 19:08:30 +08:00
|
|
|
MockClDevice *device = nullptr;
|
2019-02-11 00:50:54 +08:00
|
|
|
MockContext *context = nullptr;
|
2020-11-16 19:08:30 +08:00
|
|
|
bool createdDevice = false;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct OOQueueFixture : public CommandQueueHwFixture {
|
|
|
|
typedef CommandQueueHwFixture BaseClass;
|
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
void setUp(ClDevice *pDevice, cl_command_queue_properties properties);
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct CommandQueueFixture {
|
2022-08-16 22:51:17 +08:00
|
|
|
void setUp(
|
2017-12-21 07:45:38 +08:00
|
|
|
Context *context,
|
2020-01-14 21:32:11 +08:00
|
|
|
ClDevice *device,
|
2017-12-21 07:45:38 +08:00
|
|
|
cl_command_queue_properties properties);
|
2022-08-16 22:51:17 +08:00
|
|
|
void tearDown();
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
CommandQueue *createCommandQueue(
|
|
|
|
Context *context,
|
2020-01-14 21:32:11 +08:00
|
|
|
ClDevice *device,
|
2021-07-23 18:36:36 +08:00
|
|
|
cl_command_queue_properties properties,
|
|
|
|
bool internalUsage);
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2020-03-13 21:59:00 +08:00
|
|
|
CommandQueue *pCmdQ = nullptr;
|
2017-12-21 07:45:38 +08:00
|
|
|
};
|
|
|
|
|
2023-11-29 23:57:54 +08:00
|
|
|
static const cl_command_queue_properties allCommandQueueProperties[] = {
|
2017-12-21 07:45:38 +08:00
|
|
|
0,
|
|
|
|
CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE,
|
|
|
|
CL_QUEUE_ON_DEVICE | CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE,
|
|
|
|
CL_QUEUE_ON_DEVICE | CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE | CL_QUEUE_ON_DEVICE_DEFAULT,
|
|
|
|
CL_QUEUE_PROFILING_ENABLE,
|
|
|
|
CL_QUEUE_PROFILING_ENABLE | CL_QUEUE_ON_DEVICE | CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE,
|
|
|
|
CL_QUEUE_PROFILING_ENABLE | CL_QUEUE_ON_DEVICE | CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE | CL_QUEUE_ON_DEVICE_DEFAULT};
|
|
|
|
|
2023-11-29 23:57:54 +08:00
|
|
|
static const cl_command_queue_properties defaultCommandQueueProperties[] = {
|
2017-12-21 07:45:38 +08:00
|
|
|
0,
|
|
|
|
CL_QUEUE_PROFILING_ENABLE,
|
|
|
|
};
|
2022-02-03 00:30:03 +08:00
|
|
|
|
|
|
|
template <bool ooq>
|
|
|
|
struct CommandQueueHwBlitTest : ClDeviceFixture, ContextFixture, CommandQueueHwFixture, ::testing::Test {
|
2022-08-16 22:51:17 +08:00
|
|
|
using ContextFixture::setUp;
|
2022-02-03 00:30:03 +08:00
|
|
|
|
|
|
|
void SetUp() override {
|
|
|
|
hwInfo = *::defaultHwInfo;
|
|
|
|
hwInfo.capabilityTable.blitterOperationsSupported = true;
|
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.EnableBlitterOperationsSupport.set(1);
|
|
|
|
debugManager.flags.EnableTimestampPacket.set(1);
|
|
|
|
debugManager.flags.PreferCopyEngineForCopyBufferToBuffer.set(1);
|
|
|
|
debugManager.flags.EnableBlitterForEnqueueOperations.set(1);
|
2022-06-29 00:27:56 +08:00
|
|
|
ClDeviceFixture::setUpImpl(&hwInfo);
|
2022-02-03 00:30:03 +08:00
|
|
|
cl_device_id device = pClDevice;
|
2023-01-09 21:30:43 +08:00
|
|
|
REQUIRE_FULL_BLITTER_OR_SKIP(pClDevice->getRootDeviceEnvironment());
|
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
ContextFixture::setUp(1, &device);
|
2022-02-03 00:30:03 +08:00
|
|
|
cl_command_queue_properties queueProperties = ooq ? CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE : 0;
|
2022-08-16 22:51:17 +08:00
|
|
|
CommandQueueHwFixture::setUp(pClDevice, queueProperties);
|
2022-02-03 00:30:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override {
|
2022-08-16 22:51:17 +08:00
|
|
|
CommandQueueHwFixture::tearDown();
|
|
|
|
ContextFixture::tearDown();
|
|
|
|
ClDeviceFixture::tearDown();
|
2022-02-03 00:30:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
HardwareInfo hwInfo{};
|
|
|
|
DebugManagerStateRestore state{};
|
|
|
|
};
|
|
|
|
|
|
|
|
using IoqCommandQueueHwBlitTest = CommandQueueHwBlitTest<false>;
|
|
|
|
using OoqCommandQueueHwBlitTest = CommandQueueHwBlitTest<true>;
|
|
|
|
|
2022-04-01 01:18:58 +08:00
|
|
|
struct CommandQueueHwTest
|
|
|
|
: public ClDeviceFixture,
|
|
|
|
public ContextFixture,
|
|
|
|
public CommandQueueHwFixture,
|
|
|
|
::testing::Test {
|
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
using ContextFixture::setUp;
|
2022-04-01 01:18:58 +08:00
|
|
|
|
|
|
|
void SetUp() override;
|
|
|
|
|
|
|
|
void TearDown() override;
|
|
|
|
|
|
|
|
cl_command_queue_properties properties;
|
|
|
|
const HardwareInfo *pHwInfo = nullptr;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct OOQueueHwTest : public ClDeviceFixture,
|
|
|
|
public ContextFixture,
|
|
|
|
public OOQueueFixture,
|
|
|
|
::testing::Test {
|
2022-08-16 22:51:17 +08:00
|
|
|
using ContextFixture::setUp;
|
2022-04-01 01:18:58 +08:00
|
|
|
|
|
|
|
OOQueueHwTest() {
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetUp() override;
|
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
void setUp(ClDevice *pDevice, cl_command_queue_properties properties) {
|
2022-04-01 01:18:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override;
|
|
|
|
};
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|