2012-10-01 21:45:09 +02:00
/* RetroArch - A frontend for libretro.
* Copyright ( C ) 2010 - 2012 - Hans - Kristian Arntzen
* Copyright ( C ) 2011 - 2012 - Daniel De Matteis
*
* 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/>.
*/
# ifndef _RARCH_BENCHMARK_H
# define _RARCH_BENCHMARK_H
2012-10-01 23:43:16 +02:00
# include "general.h"
# ifdef HAVE_CONFIG_H
# include "config.h"
# endif
# include <stdint.h>
typedef unsigned long long rarch_perf_tick_t ;
typedef struct rarch_perf_counter
2012-10-01 21:45:09 +02:00
{
2012-10-01 23:43:16 +02:00
rarch_perf_tick_t start ;
rarch_perf_tick_t total ;
unsigned call_cnt ;
} rarch_perf_counter_t ;
rarch_perf_tick_t rarch_get_perf_counter ( void ) ;
2012-10-01 21:45:09 +02:00
2012-10-01 23:43:16 +02:00
# ifdef PERF_TEST
2012-10-01 21:45:09 +02:00
2012-10-01 23:43:16 +02:00
# define RARCH_PERFORMANCE_INIT(X) static rarch_perf_counter_t X
# define RARCH_PERFORMANCE_START(X) ((X).start = rarch_get_perf_counter())
2012-10-02 01:23:55 +02:00
# define RARCH_PERFORMANCE_STOP(X) do { (X).total += rarch_get_perf_counter() - (X).start; (X).call_cnt++; } while(0) /* TODO: we should increment at PERFORMANCE_START instead of PERFORMANCE_STOP since sometimes we cannot assume that we don't prematurely exit out of the function */
2012-10-01 22:02:20 +02:00
# ifdef _WIN32
2012-10-01 23:43:16 +02:00
# define RARCH_PERFORMANCE_LOG(functionname, X) RARCH_LOG("[PERF]: Avg (%s): %I64u ticks.\n", functionname, (X).total / (X).call_cnt)
2012-10-01 22:02:20 +02:00
# else
2012-10-01 23:43:16 +02:00
# define RARCH_PERFORMANCE_LOG(functionname, X) RARCH_LOG("[PERF]: Avg (%s): %llu ticks.\n", functionname, (X).total / (X).call_cnt)
2012-10-01 22:02:20 +02:00
# endif
2012-10-01 21:45:09 +02:00
2012-10-01 23:43:16 +02:00
# else
# define RARCH_PERFORMANCE_INIT(X)
# define RARCH_PERFORMANCE_START(X)
# define RARCH_PERFORMANCE_STOP(X)
# define RARCH_PERFORMANCE_LOG(functionname, X)
2012-10-01 21:45:09 +02:00
# endif
2012-10-01 23:43:16 +02:00
# endif