mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-31 03:20:47 +08:00
Related-To: LOCI-4227 Signed-off-by: Joshua Santosh Ranjan <joshua.santosh.ranjan@intel.com>
73 lines
2.7 KiB
C++
73 lines
2.7 KiB
C++
/*
|
|
* Copyright (C) 2020-2023 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "level_zero/sysman/source/firmware/linux/os_firmware_imp.h"
|
|
|
|
#include "shared/source/helpers/string.h"
|
|
|
|
#include "level_zero/sysman/source/firmware_util/firmware_util.h"
|
|
#include "level_zero/sysman/source/linux/fs_access.h"
|
|
#include "level_zero/sysman/source/sysman_const.h"
|
|
|
|
#include <algorithm>
|
|
|
|
namespace L0 {
|
|
namespace Sysman {
|
|
|
|
static const std::string mtdDescriptor("/proc/mtd");
|
|
|
|
ze_result_t OsFirmware::getSupportedFwTypes(std::vector<std::string> &supportedFwTypes, OsSysman *pOsSysman) {
|
|
LinuxSysmanImp *pLinuxSysmanImp = static_cast<LinuxSysmanImp *>(pOsSysman);
|
|
FirmwareUtil *pFwInterface = pLinuxSysmanImp->getFwUtilInterface();
|
|
std::vector<std ::string> deviceSupportedFwTypes;
|
|
if (pFwInterface != nullptr) {
|
|
pFwInterface->getDeviceSupportedFwTypes(deviceSupportedFwTypes);
|
|
}
|
|
|
|
FsAccess *pFsAccess = &pLinuxSysmanImp->getFsAccess();
|
|
std::vector<std::string> mtdDescriptorStrings = {};
|
|
ze_result_t result = pFsAccess->read(mtdDescriptor, mtdDescriptorStrings);
|
|
if (result != ZE_RESULT_SUCCESS) {
|
|
return result;
|
|
}
|
|
for (const auto &readByteLine : mtdDescriptorStrings) {
|
|
for (const auto &fwType : deviceSupportedFwTypes) {
|
|
if (std::string::npos != readByteLine.find(fwType)) {
|
|
if (std::find(supportedFwTypes.begin(), supportedFwTypes.end(), fwType) == supportedFwTypes.end()) {
|
|
supportedFwTypes.push_back(fwType);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return ZE_RESULT_SUCCESS;
|
|
}
|
|
|
|
void LinuxFirmwareImp::osGetFwProperties(zes_firmware_properties_t *pProperties) {
|
|
if (ZE_RESULT_SUCCESS != getFirmwareVersion(osFwType, pProperties)) {
|
|
strncpy_s(static_cast<char *>(pProperties->version), ZES_STRING_PROPERTY_SIZE, unknown.c_str(), ZES_STRING_PROPERTY_SIZE - 1);
|
|
}
|
|
pProperties->canControl = true; // Assuming that user has permission to flash the firmware
|
|
}
|
|
|
|
ze_result_t LinuxFirmwareImp::osFirmwareFlash(void *pImage, uint32_t size) {
|
|
return pFwInterface->flashFirmware(osFwType, pImage, size);
|
|
}
|
|
|
|
LinuxFirmwareImp::LinuxFirmwareImp(OsSysman *pOsSysman, const std::string &fwType) : osFwType(fwType) {
|
|
LinuxSysmanImp *pLinuxSysmanImp = static_cast<LinuxSysmanImp *>(pOsSysman);
|
|
pSysfsAccess = &pLinuxSysmanImp->getSysfsAccess();
|
|
pFwInterface = pLinuxSysmanImp->getFwUtilInterface();
|
|
}
|
|
|
|
std::unique_ptr<OsFirmware> OsFirmware::create(OsSysman *pOsSysman, const std::string &fwType) {
|
|
std::unique_ptr<LinuxFirmwareImp> pLinuxFirmwareImp = std::make_unique<LinuxFirmwareImp>(pOsSysman, fwType);
|
|
return pLinuxFirmwareImp;
|
|
}
|
|
|
|
} // namespace Sysman
|
|
} // namespace L0
|