WebPPictureHasTransparency: add missing pointer check

in the case of use_argb, alpha_offset may be non-zero which would cause
the null pointer check in CheckNonOpaque to pass

fixes a potential crash with invalid width/height set or an integer
sanitizer warning when passing a zeroed picture:
src/enc/picture_csp_enc.c:73:57: runtime error: applying non-zero offset
3 to null pointer

Change-Id: I9d499bba12c65ad5c65d8f9f3c8ee9298ac6081a
This commit is contained in:
James Zern 2022-08-08 16:40:21 -07:00
parent 866e349cef
commit 1a6c109c99

View File

@ -70,9 +70,12 @@ int WebPPictureHasTransparency(const WebPPicture* picture) {
if (picture == NULL) return 0; if (picture == NULL) return 0;
if (picture->use_argb) { if (picture->use_argb) {
const int alpha_offset = ALPHA_OFFSET; const int alpha_offset = ALPHA_OFFSET;
return CheckNonOpaque((const uint8_t*)picture->argb + alpha_offset, if (picture->argb != NULL) {
picture->width, picture->height, return CheckNonOpaque((const uint8_t*)picture->argb + alpha_offset,
4, picture->argb_stride * sizeof(*picture->argb)); picture->width, picture->height,
4, picture->argb_stride * sizeof(*picture->argb));
}
return 0;
} }
return CheckNonOpaque(picture->a, picture->width, picture->height, return CheckNonOpaque(picture->a, picture->width, picture->height,
1, picture->a_stride); 1, picture->a_stride);