mirror of
https://github.com/webmproject/libwebp.git
synced 2025-01-15 17:18:23 +01:00
gifdec,Remap: avoid out of bounds colormap read
make this function return success/failure. an empty map or out of bounds read is treated as an error. BUG=webp:316 Change-Id: Ic8651836915ea4dd8e0dc81ca8d5d3f247be1ff8
This commit is contained in:
parent
4595e01fd0
commit
cac9a36a23
@ -81,20 +81,27 @@ int GIFReadGraphicsExtension(const GifByteType* const buf, int* const duration,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Remap(const GifFileType* const gif, const uint8_t* const src,
|
static int Remap(const GifFileType* const gif, const uint8_t* const src,
|
||||||
int len, int transparent_index, uint32_t* dst) {
|
int len, int transparent_index, uint32_t* dst) {
|
||||||
int i;
|
int i;
|
||||||
const GifColorType* colors;
|
const GifColorType* colors;
|
||||||
const ColorMapObject* const cmap =
|
const ColorMapObject* const cmap =
|
||||||
gif->Image.ColorMap ? gif->Image.ColorMap : gif->SColorMap;
|
gif->Image.ColorMap ? gif->Image.ColorMap : gif->SColorMap;
|
||||||
if (cmap == NULL) return;
|
if (cmap == NULL) return 1;
|
||||||
|
if (cmap->Colors == NULL || cmap->ColorCount <= 0) return 0;
|
||||||
colors = cmap->Colors;
|
colors = cmap->Colors;
|
||||||
|
|
||||||
for (i = 0; i < len; ++i) {
|
for (i = 0; i < len; ++i) {
|
||||||
const GifColorType c = colors[src[i]];
|
if (src[i] == transparent_index) {
|
||||||
dst[i] = (src[i] == transparent_index) ? GIF_TRANSPARENT_COLOR
|
dst[i] = GIF_TRANSPARENT_COLOR;
|
||||||
: c.Blue | (c.Green << 8) | (c.Red << 16) | (0xffu << 24);
|
} else if (src[i] < cmap->ColorCount) {
|
||||||
|
const GifColorType c = colors[src[i]];
|
||||||
|
dst[i] = c.Blue | (c.Green << 8) | (c.Red << 16) | (0xffu << 24);
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int GIFReadFrame(GifFileType* const gif, int transparent_index,
|
int GIFReadFrame(GifFileType* const gif, int transparent_index,
|
||||||
@ -139,7 +146,7 @@ int GIFReadFrame(GifFileType* const gif, int transparent_index,
|
|||||||
const size_t jump = interlace_jumps[pass] * stride;
|
const size_t jump = interlace_jumps[pass] * stride;
|
||||||
for (; y < rect.height; y += interlace_jumps[pass], row += jump) {
|
for (; y < rect.height; y += interlace_jumps[pass], row += jump) {
|
||||||
if (DGifGetLine(gif, tmp, rect.width) == GIF_ERROR) goto End;
|
if (DGifGetLine(gif, tmp, rect.width) == GIF_ERROR) goto End;
|
||||||
Remap(gif, tmp, rect.width, transparent_index, row);
|
if (!Remap(gif, tmp, rect.width, transparent_index, row)) goto End;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else { // Non-interlaced image.
|
} else { // Non-interlaced image.
|
||||||
@ -147,7 +154,7 @@ int GIFReadFrame(GifFileType* const gif, int transparent_index,
|
|||||||
uint32_t* ptr = dst;
|
uint32_t* ptr = dst;
|
||||||
for (y = 0; y < rect.height; ++y, ptr += sub_image.argb_stride) {
|
for (y = 0; y < rect.height; ++y, ptr += sub_image.argb_stride) {
|
||||||
if (DGifGetLine(gif, tmp, rect.width) == GIF_ERROR) goto End;
|
if (DGifGetLine(gif, tmp, rect.width) == GIF_ERROR) goto End;
|
||||||
Remap(gif, tmp, rect.width, transparent_index, ptr);
|
if (!Remap(gif, tmp, rect.width, transparent_index, ptr)) goto End;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ok = 1;
|
ok = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user