2020-04-09 18:19:35 +08:00
|
|
|
/*
|
2022-10-11 22:09:50 +08:00
|
|
|
* Copyright (C) 2020-2022 Intel Corporation
|
2020-04-09 18:19:35 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "scheduler_imp.h"
|
|
|
|
|
|
|
|
#include "shared/source/helpers/debug_helpers.h"
|
|
|
|
|
2020-09-16 13:54:22 +08:00
|
|
|
#include "level_zero/tools/source/sysman/sysman_const.h"
|
2022-11-28 19:55:07 +08:00
|
|
|
#include "level_zero/tools/source/sysman/sysman_imp.h"
|
2020-04-09 18:19:35 +08:00
|
|
|
|
2020-09-16 13:54:22 +08:00
|
|
|
namespace L0 {
|
2020-05-07 01:10:49 +08:00
|
|
|
|
2020-07-31 18:34:29 +08:00
|
|
|
ze_result_t SchedulerImp::setExclusiveMode(ze_bool_t *pNeedReload) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->setExclusiveMode(pNeedReload);
|
2020-07-31 18:34:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
ze_result_t SchedulerImp::setComputeUnitDebugMode(ze_bool_t *pNeedReload) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->setComputeUnitDebugMode(pNeedReload);
|
2020-07-31 18:34:29 +08:00
|
|
|
}
|
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
ze_result_t SchedulerImp::getCurrentMode(zes_sched_mode_t *pMode) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->getCurrentMode(pMode);
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
ze_result_t SchedulerImp::getTimeoutModeProperties(ze_bool_t getDefaults, zes_sched_timeout_properties_t *pConfig) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->getTimeoutModeProperties(getDefaults, pConfig);
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
ze_result_t SchedulerImp::getTimesliceModeProperties(ze_bool_t getDefaults, zes_sched_timeslice_properties_t *pConfig) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->getTimesliceModeProperties(getDefaults, pConfig);
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-07-31 18:34:29 +08:00
|
|
|
ze_result_t SchedulerImp::setTimeoutMode(zes_sched_timeout_properties_t *pProperties, ze_bool_t *pNeedReload) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->setTimeoutMode(pProperties, pNeedReload);
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-07-31 18:34:29 +08:00
|
|
|
ze_result_t SchedulerImp::setTimesliceMode(zes_sched_timeslice_properties_t *pProperties, ze_bool_t *pNeedReload) {
|
2022-11-01 23:59:58 +08:00
|
|
|
return pOsScheduler->setTimesliceMode(pProperties, pNeedReload);
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-07-31 18:34:29 +08:00
|
|
|
ze_result_t SchedulerImp::schedulerGetProperties(zes_sched_properties_t *pProperties) {
|
|
|
|
*pProperties = properties;
|
|
|
|
return ZE_RESULT_SUCCESS;
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-07-31 18:34:29 +08:00
|
|
|
void SchedulerImp::init() {
|
2020-08-25 19:38:10 +08:00
|
|
|
pOsScheduler->getProperties(this->properties);
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
|
2020-09-23 09:38:48 +08:00
|
|
|
SchedulerImp::SchedulerImp(OsSysman *pOsSysman, zes_engine_type_flag_t engineType, std::vector<std::string> &listOfEngines, ze_device_handle_t deviceHandle) {
|
2022-11-28 19:55:07 +08:00
|
|
|
uint32_t subdeviceId = std::numeric_limits<uint32_t>::max();
|
|
|
|
ze_bool_t onSubdevice = false;
|
|
|
|
SysmanDeviceImp::getSysmanDeviceInfo(deviceHandle, subdeviceId, onSubdevice, true);
|
|
|
|
pOsScheduler = OsScheduler::create(pOsSysman, engineType, listOfEngines, onSubdevice, subdeviceId);
|
2020-06-10 10:29:07 +08:00
|
|
|
UNRECOVERABLE_IF(nullptr == pOsScheduler);
|
2020-07-31 18:34:29 +08:00
|
|
|
init();
|
|
|
|
};
|
2020-04-09 18:19:35 +08:00
|
|
|
|
|
|
|
SchedulerImp::~SchedulerImp() {
|
|
|
|
if (nullptr != pOsScheduler) {
|
|
|
|
delete pOsScheduler;
|
2020-05-07 01:10:49 +08:00
|
|
|
pOsScheduler = nullptr;
|
2020-04-09 18:19:35 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-07 01:10:49 +08:00
|
|
|
} // namespace L0
|