1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
/*
* Copyright (C) 2018-2024 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/os_interface/linux/device_time_drm.h"
#include "shared/source/debug_settings/debug_settings_manager.h"
#include "shared/source/helpers/register_offsets.h"
#include "shared/source/os_interface/linux/drm_neo.h"
#include "shared/source/os_interface/linux/drm_wrappers.h"
#include "shared/source/os_interface/linux/ioctl_helper.h"
#include "shared/source/os_interface/os_interface.h"
#include <time.h>
namespace NEO {
DeviceTimeDrm::DeviceTimeDrm(OSInterface &osInterface) {
pDrm = osInterface.getDriverModel()->as<Drm>();
}
TimeQueryStatus DeviceTimeDrm::getGpuCpuTimeImpl(TimeStampData *pGpuCpuTime, OSTime *osTime) {
if (!pDrm->getIoctlHelper()->setGpuCpuTimes(pGpuCpuTime, osTime)) {
if (pDrm->getErrno() == EOPNOTSUPP) {
return TimeQueryStatus::unsupportedFeature;
} else {
return TimeQueryStatus::deviceLost;
}
}
return TimeQueryStatus::success;
}
double DeviceTimeDrm::getDynamicDeviceTimerResolution() const {
if (pDrm) {
int frequency = 0;
auto error = pDrm->getTimestampFrequency(frequency);
if (!error) {
return nanosecondsPerSecond / frequency;
}
}
return OSTime::getDeviceTimerResolution();
}
uint64_t DeviceTimeDrm::getDynamicDeviceTimerClock() const {
if (pDrm) {
int frequency = 0;
auto error = pDrm->getTimestampFrequency(frequency);
if (!error) {
return static_cast<uint64_t>(frequency);
}
}
return static_cast<uint64_t>(nanosecondsPerSecond / OSTime::getDeviceTimerResolution());
}
bool DeviceTimeDrm::isTimestampsRefreshEnabled() const {
bool timestampsRefreshEnabled = pDrm->getIoctlHelper()->isTimestampsRefreshEnabled();
if (debugManager.flags.EnableReusingGpuTimestamps.get() != -1) {
timestampsRefreshEnabled = debugManager.flags.EnableReusingGpuTimestamps.get();
}
return timestampsRefreshEnabled;
}
} // namespace NEO
|