aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/nvdec_mpeg12.c
diff options
context:
space:
mode:
authorHendrik Leppkes <h.leppkes@gmail.com>2023-05-15 12:49:21 +0200
committerHendrik Leppkes <h.leppkes@gmail.com>2023-05-15 18:49:40 +0200
commit1c19e2c82d38244887e279d62e1d542e8932a532 (patch)
tree4b3ebfedabda0364ab32bab9d5dabce5680fc7fb /libavcodec/nvdec_mpeg12.c
parentb0fe83714bba7269dc76a5ab9ca0d87b311b0aee (diff)
downloadffmpeg-1c19e2c82d38244887e279d62e1d542e8932a532.tar.gz
avcodec/nvdec_mpeg2: fix order of quant matrix coefficients
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/nvdec_mpeg12.c')
-rw-r--r--libavcodec/nvdec_mpeg12.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/libavcodec/nvdec_mpeg12.c b/libavcodec/nvdec_mpeg12.c
index 300e1d3d88..5408ca4c76 100644
--- a/libavcodec/nvdec_mpeg12.c
+++ b/libavcodec/nvdec_mpeg12.c
@@ -76,8 +76,9 @@ static int nvdec_mpeg12_start_frame(AVCodecContext *avctx, const uint8_t *buffer
};
for (i = 0; i < 64; ++i) {
- ppc->QuantMatrixIntra[i] = s->intra_matrix[i];
- ppc->QuantMatrixInter[i] = s->inter_matrix[i];
+ int n = s->idsp.idct_permutation[i];
+ ppc->QuantMatrixIntra[i] = s->intra_matrix[n];
+ ppc->QuantMatrixInter[i] = s->inter_matrix[n];
}
return 0;