mirror of
https://github.com/libretro/RetroArch
synced 2025-02-06 18:40:49 +00:00
Install sighandler for khr_display backend.
This commit is contained in:
parent
af52f1532f
commit
c561d8c4e6
@ -14,6 +14,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <signal.h>
|
||||||
#include "../../driver.h"
|
#include "../../driver.h"
|
||||||
#include "../../general.h"
|
#include "../../general.h"
|
||||||
#include "../../runloop.h"
|
#include "../../runloop.h"
|
||||||
@ -27,6 +28,14 @@ typedef struct
|
|||||||
unsigned height;
|
unsigned height;
|
||||||
} khr_display_ctx_data_t;
|
} khr_display_ctx_data_t;
|
||||||
|
|
||||||
|
static volatile sig_atomic_t g_khr_quit;
|
||||||
|
static void khr_sighandler(int sig)
|
||||||
|
{
|
||||||
|
if (g_khr_quit)
|
||||||
|
exit(1);
|
||||||
|
g_khr_quit = 1;
|
||||||
|
}
|
||||||
|
|
||||||
static void gfx_ctx_khr_display_destroy(void *data)
|
static void gfx_ctx_khr_display_destroy(void *data)
|
||||||
{
|
{
|
||||||
khr_display_ctx_data_t *khr = (khr_display_ctx_data_t*)data;
|
khr_display_ctx_data_t *khr = (khr_display_ctx_data_t*)data;
|
||||||
@ -52,6 +61,7 @@ static void gfx_ctx_khr_display_get_video_size(void *data,
|
|||||||
|
|
||||||
static void *gfx_ctx_khr_display_init(void *video_driver)
|
static void *gfx_ctx_khr_display_init(void *video_driver)
|
||||||
{
|
{
|
||||||
|
struct sigaction sa;
|
||||||
khr_display_ctx_data_t *khr = (khr_display_ctx_data_t*)calloc(1, sizeof(*khr));
|
khr_display_ctx_data_t *khr = (khr_display_ctx_data_t*)calloc(1, sizeof(*khr));
|
||||||
if (!khr)
|
if (!khr)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -62,6 +72,13 @@ static void *gfx_ctx_khr_display_init(void *video_driver)
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sa.sa_sigaction = NULL;
|
||||||
|
sa.sa_handler = khr_sighandler;
|
||||||
|
sa.sa_flags = SA_RESTART;
|
||||||
|
sigemptyset(&sa.sa_mask);
|
||||||
|
sigaction(SIGINT, &sa, NULL);
|
||||||
|
sigaction(SIGTERM, &sa, NULL);
|
||||||
|
|
||||||
return khr;
|
return khr;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -84,7 +101,7 @@ static void gfx_ctx_khr_display_check_window(void *data, bool *quit,
|
|||||||
*resize = true;
|
*resize = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (runloop_ctl(RUNLOOP_CTL_IS_SHUTDOWN, NULL))
|
if (runloop_ctl(RUNLOOP_CTL_IS_SHUTDOWN, NULL) || g_khr_quit)
|
||||||
*quit = true;
|
*quit = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user