summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJames Courtier-Dutton <jcdutton@users.sourceforge.net>2001-08-26 09:32:38 +0000
committerJames Courtier-Dutton <jcdutton@users.sourceforge.net>2001-08-26 09:32:38 +0000
commit89fe2fba9955a9e21bd826a9c69a3bc75307a001 (patch)
tree3e388541430c8c37269a3fa7fae5ca1243d35c62 /src
parenta86b676d5c417d23e30e3455d4b1ce6cf828b478 (diff)
downloadxine-lib-89fe2fba9955a9e21bd826a9c69a3bc75307a001.tar.gz
xine-lib-89fe2fba9955a9e21bd826a9c69a3bc75307a001.tar.bz2
Speed modes work again.
CVS patchset: 497 CVS date: 2001/08/26 09:32:38
Diffstat (limited to 'src')
-rw-r--r--src/xine-engine/metronom.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/src/xine-engine/metronom.c b/src/xine-engine/metronom.c
index 7ed99f96f..c3b1dadf9 100644
--- a/src/xine-engine/metronom.c
+++ b/src/xine-engine/metronom.c
@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*
- * $Id: metronom.c,v 1.20 2001/08/25 21:34:25 jcdutton Exp $
+ * $Id: metronom.c,v 1.21 2001/08/26 09:32:38 jcdutton Exp $
*/
#ifdef HAVE_CONFIG_H
@@ -70,11 +70,36 @@ static int unixscr_get_priority (scr_plugin_t *scr) {
return 5; /* low priority */
}
+/* Only call this when already mutex locked */
+static void unixscr_set_pivot (unixscr_t *this) {
+
+ struct timeval tv;
+ uint32_t pts;
+ double pts_calc;
+
+ gettimeofday(&tv, NULL);
+
+ pts_calc = (tv.tv_sec - this->cur_time.tv_sec) * this->speed_factor;
+ pts_calc += (tv.tv_usec - this->cur_time.tv_usec) * this->speed_factor / 1e6;
+
+ pts = this->cur_pts + pts_calc;
+/* This next part introduces a one off inaccuracy
+ * to the scr due to rounding tv to pts.
+ */
+ this->cur_time.tv_sec=tv.tv_sec;
+ this->cur_time.tv_usec=tv.tv_usec;
+ printf("Old:New PTS=%d:%d\n",this->cur_pts,pts);
+
+ this->cur_pts=pts;
+
+ return ;
+}
+
static int unixscr_set_speed (scr_plugin_t *scr, int speed) {
unixscr_t *this = (unixscr_t*) scr;
pthread_mutex_lock (&this->lock);
-
+ unixscr_set_pivot( this );
this->speed_factor = (double) speed * 90000.0 / 4.0;
pthread_mutex_unlock (&this->lock);
@@ -135,7 +160,6 @@ static scr_plugin_t* unixscr_init () {
this->scr.adjust = unixscr_adjust;
this->scr.start = unixscr_start;
this->scr.get_current = unixscr_get_current;
-
unixscr_set_speed (&this->scr, SPEED_NORMAL);
pthread_mutex_init (&this->lock, NULL);