check for too-large rowBytes

BUG=446164

Review URL: https://codereview.chromium.org/871993003
This commit is contained in:
reed 2015-01-23 07:51:14 -08:00 committed by Commit bot
parent fb35940de7
commit 2ff257bd95
2 changed files with 18 additions and 3 deletions

View File

@ -56,8 +56,9 @@ SkMallocPixelRef* SkMallocPixelRef::NewAllocate(const SkImageInfo& info,
return NULL;
}
int32_t minRB = SkToS32(info.minRowBytes());
if (minRB < 0) {
// only want to permit 31bits of rowBytes
int64_t minRB = (int64_t)info.minRowBytes64();
if (minRB < 0 || !sk_64_isS32(minRB)) {
return NULL; // allocation will be too large
}
if (requestedRowBytes > 0 && (int32_t)requestedRowBytes < minRB) {

View File

@ -6,9 +6,22 @@
*/
#include "SkBitmap.h"
#include "SkMallocPixelRef.h"
#include "Test.h"
// https://code.google.com/p/chromium/issues/detail?id=446164
static void test_bigalloc(skiatest::Reporter* reporter) {
const int width = 0x40000001;
const int height = 0x00000096;
const SkImageInfo info = SkImageInfo::MakeN32Premul(width, height);
SkBitmap bm;
REPORTER_ASSERT(reporter, !bm.tryAllocPixels(info));
SkPixelRef* pr = SkMallocPixelRef::NewAllocate(info, info.minRowBytes(), NULL);
REPORTER_ASSERT(reporter, !pr);
}
static void test_allocpixels(skiatest::Reporter* reporter) {
const int width = 10;
const int height = 10;
@ -81,4 +94,5 @@ DEF_TEST(Bitmap, reporter) {
test_bigwidth(reporter);
test_allocpixels(reporter);
test_bigalloc(reporter);
}