2018-01-08 11:07:46 +08:00
|
|
|
/*
|
2019-02-27 18:39:32 +08:00
|
|
|
* Copyright (C) 2018-2019 Intel Corporation
|
2018-01-08 11:07:46 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2018-01-08 11:07:46 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "unit_tests/fixtures/preemption_fixture.h"
|
|
|
|
|
|
|
|
#include "runtime/command_queue/enqueue_common.h"
|
|
|
|
#include "runtime/command_queue/enqueue_kernel.h"
|
|
|
|
#include "runtime/command_queue/enqueue_marker.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "runtime/command_stream/preemption.h"
|
2018-01-08 11:07:46 +08:00
|
|
|
#include "runtime/helpers/dispatch_info.h"
|
|
|
|
#include "runtime/helpers/hw_info.h"
|
|
|
|
#include "runtime/scheduler/scheduler_kernel.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "test.h"
|
2018-01-08 11:07:46 +08:00
|
|
|
#include "unit_tests/fixtures/hello_world_fixture.h"
|
|
|
|
#include "unit_tests/helpers/hw_parse.h"
|
|
|
|
#include "unit_tests/mocks/mock_command_queue.h"
|
|
|
|
#include "unit_tests/mocks/mock_context.h"
|
|
|
|
#include "unit_tests/mocks/mock_device.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "unit_tests/mocks/mock_kernel.h"
|
2018-01-08 11:07:46 +08:00
|
|
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
using namespace OCLRT;
|
|
|
|
|
|
|
|
DevicePreemptionTests::DevicePreemptionTests() = default;
|
|
|
|
DevicePreemptionTests::~DevicePreemptionTests() = default;
|
|
|
|
|
|
|
|
void DevicePreemptionTests::SetUp() {
|
|
|
|
if (dbgRestore == nullptr) {
|
|
|
|
dbgRestore.reset(new DebugManagerStateRestore());
|
|
|
|
}
|
|
|
|
const cl_queue_properties properties[3] = {CL_QUEUE_PROPERTIES, 0, 0};
|
2018-08-16 20:28:58 +08:00
|
|
|
kernelInfo = std::make_unique<KernelInfo>();
|
2018-07-03 16:00:12 +08:00
|
|
|
device.reset(MockDevice::createWithNewExecutionEnvironment<MockDevice>(nullptr));
|
2018-01-08 11:07:46 +08:00
|
|
|
context.reset(new MockContext(device.get()));
|
|
|
|
cmdQ.reset(new MockCommandQueue(context.get(), device.get(), properties));
|
|
|
|
executionEnvironment.reset(new SPatchExecutionEnvironment);
|
|
|
|
memset(executionEnvironment.get(), 0, sizeof(SPatchExecutionEnvironment));
|
|
|
|
kernelInfo->patchInfo.executionEnvironment = executionEnvironment.get();
|
2018-08-06 15:46:57 +08:00
|
|
|
program = std::make_unique<MockProgram>(*device->getExecutionEnvironment());
|
2018-01-08 11:07:46 +08:00
|
|
|
kernel.reset(new MockKernel(program.get(), *kernelInfo, *device));
|
|
|
|
dispatchInfo.reset(new DispatchInfo(kernel.get(), 1, Vec3<size_t>(1, 1, 1), Vec3<size_t>(1, 1, 1), Vec3<size_t>(0, 0, 0)));
|
|
|
|
|
|
|
|
ASSERT_NE(nullptr, device);
|
|
|
|
ASSERT_NE(nullptr, context);
|
|
|
|
ASSERT_NE(nullptr, cmdQ);
|
|
|
|
forceWhitelistedRegs(true);
|
|
|
|
waTable = const_cast<WorkaroundTable *>(device->getWaTable());
|
|
|
|
}
|
|
|
|
|
|
|
|
void DevicePreemptionTests::TearDown() {
|
|
|
|
dbgRestore.reset();
|
|
|
|
kernel.reset();
|
|
|
|
kernelInfo.reset();
|
|
|
|
dispatchInfo.reset();
|
|
|
|
cmdQ.reset();
|
|
|
|
context.reset();
|
|
|
|
device.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
void DevicePreemptionTests::forceWhitelistedRegs(bool whitelisted) {
|
|
|
|
WhitelistedRegisters forceRegs = {whitelisted};
|
|
|
|
device->setForceWhitelistedRegs(true, &forceRegs);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadGroupPreemptionEnqueueKernelTest::SetUp() {
|
2018-01-12 21:18:53 +08:00
|
|
|
dbgRestore.reset(new DebugManagerStateRestore());
|
|
|
|
DebugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::ThreadGroup));
|
|
|
|
|
2018-01-08 11:07:46 +08:00
|
|
|
globalHwInfo = const_cast<HardwareInfo *>(platformDevices[0]);
|
|
|
|
originalPreemptionMode = globalHwInfo->capabilityTable.defaultPreemptionMode;
|
|
|
|
globalHwInfo->capabilityTable.defaultPreemptionMode = PreemptionMode::ThreadGroup;
|
|
|
|
|
|
|
|
HelloWorldFixture::SetUp();
|
|
|
|
pDevice->setPreemptionMode(PreemptionMode::ThreadGroup);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadGroupPreemptionEnqueueKernelTest::TearDown() {
|
|
|
|
globalHwInfo->capabilityTable.defaultPreemptionMode = originalPreemptionMode;
|
|
|
|
|
|
|
|
HelloWorldFixture::TearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
void MidThreadPreemptionEnqueueKernelTest::SetUp() {
|
2018-01-12 21:18:53 +08:00
|
|
|
dbgRestore.reset(new DebugManagerStateRestore());
|
|
|
|
DebugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::MidThread));
|
|
|
|
|
2018-01-08 11:07:46 +08:00
|
|
|
globalHwInfo = const_cast<HardwareInfo *>(platformDevices[0]);
|
|
|
|
originalPreemptionMode = globalHwInfo->capabilityTable.defaultPreemptionMode;
|
|
|
|
globalHwInfo->capabilityTable.defaultPreemptionMode = PreemptionMode::MidThread;
|
|
|
|
|
|
|
|
HelloWorldFixture::SetUp();
|
|
|
|
pDevice->setPreemptionMode(PreemptionMode::MidThread);
|
|
|
|
}
|
|
|
|
|
|
|
|
void MidThreadPreemptionEnqueueKernelTest::TearDown() {
|
|
|
|
globalHwInfo->capabilityTable.defaultPreemptionMode = originalPreemptionMode;
|
|
|
|
|
|
|
|
HelloWorldFixture::TearDown();
|
|
|
|
}
|