pthread_frame: forward error codes when flushing
This is the first part of the fix for ticket #4370. Reviewed-by: Michael Niedermayer <michaelni@gmx.at> Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun@googlemail.com> (cherry picked from commit 32a5b631267e1f8bf279e407039b9a99d012d033) Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun@googlemail.com> (cherry picked from commit acfad331adde5b4ae247bf5748211e8fdb6b4ef5) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
dc85a75332
commit
a0f50ddcb8
@ -453,6 +453,9 @@ int ff_thread_decode_frame(AVCodecContext *avctx,
|
|||||||
*got_picture_ptr = p->got_frame;
|
*got_picture_ptr = p->got_frame;
|
||||||
picture->pkt_dts = p->avpkt.dts;
|
picture->pkt_dts = p->avpkt.dts;
|
||||||
|
|
||||||
|
if (p->result < 0)
|
||||||
|
err = p->result;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* A later call with avkpt->size == 0 may loop over all threads,
|
* A later call with avkpt->size == 0 may loop over all threads,
|
||||||
* including this one, searching for a frame to return before being
|
* including this one, searching for a frame to return before being
|
||||||
@ -470,6 +473,14 @@ 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 occured in
|
||||||
|
* any thread, return it instead of 0.
|
||||||
|
* Otherwise the error can get lost.
|
||||||
|
*/
|
||||||
|
if (!avpkt->size && !*got_picture_ptr)
|
||||||
|
return err;
|
||||||
|
|
||||||
/* return the size of the consumed packet if no error occurred */
|
/* return the size of the consumed packet if no error occurred */
|
||||||
return (p->result >= 0) ? avpkt->size : p->result;
|
return (p->result >= 0) ? avpkt->size : p->result;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user