Commit 42dd1434 authored by Ronald S. Bultje's avatar Ronald S. Bultje

mdec: use correctly permutated quant matrix for dequantization.

parent 9e85c5d6
...@@ -49,6 +49,7 @@ typedef struct MDECContext { ...@@ -49,6 +49,7 @@ typedef struct MDECContext {
int mb_height; int mb_height;
int mb_x, mb_y; int mb_x, mb_y;
DECLARE_ALIGNED(16, int16_t, block)[6][64]; DECLARE_ALIGNED(16, int16_t, block)[6][64];
DECLARE_ALIGNED(16, uint16_t, quant_matrix)[64];
uint8_t *bitstream_buffer; uint8_t *bitstream_buffer;
unsigned int bitstream_buffer_size; unsigned int bitstream_buffer_size;
int block_last_index[6]; int block_last_index[6];
...@@ -61,7 +62,7 @@ static inline int mdec_decode_block_intra(MDECContext *a, int16_t *block, int n) ...@@ -61,7 +62,7 @@ static inline int mdec_decode_block_intra(MDECContext *a, int16_t *block, int n)
int component; int component;
RLTable *rl = &ff_rl_mpeg1; RLTable *rl = &ff_rl_mpeg1;
uint8_t * const scantable = a->scantable.permutated; uint8_t * const scantable = a->scantable.permutated;
const uint16_t *quant_matrix = ff_mpeg1_default_intra_matrix; const uint16_t *quant_matrix = a->quant_matrix;
const int qscale = a->qscale; const int qscale = a->qscale;
/* DC coefficient */ /* DC coefficient */
...@@ -212,6 +213,7 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -212,6 +213,7 @@ static int decode_frame(AVCodecContext *avctx,
static av_cold int decode_init(AVCodecContext *avctx) static av_cold int decode_init(AVCodecContext *avctx)
{ {
MDECContext * const a = avctx->priv_data; MDECContext * const a = avctx->priv_data;
int i;
if (avctx->idct_algo == FF_IDCT_AUTO) if (avctx->idct_algo == FF_IDCT_AUTO)
avctx->idct_algo = FF_IDCT_SIMPLE; avctx->idct_algo = FF_IDCT_SIMPLE;
...@@ -231,6 +233,13 @@ static av_cold int decode_init(AVCodecContext *avctx) ...@@ -231,6 +233,13 @@ static av_cold int decode_init(AVCodecContext *avctx)
avctx->pix_fmt = AV_PIX_FMT_YUVJ420P; avctx->pix_fmt = AV_PIX_FMT_YUVJ420P;
avctx->color_range = AVCOL_RANGE_JPEG; avctx->color_range = AVCOL_RANGE_JPEG;
/* init q matrix */
for (i = 0; i < 64; i++) {
int j = a->idsp.idct_permutation[i];
a->quant_matrix[j] = ff_mpeg1_default_intra_matrix[i];
}
return 0; return 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment