[FFmpeg-cvslog] avcodec/mjpegenc: Drop i_tex misuse, set itex/header bits correctly, fix 2pass encoding
Michael Niedermayer
git at videolan.org
Fri Feb 10 01:14:29 EET 2017
ffmpeg | branch: master | Michael Niedermayer <michael at niedermayer.cc> | Thu Feb 9 22:10:43 2017 +0100| [daccbe81a2be2e1bf3ee862ae65fcd1bdec229b1] | committer: Michael Niedermayer
avcodec/mjpegenc: Drop i_tex misuse, set itex/header bits correctly, fix 2pass encoding
Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=daccbe81a2be2e1bf3ee862ae65fcd1bdec229b1
---
libavcodec/mjpegenc.c | 14 ++------------
1 file changed, 2 insertions(+), 12 deletions(-)
diff --git a/libavcodec/mjpegenc.c b/libavcodec/mjpegenc.c
index e275f01..db2bc34 100644
--- a/libavcodec/mjpegenc.c
+++ b/libavcodec/mjpegenc.c
@@ -39,8 +39,6 @@
#include "mjpeg.h"
#include "mjpegenc.h"
-// Don't know, but let's guess 16 bits per code
-#define MJPEG_HUFFMAN_EST_BITS_PER_CODE 16
static int alloc_huffman(MpegEncContext *s)
{
@@ -148,6 +146,7 @@ void ff_mjpeg_encode_picture_frame(MpegEncContext *s)
size_t total_bits = 0;
size_t bytes_needed;
+ s->header_bits = get_bits_diff(s);
// Estimate the total size first
for (i = 0; i < m->huff_ncode; i++) {
table_id = m->huff_buffer[i].table_id;
@@ -172,6 +171,7 @@ void ff_mjpeg_encode_picture_frame(MpegEncContext *s)
}
m->huff_ncode = 0;
+ s->i_tex_bits = get_bits_diff(s);
}
/**
@@ -271,15 +271,6 @@ int ff_mjpeg_encode_mb(MpegEncContext *s, int16_t block[12][64])
{
int i, is_chroma_420;
- // Number of bits used depends on future data.
- // So, nothing that relies on encoding many times and taking the
- // one with the fewest bits will work properly here.
- if (s->i_tex_bits != MJPEG_HUFFMAN_EST_BITS_PER_CODE *
- s->mjpeg_ctx->huff_ncode) {
- av_log(s->avctx, AV_LOG_ERROR, "Unsupported encoding method\n");
- return AVERROR(EINVAL);
- }
-
if (s->chroma_format == CHROMA_444) {
encode_block(s, block[0], 0);
encode_block(s, block[2], 2);
@@ -310,7 +301,6 @@ int ff_mjpeg_encode_mb(MpegEncContext *s, int16_t block[12][64])
}
}
- s->i_tex_bits = MJPEG_HUFFMAN_EST_BITS_PER_CODE * s->mjpeg_ctx->huff_ncode;
return 0;
}
More information about the ffmpeg-cvslog
mailing list