2021-05-20 19:49:44 +02:00
|
|
|
/*
|
2023-01-27 12:45:12 +00:00
|
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
2021-05-20 19:49:44 +02:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
#include "shared/source/os_interface/os_time.h"
|
|
|
|
|
|
|
|
|
|
namespace NEO {
|
2023-01-27 12:45:12 +00:00
|
|
|
class Drm;
|
2021-05-20 19:49:44 +02:00
|
|
|
|
|
|
|
|
class DeviceTimeDrm : public DeviceTime {
|
|
|
|
|
public:
|
|
|
|
|
DeviceTimeDrm(OSInterface *osInterface);
|
|
|
|
|
bool getCpuGpuTime(TimeStampData *pGpuCpuTime, OSTime *osTime) override;
|
|
|
|
|
typedef bool (DeviceTimeDrm::*TimestampFunction)(uint64_t *);
|
|
|
|
|
void timestampTypeDetect();
|
|
|
|
|
TimestampFunction getGpuTime = nullptr;
|
|
|
|
|
bool getGpuTime32(uint64_t *timestamp);
|
|
|
|
|
bool getGpuTime36(uint64_t *timestamp);
|
|
|
|
|
bool getGpuTimeSplitted(uint64_t *timestamp);
|
|
|
|
|
double getDynamicDeviceTimerResolution(HardwareInfo const &hwInfo) const override;
|
|
|
|
|
uint64_t getDynamicDeviceTimerClock(HardwareInfo const &hwInfo) const override;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
Drm *pDrm = nullptr;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace NEO
|