From 197b14de4a613f15714d252a0a316909fccb1676 Mon Sep 17 00:00:00 2001 From: David Ludwig Date: Mon, 16 Mar 2020 19:24:25 -0400 Subject: [PATCH] Fixed Bug 5034 - Replugging in a controller crashes on macOS in SDL 2.0.12 The Darwin/macOS joystick driver was freeing its joystick's hwdata field without zeroing it out in any live instance of SDL_Joystick. --- src/joystick/darwin/SDL_sysjoystick.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/src/joystick/darwin/SDL_sysjoystick.c b/src/joystick/darwin/SDL_sysjoystick.c index 44d41365f..786b94fec 100644 --- a/src/joystick/darwin/SDL_sysjoystick.c +++ b/src/joystick/darwin/SDL_sysjoystick.c @@ -125,6 +125,7 @@ static recDevice * FreeDevice(recDevice *removeDevice) { recDevice *pDeviceNext = NULL; + SDL_Joystick *joystick = NULL; if (removeDevice) { if (removeDevice->deviceRef) { IOHIDDeviceUnscheduleFromRunLoop(removeDevice->deviceRef, CFRunLoopGetCurrent(), SDL_JOYSTICK_RUNLOOP_MODE); @@ -146,6 +147,14 @@ FreeDevice(recDevice *removeDevice) } removeDevice->pNext = NULL; + /* clear out any reference to this recDevice that are being + * held by a live instance of SDL_Joystick + */ + joystick = SDL_JoystickFromInstanceID(removeDevice->instance_id); + if (joystick) { + joystick->hwdata = NULL; + } + /* free element lists */ FreeElementList(removeDevice->firstAxis); FreeElementList(removeDevice->firstButton); @@ -871,6 +880,10 @@ DARWIN_JoystickRumble(SDL_Joystick * joystick, Uint16 low_frequency_rumble, Uint /* Scale and average the two rumble strengths */ Sint16 magnitude = (Sint16)(((low_frequency_rumble / 2) + (high_frequency_rumble / 2)) / 2); + if (!device) { + return SDL_SetError("Rumble failed, device disconnected"); + } + if (!device->ffservice) { return SDL_Unsupported(); }