summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libmpdemux/demuxer.c2
-rw-r--r--mplayer.c9
2 files changed, 8 insertions, 3 deletions
diff --git a/libmpdemux/demuxer.c b/libmpdemux/demuxer.c
index 9aaed21a8f..ef3bd36e29 100644
--- a/libmpdemux/demuxer.c
+++ b/libmpdemux/demuxer.c
@@ -779,7 +779,7 @@ void ds_free_packs(demux_stream_t *ds)
ds->current = NULL;
ds->buffer = NULL;
ds->buffer_pos = ds->buffer_size;
- ds->pts = 0;
+ ds->pts = MP_NOPTS_VALUE;
ds->pts_bytes = 0;
}
diff --git a/mplayer.c b/mplayer.c
index 23a2636989..7f22b328b0 100644
--- a/mplayer.c
+++ b/mplayer.c
@@ -1855,6 +1855,9 @@ static double written_audio_pts(struct MPContext *mpctx)
// but not accurately known in sh_audio->i_bps.
a_pts = d_audio->pts;
+ if (a_pts == MP_NOPTS_VALUE)
+ return a_pts;
+
// ds_tell_pts returns bytes read after last timestamp from
// demuxing layer, decoder might use sh_audio->a_in_buffer for bytes
// it has read but not decoded
@@ -1885,8 +1888,10 @@ static double written_audio_pts(struct MPContext *mpctx)
// Return pts value corresponding to currently playing audio.
double playing_audio_pts(struct MPContext *mpctx)
{
- return written_audio_pts(mpctx) - mpctx->opts.playback_speed *
- ao_get_delay(mpctx->ao);
+ double pts = written_audio_pts(mpctx);
+ if (pts == MP_NOPTS_VALUE)
+ return pts;
+ return pts - mpctx->opts.playback_speed * ao_get_delay(mpctx->ao);
}
static bool is_av_sub(int type)