mirror of
https://github.com/intel/compute-runtime.git
synced 2025-09-15 13:01:45 +08:00

Manually set values expected by given kernel arg info query. This prevents issues which incoming zebin switch. Related-To: NEO-6646 Signed-off-by: Kacper Nowak <kacper.nowak@intel.com>
211 lines
6.6 KiB
C++
211 lines
6.6 KiB
C++
/*
|
|
* Copyright (C) 2018-2022 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "shared/test/common/fixtures/memory_management_fixture.h"
|
|
#include "shared/test/common/helpers/kernel_binary_helper.h"
|
|
#include "shared/test/common/test_macros/test.h"
|
|
|
|
#include "opencl/source/kernel/kernel.h"
|
|
#include "opencl/test/unit_test/fixtures/cl_device_fixture.h"
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
|
#include "opencl/test/unit_test/mocks/mock_program.h"
|
|
#include "opencl/test/unit_test/program/program_tests.h"
|
|
#include "opencl/test/unit_test/program/program_with_source.h"
|
|
|
|
using namespace NEO;
|
|
|
|
class KernelArgInfoTest : public ProgramFromSourceTest {
|
|
public:
|
|
KernelArgInfoTest() {
|
|
}
|
|
|
|
~KernelArgInfoTest() override = default;
|
|
|
|
protected:
|
|
void SetUp() override {
|
|
kbHelper = new KernelBinaryHelper("copybuffer", true);
|
|
ProgramFromSourceTest::SetUp();
|
|
ASSERT_NE(nullptr, pProgram);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
|
|
retVal = pProgram->build(
|
|
pProgram->getDevices(),
|
|
nullptr,
|
|
false);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
|
|
// create a kernel
|
|
pKernel = Kernel::create(
|
|
pProgram,
|
|
pProgram->getKernelInfoForKernel(kernelName),
|
|
*pPlatform->getClDevice(0),
|
|
&retVal);
|
|
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
ASSERT_NE(nullptr, pKernel);
|
|
}
|
|
|
|
void TearDown() override {
|
|
delete pKernel;
|
|
pKernel = nullptr;
|
|
ProgramFromSourceTest::TearDown();
|
|
delete kbHelper;
|
|
}
|
|
|
|
template <typename T>
|
|
void queryArgInfo(cl_kernel_arg_info paramName, T ¶mValue) {
|
|
size_t paramValueSize = 0;
|
|
size_t paramValueSizeRet = 0;
|
|
|
|
// get size
|
|
retVal = pKernel->getArgInfo(
|
|
0,
|
|
paramName,
|
|
paramValueSize,
|
|
nullptr,
|
|
¶mValueSizeRet);
|
|
EXPECT_NE(0u, paramValueSizeRet);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
|
|
// get the name
|
|
paramValueSize = paramValueSizeRet;
|
|
|
|
retVal = pKernel->getArgInfo(
|
|
0,
|
|
paramName,
|
|
paramValueSize,
|
|
¶mValue,
|
|
nullptr);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
}
|
|
|
|
Kernel *pKernel = nullptr;
|
|
cl_int retVal = CL_SUCCESS;
|
|
KernelBinaryHelper *kbHelper = nullptr;
|
|
};
|
|
|
|
TEST_F(KernelArgInfoTest, GivenNullWhenGettingKernelInfoThenNullIsReturned) {
|
|
auto kernelInfo = this->pProgram->getKernelInfo(nullptr, 0);
|
|
EXPECT_EQ(nullptr, kernelInfo);
|
|
}
|
|
|
|
TEST_F(KernelArgInfoTest, GivenInvalidParametersWhenGettingKernelArgInfoThenValueSizeRetIsNotUpdated) {
|
|
size_t paramValueSizeRet = 0x1234;
|
|
|
|
retVal = pKernel->getArgInfo(
|
|
0,
|
|
0,
|
|
0,
|
|
nullptr,
|
|
¶mValueSizeRet);
|
|
EXPECT_EQ(CL_INVALID_VALUE, retVal);
|
|
EXPECT_EQ(0x1234u, paramValueSizeRet);
|
|
}
|
|
|
|
TEST_F(KernelArgInfoTest, GivenKernelArgAccessQualifierWhenQueryingArgInfoThenKernelArgAcessNoneIsReturned) {
|
|
auto &kernelDescriptor = const_cast<KernelDescriptor &>(pKernel->getDescriptor());
|
|
auto &argTraits = kernelDescriptor.payloadMappings.explicitArgs[0].getTraits();
|
|
argTraits.accessQualifier = KernelArgMetadata::AccessNone;
|
|
|
|
cl_kernel_arg_access_qualifier paramValue = 0;
|
|
queryArgInfo<cl_kernel_arg_access_qualifier>(CL_KERNEL_ARG_ACCESS_QUALIFIER, paramValue);
|
|
EXPECT_EQ(static_cast<cl_kernel_arg_access_qualifier>(CL_KERNEL_ARG_ACCESS_NONE), paramValue);
|
|
}
|
|
|
|
TEST_F(KernelArgInfoTest, GivenKernelArgAddressQualifierWhenQueryingArgInfoThenKernelArgAddressGlobalIsReturned) {
|
|
auto &kernelDescriptor = const_cast<KernelDescriptor &>(pKernel->getDescriptor());
|
|
auto &argTraits = kernelDescriptor.payloadMappings.explicitArgs[0].getTraits();
|
|
argTraits.addressQualifier = KernelArgMetadata::AddrGlobal;
|
|
|
|
cl_kernel_arg_address_qualifier paramValue = 0;
|
|
queryArgInfo<cl_kernel_arg_address_qualifier>(CL_KERNEL_ARG_ADDRESS_QUALIFIER, paramValue);
|
|
EXPECT_EQ(static_cast<cl_kernel_arg_address_qualifier>(CL_KERNEL_ARG_ADDRESS_GLOBAL), paramValue);
|
|
}
|
|
|
|
TEST_F(KernelArgInfoTest, GivenKernelArgTypeQualifierWhenQueryingArgInfoThenKernelArgTypeNoneIsReturned) {
|
|
cl_kernel_arg_type_qualifier paramValue = 0;
|
|
queryArgInfo<cl_kernel_arg_type_qualifier>(CL_KERNEL_ARG_TYPE_QUALIFIER, paramValue);
|
|
EXPECT_EQ(static_cast<cl_kernel_arg_type_qualifier>(CL_KERNEL_ARG_TYPE_NONE), paramValue);
|
|
}
|
|
|
|
TEST_F(KernelArgInfoTest, GivenParamWhenGettingKernelTypeNameThenCorrectValueIsReturned) {
|
|
cl_uint argInd = 0;
|
|
const char expectedArgType[] = "uint*";
|
|
auto &kernelDescriptor = const_cast<KernelDescriptor &>(pKernel->getDescriptor());
|
|
kernelDescriptor.explicitArgsExtendedMetadata.at(argInd).type = expectedArgType;
|
|
|
|
cl_kernel_arg_info paramName = CL_KERNEL_ARG_TYPE_NAME;
|
|
char *paramValue = nullptr;
|
|
size_t paramValueSize = 0;
|
|
size_t paramValueSizeRet = 0;
|
|
|
|
// get size
|
|
retVal = pKernel->getArgInfo(
|
|
argInd,
|
|
paramName,
|
|
paramValueSize,
|
|
nullptr,
|
|
¶mValueSizeRet);
|
|
EXPECT_NE(0u, paramValueSizeRet);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
|
|
// allocate space for name
|
|
paramValue = new char[paramValueSizeRet];
|
|
|
|
// get the name
|
|
paramValueSize = paramValueSizeRet;
|
|
|
|
retVal = pKernel->getArgInfo(
|
|
0,
|
|
paramName,
|
|
paramValueSize,
|
|
paramValue,
|
|
nullptr);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
auto result = strncmp(paramValue, expectedArgType, sizeof(expectedArgType));
|
|
EXPECT_EQ(0, result);
|
|
delete[] paramValue;
|
|
}
|
|
|
|
TEST_F(KernelArgInfoTest, GivenParamWhenGettingKernelArgNameThenCorrectValueIsReturned) {
|
|
cl_uint argInd = 0;
|
|
const char expectedArgName[] = "src";
|
|
auto &kernelDescriptor = const_cast<KernelDescriptor &>(pKernel->getDescriptor());
|
|
kernelDescriptor.explicitArgsExtendedMetadata.at(argInd).argName = expectedArgName;
|
|
|
|
cl_kernel_arg_info paramName = CL_KERNEL_ARG_NAME;
|
|
char *paramValue = nullptr;
|
|
size_t paramValueSize = 0;
|
|
size_t paramValueSizeRet = 0;
|
|
|
|
// get size
|
|
retVal = pKernel->getArgInfo(
|
|
argInd,
|
|
paramName,
|
|
paramValueSize,
|
|
nullptr,
|
|
¶mValueSizeRet);
|
|
EXPECT_NE(0u, paramValueSizeRet);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
|
|
// allocate space for name
|
|
paramValue = new char[paramValueSizeRet];
|
|
|
|
// get the name
|
|
paramValueSize = paramValueSizeRet;
|
|
|
|
retVal = pKernel->getArgInfo(
|
|
0,
|
|
paramName,
|
|
paramValueSize,
|
|
paramValue,
|
|
nullptr);
|
|
ASSERT_EQ(CL_SUCCESS, retVal);
|
|
EXPECT_EQ(0, strcmp(paramValue, expectedArgName));
|
|
delete[] paramValue;
|
|
}
|