diff options
author | Hendrik Leppkes <h.leppkes@gmail.com> | 2023-05-15 13:35:42 +0200 |
---|---|---|
committer | Hendrik Leppkes <h.leppkes@gmail.com> | 2023-05-15 18:49:41 +0200 |
commit | d7beb0c61fd1e027e40c6b7e8b18fd6cdbbee430 (patch) | |
tree | 0323fd0836c0ccf4f25fb06e623dc3a9f6a81101 /libavcodec | |
parent | c9408c41e7c215a44d429b880d6660c410c2a79f (diff) | |
download | ffmpeg-d7beb0c61fd1e027e40c6b7e8b18fd6cdbbee430.tar.gz |
avcodec/vdpau_mpeg4: fix order of quant matrix coefficientsrelease/4.2
The matrix coefficients are stored permutated for the IDCT,
rather then in plain raster order, and need to be un-permutated
for the hardware.
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/vdpau_mpeg4.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/libavcodec/vdpau_mpeg4.c b/libavcodec/vdpau_mpeg4.c index 96f83026a8..5bf82dc9fa 100644 --- a/libavcodec/vdpau_mpeg4.c +++ b/libavcodec/vdpau_mpeg4.c @@ -74,8 +74,9 @@ static int vdpau_mpeg4_start_frame(AVCodecContext *avctx, info->alternate_vertical_scan_flag = s->alternate_scan; info->top_field_first = s->top_field_first; for (i = 0; i < 64; ++i) { - info->intra_quantizer_matrix[i] = s->intra_matrix[i]; - info->non_intra_quantizer_matrix[i] = s->inter_matrix[i]; + int n = s->idsp.idct_permutation[i]; + info->intra_quantizer_matrix[i] = s->intra_matrix[n]; + info->non_intra_quantizer_matrix[i] = s->inter_matrix[n]; } ff_vdpau_common_start_frame(pic_ctx, buffer, size); |