2022-05-09 15:52:12 +00:00
|
|
|
/*
|
2024-12-12 13:26:54 +00:00
|
|
|
* Copyright (C) 2022-2024 Intel Corporation
|
2022-05-09 15:52:12 +00:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2023-10-23 23:35:40 +00:00
|
|
|
#include "level_zero/tools/source/debug/linux/drm_helper.h"
|
2022-05-09 15:52:12 +00:00
|
|
|
|
|
|
|
|
#include "shared/source/os_interface/linux/drm_neo.h"
|
2023-01-23 14:55:52 +00:00
|
|
|
#include "shared/source/os_interface/linux/engine_info.h"
|
|
|
|
|
#include "shared/source/os_interface/linux/ioctl_helper.h"
|
2022-05-09 15:52:12 +00:00
|
|
|
|
2022-05-25 17:05:52 +00:00
|
|
|
#include "level_zero/core/source/device/device.h"
|
|
|
|
|
|
2022-05-09 15:52:12 +00:00
|
|
|
namespace L0 {
|
|
|
|
|
|
2022-05-25 17:05:52 +00:00
|
|
|
int DrmHelper::ioctl(Device *device, NEO::DrmIoctl request, void *arg) {
|
2022-05-09 15:52:12 +00:00
|
|
|
auto drm = device->getOsInterface().getDriverModel()->as<NEO::Drm>();
|
2022-06-29 16:49:29 +00:00
|
|
|
return drm->getIoctlHelper()->ioctl(request, arg);
|
2022-05-09 15:52:12 +00:00
|
|
|
}
|
|
|
|
|
|
2024-12-12 13:26:54 +00:00
|
|
|
std::string DrmHelper::getSysFsPciPath(Device *device) {
|
|
|
|
|
auto drm = device->getOsInterface().getDriverModel()->as<NEO::Drm>();
|
|
|
|
|
return drm->getSysFsPciPath();
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-09 15:52:12 +00:00
|
|
|
int DrmHelper::getErrno(Device *device) {
|
|
|
|
|
auto drm = device->getOsInterface().getDriverModel()->as<NEO::Drm>();
|
|
|
|
|
return drm->getErrno();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
uint32_t DrmHelper::getEngineTileIndex(Device *device, const NEO::EngineClassInstance &engine) {
|
|
|
|
|
auto drm = device->getOsInterface().getDriverModel()->as<NEO::Drm>();
|
|
|
|
|
auto engineInfo = drm->getEngineInfo();
|
|
|
|
|
return engineInfo->getEngineTileIndex(engine);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const NEO::EngineClassInstance *DrmHelper::getEngineInstance(Device *device, uint32_t tile, aub_stream::EngineType engineType) {
|
|
|
|
|
auto drm = device->getOsInterface().getDriverModel()->as<NEO::Drm>();
|
|
|
|
|
auto engineInfo = drm->getEngineInfo();
|
|
|
|
|
return engineInfo->getEngineInstance(tile, engineType);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace L0
|