aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/mpeg12dec.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2020-09-25 22:05:03 +0200
committerPaul B Mahol <onemda@gmail.com>2020-09-25 22:07:29 +0200
commitc668294e8bc199ac07445338d18e81b3f04b3855 (patch)
tree3be08792212783322782636fa2b53d59fafba042 /libavcodec/mpeg12dec.c
parent2f9a3215aabbc95e43489848aea6205efa43384a (diff)
downloadffmpeg-c668294e8bc199ac07445338d18e81b3f04b3855.tar.gz
avcodec/mpeg12dec: add support for MPEG1 blocks in IPU codec
Diffstat (limited to 'libavcodec/mpeg12dec.c')
-rw-r--r--libavcodec/mpeg12dec.c50
1 files changed, 31 insertions, 19 deletions
diff --git a/libavcodec/mpeg12dec.c b/libavcodec/mpeg12dec.c
index 1dd12196b9..a771add4dc 100644
--- a/libavcodec/mpeg12dec.c
+++ b/libavcodec/mpeg12dec.c
@@ -3010,22 +3010,20 @@ static int ipu_decode_frame(AVCodecContext *avctx, void *data,
return ret;
s->flags = get_bits(gb, 8);
- if (!(s->flags & 0x80)) {
- m->intra_dc_precision = s->flags & 3;
- m->q_scale_type = !!(s->flags & 0x40);
- m->intra_vlc_format = !!(s->flags & 0x20);
- m->alternate_scan = !!(s->flags & 0x10);
-
- if (s->flags & 0x10) {
- ff_init_scantable(m->idsp.idct_permutation, &m->inter_scantable, ff_alternate_vertical_scan);
- ff_init_scantable(m->idsp.idct_permutation, &m->intra_scantable, ff_alternate_vertical_scan);
- } else {
- ff_init_scantable(m->idsp.idct_permutation, &m->inter_scantable, ff_zigzag_direct);
- ff_init_scantable(m->idsp.idct_permutation, &m->intra_scantable, ff_zigzag_direct);
- }
-
- m->last_dc[0] = m->last_dc[1] = m->last_dc[2] = 1 << (7 + (s->flags & 3));
+ m->intra_dc_precision = s->flags & 3;
+ m->q_scale_type = !!(s->flags & 0x40);
+ m->intra_vlc_format = !!(s->flags & 0x20);
+ m->alternate_scan = !!(s->flags & 0x10);
+
+ if (s->flags & 0x10) {
+ ff_init_scantable(m->idsp.idct_permutation, &m->inter_scantable, ff_alternate_vertical_scan);
+ ff_init_scantable(m->idsp.idct_permutation, &m->intra_scantable, ff_alternate_vertical_scan);
+ } else {
+ ff_init_scantable(m->idsp.idct_permutation, &m->inter_scantable, ff_zigzag_direct);
+ ff_init_scantable(m->idsp.idct_permutation, &m->intra_scantable, ff_zigzag_direct);
}
+
+ m->last_dc[0] = m->last_dc[1] = m->last_dc[2] = 1 << (7 + (s->flags & 3));
m->qscale = 1;
for (int y = 0; y < avctx->height; y += 16) {
@@ -3053,10 +3051,24 @@ static int ipu_decode_frame(AVCodecContext *avctx, void *data,
memset(s->block, 0, sizeof(s->block));
for (int n = 0; n < 6; n++) {
- if (s->flags & 0x20)
- ret = mpeg2_decode_block_intra(m, s->block[n], n);
- else
- ret = mpeg2_decode_block_non_intra(m, s->block[n], n);
+ if (s->flags & 0x80) {
+ if (s->flags & 0x20)
+ ret = mpeg1_decode_block_inter(m, s->block[n], n);
+ else
+ ret = ff_mpeg1_decode_block_intra(&m->gb,
+ m->intra_matrix,
+ m->intra_scantable.permutated,
+ m->last_dc, s->block[n],
+ n, m->qscale);
+ if (ret >= 0)
+ m->block_last_index[n] = ret;
+ } else {
+ if (s->flags & 0x20)
+ ret = mpeg2_decode_block_intra(m, s->block[n], n);
+ else
+ ret = mpeg2_decode_block_non_intra(m, s->block[n], n);
+ }
+
if (ret < 0)
return ret;
}