mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
Merge commit 'e41ff4210ac1192c62de3052b33a38c7bcf772f2'
* commit 'e41ff4210ac1192c62de3052b33a38c7bcf772f2': mpeg4videodec: move use_intra_dc_vlc from MpegEncContext to Mpeg4DecContext Conflicts: libavcodec/mpeg4videodec.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
92e10e34b1
@ -83,6 +83,7 @@ typedef struct Mpeg4DecContext {
|
|||||||
int new_pred;
|
int new_pred;
|
||||||
int enhancement_type;
|
int enhancement_type;
|
||||||
int scalability;
|
int scalability;
|
||||||
|
int use_intra_dc_vlc;
|
||||||
|
|
||||||
/* bug workarounds */
|
/* bug workarounds */
|
||||||
int divx_version;
|
int divx_version;
|
||||||
|
@ -933,9 +933,10 @@ int ff_mpeg4_decode_partitions(Mpeg4DecContext *ctx)
|
|||||||
* Decode a block.
|
* Decode a block.
|
||||||
* @return <0 if an error occurred
|
* @return <0 if an error occurred
|
||||||
*/
|
*/
|
||||||
static inline int mpeg4_decode_block(MpegEncContext *s, int16_t *block,
|
static inline int mpeg4_decode_block(Mpeg4DecContext *ctx, int16_t *block,
|
||||||
int n, int coded, int intra, int rvlc)
|
int n, int coded, int intra, int rvlc)
|
||||||
{
|
{
|
||||||
|
MpegEncContext *s = &ctx->m;
|
||||||
int level, i, last, run, qmul, qadd;
|
int level, i, last, run, qmul, qadd;
|
||||||
int av_uninit(dc_pred_dir);
|
int av_uninit(dc_pred_dir);
|
||||||
RLTable *rl;
|
RLTable *rl;
|
||||||
@ -945,7 +946,7 @@ static inline int mpeg4_decode_block(MpegEncContext *s, int16_t *block,
|
|||||||
// Note intra & rvlc should be optimized away if this is inlined
|
// Note intra & rvlc should be optimized away if this is inlined
|
||||||
|
|
||||||
if (intra) {
|
if (intra) {
|
||||||
if (s->use_intra_dc_vlc) {
|
if (ctx->use_intra_dc_vlc) {
|
||||||
/* DC coef */
|
/* DC coef */
|
||||||
if (s->partitioned_frame) {
|
if (s->partitioned_frame) {
|
||||||
level = s->dc_val[0][s->block_index[n]];
|
level = s->dc_val[0][s->block_index[n]];
|
||||||
@ -1182,7 +1183,7 @@ static inline int mpeg4_decode_block(MpegEncContext *s, int16_t *block,
|
|||||||
|
|
||||||
not_coded:
|
not_coded:
|
||||||
if (intra) {
|
if (intra) {
|
||||||
if (!s->use_intra_dc_vlc) {
|
if (!ctx->use_intra_dc_vlc) {
|
||||||
block[0] = ff_mpeg4_pred_dc(s, n, block[0], &dc_pred_dir, 0);
|
block[0] = ff_mpeg4_pred_dc(s, n, block[0], &dc_pred_dir, 0);
|
||||||
|
|
||||||
i -= i >> 31; // if (i == -1) i = 0;
|
i -= i >> 31; // if (i == -1) i = 0;
|
||||||
@ -1209,7 +1210,7 @@ static int mpeg4_decode_partitioned_mb(MpegEncContext *s, int16_t block[6][64])
|
|||||||
mb_type = s->current_picture.mb_type[xy];
|
mb_type = s->current_picture.mb_type[xy];
|
||||||
cbp = s->cbp_table[xy];
|
cbp = s->cbp_table[xy];
|
||||||
|
|
||||||
s->use_intra_dc_vlc = s->qscale < s->intra_dc_threshold;
|
ctx->use_intra_dc_vlc = s->qscale < s->intra_dc_threshold;
|
||||||
|
|
||||||
if (s->current_picture.qscale_table[xy] != s->qscale)
|
if (s->current_picture.qscale_table[xy] != s->qscale)
|
||||||
ff_set_qscale(s, s->current_picture.qscale_table[xy]);
|
ff_set_qscale(s, s->current_picture.qscale_table[xy]);
|
||||||
@ -1259,7 +1260,7 @@ static int mpeg4_decode_partitioned_mb(MpegEncContext *s, int16_t block[6][64])
|
|||||||
s->dsp.clear_blocks(s->block[0]);
|
s->dsp.clear_blocks(s->block[0]);
|
||||||
/* decode each block */
|
/* decode each block */
|
||||||
for (i = 0; i < 6; i++) {
|
for (i = 0; i < 6; i++) {
|
||||||
if (mpeg4_decode_block(s, block[i], i, cbp & 32, s->mb_intra, ctx->rvlc) < 0) {
|
if (mpeg4_decode_block(ctx, block[i], i, cbp & 32, s->mb_intra, ctx->rvlc) < 0) {
|
||||||
av_log(s->avctx, AV_LOG_ERROR,
|
av_log(s->avctx, AV_LOG_ERROR,
|
||||||
"texture corrupted at %d %d %d\n",
|
"texture corrupted at %d %d %d\n",
|
||||||
s->mb_x, s->mb_y, s->mb_intra);
|
s->mb_x, s->mb_y, s->mb_intra);
|
||||||
@ -1607,7 +1608,7 @@ intra:
|
|||||||
}
|
}
|
||||||
cbp = (cbpc & 3) | (cbpy << 2);
|
cbp = (cbpc & 3) | (cbpy << 2);
|
||||||
|
|
||||||
s->use_intra_dc_vlc = s->qscale < s->intra_dc_threshold;
|
ctx->use_intra_dc_vlc = s->qscale < s->intra_dc_threshold;
|
||||||
|
|
||||||
if (dquant)
|
if (dquant)
|
||||||
ff_set_qscale(s, s->qscale + quant_tab[get_bits(&s->gb, 2)]);
|
ff_set_qscale(s, s->qscale + quant_tab[get_bits(&s->gb, 2)]);
|
||||||
@ -1618,7 +1619,7 @@ intra:
|
|||||||
s->dsp.clear_blocks(s->block[0]);
|
s->dsp.clear_blocks(s->block[0]);
|
||||||
/* decode each block */
|
/* decode each block */
|
||||||
for (i = 0; i < 6; i++) {
|
for (i = 0; i < 6; i++) {
|
||||||
if (mpeg4_decode_block(s, block[i], i, cbp & 32, 1, 0) < 0)
|
if (mpeg4_decode_block(ctx, block[i], i, cbp & 32, 1, 0) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
cbp += cbp;
|
cbp += cbp;
|
||||||
}
|
}
|
||||||
@ -1627,7 +1628,7 @@ intra:
|
|||||||
|
|
||||||
/* decode each block */
|
/* decode each block */
|
||||||
for (i = 0; i < 6; i++) {
|
for (i = 0; i < 6; i++) {
|
||||||
if (mpeg4_decode_block(s, block[i], i, cbp & 32, 0, 0) < 0)
|
if (mpeg4_decode_block(ctx, block[i], i, cbp & 32, 0, 0) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
cbp += cbp;
|
cbp += cbp;
|
||||||
}
|
}
|
||||||
|
@ -609,7 +609,6 @@ typedef struct MpegEncContext {
|
|||||||
int vo_type;
|
int vo_type;
|
||||||
int vol_control_parameters; ///< does the stream contain the low_delay flag, used to workaround buggy encoders
|
int vol_control_parameters; ///< does the stream contain the low_delay flag, used to workaround buggy encoders
|
||||||
int intra_dc_threshold; ///< QP above whch the ac VLC should be used for intra dc
|
int intra_dc_threshold; ///< QP above whch the ac VLC should be used for intra dc
|
||||||
int use_intra_dc_vlc;
|
|
||||||
PutBitContext tex_pb; ///< used for data partitioned VOPs
|
PutBitContext tex_pb; ///< used for data partitioned VOPs
|
||||||
PutBitContext pb2; ///< used for data partitioned VOPs
|
PutBitContext pb2; ///< used for data partitioned VOPs
|
||||||
int mpeg_quant;
|
int mpeg_quant;
|
||||||
|
Loading…
Reference in New Issue
Block a user