mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-13 19:01:03 +00:00
pthread_frame: minor simplification to error handling
Get rid of the "ret" variable, and always use err. Report the packet as
consumed if err is unset. This should be equivalent to the old code,
which obviously required err=0 for p->result>=0 (and otherwise,
p->result must have had the value err was last set to). The code block
added by commit 32a5b63126
is also not needed anymore, because the new
code strictly returns err if it's >=0.
Reviewed-by: "Ronald S. Bultje" <rsbultje@gmail.com>
This commit is contained in:
parent
91ccd38c0b
commit
4cf1f68903
@ -468,7 +468,7 @@ int ff_thread_decode_frame(AVCodecContext *avctx,
|
|||||||
FrameThreadContext *fctx = avctx->internal->thread_ctx;
|
FrameThreadContext *fctx = avctx->internal->thread_ctx;
|
||||||
int finished = fctx->next_finished;
|
int finished = fctx->next_finished;
|
||||||
PerThreadContext *p;
|
PerThreadContext *p;
|
||||||
int err, ret = 0;
|
int err;
|
||||||
|
|
||||||
/* release the async lock, permitting blocked hwaccel threads to
|
/* release the async lock, permitting blocked hwaccel threads to
|
||||||
* go forward while we are in this function */
|
* go forward while we are in this function */
|
||||||
@ -496,7 +496,7 @@ int ff_thread_decode_frame(AVCodecContext *avctx,
|
|||||||
if (fctx->delaying) {
|
if (fctx->delaying) {
|
||||||
*got_picture_ptr=0;
|
*got_picture_ptr=0;
|
||||||
if (avpkt->size) {
|
if (avpkt->size) {
|
||||||
ret = avpkt->size;
|
err = avpkt->size;
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -542,21 +542,12 @@ int ff_thread_decode_frame(AVCodecContext *avctx,
|
|||||||
|
|
||||||
fctx->next_finished = finished;
|
fctx->next_finished = finished;
|
||||||
|
|
||||||
/*
|
|
||||||
* When no frame was found while flushing, but an error occurred in
|
|
||||||
* any thread, return it instead of 0.
|
|
||||||
* Otherwise the error can get lost.
|
|
||||||
*/
|
|
||||||
if (!avpkt->size && !*got_picture_ptr)
|
|
||||||
goto finish;
|
|
||||||
|
|
||||||
/* return the size of the consumed packet if no error occurred */
|
/* return the size of the consumed packet if no error occurred */
|
||||||
ret = (p->result >= 0) ? avpkt->size : p->result;
|
if (err >= 0)
|
||||||
|
err = avpkt->size;
|
||||||
finish:
|
finish:
|
||||||
async_lock(fctx);
|
async_lock(fctx);
|
||||||
if (err < 0)
|
return err;
|
||||||
return err;
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ff_thread_report_progress(ThreadFrame *f, int n, int field)
|
void ff_thread_report_progress(ThreadFrame *f, int n, int field)
|
||||||
|
Loading…
Reference in New Issue
Block a user