|
| 1 | +//==-------------- KernelInfo.cpp --- kernel info unit test ----------------==// |
| 2 | +// |
| 3 | +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| 4 | +// See https://llvm.org/LICENSE.txt for license information. |
| 5 | +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| 6 | +// |
| 7 | +//===----------------------------------------------------------------------===// |
| 8 | + |
| 9 | +#include <CL/sycl.hpp> |
| 10 | +#include <detail/context_impl.hpp> |
| 11 | +#include <gtest/gtest.h> |
| 12 | +#include <helpers/PiMock.hpp> |
| 13 | + |
| 14 | +using namespace sycl; |
| 15 | + |
| 16 | +namespace { |
| 17 | +struct TestCtx { |
| 18 | + TestCtx(context &Ctx) : Ctx{Ctx} {}; |
| 19 | + |
| 20 | + context &Ctx; |
| 21 | + bool PrivateMemSizeCalled = false; |
| 22 | +}; |
| 23 | +} // namespace |
| 24 | + |
| 25 | +static std::unique_ptr<TestCtx> TestContext; |
| 26 | + |
| 27 | +static pi_result redefinedKernelGetGroupInfo(pi_kernel kernel, pi_device device, |
| 28 | + pi_kernel_group_info param_name, |
| 29 | + size_t param_value_size, |
| 30 | + void *param_value, |
| 31 | + size_t *param_value_size_ret) { |
| 32 | + if (param_name == PI_KERNEL_GROUP_INFO_PRIVATE_MEM_SIZE) { |
| 33 | + TestContext->PrivateMemSizeCalled = true; |
| 34 | + } |
| 35 | + |
| 36 | + return PI_SUCCESS; |
| 37 | +} |
| 38 | + |
| 39 | +static pi_result redefinedProgramCreateWithSource(pi_context context, |
| 40 | + pi_uint32 count, |
| 41 | + const char **strings, |
| 42 | + const size_t *lengths, |
| 43 | + pi_program *ret_program) { |
| 44 | + return PI_SUCCESS; |
| 45 | +} |
| 46 | + |
| 47 | +static pi_result |
| 48 | +redefinedProgramBuild(pi_program program, pi_uint32 num_devices, |
| 49 | + const pi_device *device_list, const char *options, |
| 50 | + void (*pfn_notify)(pi_program program, void *user_data), |
| 51 | + void *user_data) { |
| 52 | + return PI_SUCCESS; |
| 53 | +} |
| 54 | + |
| 55 | +static pi_result redefinedKernelCreate(pi_program program, |
| 56 | + const char *kernel_name, |
| 57 | + pi_kernel *ret_kernel) { |
| 58 | + return PI_SUCCESS; |
| 59 | +} |
| 60 | + |
| 61 | +static pi_result redefinedKernelRetain(pi_kernel kernel) { return PI_SUCCESS; } |
| 62 | + |
| 63 | +static pi_result redefinedKernelRelease(pi_kernel kernel) { return PI_SUCCESS; } |
| 64 | + |
| 65 | +static pi_result redefinedKernelGetInfo(pi_kernel kernel, |
| 66 | + pi_kernel_info param_name, |
| 67 | + size_t param_value_size, |
| 68 | + void *param_value, |
| 69 | + size_t *param_value_size_ret) { |
| 70 | + EXPECT_EQ(param_name, PI_KERNEL_INFO_CONTEXT) |
| 71 | + << "Unexpected kernel info requested"; |
| 72 | + auto *Result = reinterpret_cast<RT::PiContext *>(param_value); |
| 73 | + RT::PiContext PiCtx = |
| 74 | + detail::getSyclObjImpl(TestContext->Ctx)->getHandleRef(); |
| 75 | + *Result = PiCtx; |
| 76 | + return PI_SUCCESS; |
| 77 | +} |
| 78 | + |
| 79 | +static pi_result redefinedKernelSetExecInfo(pi_kernel kernel, |
| 80 | + pi_kernel_exec_info param_name, |
| 81 | + size_t param_value_size, |
| 82 | + const void *param_value) { |
| 83 | + return PI_SUCCESS; |
| 84 | +} |
| 85 | + |
| 86 | +class KernelInfoTest : public ::testing::Test { |
| 87 | +public: |
| 88 | + KernelInfoTest() : Plt{default_selector()} {} |
| 89 | + |
| 90 | +protected: |
| 91 | + void SetUp() override { |
| 92 | + if (Plt.is_host()) { |
| 93 | + std::clog << "This test is only supported on non-host platforms.\n"; |
| 94 | + std::clog << "Current platform is " |
| 95 | + << Plt.get_info<info::platform::name>(); |
| 96 | + return; |
| 97 | + } |
| 98 | + |
| 99 | + Mock = std::make_unique<unittest::PiMock>(Plt); |
| 100 | + |
| 101 | + Mock->redefine<detail::PiApiKind::piKernelGetGroupInfo>( |
| 102 | + redefinedKernelGetGroupInfo); |
| 103 | + Mock->redefine<detail::PiApiKind::piclProgramCreateWithSource>( |
| 104 | + redefinedProgramCreateWithSource); |
| 105 | + Mock->redefine<detail::PiApiKind::piProgramBuild>(redefinedProgramBuild); |
| 106 | + Mock->redefine<detail::PiApiKind::piKernelCreate>(redefinedKernelCreate); |
| 107 | + Mock->redefine<detail::PiApiKind::piKernelRetain>(redefinedKernelRetain); |
| 108 | + Mock->redefine<detail::PiApiKind::piKernelRelease>(redefinedKernelRelease); |
| 109 | + Mock->redefine<detail::PiApiKind::piKernelGetInfo>(redefinedKernelGetInfo); |
| 110 | + Mock->redefine<detail::PiApiKind::piKernelSetExecInfo>( |
| 111 | + redefinedKernelSetExecInfo); |
| 112 | + } |
| 113 | + |
| 114 | +protected: |
| 115 | + platform Plt; |
| 116 | + std::unique_ptr<unittest::PiMock> Mock; |
| 117 | +}; |
| 118 | + |
| 119 | +TEST_F(KernelInfoTest, GetPrivateMemUsage) { |
| 120 | + if (Plt.is_host()) { |
| 121 | + return; |
| 122 | + } |
| 123 | + |
| 124 | + context Ctx{Plt}; |
| 125 | + program Prg{Ctx}; |
| 126 | + TestContext.reset(new TestCtx(Ctx)); |
| 127 | + |
| 128 | + Prg.build_with_source(""); |
| 129 | + |
| 130 | + kernel Ker = Prg.get_kernel(""); |
| 131 | + |
| 132 | + Ker.get_info<info::kernel_device_specific::private_mem_size>( |
| 133 | + Ctx.get_devices()[0]); |
| 134 | + EXPECT_EQ(TestContext->PrivateMemSizeCalled, true) |
| 135 | + << "Expect piKernelGetGroupInfo to be " |
| 136 | + << "called with PI_KERNEL_GROUP_INFO_PRIVATE_MEM_SIZE"; |
| 137 | + |
| 138 | + TestContext->PrivateMemSizeCalled = false; |
| 139 | + Ker.get_work_group_info<info::kernel_work_group::private_mem_size>( |
| 140 | + Ctx.get_devices()[0]); |
| 141 | + EXPECT_EQ(TestContext->PrivateMemSizeCalled, true) |
| 142 | + << "Expect piKernelGetGroupInfo to be " |
| 143 | + << "called with PI_KERNEL_GROUP_INFO_PRIVATE_MEM_SIZE"; |
| 144 | +} |
0 commit comments