/* * Copyright (C) 2018-2023 Intel Corporation * * SPDX-License-Identifier: MIT * */ #pragma once #include "shared/source/helpers/gfx_core_helper.h" #include "shared/test/common/mocks/mock_memory_manager.h" #include "opencl/source/command_queue/command_queue_hw.h" #include "opencl/test/unit_test/command_queue/command_queue_fixture.h" #include "opencl/test/unit_test/command_stream/command_stream_fixture.h" #include "opencl/test/unit_test/fixtures/buffer_fixture.h" #include "opencl/test/unit_test/fixtures/cl_device_fixture.h" #include "opencl/test/unit_test/fixtures/image_fixture.h" #include "opencl/test/unit_test/helpers/cl_hw_parse.h" #include "opencl/test/unit_test/indirect_heap/indirect_heap_fixture.h" #include "opencl/test/unit_test/mocks/mock_cl_device.h" namespace NEO { struct CommandDeviceFixture : public ClDeviceFixture, public CommandQueueHwFixture { using CommandQueueHwFixture::setUp; void setUp(cl_command_queue_properties cmdQueueProperties = 0) { ClDeviceFixture::setUp(); CommandQueueHwFixture::setUp(pClDevice, cmdQueueProperties); } void tearDown() { CommandQueueHwFixture::tearDown(); ClDeviceFixture::tearDown(); } }; struct CommandEnqueueBaseFixture : CommandDeviceFixture, public IndirectHeapFixture, public ClHardwareParse { using IndirectHeapFixture::setUp; void setUp(cl_command_queue_properties cmdQueueProperties = 0) { CommandDeviceFixture::setUp(cmdQueueProperties); IndirectHeapFixture::setUp(pCmdQ); ClHardwareParse::setUp(); } void tearDown() { ClHardwareParse::tearDown(); IndirectHeapFixture::tearDown(); CommandDeviceFixture::tearDown(); } }; struct CommandEnqueueFixture : public CommandEnqueueBaseFixture, public CommandStreamFixture { void setUp(cl_command_queue_properties cmdQueueProperties = 0) { CommandEnqueueBaseFixture::setUp(cmdQueueProperties); CommandStreamFixture::setUp(pCmdQ); } void tearDown() { CommandEnqueueBaseFixture::tearDown(); CommandStreamFixture::tearDown(); } }; struct NegativeFailAllocationCommandEnqueueBaseFixture : public CommandEnqueueBaseFixture { void setUp() { CommandEnqueueBaseFixture::setUp(); failMemManager.reset(new FailMemoryManager(*pDevice->getExecutionEnvironment())); BufferDefaults::context = context; Image2dDefaults::context = context; buffer.reset(BufferHelper<>::create()); image.reset(ImageHelper::create()); ptr = static_cast(array); oldMemManager = pDevice->getExecutionEnvironment()->memoryManager.release(); pDevice->injectMemoryManager(failMemManager.release()); } void tearDown() { pDevice->injectMemoryManager(oldMemManager); buffer.reset(nullptr); image.reset(nullptr); BufferDefaults::context = nullptr; Image2dDefaults::context = nullptr; CommandEnqueueBaseFixture::tearDown(); } std::unique_ptr buffer; std::unique_ptr image; std::unique_ptr failMemManager; char array[MemoryConstants::cacheLineSize]; void *ptr; MemoryManager *oldMemManager; }; template struct CommandQueueStateless : public CommandQueueHw { CommandQueueStateless(Context *context, ClDevice *device) : CommandQueueHw(context, device, nullptr, false){}; void enqueueHandlerHook(const unsigned int commandType, const MultiDispatchInfo &dispatchInfo) override { auto kernel = dispatchInfo.begin()->getKernel(); EXPECT_TRUE(kernel->getKernelInfo().kernelDescriptor.kernelAttributes.supportsBuffersBiggerThan4Gb()); if (kernel->getKernelInfo().getArgDescriptorAt(0).is()) { EXPECT_FALSE(kernel->getKernelInfo().getArgDescriptorAt(0).as().isPureStateful()); } if (validateKernelSystemMemory) { if (expectedKernelSystemMemory) { EXPECT_TRUE(kernel->getDestinationAllocationInSystemMemory()); } else { EXPECT_FALSE(kernel->getDestinationAllocationInSystemMemory()); } } } bool validateKernelSystemMemory = false; bool expectedKernelSystemMemory = false; }; template struct CommandQueueStateful : public CommandQueueHw { CommandQueueStateful(Context *context, ClDevice *device) : CommandQueueHw(context, device, nullptr, false){}; void enqueueHandlerHook(const unsigned int commandType, const MultiDispatchInfo &dispatchInfo) override { auto kernel = dispatchInfo.begin()->getKernel(); EXPECT_FALSE(kernel->getKernelInfo().kernelDescriptor.kernelAttributes.supportsBuffersBiggerThan4Gb()); auto &gfxCoreHelper = kernel->getContext().getDevice(0)->getGfxCoreHelper(); if (gfxCoreHelper.isStatelessToStatefulWithOffsetSupported()) { EXPECT_TRUE(kernel->allBufferArgsStateful); } if (validateKernelSystemMemory) { if (expectedKernelSystemMemory) { EXPECT_TRUE(kernel->getDestinationAllocationInSystemMemory()); } else { EXPECT_FALSE(kernel->getDestinationAllocationInSystemMemory()); } } } bool validateKernelSystemMemory = false; bool expectedKernelSystemMemory = false; }; } // namespace NEO