From 8b64e5df1a127d9b471d6fbc47f91a265803ed07 Mon Sep 17 00:00:00 2001 From: Lars Brinkhoff Date: Mon, 24 Feb 2020 20:59:07 +0100 Subject: [PATCH] VIDEO: SDL init/quit gamecontroller subsystem implies joystick. --- sim_video.c | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/sim_video.c b/sim_video.c index a4fedf4e..482346be 100644 --- a/sim_video.c +++ b/sim_video.c @@ -564,19 +564,24 @@ static t_stat vid_init_controllers (void) vid_gamepad_ok = (ver.major > 2 || (ver.major == 2 && (ver.minor > 0 || ver.patch >= 4))); - SDL_InitSubSystem(SDL_INIT_JOYSTICK); if (vid_gamepad_ok) SDL_InitSubSystem(SDL_INIT_GAMECONTROLLER); + else + SDL_InitSubSystem(SDL_INIT_JOYSTICK); if (SDL_JoystickEventState (SDL_ENABLE) < 0) { - SDL_QuitSubSystem(SDL_INIT_JOYSTICK); - SDL_QuitSubSystem(SDL_INIT_GAMECONTROLLER); + if (vid_gamepad_ok) + SDL_QuitSubSystem(SDL_INIT_GAMECONTROLLER); + else + SDL_QuitSubSystem(SDL_INIT_JOYSTICK); return SCPE_IOERR; } if (vid_gamepad_ok && SDL_GameControllerEventState (SDL_ENABLE) < 0) { - SDL_QuitSubSystem(SDL_INIT_JOYSTICK); - SDL_QuitSubSystem(SDL_INIT_GAMECONTROLLER); + if (vid_gamepad_ok) + SDL_QuitSubSystem(SDL_INIT_GAMECONTROLLER); + else + SDL_QuitSubSystem(SDL_INIT_JOYSTICK); return SCPE_IOERR; } @@ -661,8 +666,10 @@ if (vid_active) { vid_gamepad_inited = 0; memset (motion_callback, 0, sizeof motion_callback); memset (button_callback, 0, sizeof button_callback); - SDL_QuitSubSystem(SDL_INIT_JOYSTICK); - SDL_QuitSubSystem(SDL_INIT_GAMECONTROLLER); + if (vid_gamepad_ok) + SDL_QuitSubSystem(SDL_INIT_GAMECONTROLLER); + else + SDL_QuitSubSystem(SDL_INIT_JOYSTICK); vid_active = FALSE; if (vid_ready) {