You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-10 06:10:52 +02:00
avcodec/mjpegenc: Drop i_tex misuse, set itex/header bits correctly, fix 2pass encoding
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
@@ -39,8 +39,6 @@
|
|||||||
#include "mjpeg.h"
|
#include "mjpeg.h"
|
||||||
#include "mjpegenc.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)
|
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 total_bits = 0;
|
||||||
size_t bytes_needed;
|
size_t bytes_needed;
|
||||||
|
|
||||||
|
s->header_bits = get_bits_diff(s);
|
||||||
// Estimate the total size first
|
// Estimate the total size first
|
||||||
for (i = 0; i < m->huff_ncode; i++) {
|
for (i = 0; i < m->huff_ncode; i++) {
|
||||||
table_id = m->huff_buffer[i].table_id;
|
table_id = m->huff_buffer[i].table_id;
|
||||||
@@ -172,6 +171,7 @@ void ff_mjpeg_encode_picture_frame(MpegEncContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
m->huff_ncode = 0;
|
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;
|
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) {
|
if (s->chroma_format == CHROMA_444) {
|
||||||
encode_block(s, block[0], 0);
|
encode_block(s, block[0], 0);
|
||||||
encode_block(s, block[2], 2);
|
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;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user