diff options
author | wm4 <wm4@nowhere> | 2014-03-26 16:51:17 +0100 |
---|---|---|
committer | wm4 <wm4@nowhere> | 2014-03-26 16:51:17 +0100 |
commit | 32d818f02b4ed471c0d9f1d23fff784294d83c44 (patch) | |
tree | ac38fb89f3ed64b2c18a6f5bd46e3ec050dbe7d5 /stream | |
parent | b342b1a30ea771e15b40c23143c95dc08bef0e55 (diff) | |
download | mpv-32d818f02b4ed471c0d9f1d23fff784294d83c44.tar.bz2 mpv-32d818f02b4ed471c0d9f1d23fff784294d83c44.tar.xz |
stream_cdda: fix track time accuracy
Don't use an integer division to get the time, since that would round on
second boundaries. Also round up the time by sector size. Seeking rounds
down due to alignment constraints, but if we round up the time, we can
make it land on the exact destination sector.
This fixes that the track change code printed the previous track when
seeking by chapter.
Diffstat (limited to 'stream')
-rw-r--r-- | stream/stream_cdda.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/stream/stream_cdda.c b/stream/stream_cdda.c index 529e3aa71c..347d6f993d 100644 --- a/stream/stream_cdda.c +++ b/stream/stream_cdda.c @@ -282,9 +282,9 @@ static int control(stream_t *stream, int cmd, void *arg) if (track > end_track) return STREAM_ERROR; int64_t sector = p->cd->disc_toc[track].dwStartSector; - int64_t pos = sector * CDIO_CD_FRAMESIZE_RAW; + int64_t pos = sector * (CDIO_CD_FRAMESIZE_RAW + 1) - 1; // Assume standard audio CD: 44.1khz, 2 channels, s16 samples - *(double *)arg = pos / (44100 * 2 * 2); + *(double *)arg = pos / (44100.0 * 2 * 2); return STREAM_OK; } } |