2020-06-10 18:47:58 +08:00
|
|
|
/*
|
2021-03-19 19:22:17 +08:00
|
|
|
* Copyright (C) 2020-2021 Intel Corporation
|
2020-06-10 18:47:58 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "shared/source/command_stream/preemption.h"
|
2020-11-19 19:30:44 +08:00
|
|
|
#include "shared/source/kernel/kernel_descriptor_from_patchtokens.h"
|
2020-06-10 18:47:58 +08:00
|
|
|
|
2021-09-23 06:24:59 +08:00
|
|
|
#include "opencl/source/helpers/cl_preemption_helper.h"
|
2020-06-10 18:47:58 +08:00
|
|
|
#include "opencl/test/unit_test/fixtures/cl_preemption_fixture.h"
|
|
|
|
|
|
|
|
#include "gmock/gmock.h"
|
|
|
|
|
|
|
|
using namespace NEO;
|
|
|
|
class ThreadGroupPreemptionTests : public DevicePreemptionTests {
|
|
|
|
void SetUp() override {
|
|
|
|
dbgRestore.reset(new DebugManagerStateRestore());
|
|
|
|
DebugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::ThreadGroup));
|
|
|
|
preemptionMode = PreemptionMode::ThreadGroup;
|
|
|
|
DevicePreemptionTests::SetUp();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class MidThreadPreemptionTests : public DevicePreemptionTests {
|
|
|
|
public:
|
|
|
|
void SetUp() override {
|
|
|
|
dbgRestore.reset(new DebugManagerStateRestore());
|
|
|
|
DebugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::MidThread));
|
|
|
|
preemptionMode = PreemptionMode::MidThread;
|
|
|
|
DevicePreemptionTests::SetUp();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDisallowedByKmdThenThreadGroupPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
waTable->waDisablePerCtxtPreemptionGranularityControl = 1;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_FALSE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDisallowByDeviceThenThreadGroupPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::MidThread, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDisallowByReadWriteFencesWaThenThreadGroupPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesFencesForReadWriteImages = true;
|
2020-06-10 18:47:58 +08:00
|
|
|
waTable->waDisableLSQCROPERFforOCL = 1;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_FALSE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDisallowBySchedulerKernelThenThreadGroupPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device, true));
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_FALSE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDisallowByVmeKernelThenThreadGroupPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2021-04-08 17:05:45 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesVme = true;
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_FALSE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDefaultThenThreadGroupPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
EXPECT_TRUE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDefaultModeForNonKernelRequestThenThreadGroupPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), nullptr);
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(ThreadGroupPreemptionTests, givenKernelWithEnvironmentPatchSetWhenLSQCWaIsTurnedOnThenThreadGroupPreemptionIsBeingSelected) {
|
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesFencesForReadWriteImages = false;
|
2020-06-10 18:47:58 +08:00
|
|
|
waTable->waDisableLSQCROPERFforOCL = 1;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(ThreadGroupPreemptionTests, givenKernelWithEnvironmentPatchSetWhenLSQCWaIsTurnedOffThenThreadGroupPreemptionIsBeingSelected) {
|
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesFencesForReadWriteImages = true;
|
2020-06-10 18:47:58 +08:00
|
|
|
waTable->waDisableLSQCROPERFforOCL = 0;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowThreadGroupPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDefaultThenMidBatchPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidBatch);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), nullptr);
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDisabledThenPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::Disabled);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), nullptr);
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::Disabled, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenZeroSizedMdiThenThreadGroupPreemptioIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
MultiDispatchInfo multiDispatchInfo;
|
2021-09-23 06:24:59 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, ClPreemptionHelper::taskPreemptionMode(device->getDevice(), multiDispatchInfo));
|
2020-06-10 18:47:58 +08:00
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenValidKernelsInMdiThenThreadGroupPreemptioIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
MultiDispatchInfo multiDispatchInfo;
|
|
|
|
multiDispatchInfo.push(*dispatchInfo);
|
|
|
|
multiDispatchInfo.push(*dispatchInfo);
|
2021-09-23 06:24:59 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, ClPreemptionHelper::taskPreemptionMode(device->getDevice(), multiDispatchInfo));
|
2020-06-10 18:47:58 +08:00
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenValidKernelsInMdiAndDisabledPremptionThenPreemptionIsDisabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
device->setPreemptionMode(PreemptionMode::Disabled);
|
|
|
|
MultiDispatchInfo multiDispatchInfo;
|
|
|
|
multiDispatchInfo.push(*dispatchInfo);
|
|
|
|
multiDispatchInfo.push(*dispatchInfo);
|
2021-09-23 06:24:59 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::Disabled, ClPreemptionHelper::taskPreemptionMode(device->getDevice(), multiDispatchInfo));
|
2020-06-10 18:47:58 +08:00
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenAtLeastOneInvalidKernelInMdiThenPreemptionIsDisabled) {
|
2021-03-22 23:26:03 +08:00
|
|
|
MockKernel schedulerKernel(program.get(), *kernelInfo, *device, true);
|
2020-11-16 19:08:30 +08:00
|
|
|
DispatchInfo schedulerDispatchInfo(device.get(), &schedulerKernel, 1, Vec3<size_t>(1, 1, 1), Vec3<size_t>(1, 1, 1), Vec3<size_t>(0, 0, 0));
|
2020-06-10 18:47:58 +08:00
|
|
|
|
|
|
|
PreemptionFlags flags = {};
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), &schedulerKernel);
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
|
|
|
|
MultiDispatchInfo multiDispatchInfo;
|
|
|
|
multiDispatchInfo.push(*dispatchInfo);
|
|
|
|
multiDispatchInfo.push(schedulerDispatchInfo);
|
|
|
|
multiDispatchInfo.push(*dispatchInfo);
|
|
|
|
|
2021-09-23 06:24:59 +08:00
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, ClPreemptionHelper::taskPreemptionMode(device->getDevice(), multiDispatchInfo));
|
2020-06-10 18:47:58 +08:00
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenMidThreadPreemptionThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = false;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowMidThreadPreemption(flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenNullKernelThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), nullptr);
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowMidThreadPreemption(flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenMidThreadPreemptionDeviceSupportPreemptionOnVmeKernelThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
|
|
|
device->sharedDeviceInfo.vmeAvcSupportsPreemption = true;
|
2021-04-08 17:05:45 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesVme = true;
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowMidThreadPreemption(flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenDisallowMidThreadPreemptionByDeviceThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::ThreadGroup);
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = false;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_TRUE(PreemptionHelper::allowMidThreadPreemption(flags));
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenDisallowMidThreadPreemptionByKernelThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = true;
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_FALSE(PreemptionHelper::allowMidThreadPreemption(flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenDisallowMidThreadPreemptionByVmeKernelThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
|
|
|
device->sharedDeviceInfo.vmeAvcSupportsPreemption = false;
|
2021-04-08 17:05:45 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesVme = true;
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
EXPECT_FALSE(PreemptionHelper::allowMidThreadPreemption(flags));
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenTaskPreemptionDisallowMidThreadByDeviceThenThreadGroupPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = false;
|
2020-06-10 18:47:58 +08:00
|
|
|
device->setPreemptionMode(PreemptionMode::ThreadGroup);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, outMode);
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenTaskPreemptionDisallowMidThreadByKernelThenThreadGroupPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = true;
|
2020-06-10 18:47:58 +08:00
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, outMode);
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenTaskPreemptionDisallowMidThreadByVmeKernelThenThreadGroupPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2021-04-08 17:05:45 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesVme = true;
|
2020-06-10 18:47:58 +08:00
|
|
|
device->sharedDeviceInfo.vmeAvcSupportsPreemption = false;
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2020-06-10 18:47:58 +08:00
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
//VME disables mid thread and thread group when device does not support it
|
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, outMode);
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenDeviceSupportsMidThreadPreemptionThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = false;
|
2020-06-10 18:47:58 +08:00
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
EXPECT_EQ(PreemptionMode::MidThread, outMode);
|
|
|
|
}
|
|
|
|
|
2020-12-22 00:48:37 +08:00
|
|
|
TEST_F(MidThreadPreemptionTests, GivenTaskPreemptionAllowDeviceSupportsPreemptionOnVmeKernelThenMidThreadPreemptionIsEnabled) {
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionFlags flags = {};
|
2020-11-19 19:30:44 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.requiresDisabledMidThreadPreemption = false;
|
2021-04-08 17:05:45 +08:00
|
|
|
kernelInfo->kernelDescriptor.kernelAttributes.flags.usesVme = true;
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2020-06-10 18:47:58 +08:00
|
|
|
device->sharedDeviceInfo.vmeAvcSupportsPreemption = true;
|
|
|
|
device->setPreemptionMode(PreemptionMode::MidThread);
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
EXPECT_EQ(PreemptionMode::MidThread, outMode);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(ThreadGroupPreemptionTests, GivenDebugKernelPreemptionWhenDeviceSupportsThreadGroupThenExpectDebugKeyMidThreadValue) {
|
|
|
|
DebugManager.flags.ForceKernelPreemptionMode.set(static_cast<int32_t>(PreemptionMode::MidThread));
|
|
|
|
|
|
|
|
EXPECT_EQ(PreemptionMode::ThreadGroup, device->getPreemptionMode());
|
|
|
|
|
|
|
|
PreemptionFlags flags = {};
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
EXPECT_EQ(PreemptionMode::MidThread, outMode);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(MidThreadPreemptionTests, GivenDebugKernelPreemptionWhenDeviceSupportsMidThreadThenExpectDebugKeyMidBatchValue) {
|
|
|
|
DebugManager.flags.ForceKernelPreemptionMode.set(static_cast<int32_t>(PreemptionMode::MidBatch));
|
|
|
|
|
|
|
|
EXPECT_EQ(PreemptionMode::MidThread, device->getPreemptionMode());
|
|
|
|
|
|
|
|
PreemptionFlags flags = {};
|
2021-03-22 23:26:03 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
2021-09-23 06:24:59 +08:00
|
|
|
ClPreemptionHelper::setPreemptionLevelFlags(flags, device->getDevice(), kernel.get());
|
2020-06-10 18:47:58 +08:00
|
|
|
PreemptionMode outMode = PreemptionHelper::taskPreemptionMode(device->getPreemptionMode(), flags);
|
|
|
|
EXPECT_EQ(PreemptionMode::MidBatch, outMode);
|
|
|
|
}
|