2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2019-02-27 18:39:32 +08:00
|
|
|
* Copyright (C) 2017-2019 Intel Corporation
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2019-02-27 18:39:32 +08:00
|
|
|
#include "runtime/os_interface/linux/drm_neo.h"
|
2017-12-21 07:45:38 +08:00
|
|
|
#include "runtime/os_interface/os_time.h"
|
|
|
|
|
|
|
|
#define OCLRT_NUM_TIMESTAMP_BITS (36)
|
|
|
|
#define OCLRT_NUM_TIMESTAMP_BITS_FALLBACK (32)
|
|
|
|
#define TIMESTAMP_HIGH_REG 0x0235C
|
|
|
|
#define TIMESTAMP_LOW_REG 0x02358
|
|
|
|
|
|
|
|
namespace OCLRT {
|
|
|
|
|
|
|
|
class OSTimeLinux : public OSTime {
|
|
|
|
public:
|
|
|
|
OSTimeLinux(OSInterface *osInterface);
|
|
|
|
~OSTimeLinux() override;
|
|
|
|
bool getCpuTime(uint64_t *timeStamp) override;
|
|
|
|
bool getCpuGpuTime(TimeStampData *pGpuCpuTime) override;
|
|
|
|
typedef bool (OSTimeLinux::*TimestampFunction)(uint64_t *);
|
|
|
|
void timestampTypeDetect();
|
2018-08-08 20:19:43 +08:00
|
|
|
TimestampFunction getGpuTime = nullptr;
|
2017-12-21 07:45:38 +08:00
|
|
|
bool getGpuTime32(uint64_t *timestamp);
|
|
|
|
bool getGpuTime36(uint64_t *timestamp);
|
|
|
|
bool getGpuTimeSplitted(uint64_t *timestamp);
|
|
|
|
double getHostTimerResolution() const override;
|
|
|
|
double getDynamicDeviceTimerResolution(HardwareInfo const &hwInfo) const override;
|
|
|
|
uint64_t getCpuRawTimestamp() override;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
typedef int (*resolutionFunc_t)(clockid_t, struct timespec *);
|
|
|
|
typedef int (*getTimeFunc_t)(clockid_t, struct timespec *);
|
|
|
|
Drm *pDrm;
|
|
|
|
unsigned timestampSizeInBits;
|
|
|
|
resolutionFunc_t resolutionFunc;
|
|
|
|
getTimeFunc_t getTimeFunc;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace OCLRT
|