2009-03-01 13:13:25 +00:00
|
|
|
/*
|
|
|
|
* precise timer routines for Linux
|
|
|
|
* copyright (C) LGB & A'rpi/ASTRAL
|
|
|
|
*
|
|
|
|
* This file is part of MPlayer.
|
|
|
|
*
|
|
|
|
* MPlayer is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* MPlayer is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with MPlayer; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
2001-02-24 20:28:24 +00:00
|
|
|
|
|
|
|
#include <unistd.h>
|
2004-10-11 19:26:13 +00:00
|
|
|
#ifdef __BEOS__
|
|
|
|
#define usleep(t) snooze(t)
|
|
|
|
#endif
|
2002-03-24 00:58:27 +00:00
|
|
|
#include <stdlib.h>
|
2001-10-25 23:34:14 +00:00
|
|
|
#include <time.h>
|
2001-02-24 20:28:24 +00:00
|
|
|
#include <sys/time.h>
|
2005-11-14 00:30:37 +00:00
|
|
|
#include "config.h"
|
2001-02-24 20:28:24 +00:00
|
|
|
|
2004-08-04 16:14:43 +00:00
|
|
|
const char *timer_name =
|
2004-08-04 15:48:43 +00:00
|
|
|
#ifdef HAVE_NANOSLEEP
|
|
|
|
"nanosleep()";
|
|
|
|
#else
|
|
|
|
"usleep()";
|
|
|
|
#endif
|
|
|
|
|
2001-10-19 02:16:21 +00:00
|
|
|
int usec_sleep(int usec_delay)
|
|
|
|
{
|
2001-11-23 18:25:32 +00:00
|
|
|
#ifdef HAVE_NANOSLEEP
|
2001-10-19 02:16:21 +00:00
|
|
|
struct timespec ts;
|
|
|
|
ts.tv_sec = usec_delay / 1000000;
|
|
|
|
ts.tv_nsec = (usec_delay % 1000000) * 1000;
|
|
|
|
return nanosleep(&ts, NULL);
|
|
|
|
#else
|
|
|
|
return usleep(usec_delay);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2001-03-13 00:13:18 +00:00
|
|
|
// Returns current time in microseconds
|
2006-02-09 14:08:03 +00:00
|
|
|
unsigned int GetTimer(void){
|
2001-02-24 20:28:24 +00:00
|
|
|
struct timeval tv;
|
|
|
|
// float s;
|
2006-05-13 05:56:40 +00:00
|
|
|
gettimeofday(&tv,NULL);
|
2001-02-24 20:28:24 +00:00
|
|
|
// s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec;
|
2008-05-16 09:42:28 +00:00
|
|
|
return tv.tv_sec * 1000000 + tv.tv_usec;
|
2001-02-24 20:28:24 +00:00
|
|
|
}
|
|
|
|
|
2002-01-27 17:59:12 +00:00
|
|
|
// Returns current time in milliseconds
|
2006-02-09 14:08:03 +00:00
|
|
|
unsigned int GetTimerMS(void){
|
2002-01-27 17:59:12 +00:00
|
|
|
struct timeval tv;
|
|
|
|
// float s;
|
2006-05-13 05:56:40 +00:00
|
|
|
gettimeofday(&tv,NULL);
|
2002-01-27 17:59:12 +00:00
|
|
|
// s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec;
|
2008-05-16 09:42:28 +00:00
|
|
|
return tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
2002-01-27 17:59:12 +00:00
|
|
|
}
|
|
|
|
|
2001-02-24 20:28:24 +00:00
|
|
|
static unsigned int RelativeTime=0;
|
|
|
|
|
|
|
|
// Returns time spent between now and last call in seconds
|
2006-02-09 14:08:03 +00:00
|
|
|
float GetRelativeTime(void){
|
2001-02-24 20:28:24 +00:00
|
|
|
unsigned int t,r;
|
|
|
|
t=GetTimer();
|
|
|
|
// t*=16;printf("time=%ud\n",t);
|
|
|
|
r=t-RelativeTime;
|
|
|
|
RelativeTime=t;
|
|
|
|
return (float)r * 0.000001F;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Initialize timer, must be called at least once at start
|
2006-02-09 14:08:03 +00:00
|
|
|
void InitTimer(void){
|
2001-02-24 20:28:24 +00:00
|
|
|
GetRelativeTime();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if 0
|
2007-12-28 23:12:20 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
int main(void){
|
2001-02-24 20:28:24 +00:00
|
|
|
float t=0;
|
|
|
|
InitTimer();
|
|
|
|
while(1){ t+=GetRelativeTime();printf("time= %10.6f\r",t);fflush(stdout); }
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|