aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorHendrik Leppkes <h.leppkes@gmail.com>2023-05-15 13:35:42 +0200
committerHendrik Leppkes <h.leppkes@gmail.com>2023-05-15 18:48:06 +0200
commitd5fa6e3a910c7f861976b8220c6a1a4bf30698d3 (patch)
treea0bb04160c11b13872c0bd65c932b6b622a13a30 /libavcodec
parentf754c7129c1b66319b2db7cdecd36938839c58fe (diff)
downloadffmpeg-d5fa6e3a910c7f861976b8220c6a1a4bf30698d3.tar.gz
avcodec/vdpau_mpeg4: fix order of quant matrix coefficientsrelease/4.4
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.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/libavcodec/vdpau_mpeg4.c b/libavcodec/vdpau_mpeg4.c
index 93b25beb1f..59cdb96378 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);