diff options
author | Ronald S. Bultje <rsbultje@gmail.com> | 2014-08-12 18:11:05 -0400 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-08-13 20:46:00 +0200 |
commit | 14e3025518124f99cb0f5885feb603a9f217d25d (patch) | |
tree | c8bf3025e467273d9c8eecd1848f7c96b4b24429 | |
parent | 8fcd9386ec791dfde82f5389e0aca2c2fffb5433 (diff) | |
download | ffmpeg-14e3025518124f99cb0f5885feb603a9f217d25d.tar.gz |
vp9: ignore reference segmentation map if error_resilience flag is set.
Fixes ffvp9_fails_where_libvpx.succeeds.webm from ticket 3849.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | libavcodec/vp9.c | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/libavcodec/vp9.c b/libavcodec/vp9.c index 96da823826..8f22685619 100644 --- a/libavcodec/vp9.c +++ b/libavcodec/vp9.c @@ -278,7 +278,7 @@ static int vp9_alloc_frame(AVCodecContext *ctx, VP9Frame *f) // retain segmentation map if it doesn't update if (s->segmentation.enabled && !s->segmentation.update_map && - !s->intraonly && !s->keyframe) { + !s->intraonly && !s->keyframe && !s->errorres) { memcpy(f->segmentation_map, s->frames[LAST_FRAME].segmentation_map, sz); } @@ -1344,16 +1344,20 @@ static void decode_mode(AVCodecContext *ctx) vp56_rac_get_prob_branchy(&s->c, s->prob.segpred[s->above_segpred_ctx[col] + s->left_segpred_ctx[row7]]))) { - int pred = 8, x; - uint8_t *refsegmap = s->frames[LAST_FRAME].segmentation_map; - - if (!s->last_uses_2pass) - ff_thread_await_progress(&s->frames[LAST_FRAME].tf, row >> 3, 0); - for (y = 0; y < h4; y++) - for (x = 0; x < w4; x++) - pred = FFMIN(pred, refsegmap[(y + row) * 8 * s->sb_cols + x + col]); - av_assert1(pred < 8); - b->seg_id = pred; + if (!s->errorres) { + int pred = 8, x; + uint8_t *refsegmap = s->frames[LAST_FRAME].segmentation_map; + + if (!s->last_uses_2pass) + ff_thread_await_progress(&s->frames[LAST_FRAME].tf, row >> 3, 0); + for (y = 0; y < h4; y++) + for (x = 0; x < w4; x++) + pred = FFMIN(pred, refsegmap[(y + row) * 8 * s->sb_cols + x + col]); + av_assert1(pred < 8); + b->seg_id = pred; + } else { + b->seg_id = 0; + } memset(&s->above_segpred_ctx[col], 1, w4); memset(&s->left_segpred_ctx[row7], 1, h4); |