mirror of
https://github.com/webmproject/libwebp.git
synced 2025-01-15 17:18:23 +01:00
dec/webp: use GetLE(24|32) from utils
picks up the undefined behavior fix from the previous commit BUG=278 Change-Id: Ie17bf7db827b1dc564194aadcf6c5e47f61681f7
This commit is contained in:
parent
f1694481a9
commit
912c9fdf0c
@ -16,6 +16,7 @@
|
|||||||
#include "./vp8i.h"
|
#include "./vp8i.h"
|
||||||
#include "./vp8li.h"
|
#include "./vp8li.h"
|
||||||
#include "./webpi.h"
|
#include "./webpi.h"
|
||||||
|
#include "../utils/utils.h"
|
||||||
#include "../webp/mux_types.h" // ALPHA_FLAG
|
#include "../webp/mux_types.h" // ALPHA_FLAG
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
@ -43,14 +44,6 @@
|
|||||||
// All sizes are in little-endian order.
|
// All sizes are in little-endian order.
|
||||||
// Note: chunk data size must be padded to multiple of 2 when written.
|
// Note: chunk data size must be padded to multiple of 2 when written.
|
||||||
|
|
||||||
static WEBP_INLINE uint32_t get_le24(const uint8_t* const data) {
|
|
||||||
return data[0] | (data[1] << 8) | (data[2] << 16);
|
|
||||||
}
|
|
||||||
|
|
||||||
static WEBP_INLINE uint32_t get_le32(const uint8_t* const data) {
|
|
||||||
return (uint32_t)get_le24(data) | (data[3] << 24);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Validates the RIFF container (if detected) and skips over it.
|
// Validates the RIFF container (if detected) and skips over it.
|
||||||
// If a RIFF container is detected, returns:
|
// If a RIFF container is detected, returns:
|
||||||
// VP8_STATUS_BITSTREAM_ERROR for invalid header,
|
// VP8_STATUS_BITSTREAM_ERROR for invalid header,
|
||||||
@ -70,7 +63,7 @@ static VP8StatusCode ParseRIFF(const uint8_t** const data,
|
|||||||
if (memcmp(*data + 8, "WEBP", TAG_SIZE)) {
|
if (memcmp(*data + 8, "WEBP", TAG_SIZE)) {
|
||||||
return VP8_STATUS_BITSTREAM_ERROR; // Wrong image file signature.
|
return VP8_STATUS_BITSTREAM_ERROR; // Wrong image file signature.
|
||||||
} else {
|
} else {
|
||||||
const uint32_t size = get_le32(*data + TAG_SIZE);
|
const uint32_t size = GetLE32(*data + TAG_SIZE);
|
||||||
// Check that we have at least one chunk (i.e "WEBP" + "VP8?nnnn").
|
// Check that we have at least one chunk (i.e "WEBP" + "VP8?nnnn").
|
||||||
if (size < TAG_SIZE + CHUNK_HEADER_SIZE) {
|
if (size < TAG_SIZE + CHUNK_HEADER_SIZE) {
|
||||||
return VP8_STATUS_BITSTREAM_ERROR;
|
return VP8_STATUS_BITSTREAM_ERROR;
|
||||||
@ -116,7 +109,7 @@ static VP8StatusCode ParseVP8X(const uint8_t** const data,
|
|||||||
if (!memcmp(*data, "VP8X", TAG_SIZE)) {
|
if (!memcmp(*data, "VP8X", TAG_SIZE)) {
|
||||||
int width, height;
|
int width, height;
|
||||||
uint32_t flags;
|
uint32_t flags;
|
||||||
const uint32_t chunk_size = get_le32(*data + TAG_SIZE);
|
const uint32_t chunk_size = GetLE32(*data + TAG_SIZE);
|
||||||
if (chunk_size != VP8X_CHUNK_SIZE) {
|
if (chunk_size != VP8X_CHUNK_SIZE) {
|
||||||
return VP8_STATUS_BITSTREAM_ERROR; // Wrong chunk size.
|
return VP8_STATUS_BITSTREAM_ERROR; // Wrong chunk size.
|
||||||
}
|
}
|
||||||
@ -125,9 +118,9 @@ static VP8StatusCode ParseVP8X(const uint8_t** const data,
|
|||||||
if (*data_size < vp8x_size) {
|
if (*data_size < vp8x_size) {
|
||||||
return VP8_STATUS_NOT_ENOUGH_DATA; // Insufficient data.
|
return VP8_STATUS_NOT_ENOUGH_DATA; // Insufficient data.
|
||||||
}
|
}
|
||||||
flags = get_le32(*data + 8);
|
flags = GetLE32(*data + 8);
|
||||||
width = 1 + get_le24(*data + 12);
|
width = 1 + GetLE24(*data + 12);
|
||||||
height = 1 + get_le24(*data + 15);
|
height = 1 + GetLE24(*data + 15);
|
||||||
if (width * (uint64_t)height >= MAX_IMAGE_AREA) {
|
if (width * (uint64_t)height >= MAX_IMAGE_AREA) {
|
||||||
return VP8_STATUS_BITSTREAM_ERROR; // image is too large
|
return VP8_STATUS_BITSTREAM_ERROR; // image is too large
|
||||||
}
|
}
|
||||||
@ -181,7 +174,7 @@ static VP8StatusCode ParseOptionalChunks(const uint8_t** const data,
|
|||||||
return VP8_STATUS_NOT_ENOUGH_DATA;
|
return VP8_STATUS_NOT_ENOUGH_DATA;
|
||||||
}
|
}
|
||||||
|
|
||||||
chunk_size = get_le32(buf + TAG_SIZE);
|
chunk_size = GetLE32(buf + TAG_SIZE);
|
||||||
if (chunk_size > MAX_CHUNK_PAYLOAD) {
|
if (chunk_size > MAX_CHUNK_PAYLOAD) {
|
||||||
return VP8_STATUS_BITSTREAM_ERROR; // Not a valid chunk size.
|
return VP8_STATUS_BITSTREAM_ERROR; // Not a valid chunk size.
|
||||||
}
|
}
|
||||||
@ -247,7 +240,7 @@ static VP8StatusCode ParseVP8Header(const uint8_t** const data_ptr,
|
|||||||
|
|
||||||
if (is_vp8 || is_vp8l) {
|
if (is_vp8 || is_vp8l) {
|
||||||
// Bitstream contains VP8/VP8L header.
|
// Bitstream contains VP8/VP8L header.
|
||||||
const uint32_t size = get_le32(data + TAG_SIZE);
|
const uint32_t size = GetLE32(data + TAG_SIZE);
|
||||||
if ((riff_size >= minimal_size) && (size > riff_size - minimal_size)) {
|
if ((riff_size >= minimal_size) && (size > riff_size - minimal_size)) {
|
||||||
return VP8_STATUS_BITSTREAM_ERROR; // Inconsistent size information.
|
return VP8_STATUS_BITSTREAM_ERROR; // Inconsistent size information.
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user