mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-10 04:35:30 +00:00
Keep track of maximum number of events in-flight in the SDL queue at once.
This commit is contained in:
parent
3f9f0027bc
commit
87ef19c44a
|
@ -75,12 +75,13 @@ static struct
|
||||||
SDL_mutex *lock;
|
SDL_mutex *lock;
|
||||||
volatile SDL_bool active;
|
volatile SDL_bool active;
|
||||||
volatile int count;
|
volatile int count;
|
||||||
|
volatile int max_events_seen;
|
||||||
SDL_EventEntry *head;
|
SDL_EventEntry *head;
|
||||||
SDL_EventEntry *tail;
|
SDL_EventEntry *tail;
|
||||||
SDL_EventEntry *free;
|
SDL_EventEntry *free;
|
||||||
SDL_SysWMEntry *wmmsg_used;
|
SDL_SysWMEntry *wmmsg_used;
|
||||||
SDL_SysWMEntry *wmmsg_free;
|
SDL_SysWMEntry *wmmsg_free;
|
||||||
} SDL_EventQ = { NULL, SDL_TRUE };
|
} SDL_EventQ = { NULL, SDL_TRUE, 0, 0, NULL, NULL, NULL, NULL, NULL };
|
||||||
|
|
||||||
|
|
||||||
/* Public functions */
|
/* Public functions */
|
||||||
|
@ -88,6 +89,7 @@ static struct
|
||||||
void
|
void
|
||||||
SDL_StopEventLoop(void)
|
SDL_StopEventLoop(void)
|
||||||
{
|
{
|
||||||
|
const char *report = SDL_GetHint("SDL_EVENT_QUEUE_STATISTICS");
|
||||||
int i;
|
int i;
|
||||||
SDL_EventEntry *entry;
|
SDL_EventEntry *entry;
|
||||||
SDL_SysWMEntry *wmmsg;
|
SDL_SysWMEntry *wmmsg;
|
||||||
|
@ -98,6 +100,11 @@ SDL_StopEventLoop(void)
|
||||||
|
|
||||||
SDL_EventQ.active = SDL_FALSE;
|
SDL_EventQ.active = SDL_FALSE;
|
||||||
|
|
||||||
|
if (report && SDL_atoi(report)) {
|
||||||
|
SDL_Log("SDL EVENT QUEUE: Maximum events in-flight: %d\n",
|
||||||
|
SDL_EventQ.max_events_seen);
|
||||||
|
}
|
||||||
|
|
||||||
/* Clean out EventQ */
|
/* Clean out EventQ */
|
||||||
for (entry = SDL_EventQ.head; entry; ) {
|
for (entry = SDL_EventQ.head; entry; ) {
|
||||||
SDL_EventEntry *next = entry->next;
|
SDL_EventEntry *next = entry->next;
|
||||||
|
@ -119,7 +126,9 @@ SDL_StopEventLoop(void)
|
||||||
SDL_free(wmmsg);
|
SDL_free(wmmsg);
|
||||||
wmmsg = next;
|
wmmsg = next;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_EventQ.count = 0;
|
SDL_EventQ.count = 0;
|
||||||
|
SDL_EventQ.max_events_seen = 0;
|
||||||
SDL_EventQ.head = NULL;
|
SDL_EventQ.head = NULL;
|
||||||
SDL_EventQ.tail = NULL;
|
SDL_EventQ.tail = NULL;
|
||||||
SDL_EventQ.free = NULL;
|
SDL_EventQ.free = NULL;
|
||||||
|
@ -218,6 +227,10 @@ SDL_AddEvent(SDL_Event * event)
|
||||||
}
|
}
|
||||||
++SDL_EventQ.count;
|
++SDL_EventQ.count;
|
||||||
|
|
||||||
|
if (SDL_EventQ.count > SDL_EventQ.max_events_seen) {
|
||||||
|
SDL_EventQ.max_events_seen = SDL_EventQ.count;
|
||||||
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue