avconv: send EOF to lavfi even if flushing the decoder fails
This commit is contained in:
parent
cc2133b66a
commit
f154ef1ae5
22
avconv.c
22
avconv.c
@ -1069,15 +1069,11 @@ static int decode_audio(InputStream *ist, AVPacket *pkt, int *got_output)
|
|||||||
decoded_frame = ist->decoded_frame;
|
decoded_frame = ist->decoded_frame;
|
||||||
|
|
||||||
ret = avcodec_decode_audio4(avctx, decoded_frame, got_output, pkt);
|
ret = avcodec_decode_audio4(avctx, decoded_frame, got_output, pkt);
|
||||||
if (ret < 0) {
|
if (!*got_output || ret < 0) {
|
||||||
return ret;
|
if (!pkt->size) {
|
||||||
}
|
|
||||||
|
|
||||||
if (!*got_output) {
|
|
||||||
/* no audio frame */
|
|
||||||
if (!pkt->size)
|
|
||||||
for (i = 0; i < ist->nb_filters; i++)
|
for (i = 0; i < ist->nb_filters; i++)
|
||||||
av_buffersrc_buffer(ist->filters[i]->filter, NULL);
|
av_buffersrc_buffer(ist->filters[i]->filter, NULL);
|
||||||
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1216,17 +1212,15 @@ static int decode_video(InputStream *ist, AVPacket *pkt, int *got_output)
|
|||||||
|
|
||||||
ret = avcodec_decode_video2(ist->st->codec,
|
ret = avcodec_decode_video2(ist->st->codec,
|
||||||
decoded_frame, got_output, pkt);
|
decoded_frame, got_output, pkt);
|
||||||
if (ret < 0)
|
if (!*got_output || ret < 0) {
|
||||||
return ret;
|
if (!pkt->size) {
|
||||||
|
|
||||||
quality = same_quant ? decoded_frame->quality : 0;
|
|
||||||
if (!*got_output) {
|
|
||||||
/* no picture yet */
|
|
||||||
if (!pkt->size)
|
|
||||||
for (i = 0; i < ist->nb_filters; i++)
|
for (i = 0; i < ist->nb_filters; i++)
|
||||||
av_buffersrc_buffer(ist->filters[i]->filter, NULL);
|
av_buffersrc_buffer(ist->filters[i]->filter, NULL);
|
||||||
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
quality = same_quant ? decoded_frame->quality : 0;
|
||||||
decoded_frame->pts = guess_correct_pts(&ist->pts_ctx, decoded_frame->pkt_pts,
|
decoded_frame->pts = guess_correct_pts(&ist->pts_ctx, decoded_frame->pkt_pts,
|
||||||
decoded_frame->pkt_dts);
|
decoded_frame->pkt_dts);
|
||||||
pkt->size = 0;
|
pkt->size = 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user