mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-19 05:49:09 +02:00
avcodec/ffv1dec: Remove redundant writes, fix races
Every modification of the data that is copied in update_thread_context() is a data race if it happens after ff_thread_finish_setup. ffv1dec's update_thread_context() simply uses memcpy for updating the new context, so that every modification of the src's context is a race. Some of these modifications are unnecessary: picture_number is write-only for the decoder and cur will be reset when decoding the next frame anyway. So remove them. And while just at it, also don't set cur for the slice contexts as this variable is write-only. Reviewed-by: Anton Khirnov <anton@khirnov.net> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
parent
dfd06ee710
commit
17605d1a4a
@ -924,7 +924,6 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPac
|
|||||||
fs->c.bytestream_end = buf_p + v;
|
fs->c.bytestream_end = buf_p + v;
|
||||||
|
|
||||||
fs->avctx = avctx;
|
fs->avctx = avctx;
|
||||||
fs->cur = p;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
avctx->execute(avctx,
|
avctx->execute(avctx,
|
||||||
@ -965,11 +964,8 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPac
|
|||||||
}
|
}
|
||||||
ff_thread_report_progress(&f->picture, INT_MAX, 0);
|
ff_thread_report_progress(&f->picture, INT_MAX, 0);
|
||||||
|
|
||||||
f->picture_number++;
|
|
||||||
|
|
||||||
if (f->last_picture.f)
|
if (f->last_picture.f)
|
||||||
ff_thread_release_buffer(avctx, &f->last_picture);
|
ff_thread_release_buffer(avctx, &f->last_picture);
|
||||||
f->cur = NULL;
|
|
||||||
if ((ret = av_frame_ref(data, f->picture.f)) < 0)
|
if ((ret = av_frame_ref(data, f->picture.f)) < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user