2001-02-24 21:28:24 +01:00
|
|
|
// Precise timer routines for LINUX (C) LGB & A'rpi/ASTRAL
|
|
|
|
|
|
|
|
#include <unistd.h>
|
2004-10-11 21:26:13 +02:00
|
|
|
#ifdef __BEOS__
|
|
|
|
#define usleep(t) snooze(t)
|
|
|
|
#endif
|
2002-03-24 01:58:27 +01:00
|
|
|
#include <stdlib.h>
|
2001-10-26 01:34:14 +02:00
|
|
|
#include <time.h>
|
2001-02-24 21:28:24 +01:00
|
|
|
#include <sys/time.h>
|
2005-11-14 01:30:37 +01:00
|
|
|
#include "config.h"
|
2001-02-24 21:28:24 +01:00
|
|
|
|
2004-08-04 18:14:43 +02:00
|
|
|
const char *timer_name =
|
2004-08-04 17:48:43 +02:00
|
|
|
#ifdef HAVE_NANOSLEEP
|
|
|
|
"nanosleep()";
|
|
|
|
#else
|
|
|
|
"usleep()";
|
|
|
|
#endif
|
|
|
|
|
2001-10-19 04:16:21 +02:00
|
|
|
int usec_sleep(int usec_delay)
|
|
|
|
{
|
2001-11-23 19:25:32 +01:00
|
|
|
#ifdef HAVE_NANOSLEEP
|
2001-10-19 04:16:21 +02: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 01:13:18 +01:00
|
|
|
// Returns current time in microseconds
|
2006-02-09 15:08:03 +01:00
|
|
|
unsigned int GetTimer(void){
|
2001-02-24 21:28:24 +01:00
|
|
|
struct timeval tv;
|
|
|
|
// float s;
|
2006-05-13 07:56:40 +02:00
|
|
|
gettimeofday(&tv,NULL);
|
2001-02-24 21:28:24 +01:00
|
|
|
// s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec;
|
|
|
|
return (tv.tv_sec*1000000+tv.tv_usec);
|
|
|
|
}
|
|
|
|
|
2002-01-27 18:59:12 +01:00
|
|
|
// Returns current time in milliseconds
|
2006-02-09 15:08:03 +01:00
|
|
|
unsigned int GetTimerMS(void){
|
2002-01-27 18:59:12 +01:00
|
|
|
struct timeval tv;
|
|
|
|
// float s;
|
2006-05-13 07:56:40 +02:00
|
|
|
gettimeofday(&tv,NULL);
|
2002-01-27 18:59:12 +01:00
|
|
|
// s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec;
|
|
|
|
return (tv.tv_sec*1000+tv.tv_usec/1000);
|
|
|
|
}
|
|
|
|
|
2001-02-24 21:28:24 +01:00
|
|
|
static unsigned int RelativeTime=0;
|
|
|
|
|
|
|
|
// Returns time spent between now and last call in seconds
|
2006-02-09 15:08:03 +01:00
|
|
|
float GetRelativeTime(void){
|
2001-02-24 21:28:24 +01: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 15:08:03 +01:00
|
|
|
void InitTimer(void){
|
2001-02-24 21:28:24 +01:00
|
|
|
GetRelativeTime();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if 0
|
2007-12-29 00:12:20 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
int main(void){
|
2001-02-24 21:28:24 +01:00
|
|
|
float t=0;
|
|
|
|
InitTimer();
|
|
|
|
while(1){ t+=GetRelativeTime();printf("time= %10.6f\r",t);fflush(stdout); }
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|