/* * Copyright (C) 2023 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "shared/source/helpers/basic_math.h" #include "level_zero/sysman/source/os_sysman.h" #include "level_zero/sysman/source/ras/ras_imp.h" namespace L0 { namespace Sysman { void RasHandleContext::releaseRasHandles() { for (Ras *pRas : handleList) { delete pRas; } handleList.clear(); } RasHandleContext::~RasHandleContext() { releaseRasHandles(); } void RasHandleContext::createHandle(zes_ras_error_type_t type, ze_bool_t isSubDevice, uint32_t subDeviceId) { Ras *pRas = new RasImp(pOsSysman, type, isSubDevice, subDeviceId); handleList.push_back(pRas); } void RasHandleContext::init(uint32_t subDeviceCount) { const auto isSubDevice = (subDeviceCount > 0); uint32_t subDeviceCountLimit = (isSubDevice) ? subDeviceCount - 1 : 0; for (uint32_t subDeviceId = 0; subDeviceId <= subDeviceCountLimit; subDeviceId++) { std::set errorTypeSubDev = {}; OsRas::getSupportedRasErrorTypes(errorTypeSubDev, pOsSysman, isSubDevice, subDeviceId); int32_t typeId = 0; for (const auto &type : errorTypeSubDev) { createHandle(type, isSubDevice, subDeviceId); typeId++; } } } ze_result_t RasHandleContext::rasGet(uint32_t *pCount, zes_ras_handle_t *phRas) { std::call_once(initRasOnce, [this]() { this->init(pOsSysman->getSubDeviceCount()); this->rasInitDone = true; }); uint32_t handleListSize = static_cast(handleList.size()); uint32_t numToCopy = std::min(*pCount, handleListSize); if (0 == *pCount || *pCount > handleListSize) { *pCount = handleListSize; } if (nullptr != phRas) { for (uint32_t i = 0; i < numToCopy; i++) { phRas[i] = handleList[i]->toHandle(); } } return ZE_RESULT_SUCCESS; } } // namespace Sysman } // namespace L0