mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-28 20:53:54 +02:00
avcodec/lcldec: More space for rgb24
Fixes: Ticket 10239
Fixes: zlib_306_306_rgb24.av
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
(cherry picked from commit e2c3aa8e2b
)
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
002471255d
commit
1480cc1d9c
@ -152,6 +152,8 @@ static int zlib_decomp(AVCodecContext *avctx, const uint8_t *src, int src_len, i
|
|||||||
if (expected != (unsigned int)zstream->total_out) {
|
if (expected != (unsigned int)zstream->total_out) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "Decoded size differs (%d != %lu)\n",
|
av_log(avctx, AV_LOG_ERROR, "Decoded size differs (%d != %lu)\n",
|
||||||
expected, zstream->total_out);
|
expected, zstream->total_out);
|
||||||
|
if (expected > (unsigned int)zstream->total_out)
|
||||||
|
return (unsigned int)zstream->total_out;
|
||||||
return AVERROR_UNKNOWN;
|
return AVERROR_UNKNOWN;
|
||||||
}
|
}
|
||||||
return zstream->total_out;
|
return zstream->total_out;
|
||||||
@ -276,12 +278,13 @@ static int decode_frame(AVCodecContext *avctx, AVFrame *frame,
|
|||||||
ret = zlib_decomp(avctx, buf + 8 + mthread_inlen, len - 8 - mthread_inlen,
|
ret = zlib_decomp(avctx, buf + 8 + mthread_inlen, len - 8 - mthread_inlen,
|
||||||
mthread_outlen, mthread_outlen);
|
mthread_outlen, mthread_outlen);
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
|
len = c->decomp_size;
|
||||||
} else {
|
} else {
|
||||||
int ret = zlib_decomp(avctx, buf, len, 0, c->decomp_size);
|
int ret = zlib_decomp(avctx, buf, len, 0, c->decomp_size);
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
|
len = ret;
|
||||||
}
|
}
|
||||||
encoded = c->decomp_buf;
|
encoded = c->decomp_buf;
|
||||||
len = c->decomp_size;
|
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
@ -519,7 +522,7 @@ static av_cold int decode_init(AVCodecContext *avctx)
|
|||||||
partial_h_supported = 1;
|
partial_h_supported = 1;
|
||||||
break;
|
break;
|
||||||
case IMGTYPE_RGB24:
|
case IMGTYPE_RGB24:
|
||||||
c->decomp_size = basesize * 3;
|
c->decomp_size = FFALIGN(avctx->width*3, 4) * avctx->height;
|
||||||
max_decomp_size = max_basesize * 3;
|
max_decomp_size = max_basesize * 3;
|
||||||
avctx->pix_fmt = AV_PIX_FMT_BGR24;
|
avctx->pix_fmt = AV_PIX_FMT_BGR24;
|
||||||
av_log(avctx, AV_LOG_DEBUG, "Image type is RGB 24.\n");
|
av_log(avctx, AV_LOG_DEBUG, "Image type is RGB 24.\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user