2019-11-07 18:49:46 +01:00
|
|
|
/*
|
2024-01-19 16:00:58 +00:00
|
|
|
* Copyright (C) 2019-2024 Intel Corporation
|
2019-11-07 18:49:46 +01:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/helpers/basic_math.h"
|
2020-04-28 15:23:04 +02:00
|
|
|
#include "shared/source/helpers/constants.h"
|
2023-02-01 16:23:01 +00:00
|
|
|
#include "shared/source/helpers/gfx_core_helper.h"
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/helpers/kernel_helpers.h"
|
2022-10-28 13:58:31 +02:00
|
|
|
#include "shared/test/common/fixtures/device_fixture.h"
|
2021-05-27 17:07:13 +00:00
|
|
|
#include "shared/test/common/helpers/debug_manager_state_restore.h"
|
2023-01-16 16:40:13 +00:00
|
|
|
#include "shared/test/common/mocks/mock_device.h"
|
2024-01-19 16:00:58 +00:00
|
|
|
#include "shared/test/common/mocks/mock_execution_environment.h"
|
2021-12-14 17:40:08 +00:00
|
|
|
#include "shared/test/common/test_macros/test.h"
|
2019-11-07 18:49:46 +01:00
|
|
|
|
2024-01-19 16:00:58 +00:00
|
|
|
#include <algorithm>
|
|
|
|
|
|
2019-11-07 18:49:46 +01:00
|
|
|
using namespace NEO;
|
|
|
|
|
|
|
|
|
|
struct KernelHelperMaxWorkGroupsTests : ::testing::Test {
|
2024-01-19 16:00:58 +00:00
|
|
|
EngineGroupType engineType = EngineGroupType::compute;
|
2019-11-07 18:49:46 +01:00
|
|
|
uint32_t simd = 8;
|
|
|
|
|
uint32_t dssCount = 16;
|
2023-12-04 15:55:01 +00:00
|
|
|
uint32_t availableSlm = 64 * MemoryConstants::kiloByte;
|
2019-11-07 18:49:46 +01:00
|
|
|
uint32_t usedSlm = 0;
|
|
|
|
|
uint32_t numberOfBarriers = 0;
|
|
|
|
|
uint32_t workDim = 3;
|
2024-01-19 16:00:58 +00:00
|
|
|
uint32_t grf = 128;
|
2024-01-22 11:57:53 +00:00
|
|
|
uint32_t numSubdevices = 1;
|
2019-11-07 18:49:46 +01:00
|
|
|
size_t lws[3] = {10, 10, 10};
|
|
|
|
|
|
2024-01-19 16:00:58 +00:00
|
|
|
void SetUp() override {
|
|
|
|
|
executionEnvironment = std::make_unique<MockExecutionEnvironment>(defaultHwInfo.get(), false, 1u);
|
|
|
|
|
rootDeviceEnvironment = executionEnvironment->rootDeviceEnvironments[0].get();
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-07 18:49:46 +01:00
|
|
|
uint32_t getMaxWorkGroupCount() {
|
2024-01-19 16:00:58 +00:00
|
|
|
KernelDescriptor descriptor = {};
|
|
|
|
|
descriptor.kernelAttributes.simdSize = simd;
|
|
|
|
|
descriptor.kernelAttributes.barrierCount = numberOfBarriers;
|
|
|
|
|
descriptor.kernelAttributes.numGrfRequired = grf;
|
|
|
|
|
|
|
|
|
|
auto hwInfo = rootDeviceEnvironment->getMutableHardwareInfo();
|
|
|
|
|
hwInfo->gtSystemInfo.DualSubSliceCount = dssCount;
|
|
|
|
|
hwInfo->capabilityTable.slmSize = (availableSlm / MemoryConstants::kiloByte) / dssCount;
|
|
|
|
|
|
2024-01-22 11:57:53 +00:00
|
|
|
return KernelHelper::getMaxWorkGroupCount(*rootDeviceEnvironment, descriptor, numSubdevices, usedSlm, workDim, lws, engineType, false);
|
2019-11-07 18:49:46 +01:00
|
|
|
}
|
2024-01-19 16:00:58 +00:00
|
|
|
|
|
|
|
|
std::unique_ptr<MockExecutionEnvironment> executionEnvironment;
|
|
|
|
|
RootDeviceEnvironment *rootDeviceEnvironment = nullptr;
|
2019-11-07 18:49:46 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperMaxWorkGroupsTests, GivenNoBarriersOrSlmUsedWhenCalculatingMaxWorkGroupsCountThenResultIsCalculatedWithSimd) {
|
2024-01-19 16:00:58 +00:00
|
|
|
auto &helper = rootDeviceEnvironment->getHelper<NEO::GfxCoreHelper>();
|
|
|
|
|
|
|
|
|
|
uint32_t workGroupSize = static_cast<uint32_t>(lws[0] * lws[1] * lws[2]);
|
|
|
|
|
uint32_t expected = helper.calculateAvailableThreadCount(*rootDeviceEnvironment->getHardwareInfo(), grf) / static_cast<uint32_t>(Math::divideAndRoundUp(workGroupSize, simd));
|
|
|
|
|
|
|
|
|
|
expected = helper.adjustMaxWorkGroupCount(expected, EngineGroupType::compute, *rootDeviceEnvironment, false);
|
2019-11-07 18:49:46 +01:00
|
|
|
EXPECT_EQ(expected, getMaxWorkGroupCount());
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-27 17:07:13 +00:00
|
|
|
TEST_F(KernelHelperMaxWorkGroupsTests, GivenDebugFlagSetWhenGetMaxWorkGroupCountCalledThenReturnCorrectValue) {
|
|
|
|
|
DebugManagerStateRestore restore;
|
2023-11-30 08:32:25 +00:00
|
|
|
debugManager.flags.OverrideMaxWorkGroupCount.set(123);
|
2021-05-27 17:07:13 +00:00
|
|
|
|
|
|
|
|
EXPECT_EQ(123u, getMaxWorkGroupCount());
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-22 11:57:53 +00:00
|
|
|
TEST_F(KernelHelperMaxWorkGroupsTests, givenMultipleSubdevicesWenCalculatingMaxWorkGroupsCountTenMultiply) {
|
|
|
|
|
auto &helper = rootDeviceEnvironment->getHelper<NEO::GfxCoreHelper>();
|
|
|
|
|
|
|
|
|
|
auto baseCount = getMaxWorkGroupCount();
|
|
|
|
|
|
|
|
|
|
numSubdevices = 4;
|
|
|
|
|
|
|
|
|
|
auto countWithSubdevices = getMaxWorkGroupCount();
|
|
|
|
|
|
|
|
|
|
if (helper.singleTileExecImplicitScalingRequired(true)) {
|
|
|
|
|
EXPECT_EQ(baseCount, countWithSubdevices);
|
|
|
|
|
} else {
|
|
|
|
|
EXPECT_EQ(baseCount * numSubdevices, countWithSubdevices);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-07 18:49:46 +01:00
|
|
|
TEST_F(KernelHelperMaxWorkGroupsTests, GivenBarriersWhenCalculatingMaxWorkGroupsCountThenResultIsCalculatedWithRegardToBarriersCount) {
|
2024-01-19 16:00:58 +00:00
|
|
|
numberOfBarriers = 0;
|
|
|
|
|
auto baseCount = getMaxWorkGroupCount();
|
|
|
|
|
|
2019-11-07 18:49:46 +01:00
|
|
|
numberOfBarriers = 16;
|
|
|
|
|
|
2024-01-19 16:00:58 +00:00
|
|
|
auto &helper = rootDeviceEnvironment->getHelper<NEO::GfxCoreHelper>();
|
|
|
|
|
auto maxBarrierCount = helper.getMaxBarrierRegisterPerSlice();
|
|
|
|
|
|
|
|
|
|
auto expected = std::min(baseCount, static_cast<uint32_t>(dssCount * (maxBarrierCount / numberOfBarriers)));
|
2019-11-07 18:49:46 +01:00
|
|
|
EXPECT_EQ(expected, getMaxWorkGroupCount());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperMaxWorkGroupsTests, GivenUsedSlmSizeWhenCalculatingMaxWorkGroupsCountThenResultIsCalculatedWithRegardToUsedSlmSize) {
|
2024-01-19 16:00:58 +00:00
|
|
|
usedSlm = 0;
|
|
|
|
|
auto baseCount = getMaxWorkGroupCount();
|
|
|
|
|
|
2023-12-04 15:55:01 +00:00
|
|
|
usedSlm = 4 * MemoryConstants::kiloByte;
|
2019-11-07 18:49:46 +01:00
|
|
|
|
2024-01-19 16:00:58 +00:00
|
|
|
auto expected = std::min(baseCount, availableSlm / usedSlm);
|
2019-11-07 18:49:46 +01:00
|
|
|
EXPECT_EQ(expected, getMaxWorkGroupCount());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperMaxWorkGroupsTests, GivenVariousValuesWhenCalculatingMaxWorkGroupsCountThenLowestResultIsAlwaysReturned) {
|
2024-01-19 16:00:58 +00:00
|
|
|
auto &helper = rootDeviceEnvironment->getHelper<NEO::GfxCoreHelper>();
|
|
|
|
|
|
|
|
|
|
engineType = EngineGroupType::cooperativeCompute;
|
2023-12-04 15:55:01 +00:00
|
|
|
usedSlm = 1 * MemoryConstants::kiloByte;
|
2019-11-07 18:49:46 +01:00
|
|
|
numberOfBarriers = 1;
|
|
|
|
|
dssCount = 1;
|
|
|
|
|
|
|
|
|
|
workDim = 1;
|
|
|
|
|
lws[0] = simd;
|
2024-01-19 16:00:58 +00:00
|
|
|
auto hwInfo = rootDeviceEnvironment->getMutableHardwareInfo();
|
2019-11-07 18:49:46 +01:00
|
|
|
|
2024-01-19 16:00:58 +00:00
|
|
|
hwInfo->gtSystemInfo.ThreadCount = 1024;
|
2019-11-07 18:49:46 +01:00
|
|
|
EXPECT_NE(1u, getMaxWorkGroupCount());
|
|
|
|
|
|
2024-01-19 16:00:58 +00:00
|
|
|
numberOfBarriers = static_cast<uint32_t>(helper.getMaxBarrierRegisterPerSlice());
|
2019-11-07 18:49:46 +01:00
|
|
|
EXPECT_EQ(1u, getMaxWorkGroupCount());
|
|
|
|
|
|
|
|
|
|
numberOfBarriers = 1;
|
|
|
|
|
EXPECT_NE(1u, getMaxWorkGroupCount());
|
|
|
|
|
|
|
|
|
|
usedSlm = availableSlm;
|
|
|
|
|
EXPECT_EQ(1u, getMaxWorkGroupCount());
|
|
|
|
|
}
|
2022-10-28 13:58:31 +02:00
|
|
|
|
|
|
|
|
using KernelHelperTest = Test<DeviceFixture>;
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenStatelessPrivateSizeGreaterThanGlobalSizeWhenCheckingIfThereIsEnaughSpaceThenOutOfMemReturned) {
|
2022-11-03 11:30:51 +01:00
|
|
|
auto globalSize = pDevice->getDeviceInfo().globalMemSize;
|
2022-10-28 13:58:31 +02:00
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
|
|
|
|
attributes.perHwThreadPrivateMemorySize = (static_cast<uint32_t>((globalSize + pDevice->getDeviceInfo().computeUnitsUsedForScratch) / pDevice->getDeviceInfo().computeUnitsUsedForScratch)) + 100;
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::outOfDeviceMemory);
|
2022-10-28 13:58:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchSizeGreaterThanGlobalSizeWhenCheckingIfThereIsEnaughSpaceThenOutOfMemReturned) {
|
2022-11-03 11:30:51 +01:00
|
|
|
auto globalSize = pDevice->getDeviceInfo().globalMemSize;
|
2022-10-28 13:58:31 +02:00
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
|
|
|
|
attributes.perThreadScratchSize[0] = (static_cast<uint32_t>((globalSize + pDevice->getDeviceInfo().computeUnitsUsedForScratch) / pDevice->getDeviceInfo().computeUnitsUsedForScratch)) + 100;
|
2022-12-30 15:22:14 +00:00
|
|
|
auto &gfxCoreHelper = pDevice->getGfxCoreHelper();
|
2024-04-29 11:22:46 +00:00
|
|
|
auto &productHelper = pDevice->getProductHelper();
|
|
|
|
|
if (attributes.perThreadScratchSize[0] > gfxCoreHelper.getMaxScratchSize(productHelper)) {
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::invalidKernel);
|
2022-11-17 14:27:52 +00:00
|
|
|
} else {
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::outOfDeviceMemory);
|
2022-11-17 14:27:52 +00:00
|
|
|
}
|
2022-10-28 13:58:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchPrivateSizeGreaterThanGlobalSizeWhenCheckingIfThereIsEnaughSpaceThenOutOfMemReturned) {
|
2022-11-03 11:30:51 +01:00
|
|
|
auto globalSize = pDevice->getDeviceInfo().globalMemSize;
|
2022-10-28 13:58:31 +02:00
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
|
|
|
|
attributes.perThreadScratchSize[1] = (static_cast<uint32_t>((globalSize + pDevice->getDeviceInfo().computeUnitsUsedForScratch) / pDevice->getDeviceInfo().computeUnitsUsedForScratch)) + 100;
|
2022-12-30 15:22:14 +00:00
|
|
|
auto &gfxCoreHelper = pDevice->getGfxCoreHelper();
|
2024-04-29 11:22:46 +00:00
|
|
|
auto &productHelper = pDevice->getProductHelper();
|
|
|
|
|
if (attributes.perThreadScratchSize[1] > gfxCoreHelper.getMaxScratchSize(productHelper)) {
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::invalidKernel);
|
2022-11-17 14:27:52 +00:00
|
|
|
} else {
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::outOfDeviceMemory);
|
2022-11-17 14:27:52 +00:00
|
|
|
}
|
2022-10-28 13:58:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchAndPrivateSizeLessThanGlobalSizeWhenCheckingIfThereIsEnaughSpaceThenSuccessReturned) {
|
2022-11-03 11:30:51 +01:00
|
|
|
auto globalSize = pDevice->getDeviceInfo().globalMemSize;
|
2022-10-28 13:58:31 +02:00
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
|
|
|
|
auto size = (static_cast<uint32_t>((globalSize + pDevice->getDeviceInfo().computeUnitsUsedForScratch) / pDevice->getDeviceInfo().computeUnitsUsedForScratch)) - 100;
|
|
|
|
|
attributes.perHwThreadPrivateMemorySize = size;
|
2022-12-08 12:22:35 +00:00
|
|
|
auto &gfxCoreHelper = pDevice->getRootDeviceEnvironment().getHelper<NEO::GfxCoreHelper>();
|
2024-04-29 11:22:46 +00:00
|
|
|
auto &productHelper = pDevice->getProductHelper();
|
|
|
|
|
uint32_t maxScratchSize = gfxCoreHelper.getMaxScratchSize(productHelper);
|
2022-11-17 14:27:52 +00:00
|
|
|
attributes.perThreadScratchSize[0] = (size > maxScratchSize) ? maxScratchSize : size;
|
|
|
|
|
attributes.perThreadScratchSize[1] = (size > maxScratchSize) ? maxScratchSize : size;
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::success);
|
2022-11-17 14:27:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchSizeGreaterThanMaxScratchSizeWhenCheckingIfThereIsEnaughSpaceThenInvalidKernelIsReturned) {
|
|
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
2022-12-08 12:22:35 +00:00
|
|
|
auto &gfxCoreHelper = pDevice->getRootDeviceEnvironment().getHelper<NEO::GfxCoreHelper>();
|
2024-04-29 11:22:46 +00:00
|
|
|
auto &productHelper = pDevice->getProductHelper();
|
|
|
|
|
uint32_t maxScratchSize = gfxCoreHelper.getMaxScratchSize(productHelper);
|
2022-11-17 14:27:52 +00:00
|
|
|
attributes.perHwThreadPrivateMemorySize = 0x10;
|
|
|
|
|
attributes.perThreadScratchSize[0] = maxScratchSize + 1;
|
|
|
|
|
attributes.perThreadScratchSize[1] = 0x10;
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::invalidKernel);
|
2022-11-17 14:27:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchPrivateSizeGreaterThanMaxScratchSizeWhenCheckingIfThereIsEnaughSpaceThenInvalidKernelIsReturned) {
|
|
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
2022-12-08 12:22:35 +00:00
|
|
|
auto &gfxCoreHelper = pDevice->getRootDeviceEnvironment().getHelper<NEO::GfxCoreHelper>();
|
2024-04-29 11:22:46 +00:00
|
|
|
auto &productHelper = pDevice->getProductHelper();
|
|
|
|
|
uint32_t maxScratchSize = gfxCoreHelper.getMaxScratchSize(productHelper);
|
2022-11-17 14:27:52 +00:00
|
|
|
attributes.perHwThreadPrivateMemorySize = 0x10;
|
|
|
|
|
attributes.perThreadScratchSize[0] = 0x10;
|
|
|
|
|
attributes.perThreadScratchSize[1] = maxScratchSize + 1;
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::invalidKernel);
|
2022-11-17 14:27:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchAndEqualsZeroWhenCheckingIfThereIsEnaughSpaceThenSuccessIsReturned) {
|
|
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
|
|
|
|
attributes.perHwThreadPrivateMemorySize = 0;
|
|
|
|
|
attributes.perThreadScratchSize[0] = 0;
|
|
|
|
|
attributes.perThreadScratchSize[1] = 0;
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::success);
|
2022-11-17 14:27:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenScratchEqualsZeroAndPrivetGreaterThanZeroWhenCheckingIfThereIsEnaughSpaceThenSuccessIsReturned) {
|
|
|
|
|
KernelDescriptor::KernelAttributes attributes = {};
|
|
|
|
|
attributes.perHwThreadPrivateMemorySize = 0x10;
|
|
|
|
|
attributes.perThreadScratchSize[0] = 0;
|
|
|
|
|
attributes.perThreadScratchSize[1] = 0;
|
2023-12-12 11:37:31 +00:00
|
|
|
EXPECT_EQ(KernelHelper::checkIfThereIsSpaceForScratchOrPrivate(attributes, pDevice), KernelHelper::ErrorCode::success);
|
2023-03-07 15:22:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenNoPtrByValueWhenCheckingIsAnyArgumentPtrByValueThenFalseIsReturned) {
|
|
|
|
|
KernelDescriptor kernelDescriptor;
|
2023-12-13 16:09:52 +00:00
|
|
|
auto pointerArg = ArgDescriptor(ArgDescriptor::argTPointer);
|
2023-03-07 15:22:10 +00:00
|
|
|
|
2023-12-13 16:09:52 +00:00
|
|
|
auto valueArg = ArgDescriptor(ArgDescriptor::argTValue);
|
2023-03-07 15:22:10 +00:00
|
|
|
ArgDescValue::Element element;
|
|
|
|
|
element.isPtr = false;
|
|
|
|
|
valueArg.as<ArgDescValue>().elements.push_back(element);
|
|
|
|
|
|
|
|
|
|
kernelDescriptor.payloadMappings.explicitArgs.push_back(pointerArg);
|
|
|
|
|
kernelDescriptor.payloadMappings.explicitArgs.push_back(valueArg);
|
|
|
|
|
EXPECT_FALSE(KernelHelper::isAnyArgumentPtrByValue(kernelDescriptor));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(KernelHelperTest, GivenPtrByValueWhenCheckingIsAnyArgumentPtrByValueThenTrueIsReturned) {
|
|
|
|
|
KernelDescriptor kernelDescriptor;
|
2023-12-13 16:09:52 +00:00
|
|
|
auto pointerArg = ArgDescriptor(ArgDescriptor::argTPointer);
|
2023-03-07 15:22:10 +00:00
|
|
|
|
2023-12-13 16:09:52 +00:00
|
|
|
auto valueArg = ArgDescriptor(ArgDescriptor::argTValue);
|
2023-03-07 15:22:10 +00:00
|
|
|
ArgDescValue::Element element;
|
|
|
|
|
element.isPtr = true;
|
|
|
|
|
valueArg.as<ArgDescValue>().elements.push_back(element);
|
|
|
|
|
|
|
|
|
|
kernelDescriptor.payloadMappings.explicitArgs.push_back(pointerArg);
|
|
|
|
|
kernelDescriptor.payloadMappings.explicitArgs.push_back(valueArg);
|
|
|
|
|
EXPECT_TRUE(KernelHelper::isAnyArgumentPtrByValue(kernelDescriptor));
|
2022-10-28 13:58:31 +02:00
|
|
|
}
|