/* * Copyright (C) 2018-2021 Intel Corporation * * SPDX-License-Identifier: MIT * */ #pragma once #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" 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() override { 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() override { 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() override { CommandEnqueueBaseFixture::TearDown(); CommandStreamFixture::TearDown(); } }; struct NegativeFailAllocationCommandEnqueueBaseFixture : public CommandEnqueueBaseFixture { void SetUp() override { 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() override { 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()); } } }; 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(); auto &device = dispatchInfo.begin()->getClDevice(); if (!device.areSharedSystemAllocationsAllowed()) { EXPECT_FALSE(kernel->getKernelInfo().kernelDescriptor.kernelAttributes.supportsBuffersBiggerThan4Gb()); if (HwHelperHw::get().isStatelesToStatefullWithOffsetSupported()) { EXPECT_TRUE(kernel->allBufferArgsStateful); } } else { EXPECT_TRUE(kernel->getKernelInfo().kernelDescriptor.kernelAttributes.supportsBuffersBiggerThan4Gb()); EXPECT_FALSE(kernel->getKernelInfo().getArgDescriptorAt(0).as().isPureStateful()); } } }; } // namespace NEO