2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2025-02-25 20:34:16 +08:00
|
|
|
* Copyright (C) 2018-2025 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
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-06-30 03:17:47 +08:00
|
|
|
#include "shared/test/common/test_macros/hw_test.h"
|
2021-12-15 01:40:08 +08:00
|
|
|
|
2020-02-23 05:50:57 +08:00
|
|
|
#include "opencl/source/kernel/kernel.h"
|
2020-05-28 20:05:12 +08:00
|
|
|
#include "opencl/test/unit_test/fixtures/cl_device_fixture.h"
|
2020-02-23 22:20:22 +08:00
|
|
|
#include "opencl/test/unit_test/fixtures/context_fixture.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_buffer.h"
|
2023-01-13 03:31:00 +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"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_program.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
|
|
|
|
#include "CL/cl.h"
|
2017-12-21 07:45:38 +08:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
using namespace NEO;
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2020-05-28 20:05:12 +08:00
|
|
|
class KernelArgPipeFixture : public ContextFixture, public ClDeviceFixture {
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
using ContextFixture::setUp;
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
public:
|
|
|
|
KernelArgPipeFixture() {
|
|
|
|
}
|
|
|
|
|
|
|
|
protected:
|
2022-08-16 22:51:17 +08:00
|
|
|
void setUp() {
|
|
|
|
ClDeviceFixture::setUp();
|
2020-01-14 21:32:11 +08:00
|
|
|
cl_device_id device = pClDevice;
|
2022-08-16 22:51:17 +08:00
|
|
|
ContextFixture::setUp(1, &device);
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
// define kernel info
|
2021-04-08 17:05:45 +08:00
|
|
|
pKernelInfo = std::make_unique<MockKernelInfo>();
|
2020-11-19 19:30:44 +08:00
|
|
|
pKernelInfo->kernelDescriptor.kernelAttributes.simdSize = 1;
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2021-04-08 17:05:45 +08:00
|
|
|
pKernelInfo->addArgPipe(0, 0x30, sizeof(void *));
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2020-10-16 21:00:28 +08:00
|
|
|
pProgram = new MockProgram(pContext, false, toClDeviceVector(*pClDevice));
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2021-03-22 23:26:03 +08:00
|
|
|
pKernel = new MockKernel(pProgram, *pKernelInfo, *pClDevice);
|
2017-12-21 07:45:38 +08:00
|
|
|
ASSERT_EQ(CL_SUCCESS, pKernel->initialize());
|
|
|
|
pKernel->setKernelArgHandler(0, &Kernel::setArgPipe);
|
|
|
|
}
|
|
|
|
|
2022-08-16 22:51:17 +08:00
|
|
|
void tearDown() {
|
2017-12-21 07:45:38 +08:00
|
|
|
delete pKernel;
|
2018-08-16 20:28:58 +08:00
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
delete pProgram;
|
2022-08-16 22:51:17 +08:00
|
|
|
ContextFixture::tearDown();
|
|
|
|
ClDeviceFixture::tearDown();
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
MockProgram *pProgram = nullptr;
|
|
|
|
MockKernel *pKernel = nullptr;
|
2021-04-08 17:05:45 +08:00
|
|
|
std::unique_ptr<MockKernelInfo> pKernelInfo;
|
2017-12-21 07:45:38 +08:00
|
|
|
SKernelBinaryHeaderCommon kernelHeader;
|
|
|
|
};
|
|
|
|
|
2025-02-25 20:34:16 +08:00
|
|
|
using KernelArgPipeTest = Test<KernelArgPipeFixture>;
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2025-02-25 20:34:16 +08:00
|
|
|
TEST_F(KernelArgPipeTest, givenPointerWhenSettingKernelArgThenInvalidMemObjIsReturned) {
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2025-02-25 20:34:16 +08:00
|
|
|
auto val = reinterpret_cast<void *>(0xBADF00D);
|
2017-12-21 07:45:38 +08:00
|
|
|
auto pVal = &val;
|
|
|
|
|
|
|
|
auto retVal = this->pKernel->setArg(0, sizeof(cl_mem *), pVal);
|
|
|
|
EXPECT_EQ(CL_INVALID_MEM_OBJECT, retVal);
|
|
|
|
}
|
|
|
|
|
2025-02-25 20:34:16 +08:00
|
|
|
TEST_F(KernelArgPipeTest, givenIncorrectSizeWhenSettingKernelArgThenInvalidMemObjIsReturned) {
|
|
|
|
auto val = reinterpret_cast<void *>(0xBADF00D);
|
2017-12-21 07:45:38 +08:00
|
|
|
auto pVal = &val;
|
|
|
|
|
|
|
|
auto retVal = this->pKernel->setArg(0, 1, pVal);
|
|
|
|
EXPECT_EQ(CL_INVALID_ARG_SIZE, retVal);
|
|
|
|
}
|