2018-04-05 17:14:12 +02:00
|
|
|
/*
|
2023-01-12 19:31:00 +00:00
|
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
2018-04-05 17:14:12 +02:00
|
|
|
*
|
2018-09-18 09:11:08 +02:00
|
|
|
* SPDX-License-Identifier: MIT
|
2018-04-05 17:14:12 +02:00
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2020-02-23 15:20:22 +01:00
|
|
|
#include "opencl/test/unit_test/fixtures/kernel_arg_fixture.h"
|
2018-04-05 17:14:12 +02:00
|
|
|
|
2020-11-17 11:55:37 +00:00
|
|
|
#include "shared/source/helpers/api_specific_config.h"
|
2021-09-29 19:10:53 +00:00
|
|
|
#include "shared/source/program/kernel_info.h"
|
2020-11-17 11:55:37 +00:00
|
|
|
|
2020-02-23 15:20:22 +01:00
|
|
|
#include "opencl/test/unit_test/fixtures/image_fixture.h"
|
2023-01-12 19:31:00 +00:00
|
|
|
#include "opencl/test/unit_test/mocks/mock_cl_device.h"
|
2020-02-23 15:20:22 +01:00
|
|
|
#include "opencl/test/unit_test/mocks/mock_context.h"
|
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_image.h"
|
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_program.h"
|
2020-02-22 09:28:27 +01:00
|
|
|
|
2020-03-19 14:26:08 +01:00
|
|
|
using namespace NEO;
|
|
|
|
|
|
2018-04-05 17:14:12 +02:00
|
|
|
KernelImageArgTest::~KernelImageArgTest() = default;
|
|
|
|
|
|
|
|
|
|
void KernelImageArgTest::SetUp() {
|
2021-04-08 11:05:45 +02:00
|
|
|
pKernelInfo = std::make_unique<MockKernelInfo>();
|
2020-11-19 12:30:44 +01:00
|
|
|
pKernelInfo->kernelDescriptor.kernelAttributes.simdSize = 1;
|
|
|
|
|
|
2023-04-28 09:38:31 +00:00
|
|
|
pKernelInfo->heapInfo.surfaceStateHeapSize = sizeof(surfaceStateHeap);
|
2018-04-05 17:14:12 +02:00
|
|
|
pKernelInfo->heapInfo.pSsh = surfaceStateHeap;
|
|
|
|
|
|
2020-04-27 15:40:12 +02:00
|
|
|
constexpr int numImages = 5;
|
2018-04-05 17:14:12 +02:00
|
|
|
|
2021-04-08 11:05:45 +02:00
|
|
|
pKernelInfo->addArgImage(0, 0);
|
|
|
|
|
auto &img0 = pKernelInfo->argAsImg(0);
|
|
|
|
|
img0.metadataPayload.imgWidth = 0x4;
|
|
|
|
|
img0.metadataPayload.flatBaseOffset = 0x8;
|
|
|
|
|
img0.metadataPayload.flatWidth = 0x10;
|
|
|
|
|
img0.metadataPayload.flatHeight = 0x18;
|
|
|
|
|
img0.metadataPayload.flatPitch = 0x24;
|
|
|
|
|
img0.metadataPayload.numSamples = 0x3c;
|
|
|
|
|
img0.metadataPayload.numMipLevels = offsetNumMipLevelsImage0;
|
|
|
|
|
|
|
|
|
|
pKernelInfo->addArgImage(1, 0);
|
|
|
|
|
pKernelInfo->argAsImg(1).metadataPayload.imgHeight = 0xc;
|
|
|
|
|
|
|
|
|
|
pKernelInfo->addArgImmediate(2, sizeof(void *), 0x20);
|
|
|
|
|
|
|
|
|
|
pKernelInfo->addArgImage(3, 0);
|
|
|
|
|
|
|
|
|
|
pKernelInfo->addArgImage(4, 0x20);
|
2018-04-05 17:14:12 +02:00
|
|
|
|
2023-05-30 08:26:29 +00:00
|
|
|
pKernelInfo->kernelDescriptor.kernelAttributes.bufferAddressingMode = ApiSpecificConfig::getBindlessMode() ? KernelDescriptor::AddressingMode::BindlessAndStateless : KernelDescriptor::AddressingMode::BindfulAndStateless;
|
|
|
|
|
pKernelInfo->kernelDescriptor.kernelAttributes.imageAddressingMode = ApiSpecificConfig::getBindlessMode() ? KernelDescriptor::AddressingMode::Bindless : KernelDescriptor::AddressingMode::Bindful;
|
2018-04-05 17:14:12 +02:00
|
|
|
|
2022-08-16 14:51:17 +00:00
|
|
|
ClDeviceFixture::setUp();
|
2020-11-18 17:06:55 +01:00
|
|
|
context.reset(new MockContext(pClDevice));
|
|
|
|
|
program = std::make_unique<MockProgram>(context.get(), false, toClDeviceVector(*pClDevice));
|
2021-03-16 11:32:40 +00:00
|
|
|
int32_t retVal = CL_INVALID_VALUE;
|
2023-04-06 21:44:42 +00:00
|
|
|
pMultiDeviceKernel.reset(MultiDeviceKernel::create<MockKernel>(program.get(), MockKernel::toKernelInfoContainer(*pKernelInfo, rootDeviceIndex), retVal));
|
2021-03-16 11:32:40 +00:00
|
|
|
pKernel = static_cast<MockKernel *>(pMultiDeviceKernel->getKernel(rootDeviceIndex));
|
|
|
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
2018-04-05 17:14:12 +02:00
|
|
|
|
2020-03-19 14:26:08 +01:00
|
|
|
pKernel->setKernelArgHandler(0, &Kernel::setArgImage);
|
|
|
|
|
pKernel->setKernelArgHandler(1, &Kernel::setArgImage);
|
|
|
|
|
pKernel->setKernelArgHandler(2, &Kernel::setArgImmediate);
|
|
|
|
|
pKernel->setKernelArgHandler(3, &Kernel::setArgImage);
|
|
|
|
|
pKernel->setKernelArgHandler(4, &Kernel::setArgImage);
|
2018-04-05 17:14:12 +02:00
|
|
|
|
2020-04-27 15:40:12 +02:00
|
|
|
uint32_t crossThreadData[numImages * 0x20] = {};
|
2018-04-05 17:14:12 +02:00
|
|
|
crossThreadData[0x20 / sizeof(uint32_t)] = 0x12344321;
|
|
|
|
|
pKernel->setCrossThreadData(crossThreadData, sizeof(crossThreadData));
|
|
|
|
|
|
|
|
|
|
image.reset(Image2dHelper<>::create(context.get()));
|
|
|
|
|
ASSERT_NE(nullptr, image);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void KernelImageArgTest::TearDown() {
|
|
|
|
|
image.reset();
|
2021-03-09 10:30:21 +00:00
|
|
|
pMultiDeviceKernel.reset();
|
2018-04-05 17:14:12 +02:00
|
|
|
program.reset();
|
|
|
|
|
context.reset();
|
2022-08-16 14:51:17 +00:00
|
|
|
ClDeviceFixture::tearDown();
|
2018-04-05 17:14:12 +02:00
|
|
|
}
|