mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-02-04 06:08:26 +02:00
png: Clear up the calculation of max packet size
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
65a646eb0b
commit
749fbfd081
@ -307,12 +307,16 @@ static int encode_frame(AVCodecContext *avctx, AVPacket *pkt,
|
||||
row_size = (avctx->width * s->bits_per_pixel + 7) >> 3;
|
||||
|
||||
enc_row_size = deflateBound(&s->zstream, row_size);
|
||||
max_packet_size = avctx->height * (int64_t)(enc_row_size +
|
||||
((enc_row_size + IOBUF_SIZE - 1) / IOBUF_SIZE) * 12)
|
||||
+ FF_MIN_BUFFER_SIZE;
|
||||
max_packet_size =
|
||||
FF_MIN_BUFFER_SIZE + // headers
|
||||
avctx->height * (
|
||||
enc_row_size +
|
||||
12 * (((int64_t)enc_row_size + IOBUF_SIZE - 1) / IOBUF_SIZE) // IDAT * ceil(enc_row_size / IOBUF_SIZE)
|
||||
);
|
||||
if (max_packet_size > INT_MAX)
|
||||
return AVERROR(ENOMEM);
|
||||
if ((ret = ff_alloc_packet2(avctx, pkt, max_packet_size)) < 0)
|
||||
ret = ff_alloc_packet2(avctx, pkt, max_packet_size);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
s->bytestream_start =
|
||||
|
Loading…
x
Reference in New Issue
Block a user