summaryrefslogtreecommitdiff
path: root/libavcodec/mjpegenc.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2017-02-09 22:10:43 +0100
committerMichael Niedermayer <michael@niedermayer.cc>2017-02-10 00:12:01 +0100
commitdaccbe81a2be2e1bf3ee862ae65fcd1bdec229b1 (patch)
tree5d77e0b57c15fe840902016f0ea6a5e69dcb8ae2 /libavcodec/mjpegenc.c
parente10bd12c250afb89046c4b0ee3f30d6d23eb8127 (diff)
avcodec/mjpegenc: Drop i_tex misuse, set itex/header bits correctly, fix 2pass encoding
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavcodec/mjpegenc.c')
-rw-r--r--libavcodec/mjpegenc.c14
1 files changed, 2 insertions, 12 deletions
diff --git a/libavcodec/mjpegenc.c b/libavcodec/mjpegenc.c
index e275f01202..db2bc34fd5 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;
}