diff options
author | Hendrik Leppkes <h.leppkes@gmail.com> | 2023-05-15 13:33:18 +0200 |
---|---|---|
committer | Hendrik Leppkes <h.leppkes@gmail.com> | 2023-05-15 18:30:43 +0200 |
commit | b3e938ef8057a1c248e650a7e54ac423fe1aaf03 (patch) | |
tree | 38d71fd57cee5c0b7002b93c39d5859a7bea148c /libavcodec/nvdec_mpeg4.c | |
parent | af8affb77efe8e1b9cfb4a288aec8feb8c25f569 (diff) | |
download | ffmpeg-b3e938ef8057a1c248e650a7e54ac423fe1aaf03.tar.gz |
avcodec/nvdec_mpeg4: 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_mpeg4.c')
-rw-r--r-- | libavcodec/nvdec_mpeg4.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/libavcodec/nvdec_mpeg4.c b/libavcodec/nvdec_mpeg4.c index eac138cc38..c193f6b6e4 100644 --- a/libavcodec/nvdec_mpeg4.c +++ b/libavcodec/nvdec_mpeg4.c @@ -88,8 +88,9 @@ static int nvdec_mpeg4_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]; } // We need to pass the full frame buffer and not just the slice |