summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTreeHugger Robot <treehugger-gerrit@google.com>2020-01-27 16:06:27 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2020-01-27 16:06:27 +0000
commita4a8be37482d804c857f3b34ec63b0fef6415e3f (patch)
tree04ce277941030ccc50bd97026b6016632d299422
parent992ba2ddd30a0db10b511379169d0392b17d37a6 (diff)
parentd894c59881d1172f98981fa0da7a675cbd7130b8 (diff)
Merge "AImageDecoder: ensure that stride is pixel aligned"
-rw-r--r--native/graphics/jni/imagedecoder.cpp8
1 files changed, 3 insertions, 5 deletions
diff --git a/native/graphics/jni/imagedecoder.cpp b/native/graphics/jni/imagedecoder.cpp
index 79bcc15e1f0f..c1143ce9c3dc 100644
--- a/native/graphics/jni/imagedecoder.cpp
+++ b/native/graphics/jni/imagedecoder.cpp
@@ -325,11 +325,9 @@ int AImageDecoder_decodeImage(AImageDecoder* decoder,
ImageDecoder* imageDecoder = toDecoder(decoder);
- const int height = imageDecoder->getOutputInfo().height();
- const size_t minStride = AImageDecoder_getMinimumStride(decoder);
- // If this calculation were to overflow, it would have been caught in
- // setTargetSize.
- if (stride < minStride || size < stride * (height - 1) + minStride) {
+ SkImageInfo info = imageDecoder->getOutputInfo();
+ size_t minSize = info.computeByteSize(stride);
+ if (SkImageInfo::ByteSizeOverflowed(minSize) || size < minSize || !info.validRowBytes(stride)) {
return ANDROID_IMAGE_DECODER_BAD_PARAMETER;
}