avformat/dvdvideodec: simplify dvdvideo_read_packet()

The function has a few branches where it discards frames via
FFERROR_REDO; consolidate is via a goto block to simplify the
function and improve readability. Logging still maintains
all the relevant details for the reason of the discard.

Signed-off-by: Marth64 <marth64@proxyid.net>
master
Marth64 3 months ago
parent c1e4b6c676
commit 1964faa568
  1. 44
      libavformat/dvdvideodec.c

@ -1615,8 +1615,9 @@ static int dvdvideo_read_packet(AVFormatContext *s, AVPacket *pkt)
DVDVideoDemuxContext *c = s->priv_data; DVDVideoDemuxContext *c = s->priv_data;
int ret; int ret;
enum AVMediaType st_type; int is_key = 0;
int found_stream = 0; int st_mapped = 0;
AVStream *st_subdemux;
if (c->play_end) if (c->play_end)
return AVERROR_EOF; return AVERROR_EOF;
@ -1629,32 +1630,27 @@ static int dvdvideo_read_packet(AVFormatContext *s, AVPacket *pkt)
if (!c->segment_started) if (!c->segment_started)
c->segment_started = 1; c->segment_started = 1;
st_type = c->mpeg_ctx->streams[pkt->stream_index]->codecpar->codec_type; st_subdemux = c->mpeg_ctx->streams[pkt->stream_index];
is_key = pkt->flags & AV_PKT_FLAG_KEY;
/* map the subdemuxer stream to the parent demuxer's stream (by startcode) */ /* map the subdemuxer stream to the parent demuxer's stream (by startcode) */
for (int i = 0; i < s->nb_streams; i++) { for (int i = 0; i < s->nb_streams; i++) {
if (s->streams[i]->id == c->mpeg_ctx->streams[pkt->stream_index]->id) { if (s->streams[i]->id == st_subdemux->id) {
pkt->stream_index = s->streams[i]->index; pkt->stream_index = s->streams[i]->index;
found_stream = 1; st_mapped = 1;
break; break;
} }
} }
if (!found_stream) { if (!st_mapped)
av_log(s, AV_LOG_DEBUG, "discarding frame with stream that was not in IFO headers " goto discard;
"(stream id=%d)\n", c->mpeg_ctx->streams[pkt->stream_index]->id);
return FFERROR_REDO;
}
if (pkt->pts != AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE) { if (pkt->pts != AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE) {
if (!c->play_started) { if (!c->play_started) {
/* try to start at the beginning of a GOP */ /* try to start at the beginning of a GOP */
if (st_type != AVMEDIA_TYPE_VIDEO || !(pkt->flags & AV_PKT_FLAG_KEY)) { if (st_subdemux->codecpar->codec_type != AVMEDIA_TYPE_VIDEO || !is_key)
av_log(s, AV_LOG_VERBOSE, "Discarding packet which is not a video keyframe or " goto discard;
"with unset PTS/DTS at start\n");
return FFERROR_REDO;
}
c->first_pts = pkt->pts; c->first_pts = pkt->pts;
c->play_started = 1; c->play_started = 1;
@ -1663,13 +1659,8 @@ static int dvdvideo_read_packet(AVFormatContext *s, AVPacket *pkt)
pkt->pts += c->play_state.ts_offset - c->first_pts; pkt->pts += c->play_state.ts_offset - c->first_pts;
pkt->dts += c->play_state.ts_offset - c->first_pts; pkt->dts += c->play_state.ts_offset - c->first_pts;
if (pkt->pts < 0) { if (pkt->pts < 0)
av_log(s, AV_LOG_VERBOSE, "Discarding packet with negative PTS (st=%d pts=%" PRId64 "), " goto discard;
"this is OK at start of playback\n",
pkt->stream_index, pkt->pts);
return FFERROR_REDO;
}
} else { } else {
av_log(s, AV_LOG_WARNING, "Unset PTS or DTS @ st=%d pts=%" PRId64 " dts=%" PRId64 "\n", av_log(s, AV_LOG_WARNING, "Unset PTS or DTS @ st=%d pts=%" PRId64 " dts=%" PRId64 "\n",
pkt->stream_index, pkt->pts, pkt->dts); pkt->stream_index, pkt->pts, pkt->dts);
@ -1681,6 +1672,13 @@ static int dvdvideo_read_packet(AVFormatContext *s, AVPacket *pkt)
c->play_state.ts_offset, c->first_pts); c->play_state.ts_offset, c->first_pts);
return c->play_end ? AVERROR_EOF : 0; return c->play_end ? AVERROR_EOF : 0;
discard:
av_log(s, st_mapped ? AV_LOG_VERBOSE : AV_LOG_DEBUG,
"Discarding frame @ st=%d pts=%" PRId64 " dts=%" PRId64 " is_key=%d st_mapped=%d\n",
st_mapped ? pkt->stream_index : -1, pkt->pts, pkt->dts, is_key, st_mapped);
return FFERROR_REDO;
} }
static int dvdvideo_close(AVFormatContext *s) static int dvdvideo_close(AVFormatContext *s)

Loading…
Cancel
Save