|   | 3f1fd5ab | 2023-05-23T10:59:03 |  | Updated source to match SDL function prototype style | 
            
              |   | 0d763800 | 2023-03-09T15:10:00 |  | Code style: changed "sizeof foo" to "sizeof(foo)" (thanks @sezero!)
(cherry picked from commit c6443d86c92e962683a1efe5f123a144988875b5) | 
            
              |   | 0479df53 | 2023-01-09T09:48:21 |  | Updated copyright for 2023 | 
            
              |   | a70bb259 | 2022-01-20T13:16:03 |  | drop handle parameter of OpenDevice | 
            
              |   | 1043dd8c | 2022-01-19T12:58:04 |  | adjust handling of iscapture
- drop iscapture parameter of OpenDevice
- use SDL_bool for iscapture | 
            
              |   | 0dda8a7f | 2022-01-17T11:21:01 |  | cleanup init functions of audio
- use SDL_bool if possible
- assume NULL/SDL_FALSE filled impl
- skip zfill of current_audio at the beginning of SDL_AudioInit (done before the init() calls) | 
            
              |   | 120c76c8 | 2022-01-03T09:40:00 |  | Updated copyright for 2022 | 
            
              |   | c97c4687 | 2021-10-30T15:56:54 |  | core: Convert SDL_IOReady()'s 2nd parameter to flags | 
            
              |   | 9130f7c3 | 2021-01-02T10:25:38 |  | Updated copyright for 2021 | 
            
              |   | a8780c6a | 2020-01-16T20:49:25 |  | Updated copyright date for 2020 | 
            
              |   | 5e13087b | 2019-01-04T22:01:14 |  | Updated copyright for 2019 | 
            
              |   | e3cc5b2c | 2018-01-03T10:03:25 |  | Updated copyright for 2018 | 
            
              |   | 0d011ec6 | 2017-08-28T00:22:23 |  | Renaming of guard header names to quiet -Wreserved-id-macro | 
            
              |   | fb835f9e | 2017-08-14T20:22:19 |  | Fixed bug 2330 - Debian bug report: SDL2 X11 driver buffer overflow with large X11 file descriptor
manuel.montezelo
Original bug report (note that it was against 2.0.0, it might have been fixed in between):  http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=733015
--------------------------------------------------------
Package: libsdl2-2.0-0
Version: 2.0.0+dfsg1-3
Severity: normal
Tags: patch
I have occasional crashes here caused by the X11 backend of SDL2. It seems to
be caused by the X11_Pending function trying to add a high number (> 1024)
file descriptor to a fd_set before doing a select on it to avoid busy waiting
on X11 events. This causes a buffer overflow because the file descriptor is
larger (or equal) than the limit FD_SETSIZE.
Attached is a possible workaround patch.
Please also keep in mind that fd_set are also used in following files which
may have similar problems.
src/audio/bsd/SDL_bsdaudio.c
src/audio/paudio/SDL_paudio.c
src/audio/qsa/SDL_qsa_audio.c
src/audio/sun/SDL_sunaudio.c
src/joystick/linux/SDL_sysjoystick.c
--------------------------------------------------------
On Tuesday 24 December 2013 00:43:13 Sven Eckelmann wrote:
> I have occasional crashes here caused by the X11 backend of SDL2. It seems
> to be caused by the X11_Pending function trying to add a high number (>
> 1024) file descriptor to a fd_set before doing a select on it to avoid busy
> waiting on X11 events. This causes a buffer overflow because the file
> descriptor is larger (or equal) than the limit FD_SETSIZE.
I personally experienced this problem while hacking on the python bindings
package for SDL2 [1] (while doing make runtest). But it easier to reproduce in
a smaller, synthetic testcase. | 
            
              |   | 45b774e3 | 2017-01-01T18:33:28 |  | Updated copyright for 2017 | 
            
              |   | 9492492d | 2016-12-26T01:56:52 |  | Fixed bug 3516 - fix build on illumos
Sylvain
trivial patch to fix the build on illumos
 -Werror=declaration-after-statement
https://gist.github.com/wiedi/15b71456667f7aa2a7f8815663723bb3 | 
            
              |   | 761a7978 | 2016-08-05T01:59:06 |  | audio: changed some SDL_memset() calls to SDL_zero(), other minor corrections. | 
            
              |   | 9b647727 | 2016-08-05T01:44:41 |  | audio: Clean up some CloseDevice() interface details.
- It's now always called if device->hidden isn't NULL, even if OpenDevice()
  failed halfway through. This lets implementation code not have to clean up
  itself on every possible failure point; just return an error and SDL will
  handle it for you.
- Implementations can assume this->hidden != NULL and not check for it.
- implementations don't have to set this->hidden = NULL when done, because
  the caller is always about to free(this).
- Don't reset other fields that are in a block of memory about to be free()'d.
- Implementations all now free things like internal mix buffers last, after
  closing devices and such, to guarantee they definitely aren't in use anymore
  at the point of deallocation. | 
            
              |   | 979de761 | 2016-08-05T01:44:15 |  | audio: Removed internal SDL_audiomem.h and macros.
I think this was important for SDL 1.2 because some targets needed
special device memory for DMA buffers or locked memory buffers for use in
hardware interrupts or something, but since it just defines to SDL_malloc
and SDL_free now, I took it out for clarity's sake. | 
            
              |   | 68a32728 | 2016-01-02T10:38:51 |  | Fixed sed error on Mac OS X and updated copyright on a few last files | 
            
              |   | 42065e78 | 2016-01-02T10:10:34 |  | Updated copyright to 2016 | 
            
              |   | 0e45984f | 2015-06-21T17:33:46 |  | Fixed crash if initialization of EGL failed but was tried again later.
