2016-05-10 08:53:14 +02:00
|
|
|
/* RetroArch - A frontend for libretro.
|
|
|
|
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
|
2017-03-22 03:09:18 +01:00
|
|
|
* Copyright (C) 2011-2017 - Daniel De Matteis
|
2016-05-10 08:53:14 +02:00
|
|
|
*
|
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
|
|
|
* of the GNU General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2016-05-11 00:26:31 +02:00
|
|
|
#ifdef _WIN32
|
|
|
|
#include <direct.h>
|
|
|
|
#else
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
|
2016-09-01 18:01:41 +02:00
|
|
|
#include <compat/strl.h>
|
2016-05-10 20:31:27 +02:00
|
|
|
|
2016-05-10 08:53:14 +02:00
|
|
|
#include "performance_counters.h"
|
|
|
|
|
2017-05-11 09:11:46 +02:00
|
|
|
#include "retroarch.h"
|
2016-05-10 08:53:14 +02:00
|
|
|
#include "verbosity.h"
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
#define PERF_LOG_FMT "[PERF]: Avg (%s): %I64u ticks, %I64u runs.\n"
|
|
|
|
#else
|
|
|
|
#define PERF_LOG_FMT "[PERF]: Avg (%s): %llu ticks, %llu runs.\n"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static struct retro_perf_counter *perf_counters_rarch[MAX_COUNTERS];
|
|
|
|
static struct retro_perf_counter *perf_counters_libretro[MAX_COUNTERS];
|
|
|
|
static unsigned perf_ptr_rarch;
|
|
|
|
static unsigned perf_ptr_libretro;
|
|
|
|
|
|
|
|
struct retro_perf_counter **retro_get_perf_counter_rarch(void)
|
|
|
|
{
|
|
|
|
return perf_counters_rarch;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct retro_perf_counter **retro_get_perf_counter_libretro(void)
|
|
|
|
{
|
|
|
|
return perf_counters_libretro;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned retro_get_perf_count_rarch(void)
|
|
|
|
{
|
|
|
|
return perf_ptr_rarch;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned retro_get_perf_count_libretro(void)
|
|
|
|
{
|
|
|
|
return perf_ptr_libretro;
|
|
|
|
}
|
|
|
|
|
|
|
|
void rarch_perf_register(struct retro_perf_counter *perf)
|
|
|
|
{
|
|
|
|
if (
|
2017-05-15 05:06:23 +02:00
|
|
|
!rarch_ctl(RARCH_CTL_IS_PERFCNT_ENABLE, NULL)
|
2016-05-10 08:53:14 +02:00
|
|
|
|| perf->registered
|
|
|
|
|| perf_ptr_rarch >= MAX_COUNTERS
|
|
|
|
)
|
|
|
|
return;
|
|
|
|
|
|
|
|
perf_counters_rarch[perf_ptr_rarch++] = perf;
|
|
|
|
perf->registered = true;
|
|
|
|
}
|
|
|
|
|
2016-05-16 10:03:31 +02:00
|
|
|
void performance_counter_register(struct retro_perf_counter *perf)
|
2016-05-10 08:53:14 +02:00
|
|
|
{
|
|
|
|
if (perf->registered || perf_ptr_libretro >= MAX_COUNTERS)
|
|
|
|
return;
|
|
|
|
|
|
|
|
perf_counters_libretro[perf_ptr_libretro++] = perf;
|
|
|
|
perf->registered = true;
|
|
|
|
}
|
|
|
|
|
2016-05-16 10:00:50 +02:00
|
|
|
void performance_counters_clear(void)
|
2016-05-10 08:53:14 +02:00
|
|
|
{
|
|
|
|
perf_ptr_libretro = 0;
|
|
|
|
memset(perf_counters_libretro, 0, sizeof(perf_counters_libretro));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void log_counters(struct retro_perf_counter **counters, unsigned num)
|
|
|
|
{
|
|
|
|
unsigned i;
|
|
|
|
for (i = 0; i < num; i++)
|
|
|
|
{
|
|
|
|
if (counters[i]->call_cnt)
|
|
|
|
{
|
|
|
|
RARCH_LOG(PERF_LOG_FMT,
|
|
|
|
counters[i]->ident,
|
2017-09-05 16:39:12 -04:00
|
|
|
(uint64_t)counters[i]->total /
|
|
|
|
(uint64_t)counters[i]->call_cnt,
|
|
|
|
(uint64_t)counters[i]->call_cnt);
|
2016-05-10 08:53:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void rarch_perf_log(void)
|
|
|
|
{
|
2017-05-15 05:06:23 +02:00
|
|
|
if (!rarch_ctl(RARCH_CTL_IS_PERFCNT_ENABLE, NULL))
|
2016-05-10 08:53:14 +02:00
|
|
|
return;
|
|
|
|
|
|
|
|
RARCH_LOG("[PERF]: Performance counters (RetroArch):\n");
|
|
|
|
log_counters(perf_counters_rarch, perf_ptr_rarch);
|
|
|
|
}
|
|
|
|
|
|
|
|
void retro_perf_log(void)
|
|
|
|
{
|
|
|
|
RARCH_LOG("[PERF]: Performance counters (libretro):\n");
|
|
|
|
log_counters(perf_counters_libretro, perf_ptr_libretro);
|
|
|
|
}
|
|
|
|
|
2016-12-23 15:36:47 +01:00
|
|
|
void rarch_timer_tick(rarch_timer_t *timer)
|
|
|
|
{
|
|
|
|
if (!timer)
|
|
|
|
return;
|
|
|
|
timer->current = cpu_features_get_time_usec();
|
|
|
|
timer->timeout = (timer->timeout_end - timer->current) / 1000000;
|
|
|
|
}
|
|
|
|
|
2016-12-23 19:17:38 +01:00
|
|
|
int rarch_timer_get_timeout(rarch_timer_t *timer)
|
|
|
|
{
|
|
|
|
if (!timer)
|
|
|
|
return 0;
|
2017-02-26 10:33:03 +01:00
|
|
|
return (int)timer->timeout;
|
2016-12-23 19:17:38 +01:00
|
|
|
}
|
|
|
|
|
2016-12-23 15:36:47 +01:00
|
|
|
bool rarch_timer_is_running(rarch_timer_t *timer)
|
|
|
|
{
|
|
|
|
if (!timer)
|
|
|
|
return false;
|
|
|
|
return timer->timer_begin;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool rarch_timer_has_expired(rarch_timer_t *timer)
|
|
|
|
{
|
2016-12-23 16:32:21 +01:00
|
|
|
if (!timer || timer->timeout <= 0)
|
2016-12-23 15:36:47 +01:00
|
|
|
return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void rarch_timer_end(rarch_timer_t *timer)
|
|
|
|
{
|
|
|
|
if (!timer)
|
|
|
|
return;
|
|
|
|
timer->timer_end = true;
|
|
|
|
timer->timer_begin = false;
|
|
|
|
timer->timeout_end = 0;
|
|
|
|
}
|
|
|
|
|
2016-12-23 19:17:38 +01:00
|
|
|
void rarch_timer_begin_new_time(rarch_timer_t *timer, uint64_t sec)
|
2016-12-23 15:36:47 +01:00
|
|
|
{
|
|
|
|
if (!timer)
|
|
|
|
return;
|
|
|
|
timer->timeout_end = cpu_features_get_time_usec() + sec * 1000000;
|
2016-12-23 19:17:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void rarch_timer_begin(rarch_timer_t *timer, uint64_t sec)
|
|
|
|
{
|
|
|
|
if (!timer)
|
|
|
|
return;
|
|
|
|
rarch_timer_begin_new_time(timer, sec);
|
2016-12-23 15:36:47 +01:00
|
|
|
timer->timer_begin = true;
|
|
|
|
timer->timer_end = false;
|
|
|
|
}
|