You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-15 14:13:16 +02:00
bfi: return meaningful error codes.
This commit is contained in:
@@ -55,16 +55,16 @@ static int bfi_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
uint8_t *src, *dst_offset, colour1, colour2;
|
uint8_t *src, *dst_offset, colour1, colour2;
|
||||||
uint8_t *frame_end = bfi->dst + avctx->width * avctx->height;
|
uint8_t *frame_end = bfi->dst + avctx->width * avctx->height;
|
||||||
uint32_t *pal;
|
uint32_t *pal;
|
||||||
int i, j, height = avctx->height;
|
int i, j, ret, height = avctx->height;
|
||||||
|
|
||||||
if (bfi->frame.data[0])
|
if (bfi->frame.data[0])
|
||||||
avctx->release_buffer(avctx, &bfi->frame);
|
avctx->release_buffer(avctx, &bfi->frame);
|
||||||
|
|
||||||
bfi->frame.reference = 1;
|
bfi->frame.reference = 1;
|
||||||
|
|
||||||
if (ff_get_buffer(avctx, &bfi->frame) < 0) {
|
if ((ret = ff_get_buffer(avctx, &bfi->frame)) < 0) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
|
av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
|
||||||
return -1;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
bytestream2_init(&g, avpkt->data, buf_size);
|
bytestream2_init(&g, avpkt->data, buf_size);
|
||||||
@@ -76,7 +76,7 @@ static int bfi_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
/* Setting the palette */
|
/* Setting the palette */
|
||||||
if (avctx->extradata_size > 768) {
|
if (avctx->extradata_size > 768) {
|
||||||
av_log(NULL, AV_LOG_ERROR, "Palette is too large.\n");
|
av_log(NULL, AV_LOG_ERROR, "Palette is too large.\n");
|
||||||
return -1;
|
return AVERROR_INVALIDDATA;
|
||||||
}
|
}
|
||||||
pal = (uint32_t *)bfi->frame.data[1];
|
pal = (uint32_t *)bfi->frame.data[1];
|
||||||
for (i = 0; i < avctx->extradata_size / 3; i++) {
|
for (i = 0; i < avctx->extradata_size / 3; i++) {
|
||||||
@@ -104,7 +104,7 @@ static int bfi_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
if (!bytestream2_get_bytes_left(&g)) {
|
if (!bytestream2_get_bytes_left(&g)) {
|
||||||
av_log(avctx, AV_LOG_ERROR,
|
av_log(avctx, AV_LOG_ERROR,
|
||||||
"Input resolution larger than actual frame.\n");
|
"Input resolution larger than actual frame.\n");
|
||||||
return -1;
|
return AVERROR_INVALIDDATA;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get length and offset (if required) */
|
/* Get length and offset (if required) */
|
||||||
@@ -130,7 +130,7 @@ static int bfi_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
case 0: // normal chain
|
case 0: // normal chain
|
||||||
if (length >= bytestream2_get_bytes_left(&g)) {
|
if (length >= bytestream2_get_bytes_left(&g)) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "Frame larger than buffer.\n");
|
av_log(avctx, AV_LOG_ERROR, "Frame larger than buffer.\n");
|
||||||
return -1;
|
return AVERROR_INVALIDDATA;
|
||||||
}
|
}
|
||||||
bytestream2_get_buffer(&g, dst, length);
|
bytestream2_get_buffer(&g, dst, length);
|
||||||
dst += length;
|
dst += length;
|
||||||
|
Reference in New Issue
Block a user