[FFmpeg-devel] [PATCH 2/2] avformat/mov: increase current_sample after reading, to avoid discontinuous sample
Zhang Rui
bbcallen at gmail.com
Wed Jun 3 13:49:25 CEST 2015
2015-06-03 19:24 GMT+08:00 Michael Niedermayer <michaelni at gmx.at>:
> would below work ?
Looks better than mine.
>
> commit 816047eb161e804ba6312947f6bd7349cf934f80
> Author: Michael Niedermayer <michaelni at gmx.at>
> Date: Wed Jun 3 13:04:37 2015 +0200
>
> avformat/mov: Retry same packet on IO failure to avoid loosing a packet
>
> Based on patch by: Zhang Rui <bbcallen at gmail.com>
> Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
>
> diff --git a/libavformat/mov.c b/libavformat/mov.c
> index 5300704..bc5743a 100644
> --- a/libavformat/mov.c
> +++ b/libavformat/mov.c
> @@ -4316,6 +4316,13 @@ static AVIndexEntry *mov_find_next_sample(AVFormatContext *s, AVStream **st)
> return sample;
> }
>
> +static int should_retry(AVIOContext *pb, int error_code) {
> + if (error_code == AVERROR_EOF || avio_feof(pb))
> + return 0;
> +
> + return 1;
> +}
> +
> static int mov_read_packet(AVFormatContext *s, AVPacket *pkt)
> {
> MOVContext *mov = s->priv_data;
> @@ -4351,14 +4358,18 @@ static int mov_read_packet(AVFormatContext *s, AVPacket *pkt)
> }
>
> if (st->discard != AVDISCARD_ALL) {
> - if (avio_seek(sc->pb, sample->pos, SEEK_SET) != sample->pos) {
> + int64_t ret64 = avio_seek(sc->pb, sample->pos, SEEK_SET);
> + if (ret64 != sample->pos) {
> av_log(mov->fc, AV_LOG_ERROR, "stream %d, offset 0x%"PRIx64": partial file\n",
> sc->ffindex, sample->pos);
> + sc->current_sample -= should_retry(sc->pb, ret64);
> return AVERROR_INVALIDDATA;
> }
> ret = av_get_packet(sc->pb, pkt, sample->size);
> - if (ret < 0)
> + if (ret < 0) {
> + sc->current_sample -= should_retry(sc->pb, ret);
> return ret;
> + }
> if (sc->has_palette) {
> uint8_t *pal;
>
>
Thanks for your reply.
More information about the ffmpeg-devel
mailing list