The internal function SDL_EGL_LoadLibrary() did not delete and remove a mostly
uninitialized data structure if loading the library first failed. A later try to
use EGL then skipped initialization and assumed it was previously successful
because the data structure now already existed. This led to at least one crash
in the internal function SDL_EGL_ChooseConfig() because a NULL pointer was
dereferenced to make a call to eglBindAPI(). | 
            
              |   | 2c4a6ea0 | 2015-05-26T06:27:46 |  | Updated the copyright year to 2015 | 
            
              |   | b72938c8 | 2015-04-20T12:22:44 |  | Windows: Always set the system timer resolution to 1ms by default.
An existing hint lets apps that don't need the timer resolution changed avoid
this, to save battery, etc, but this fixes several problems in timing, audio
callbacks not firing fast enough, etc.
Fixes Bugzilla #2944. | 
            
              |   | fe6c797c | 2015-04-10T23:30:31 |  | Fixed an iOS view orientation issue when SDL_GL_CreateContext or SDL_CreateRenderer is called. | 
            
              |   | f9cfd9fa | 2015-03-18T02:01:17 |  | Bunch of reworking to how we manage audio devices.
Device enumeration now happens at startup and then is managed exclusively
through hotplugging instead of full redetection. The device name list now has
a unique "handle" associated with each item and SDL will pass this to the
backend so they don't have to figure out how a human readable name maps to
real hardware for a second time.
Other cleanups, fixes, improvements, plus all the audio backends updated to
the new interface...largely untested at this point, though. | 
            
              |   | 0e02ce08 | 2015-03-16T02:11:39 |  | Initial work on audio device hotplug support.
This fills in the core pieces and fully implements it for Mac OS X.
Most other platforms, at the moment, will report a disconnected device if
it fails to write audio, but don't notice if the system's device list changed
at all. | 
            
              |   | b88ca1b4 | 2015-02-10T16:28:56 |  | the last parameter of XChangeProperty is the number of elements.. and when the element format is 32.. the element is "long" so we have 5 long elements here.
Yes this seems confusing as on mac+linux Long is either 32 or 64bits depending on the architecture, but this is how the X11 protocol is defined. Thus 5 is the correct value for the nelts here.  Not 5 or 10 depending on the architecture.
More info on the confusion https://bugs.freedesktop.org/show_bug.cgi?id=16802 | 
            
              |   | b48e54aa | 2015-01-26T22:00:29 |  | Fixed bug 2802 - [patch] Fix android build compiling in wrong filesystem implementation
Jonas Kulla
The configure script didn't differentiate between Linux and Android, unconditionally compiling in the unix implementation of SDL_sysfilesystem.c.
I'm probably one of the very few people building SDL for android using classic configure + standalone toolchain, so this has gone undetected all along. | 
            
              |   | 70438be2 | 2014-12-03T10:55:23 |  | WinRT: fixed bug whereby SDL would override an app's default orientation
WinRT apps can set a default, preferred orientation via a .appxmanifest file.
SDL was overriding this on app startup, and making the app use all possible
orientations (landscape and portrait).
Thanks to Eric Wing for the heads up on this! | 
            
              |   | 9c398852 | 2014-11-22T22:20:40 |  | Corrected header file documentation comment. | 
            
              |   | 24c86b55 | 2014-09-11T19:24:42 |  | [X11] Reconcile logical keyboard state with physical state on FocusIn
since the window system doesn't do it for us like other platforms.
This prevents sticky keys and missed keys when going in and out
of focus, for example Alt would appear to stick if switching away
from an SDL app with Alt-Tab and had to be pressed again.
CR: Sam | 
            
              |   | 3dcb451f | 2014-04-09T21:29:19 |  | Added a README file regarding WinRT support
To note, this file is currently formatted with CRLF line endings, rather than
LF, to allow the file to be viewed with Notepad. | 
            
              |   | 58edac3e | 2014-02-02T00:53:27 |  | Fixed bug 2374 - Update copyright for 2014...
Is it that time already?? | 
            
              |   | f848adff | 2013-11-29T10:06:08 |  | Improve Android pause/resume behavior. | 
            
              |   | 7e1289af | 2013-11-24T23:56:17 |  | Make internal SDL sources include SDL_internal.h instead of SDL_config.h
The new header will include SDL_config.h, but allows for other global stuff. | 
            
              |   | f79fc33a | 2013-08-29T08:29:21 |  | Christoph Mallon: Remove pointless if (x) before SDL_free(x) | 
            
              |   | dad42067 | 2013-08-12T11:13:50 |  | Fixes #2022, do not resume on Android when surfaceChanged
If the app is in landscape mode and the user presses the power button, a pause
is followed immediately by a surfaceChanged event because the lock screen
is shown in portrait mode. This triggers a "false" resume.
So, we just pause and resume following the onWindowFocusChanged events.
Also, wait for SDL_APP_WILLENTERBACKGROUND and SDL_APP_DIDENTERBACKGROUND before
blocking the event pump. | 
            
              |   | 1ad936eb | 2013-08-11T19:56:43 |  | Fixed bug 2027 - Full-screen appears to be broken - hang in SDL_DestroyWindow()
Rainer Deyke
I'm running Linux Mint 15 with the Cinnamon window manager.  SDL_DestroyWindow consistently locks up for me when the window if fullscreen. |