2017-12-21 00:45:38 +01:00
|
|
|
/*
|
2021-01-21 13:10:13 +01:00
|
|
|
* Copyright (C) 2017-2021 Intel Corporation
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
2018-09-18 09:11:08 +02:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2021-01-21 13:10:13 +01:00
|
|
|
#include "shared/test/common/mocks/mock_device.h"
|
2020-04-02 09:35:50 +02:00
|
|
|
|
2020-02-23 15:20:22 +01:00
|
|
|
#include "opencl/test/unit_test/fixtures/execution_model_kernel_fixture.h"
|
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_program.h"
|
2019-02-27 11:39:32 +01:00
|
|
|
#include "test.h"
|
2020-02-22 22:50:57 +01:00
|
|
|
|
2017-12-21 00:45:38 +01:00
|
|
|
#include <memory>
|
|
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
using namespace NEO;
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
class MockKernelWithArgumentAccess : public Kernel {
|
|
|
|
|
public:
|
|
|
|
|
std::vector<SimpleKernelArgInfo> &getKernelArguments() {
|
|
|
|
|
return kernelArguments;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class ObjectCountsPublic : public Kernel::ObjectCounts {
|
|
|
|
|
};
|
|
|
|
|
|
2020-12-02 18:19:05 +00:00
|
|
|
MockKernelWithArgumentAccess(Program *programArg, const KernelInfoContainer &kernelInfoArg) : Kernel(programArg, kernelInfoArg, false) {
|
2017-12-21 00:45:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void getParentObjectCountsPublic(MockKernelWithArgumentAccess::ObjectCountsPublic &objectCount) {
|
|
|
|
|
getParentObjectCounts(objectCount);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
2020-05-07 10:20:43 +02:00
|
|
|
TEST(ParentKernelTest, WhenArgsAddedThenObjectCountsAreIncremented) {
|
2020-01-14 14:32:11 +01:00
|
|
|
MockClDevice *device = new MockClDevice{new MockDevice};
|
2020-10-16 15:00:28 +02:00
|
|
|
MockProgram program(toClDeviceVector(*device));
|
2020-11-19 12:30:44 +01:00
|
|
|
KernelInfo info;
|
|
|
|
|
info.kernelDescriptor.kernelAttributes.flags.usesDeviceSideEnqueue = true;
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2020-12-02 18:19:05 +00:00
|
|
|
MockKernelWithArgumentAccess kernel(&program, MockKernel::toKernelInfoContainer(info, device->getRootDeviceIndex()));
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
std::vector<Kernel::SimpleKernelArgInfo> &args = kernel.getKernelArguments();
|
|
|
|
|
|
|
|
|
|
Kernel::SimpleKernelArgInfo argInfo;
|
|
|
|
|
argInfo.type = Kernel::kernelArgType::SAMPLER_OBJ;
|
|
|
|
|
args.push_back(argInfo);
|
|
|
|
|
argInfo.type = Kernel::kernelArgType::IMAGE_OBJ;
|
|
|
|
|
args.push_back(argInfo);
|
|
|
|
|
|
|
|
|
|
MockKernelWithArgumentAccess::ObjectCountsPublic objectCounts;
|
|
|
|
|
|
|
|
|
|
kernel.getParentObjectCountsPublic(objectCounts);
|
|
|
|
|
|
|
|
|
|
EXPECT_EQ(1u, objectCounts.imageCount);
|
|
|
|
|
EXPECT_EQ(1u, objectCounts.samplerCount);
|
|
|
|
|
|
|
|
|
|
delete device;
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-07 10:20:43 +02:00
|
|
|
TEST(ParentKernelTest, WhenPatchingBlocksSimdSizeThenPatchIsAppliedCorrectly) {
|
2020-01-14 14:32:11 +01:00
|
|
|
MockClDevice device{new MockDevice};
|
2020-11-18 18:39:32 +00:00
|
|
|
auto rootDeviceIndex = device.getRootDeviceIndex();
|
2018-07-30 14:13:37 +02:00
|
|
|
MockContext context(&device);
|
|
|
|
|
std::unique_ptr<MockParentKernel> parentKernel(MockParentKernel::create(context, true));
|
2017-12-21 00:45:38 +01:00
|
|
|
MockProgram *program = (MockProgram *)parentKernel->mockProgram;
|
|
|
|
|
|
2020-11-18 18:39:32 +00:00
|
|
|
parentKernel->patchBlocksSimdSize(rootDeviceIndex);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2020-12-07 14:41:52 +00:00
|
|
|
void *blockSimdSize = ptrOffset(parentKernel->getCrossThreadData(rootDeviceIndex), parentKernel->getKernelInfo(rootDeviceIndex).childrenKernelsIdOffset[0].second);
|
2017-12-21 00:45:38 +01:00
|
|
|
uint32_t *simdSize = reinterpret_cast<uint32_t *>(blockSimdSize);
|
|
|
|
|
|
2019-10-27 19:48:26 +01:00
|
|
|
EXPECT_EQ(program->blockKernelManager->getBlockKernelInfo(0)->getMaxSimdSize(), *simdSize);
|
2017-12-21 00:45:38 +01:00
|
|
|
}
|
|
|
|
|
|
2020-05-07 10:20:43 +02:00
|
|
|
TEST(ParentKernelTest, GivenParentKernelWhenCheckingForDeviceEnqueueThenTrueIsReturned) {
|
2020-01-14 14:32:11 +01:00
|
|
|
MockClDevice device{new MockDevice};
|
2018-07-30 14:13:37 +02:00
|
|
|
MockContext context(&device);
|
|
|
|
|
std::unique_ptr<MockParentKernel> parentKernel(MockParentKernel::create(context));
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2020-12-07 14:41:52 +00:00
|
|
|
auto rootDeviceIndex = device.getRootDeviceIndex();
|
|
|
|
|
EXPECT_TRUE(parentKernel->getKernelInfo(rootDeviceIndex).hasDeviceEnqueue());
|
2017-12-21 00:45:38 +01:00
|
|
|
}
|
|
|
|
|
|
2020-05-07 10:20:43 +02:00
|
|
|
TEST(ParentKernelTest, GivenNormalKernelWhenCheckingForDeviceEnqueueThenFalseIsReturned) {
|
2020-01-14 14:32:11 +01:00
|
|
|
MockClDevice device{new MockDevice};
|
2017-12-21 00:45:38 +01:00
|
|
|
MockKernelWithInternals kernel(device);
|
|
|
|
|
|
|
|
|
|
EXPECT_FALSE(kernel.kernelInfo.hasDeviceEnqueue());
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-07 10:20:43 +02:00
|
|
|
TEST(ParentKernelTest, WhenInitializingParentKernelThenBlocksSimdSizeIsPatched) {
|
2020-01-14 14:32:11 +01:00
|
|
|
MockClDevice device{new MockDevice};
|
2020-11-18 18:39:32 +00:00
|
|
|
auto rootDeviceIndex = device.getRootDeviceIndex();
|
2018-07-30 14:13:37 +02:00
|
|
|
MockContext context(&device);
|
|
|
|
|
std::unique_ptr<MockParentKernel> parentKernel(MockParentKernel::create(context, true));
|
2017-12-21 00:45:38 +01:00
|
|
|
MockProgram *program = (MockProgram *)parentKernel->mockProgram;
|
|
|
|
|
|
|
|
|
|
parentKernel->initialize();
|
|
|
|
|
|
2020-12-07 14:41:52 +00:00
|
|
|
void *blockSimdSize = ptrOffset(parentKernel->getCrossThreadData(rootDeviceIndex), parentKernel->getKernelInfo(rootDeviceIndex).childrenKernelsIdOffset[0].second);
|
2017-12-21 00:45:38 +01:00
|
|
|
uint32_t *simdSize = reinterpret_cast<uint32_t *>(blockSimdSize);
|
|
|
|
|
|
2019-10-27 19:48:26 +01:00
|
|
|
EXPECT_EQ(program->blockKernelManager->getBlockKernelInfo(0)->getMaxSimdSize(), *simdSize);
|
2017-12-21 00:45:38 +01:00
|
|
|
}
|
|
|
|
|
|
2020-05-07 10:20:43 +02:00
|
|
|
TEST(ParentKernelTest, WhenInitializingParentKernelThenPrivateMemoryForBlocksIsAllocated) {
|
2020-01-14 14:32:11 +01:00
|
|
|
MockClDevice device{new MockDevice};
|
2018-07-30 14:13:37 +02:00
|
|
|
MockContext context(&device);
|
|
|
|
|
std::unique_ptr<MockParentKernel> parentKernel(MockParentKernel::create(context, true));
|
2017-12-21 00:45:38 +01:00
|
|
|
MockProgram *program = (MockProgram *)parentKernel->mockProgram;
|
|
|
|
|
|
|
|
|
|
uint32_t crossThreadOffsetBlock = 0;
|
|
|
|
|
|
2018-08-16 14:28:58 +02:00
|
|
|
auto infoBlock = new KernelInfo();
|
2021-02-26 12:04:49 +01:00
|
|
|
infoBlock->kernelDescriptor.kernelAttributes.bufferAddressingMode = KernelDescriptor::Stateless;
|
|
|
|
|
SPatchAllocateStatelessDefaultDeviceQueueSurface allocateDeviceQueueSurface = {};
|
|
|
|
|
allocateDeviceQueueSurface.DataParamOffset = crossThreadOffsetBlock;
|
|
|
|
|
allocateDeviceQueueSurface.DataParamSize = 8;
|
|
|
|
|
allocateDeviceQueueSurface.Size = 8;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, allocateDeviceQueueSurface);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
crossThreadOffsetBlock += 8;
|
|
|
|
|
|
2021-02-23 10:55:12 +01:00
|
|
|
SPatchAllocateStatelessEventPoolSurface allocateEventPoolSurface = {};
|
|
|
|
|
allocateEventPoolSurface.DataParamOffset = crossThreadOffsetBlock;
|
|
|
|
|
allocateEventPoolSurface.DataParamSize = 8;
|
|
|
|
|
allocateEventPoolSurface.EventPoolSurfaceIndex = 0;
|
|
|
|
|
allocateEventPoolSurface.Size = 8;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, allocateEventPoolSurface);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
crossThreadOffsetBlock += 8;
|
|
|
|
|
|
Remove PatchTokens from KernelInfo
Use KernelDescriptor instead of patchTokens stored in KernelInfo's
patchInfo.
Removed: SPatchMediaInterfaceDescriptorLoad, SPatchAllocateLocalSurface,
SPatchMediaVFEState(slot 0), SPatchMediaVFEState(slot 1),
SPatchInterfaceDescriptorData, SPatchSamplerStateArray,
SPatchBindingTableState, SPatchDataParameterBuffer,
SPatchDataParameterStream, SPatchThreadPayload,
SPatchKernelAttributesInfo, SPatchAllocateStatelessPrivateSurface,
SPatchAllocateSyncBuffer,
SPatchAllocateStatelessConstantMemorySurfaceWithInitialization,
SPatchAllocateStatelessGlobalMemorySurfaceWithInitialization,
SPatchAllocateSystemThreadSurface.
Related-To: NEO-4729
Signed-off-by: Krystian Chmielewski <krystian.chmielewski@intel.com>
2021-03-04 10:14:23 +01:00
|
|
|
SPatchAllocateStatelessPrivateSurface privateSurfaceBlock = {};
|
|
|
|
|
privateSurfaceBlock.DataParamOffset = crossThreadOffsetBlock;
|
|
|
|
|
privateSurfaceBlock.DataParamSize = 8;
|
|
|
|
|
privateSurfaceBlock.Size = 8;
|
|
|
|
|
privateSurfaceBlock.SurfaceStateHeapOffset = 0;
|
|
|
|
|
privateSurfaceBlock.Token = 0;
|
|
|
|
|
privateSurfaceBlock.PerThreadPrivateMemorySize = 1000;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, privateSurfaceBlock);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
crossThreadOffsetBlock += 8;
|
|
|
|
|
|
Remove PatchTokens from KernelInfo
Use KernelDescriptor instead of patchTokens stored in KernelInfo's
patchInfo.
Removed: SPatchMediaInterfaceDescriptorLoad, SPatchAllocateLocalSurface,
SPatchMediaVFEState(slot 0), SPatchMediaVFEState(slot 1),
SPatchInterfaceDescriptorData, SPatchSamplerStateArray,
SPatchBindingTableState, SPatchDataParameterBuffer,
SPatchDataParameterStream, SPatchThreadPayload,
SPatchKernelAttributesInfo, SPatchAllocateStatelessPrivateSurface,
SPatchAllocateSyncBuffer,
SPatchAllocateStatelessConstantMemorySurfaceWithInitialization,
SPatchAllocateStatelessGlobalMemorySurfaceWithInitialization,
SPatchAllocateSystemThreadSurface.
Related-To: NEO-4729
Signed-off-by: Krystian Chmielewski <krystian.chmielewski@intel.com>
2021-03-04 10:14:23 +01:00
|
|
|
SPatchThreadPayload threadPayloadBlock = {};
|
|
|
|
|
threadPayloadBlock.LocalIDXPresent = 0;
|
|
|
|
|
threadPayloadBlock.LocalIDYPresent = 0;
|
|
|
|
|
threadPayloadBlock.LocalIDZPresent = 0;
|
|
|
|
|
threadPayloadBlock.HeaderPresent = 0;
|
|
|
|
|
threadPayloadBlock.Size = 128;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, threadPayloadBlock);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2020-11-19 12:30:44 +01:00
|
|
|
infoBlock->kernelDescriptor.kernelAttributes.flags.usesDeviceSideEnqueue = true;
|
2017-12-21 00:45:38 +01:00
|
|
|
|
Remove PatchTokens from KernelInfo
Use KernelDescriptor instead of patchTokens stored in KernelInfo's
patchInfo.
Removed: SPatchMediaInterfaceDescriptorLoad, SPatchAllocateLocalSurface,
SPatchMediaVFEState(slot 0), SPatchMediaVFEState(slot 1),
SPatchInterfaceDescriptorData, SPatchSamplerStateArray,
SPatchBindingTableState, SPatchDataParameterBuffer,
SPatchDataParameterStream, SPatchThreadPayload,
SPatchKernelAttributesInfo, SPatchAllocateStatelessPrivateSurface,
SPatchAllocateSyncBuffer,
SPatchAllocateStatelessConstantMemorySurfaceWithInitialization,
SPatchAllocateStatelessGlobalMemorySurfaceWithInitialization,
SPatchAllocateSystemThreadSurface.
Related-To: NEO-4729
Signed-off-by: Krystian Chmielewski <krystian.chmielewski@intel.com>
2021-03-04 10:14:23 +01:00
|
|
|
SPatchDataParameterStream streamBlock = {};
|
|
|
|
|
streamBlock.DataParameterStreamSize = 0;
|
|
|
|
|
streamBlock.Size = 0;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, streamBlock);
|
|
|
|
|
|
|
|
|
|
SPatchBindingTableState bindingTable = {};
|
|
|
|
|
bindingTable.Count = 0;
|
|
|
|
|
bindingTable.Offset = 0;
|
|
|
|
|
bindingTable.Size = 0;
|
|
|
|
|
bindingTable.SurfaceStateOffset = 0;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, bindingTable);
|
|
|
|
|
|
|
|
|
|
SPatchInterfaceDescriptorData idData = {};
|
|
|
|
|
idData.BindingTableOffset = 0;
|
|
|
|
|
idData.KernelOffset = 0;
|
|
|
|
|
idData.Offset = 0;
|
|
|
|
|
idData.SamplerStateOffset = 0;
|
|
|
|
|
idData.Size = 0;
|
|
|
|
|
populateKernelDescriptor(infoBlock->kernelDescriptor, idData);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
infoBlock->heapInfo.pDsh = (void *)new uint64_t[64];
|
|
|
|
|
infoBlock->crossThreadData = new char[crossThreadOffsetBlock];
|
|
|
|
|
|
2019-10-27 19:48:26 +01:00
|
|
|
program->blockKernelManager->addBlockKernelInfo(infoBlock);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
parentKernel->initialize();
|
|
|
|
|
|
|
|
|
|
EXPECT_NE(nullptr, program->getBlockKernelManager()->getPrivateSurface(program->getBlockKernelManager()->getCount() - 1));
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-02 12:43:54 +00:00
|
|
|
struct ParentKernelFromBinaryTest : public ExecutionModelKernelFixture {
|
|
|
|
|
|
|
|
|
|
void SetUp() override {
|
|
|
|
|
ExecutionModelKernelFixture::SetUp("simple_block_kernel", "simple_block_kernel");
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
TEST_F(ParentKernelFromBinaryTest, GivenParentKernelWhenGettingInstructionHeapSizeForExecutionModelThenSizeIsGreaterThanZero) {
|
2020-10-07 13:37:34 +02:00
|
|
|
EXPECT_TRUE(pKernel->isParentKernel);
|
|
|
|
|
EXPECT_LT(0u, pKernel->getInstructionHeapSizeForExecutionModel());
|
2017-12-21 00:45:38 +01:00
|
|
|
}
|