2021-09-17 22:01:53 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <util/types.hpp>
|
2022-03-06 13:12:29 +01:00
|
|
|
#include "time.hpp"
|
2021-09-17 22:01:53 +02:00
|
|
|
|
|
|
|
|
namespace rsx
|
|
|
|
|
{
|
|
|
|
|
struct profiling_timer
|
|
|
|
|
{
|
|
|
|
|
bool enabled = false;
|
2022-03-06 13:12:29 +01:00
|
|
|
u64 last;
|
2021-09-17 22:01:53 +02:00
|
|
|
|
|
|
|
|
profiling_timer() = default;
|
|
|
|
|
|
|
|
|
|
void start()
|
|
|
|
|
{
|
|
|
|
|
if (enabled) [[unlikely]]
|
|
|
|
|
{
|
2022-03-06 13:12:29 +01:00
|
|
|
last = rsx::uclock();
|
2021-09-17 22:01:53 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
s64 duration()
|
|
|
|
|
{
|
|
|
|
|
if (!enabled) [[likely]]
|
|
|
|
|
{
|
|
|
|
|
return 0ll;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auto old = last;
|
2022-03-06 13:12:29 +01:00
|
|
|
last = rsx::uclock();
|
|
|
|
|
return static_cast<s64>(last - old);
|
2021-09-17 22:01:53 +02:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|