forked from jengelh/SDL2
Accepting request 535102 from home:sreeves1:branches:games
fix for bnc1062784 OBS-URL: https://build.opensuse.org/request/show/535102 OBS-URL: https://build.opensuse.org/package/show/games/SDL2?expand=0&rev=66
This commit is contained in:
parent
32d3b82a1b
commit
dd6f816a78
47
SDL-bnc1062784-check-overflow-xcf-props.patch
Normal file
47
SDL-bnc1062784-check-overflow-xcf-props.patch
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
# Based on upstream patch: 81a4950907a01359f2f9390875291eb3951e6c6b
|
||||||
|
|
||||||
|
Index: SDL2-2.0.6/include/SDL_stdinc.h
|
||||||
|
===================================================================
|
||||||
|
--- SDL2-2.0.6.orig/include/SDL_stdinc.h
|
||||||
|
+++ SDL2-2.0.6/include/SDL_stdinc.h
|
||||||
|
@@ -162,6 +162,7 @@ typedef uint16_t Uint16;
|
||||||
|
/**
|
||||||
|
* \brief A signed 32-bit integer type.
|
||||||
|
*/
|
||||||
|
+#define SDL_MAX_SINT32 ((Sint32)0x7FFFFFFF) /* 2147483647 */
|
||||||
|
typedef int32_t Sint32;
|
||||||
|
/**
|
||||||
|
* \brief An unsigned 32-bit integer type.
|
||||||
|
Index: SDL2-2.0.6/src/video/SDL_surface.c
|
||||||
|
===================================================================
|
||||||
|
--- SDL2-2.0.6.orig/src/video/SDL_surface.c
|
||||||
|
+++ SDL2-2.0.6/src/video/SDL_surface.c
|
||||||
|
@@ -26,6 +26,10 @@
|
||||||
|
#include "SDL_RLEaccel_c.h"
|
||||||
|
#include "SDL_pixels_c.h"
|
||||||
|
|
||||||
|
+/* Check to make sure we can safely check multiplication of surface w and pitch and it won't overflow size_t */
|
||||||
|
+SDL_COMPILE_TIME_ASSERT(surface_size_assumptions,
|
||||||
|
+ sizeof(int) == sizeof(Sint32) && sizeof(size_t) >= sizeof(Sint32));
|
||||||
|
+
|
||||||
|
/* Public routines */
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ -80,7 +84,16 @@ SDL_CreateRGBSurfaceWithFormat(Uint32 fl
|
||||||
|
|
||||||
|
/* Get the pixels */
|
||||||
|
if (surface->w && surface->h) {
|
||||||
|
- surface->pixels = SDL_malloc(surface->h * surface->pitch);
|
||||||
|
+ /* Assumptions checked in surface_size_assumptions assert above */
|
||||||
|
+ Sint64 size = ((Sint64)surface->h * surface->pitch);
|
||||||
|
+ if (size < 0 || size > SDL_MAX_SINT32) {
|
||||||
|
+ /* Overflow... */
|
||||||
|
+ SDL_FreeSurface(surface);
|
||||||
|
+ SDL_OutOfMemory();
|
||||||
|
+ return NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ surface->pixels = SDL_malloc((size_t)size);
|
||||||
|
if (!surface->pixels) {
|
||||||
|
SDL_FreeSurface(surface);
|
||||||
|
SDL_OutOfMemory();
|
@ -1,3 +1,8 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Oct 19 04:00:09 UTC 2017 - sreeves@suse.com
|
||||||
|
|
||||||
|
- Add SDL-bnc1062784-check-overflow-xcf-props.patch. CVE-2017-2888
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Mon Oct 16 16:31:47 UTC 2017 - wbauer@tmo.at
|
Mon Oct 16 16:31:47 UTC 2017 - wbauer@tmo.at
|
||||||
|
|
||||||
|
@ -32,6 +32,8 @@ Source3: %name.keyring
|
|||||||
Source4: baselibs.conf
|
Source4: baselibs.conf
|
||||||
Patch1: dbus.diff
|
Patch1: dbus.diff
|
||||||
Patch2: %name-ppc64-declaration-after-statement.patch
|
Patch2: %name-ppc64-declaration-after-statement.patch
|
||||||
|
# PATCH-FIX-UPSTREAM SDL-bnc1062784-check-overflow-xcf-props.patch sreeves@suse.com - CVE-2017-2888. Check for overflow when computing size.
|
||||||
|
Patch3: SDL-bnc1062784-check-overflow-xcf-props.patch
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
BuildRequires: cmake
|
BuildRequires: cmake
|
||||||
BuildRequires: dos2unix
|
BuildRequires: dos2unix
|
||||||
@ -109,6 +111,7 @@ library.
|
|||||||
%ifarch ppc64 ppc64le
|
%ifarch ppc64 ppc64le
|
||||||
%patch -P 2 -p1
|
%patch -P 2 -p1
|
||||||
%endif
|
%endif
|
||||||
|
%patch -P 3 -p1
|
||||||
dos2unix WhatsNew.txt
|
dos2unix WhatsNew.txt
|
||||||
dos2unix TODO.txt
|
dos2unix TODO.txt
|
||||||
dos2unix BUGS.txt
|
dos2unix BUGS.txt
|
||||||
|
Loading…
Reference in New Issue
Block a user