Fixed bug 4838 - Use after free in SDL_JoystickUpdate (Thanks!)
parent
3ac67cf458
commit
b7ab3b3984
|
@ -1018,7 +1018,7 @@ void
|
|||
SDL_JoystickUpdate(void)
|
||||
{
|
||||
int i;
|
||||
SDL_Joystick *joystick;
|
||||
SDL_Joystick *joystick, *next;
|
||||
|
||||
if (!SDL_WasInit(SDL_INIT_JOYSTICK)) {
|
||||
return;
|
||||
|
@ -1074,7 +1074,8 @@ SDL_JoystickUpdate(void)
|
|||
SDL_updating_joystick = SDL_FALSE;
|
||||
|
||||
/* If any joysticks were closed while updating, free them here */
|
||||
for (joystick = SDL_joysticks; joystick; joystick = joystick->next) {
|
||||
for (joystick = SDL_joysticks; joystick; joystick = next) {
|
||||
next = joystick->next;
|
||||
if (joystick->ref_count <= 0) {
|
||||
SDL_JoystickClose(joystick);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue