diff options
author | Moonchild <moonchild@palemoon.org> | 2020-07-09 11:22:40 +0000 |
---|---|---|
committer | Moonchild <moonchild@palemoon.org> | 2020-07-10 18:32:26 +0000 |
commit | 0c5a41e89412fb441318327157abc75c670898d5 (patch) | |
tree | b05cf8990c071f5a6bdd09f56b48a0ed4c8ccca4 /image/encoders | |
parent | e29a8bd113594a55d5087989c90317cc86d03f48 (diff) | |
download | UXP-0c5a41e89412fb441318327157abc75c670898d5.tar UXP-0c5a41e89412fb441318327157abc75c670898d5.tar.gz UXP-0c5a41e89412fb441318327157abc75c670898d5.tar.lz UXP-0c5a41e89412fb441318327157abc75c670898d5.tar.xz UXP-0c5a41e89412fb441318327157abc75c670898d5.zip |
[image] Add a sanity check to JPEG encoder buffer handling, just in case.
Diffstat (limited to 'image/encoders')
-rw-r--r-- | image/encoders/jpeg/nsJPEGEncoder.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/image/encoders/jpeg/nsJPEGEncoder.cpp b/image/encoders/jpeg/nsJPEGEncoder.cpp index 04cfef07b..e5835c295 100644 --- a/image/encoders/jpeg/nsJPEGEncoder.cpp +++ b/image/encoders/jpeg/nsJPEGEncoder.cpp @@ -8,6 +8,7 @@ #include "nsString.h" #include "nsStreamUtils.h" #include "gfxColor.h" +#include "mozilla/CheckedInt.h" #include <setjmp.h> #include "jerror.h" @@ -430,10 +431,14 @@ nsJPEGEncoder::emptyOutputBuffer(jpeg_compress_struct* cinfo) that->mImageBufferUsed = that->mImageBufferSize; // expand buffer, just double size each time - that->mImageBufferSize *= 2; + uint8_t* newBuf = nullptr; + CheckedInt<uint32_t> bufSize = + CheckedInt<uint32_t>(that->mImageBufferSize) * 2; + if (bufSize.isValid()) { + that->mImageBufferSize = bufSize.value(); + newBuf = (uint8_t*)realloc(that->mImageBuffer, that->mImageBufferSize); + } - uint8_t* newBuf = (uint8_t*)realloc(that->mImageBuffer, - that->mImageBufferSize); if (!newBuf) { // can't resize, just zero (this will keep us from writing more) free(that->mImageBuffer); |