2020-05-18 20:23:44 +01:00
|
|
|
#if defined (__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2020-05-18 19:39:33 +01:00
|
|
|
|
2020-05-18 23:22:56 +01:00
|
|
|
#define _POSIX_C_SOURCE 199309L
|
|
|
|
|
2020-05-18 19:39:33 +01:00
|
|
|
#include "map.h"
|
|
|
|
|
2020-05-18 23:22:56 +01:00
|
|
|
#include <time.h>
|
|
|
|
|
2020-05-18 19:39:33 +01:00
|
|
|
#define MILLION 1000000.0
|
|
|
|
|
|
|
|
#define MAX_FUNCTIONS 8192
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
map funcDatabase;
|
2020-05-18 23:22:56 +01:00
|
|
|
uint32_t frameCounter;
|
2020-05-18 19:39:33 +01:00
|
|
|
} profiler;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
char* funcName; //stores function name
|
|
|
|
double timeSpent; //stores time spent in function in milliseconds
|
2020-05-18 23:22:56 +01:00
|
|
|
struct timespec start; //for timekeeping
|
2020-05-18 19:39:33 +01:00
|
|
|
uint32_t inProgress;
|
|
|
|
} funcData;
|
|
|
|
|
|
|
|
void initProfiler();
|
|
|
|
void startMeasure(void* func, const char* funcName);
|
2020-05-18 23:22:56 +01:00
|
|
|
void endMeasure(void* func);
|
|
|
|
void endFrame();
|
2020-05-18 19:39:33 +01:00
|
|
|
double getTimeSpent(void* func);
|
|
|
|
void profilePrintResults();
|
2020-05-18 23:22:56 +01:00
|
|
|
|
2020-05-18 20:23:44 +01:00
|
|
|
#if defined (__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|