2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2021-01-21 20:10:13 +08:00
|
|
|
* Copyright (C) 2017-2021 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
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2021-01-21 20:10:13 +08:00
|
|
|
#include "shared/test/common/mocks/mock_device.h"
|
2020-04-02 15:35:50 +08:00
|
|
|
|
2020-03-18 20:08:45 +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"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
|
|
|
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
using namespace NEO;
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
class PatchedKernelTest : public ::testing::Test {
|
|
|
|
public:
|
|
|
|
void SetUp() override {
|
2020-12-01 01:38:28 +08:00
|
|
|
device = std::make_unique<MockClDevice>(MockDevice::createWithNewExecutionEnvironment<MockDevice>(defaultHwInfo.get(), rootDeviceIndex));
|
2018-05-28 22:16:06 +08:00
|
|
|
context.reset(new MockContext(device.get()));
|
2020-12-03 02:19:05 +08:00
|
|
|
program.reset(Program::createBuiltInFromSource<MockProgram>("FillBufferBytes", context.get(), context->getDevices(), &retVal));
|
2017-12-21 07:45:38 +08:00
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
2020-10-30 18:10:00 +08:00
|
|
|
program->build(program->getDevices(), nullptr, false);
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(Kernel::create(program.get(), program->getKernelInfoForKernel("FillBufferBytes"), *device, &retVal));
|
2017-12-21 07:45:38 +08:00
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
}
|
2018-03-05 16:25:40 +08:00
|
|
|
void TearDown() override {
|
2018-05-28 22:16:06 +08:00
|
|
|
context.reset();
|
2018-03-05 16:25:40 +08:00
|
|
|
}
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2020-12-01 01:38:28 +08:00
|
|
|
const uint32_t rootDeviceIndex = 0u;
|
2018-05-28 22:16:06 +08:00
|
|
|
std::unique_ptr<MockContext> context;
|
2020-01-14 21:32:11 +08:00
|
|
|
std::unique_ptr<MockClDevice> device;
|
2020-12-03 02:19:05 +08:00
|
|
|
std::unique_ptr<MockProgram> program;
|
2017-12-21 07:45:38 +08:00
|
|
|
std::unique_ptr<Kernel> kernel;
|
|
|
|
cl_int retVal = CL_SUCCESS;
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(PatchedKernelTest, givenKernelWithoutPatchedArgsWhenIsPatchedIsCalledThenReturnsFalse) {
|
|
|
|
EXPECT_FALSE(kernel->isPatched());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PatchedKernelTest, givenKernelWithAllArgsSetWithBufferWhenIsPatchedIsCalledThenReturnsTrue) {
|
2018-05-28 22:16:06 +08:00
|
|
|
auto buffer = clCreateBuffer(context.get(), CL_MEM_READ_ONLY, sizeof(int), nullptr, &retVal);
|
2017-12-21 07:45:38 +08:00
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
auto argsNum = kernel->getKernelArgsNumber();
|
|
|
|
for (uint32_t i = 0; i < argsNum; i++) {
|
|
|
|
kernel->setArg(i, buffer);
|
|
|
|
}
|
|
|
|
EXPECT_TRUE(kernel->isPatched());
|
|
|
|
clReleaseMemObject(buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PatchedKernelTest, givenKernelWithoutAllArgsSetWhenIsPatchedIsCalledThenReturnsFalse) {
|
2018-05-28 22:16:06 +08:00
|
|
|
auto buffer = clCreateBuffer(context.get(), CL_MEM_READ_ONLY, sizeof(int), nullptr, &retVal);
|
2017-12-21 07:45:38 +08:00
|
|
|
EXPECT_EQ(CL_SUCCESS, retVal);
|
|
|
|
auto argsNum = kernel->getKernelArgsNumber();
|
|
|
|
for (uint32_t i = 0; i < argsNum; i++) {
|
|
|
|
kernel->setArg(0, buffer);
|
|
|
|
}
|
|
|
|
EXPECT_FALSE(kernel->isPatched());
|
|
|
|
clReleaseMemObject(buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PatchedKernelTest, givenKernelWithAllArgsSetWithSvmAllocWhenIsPatchedIsCalledThenReturnsTrue) {
|
|
|
|
auto argsNum = kernel->getKernelArgsNumber();
|
|
|
|
for (uint32_t i = 0; i < argsNum; i++) {
|
|
|
|
kernel->setArgSvmAlloc(0, nullptr, nullptr);
|
|
|
|
}
|
|
|
|
EXPECT_FALSE(kernel->isPatched());
|
|
|
|
for (uint32_t i = 0; i < argsNum; i++) {
|
|
|
|
kernel->setArgSvmAlloc(i, nullptr, nullptr);
|
|
|
|
}
|
|
|
|
EXPECT_TRUE(kernel->isPatched());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PatchedKernelTest, givenKernelWithAllArgsSetWithSvmWhenIsPatchedIsCalledThenReturnsTrue) {
|
|
|
|
uint32_t size = sizeof(int);
|
|
|
|
auto argsNum = kernel->getKernelArgsNumber();
|
|
|
|
for (uint32_t i = 0; i < argsNum; i++) {
|
2019-01-28 17:24:11 +08:00
|
|
|
kernel->setArgSvm(0, size, nullptr, nullptr, 0u);
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
EXPECT_FALSE(kernel->isPatched());
|
|
|
|
for (uint32_t i = 0; i < argsNum; i++) {
|
2019-01-28 17:24:11 +08:00
|
|
|
kernel->setArgSvm(i, size, nullptr, nullptr, 0u);
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
EXPECT_TRUE(kernel->isPatched());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PatchedKernelTest, givenKernelWithOneArgumentToPatchWhichIsNonzeroIndexedWhenThatArgumentIsSetThenKernelIsPatched) {
|
|
|
|
uint32_t size = sizeof(int);
|
2018-05-28 22:16:06 +08:00
|
|
|
MockKernelWithInternals mockKernel(*device.get(), context.get());
|
2017-12-21 07:45:38 +08:00
|
|
|
EXPECT_EQ(0u, mockKernel.kernelInfo.argumentsToPatchNum);
|
|
|
|
mockKernel.kernelInfo.storeKernelArgPatchInfo(1, 0, 0, 0, 0);
|
|
|
|
EXPECT_EQ(1u, mockKernel.kernelInfo.argumentsToPatchNum);
|
|
|
|
mockKernel.kernelInfo.storeKernelArgPatchInfo(1, 0, 0, 0, 0);
|
|
|
|
EXPECT_EQ(1u, mockKernel.kernelInfo.argumentsToPatchNum);
|
|
|
|
kernel.reset(mockKernel.mockKernel);
|
|
|
|
kernel->initialize();
|
|
|
|
EXPECT_FALSE(kernel->Kernel::isPatched());
|
2019-01-28 17:24:11 +08:00
|
|
|
kernel->setArgSvm(1, size, nullptr, nullptr, 0u);
|
2017-12-21 07:45:38 +08:00
|
|
|
EXPECT_TRUE(kernel->Kernel::isPatched());
|
|
|
|
kernel.release();
|
|
|
|
}
|