You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I came across what I think is a bug in a 32 bit CI build for another library: If SDL is built with support for XInput2, but the shared library is not available on the run-time system, then you get a crash, for example, here, because the function pointer is null. I only came across this as we had missed the 32 bit version of the libxi-dev package, but since the 64 bit version was installed the build system (modified some from the base SDL build system) detected that XInput2 was available (since it found the 64 bit version) but when running the 32 bit executable, it could not load the library (as there was no 32 bit version installed).
I don't know if it is actually a sane setup to be missing libxi or not, but since it seems SDL can be built for X11 without it, I suppose it might be. The Github Actions runner running with xvfb-run for the "display" is hardly a representative use case, so I don't really know what would be expected on a normal system. I just know that I encountered this crash when upgrading SDL versions, and it seems like it's still present in master (the older version of SDL didn't have the XInput2 specific code).
If it is reasonable for users to not have libxi installed, I think there need to be runtime checks for the functions availability, or they need to be replaced with functions that fall back to the non-XInput2 functions. E.g. for this
This specifically fixes a crash in X11_WarpMouseInternal if XInput2 was
missing at runtime, but also cleans up a few other existing checks.
Fixes#8378.
(cherry picked from commit 82f54af)
(cherry picked from commit 2849ca4)
This specifically fixes a crash in X11_WarpMouseInternal if XInput2 was
missing at runtime, but also cleans up a few other existing checks.
Fixes#8378.
(cherry picked from commit 82f54af)
This specifically fixes a crash in X11_WarpMouseInternal if XInput2 was
missing at runtime, but also cleans up a few other existing checks.
Fixeslibsdl-org#8378.
I came across what I think is a bug in a 32 bit CI build for another library: If SDL is built with support for XInput2, but the shared library is not available on the run-time system, then you get a crash, for example, here, because the function pointer is null. I only came across this as we had missed the 32 bit version of the libxi-dev package, but since the 64 bit version was installed the build system (modified some from the base SDL build system) detected that XInput2 was available (since it found the 64 bit version) but when running the 32 bit executable, it could not load the library (as there was no 32 bit version installed).
I don't know if it is actually a sane setup to be missing libxi or not, but since it seems SDL can be built for X11 without it, I suppose it might be. The Github Actions runner running with
xvfb-run
for the "display" is hardly a representative use case, so I don't really know what would be expected on a normal system. I just know that I encountered this crash when upgrading SDL versions, and it seems like it's still present in master (the older version of SDL didn't have the XInput2 specific code).For more details on the crash, you can refer to my comment here
u3d-community/U3D#4 (comment)
If it is reasonable for users to not have libxi installed, I think there need to be runtime checks for the functions availability, or they need to be replaced with functions that fall back to the non-XInput2 functions. E.g. for this
we would have fallen back to something like
X11_XIGetClientPointer = //lambda setting deviceid to 0
X11_XIWarpPointer = [](...) { X11_XWarpPointer(.../*args dropping deviceid*/); }
The text was updated successfully, but these errors were encountered: