2020-03-06 11:09:57 +01:00
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2019-2020 Intel Corporation
|
|
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2020-03-22 08:52:57 +01:00
|
|
|
#include "level_zero/tools/source/sysman/linux/os_sysman_imp.h"
|
2020-03-06 11:09:57 +01:00
|
|
|
|
2020-03-19 12:36:29 -04:00
|
|
|
#include "level_zero/tools/source/sysman/linux/fs_access.h"
|
2020-03-06 11:09:57 +01:00
|
|
|
|
|
|
|
|
namespace L0 {
|
|
|
|
|
|
|
|
|
|
ze_result_t LinuxSysmanImp::init() {
|
2020-03-19 12:36:29 -04:00
|
|
|
pFsAccess = FsAccess::create();
|
|
|
|
|
UNRECOVERABLE_IF(nullptr == pFsAccess);
|
|
|
|
|
|
|
|
|
|
pProcfsAccess = ProcfsAccess::create();
|
|
|
|
|
UNRECOVERABLE_IF(nullptr == pProcfsAccess);
|
|
|
|
|
|
2020-03-06 11:09:57 +01:00
|
|
|
Device *pDevice = Device::fromHandle(pParentSysmanImp->hCoreDevice);
|
|
|
|
|
NEO::OSInterface &OsInterface = pDevice->getOsInterface();
|
|
|
|
|
NEO::Drm *pDrm = OsInterface.get()->getDrm();
|
2020-03-19 12:36:29 -04:00
|
|
|
int myDeviceFd = pDrm->getFileDescriptor();
|
|
|
|
|
std::string myDeviceName;
|
|
|
|
|
ze_result_t result = pProcfsAccess->getFileName(pProcfsAccess->myProcessId(), myDeviceFd, myDeviceName);
|
|
|
|
|
if (ZE_RESULT_SUCCESS != result) {
|
|
|
|
|
return result;
|
|
|
|
|
}
|
2020-03-06 11:09:57 +01:00
|
|
|
|
2020-03-19 12:36:29 -04:00
|
|
|
pSysfsAccess = SysfsAccess::create(myDeviceName);
|
2020-03-06 11:09:57 +01:00
|
|
|
UNRECOVERABLE_IF(nullptr == pSysfsAccess);
|
2020-03-19 12:36:29 -04:00
|
|
|
|
2020-03-06 11:09:57 +01:00
|
|
|
return ZE_RESULT_SUCCESS;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-19 12:36:29 -04:00
|
|
|
FsAccess &LinuxSysmanImp::getFsAccess() {
|
|
|
|
|
UNRECOVERABLE_IF(nullptr == pFsAccess);
|
|
|
|
|
return *pFsAccess;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ProcfsAccess &LinuxSysmanImp::getProcfsAccess() {
|
|
|
|
|
UNRECOVERABLE_IF(nullptr == pProcfsAccess);
|
|
|
|
|
return *pProcfsAccess;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-06 11:09:57 +01:00
|
|
|
SysfsAccess &LinuxSysmanImp::getSysfsAccess() {
|
|
|
|
|
UNRECOVERABLE_IF(nullptr == pSysfsAccess);
|
|
|
|
|
return *pSysfsAccess;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-19 12:36:29 -04:00
|
|
|
LinuxSysmanImp::LinuxSysmanImp(SysmanImp *pParentSysmanImp) {
|
|
|
|
|
this->pParentSysmanImp = pParentSysmanImp;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-06 11:09:57 +01:00
|
|
|
LinuxSysmanImp::~LinuxSysmanImp() {
|
|
|
|
|
if (nullptr != pSysfsAccess) {
|
|
|
|
|
delete pSysfsAccess;
|
|
|
|
|
}
|
2020-03-19 12:36:29 -04:00
|
|
|
if (nullptr != pProcfsAccess) {
|
|
|
|
|
delete pProcfsAccess;
|
|
|
|
|
}
|
|
|
|
|
if (nullptr != pFsAccess) {
|
|
|
|
|
delete pFsAccess;
|
|
|
|
|
}
|
2020-03-06 11:09:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
OsSysman *OsSysman::create(SysmanImp *pParentSysmanImp) {
|
|
|
|
|
LinuxSysmanImp *pLinuxSysmanImp = new LinuxSysmanImp(pParentSysmanImp);
|
|
|
|
|
return static_cast<OsSysman *>(pLinuxSysmanImp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace L0
|