From: Stanislav Malyshev Date: Tue, 8 Dec 2015 07:30:49 +0000 (-0800) Subject: Fix bug #70976: fix boundary check on gdImageRotateInterpolated X-Git-Tag: php-5.5.31~7 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4bb422343f29f06b7081323844d9b52e1a71e4a5;p=php Fix bug #70976: fix boundary check on gdImageRotateInterpolated --- diff --git a/NEWS b/NEWS index d2a2f95b9a..d9fcf14df4 100644 --- a/NEWS +++ b/NEWS @@ -4,6 +4,10 @@ PHP NEWS ?? ??? 2015, PHP 5.5.31 +- GD: + . Fixed bug #70976 (Memory Read via gdImageRotateInterpolated Array Index + Out of Bounds). (emmanuel dot law at gmail dot com). + 01 Oct 2015, PHP 5.5.30 - Phar: diff --git a/ext/gd/libgd/gd_interpolation.c b/ext/gd/libgd/gd_interpolation.c index 65e2360776..efb584c1e4 100644 --- a/ext/gd/libgd/gd_interpolation.c +++ b/ext/gd/libgd/gd_interpolation.c @@ -2154,7 +2154,7 @@ gdImagePtr gdImageRotateInterpolated(const gdImagePtr src, const float angle, in { const int angle_rounded = (int)floor(angle * 100); - if (bgcolor < 0) { + if (bgcolor < 0 || bgcolor >= gdMaxColors) { return NULL; } diff --git a/ext/gd/tests/bug70976.phpt b/ext/gd/tests/bug70976.phpt new file mode 100644 index 0000000000..23af4eedc7 --- /dev/null +++ b/ext/gd/tests/bug70976.phpt @@ -0,0 +1,13 @@ +--TEST-- +Bug #70976 (Memory Read via gdImageRotateInterpolated Array Index Out of Bounds) +--SKIPIF-- + +--FILE-- + +--EXPECTF-- +bool(false) \ No newline at end of file