mirror of
https://github.com/libretro/RetroArch
synced 2025-01-26 00:35:21 +00:00
Report delta times for vblank misses.
For debugging purposes, report time from PageFlip is queued, till it actually happens.
This commit is contained in:
parent
145bf19208
commit
580cf1c07e
@ -32,6 +32,7 @@
|
||||
#include <signal.h>
|
||||
#include <unistd.h>
|
||||
#include <sched.h>
|
||||
#include <sys/time.h>
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <EGL/eglext.h>
|
||||
@ -108,15 +109,14 @@ static unsigned last_page_flip;
|
||||
static uint64_t first_usec;
|
||||
static uint64_t last_usec;
|
||||
|
||||
static uint64_t flip_request_usec;
|
||||
|
||||
static unsigned missed_vblanks;
|
||||
static unsigned hit_vblanks;
|
||||
|
||||
static void page_flip_handler(int fd, unsigned frame, unsigned sec, unsigned usec, void *data)
|
||||
{
|
||||
(void)fd;
|
||||
(void)frame;
|
||||
(void)sec;
|
||||
(void)usec;
|
||||
|
||||
uint64_t current_usec = (uint64_t)sec * 1000000 + usec;
|
||||
if (!first_page_flip)
|
||||
@ -135,15 +135,16 @@ static void page_flip_handler(int fd, unsigned frame, unsigned sec, unsigned use
|
||||
RARCH_LOG("[KMS/EGL]: Missed %u VBlank(s) (Frame: %u).\n",
|
||||
missed, frame - first_page_flip);
|
||||
missed_vblanks += missed;
|
||||
|
||||
unsigned flip_time = current_usec - flip_request_usec;
|
||||
RARCH_LOG("\tDelta request => flip: %.5f ms.\n", flip_time / 1000.0);
|
||||
}
|
||||
}
|
||||
|
||||
last_page_flip = frame;
|
||||
last_usec = current_usec;
|
||||
|
||||
|
||||
bool *waiting = (bool*)data;
|
||||
*waiting = false;
|
||||
*(bool*)data = false;
|
||||
}
|
||||
|
||||
static bool waiting_for_flip;
|
||||
@ -196,6 +197,10 @@ static void queue_flip(void)
|
||||
return;
|
||||
}
|
||||
|
||||
struct timeval tv;
|
||||
gettimeofday(&tv, NULL);
|
||||
flip_request_usec = (uint64_t)tv.tv_sec * 1000000 + tv.tv_usec;
|
||||
|
||||
waiting_for_flip = true;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user