Mercurial > mplayer.hg
annotate osdep/timer-lx.c @ 18226:fcf90803a951
Add properties to get/set the stream position and get the stream
start pos, end pos and length. Based on Reimar's patch.
author | albeu |
---|---|
date | Sun, 23 Apr 2006 15:39:51 +0000 |
parents | f580a7755ac5 |
children | 1f956f8f881e |
rev | line source |
---|---|
1 | 1 // Precise timer routines for LINUX (C) LGB & A'rpi/ASTRAL |
2 | |
3 #include <unistd.h> | |
13612 | 4 #ifdef __BEOS__ |
5 #define usleep(t) snooze(t) | |
6 #endif | |
5297 | 7 #include <stdlib.h> |
2476 | 8 #include <time.h> |
1 | 9 #include <sys/time.h> |
16985 | 10 #include "config.h" |
1 | 11 |
12955 | 12 const char *timer_name = |
12954 | 13 #ifdef HAVE_NANOSLEEP |
14 "nanosleep()"; | |
15 #else | |
16 "usleep()"; | |
17 #endif | |
18 | |
2273 | 19 int usec_sleep(int usec_delay) |
20 { | |
3090 | 21 #ifdef HAVE_NANOSLEEP |
2273 | 22 struct timespec ts; |
23 ts.tv_sec = usec_delay / 1000000; | |
24 ts.tv_nsec = (usec_delay % 1000000) * 1000; | |
25 return nanosleep(&ts, NULL); | |
26 #else | |
27 return usleep(usec_delay); | |
28 #endif | |
29 } | |
30 | |
99 | 31 // Returns current time in microseconds |
17566
f580a7755ac5
Patch by Stefan Huehner / stefan % huehner ! org \
rathann
parents:
16985
diff
changeset
|
32 unsigned int GetTimer(void){ |
1 | 33 struct timeval tv; |
34 struct timezone tz; | |
35 // float s; | |
36 gettimeofday(&tv,&tz); | |
37 // s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec; | |
38 return (tv.tv_sec*1000000+tv.tv_usec); | |
39 } | |
40 | |
4385 | 41 // Returns current time in milliseconds |
17566
f580a7755ac5
Patch by Stefan Huehner / stefan % huehner ! org \
rathann
parents:
16985
diff
changeset
|
42 unsigned int GetTimerMS(void){ |
4385 | 43 struct timeval tv; |
44 struct timezone tz; | |
45 // float s; | |
46 gettimeofday(&tv,&tz); | |
47 // s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec; | |
48 return (tv.tv_sec*1000+tv.tv_usec/1000); | |
49 } | |
50 | |
1 | 51 static unsigned int RelativeTime=0; |
52 | |
53 // Returns time spent between now and last call in seconds | |
17566
f580a7755ac5
Patch by Stefan Huehner / stefan % huehner ! org \
rathann
parents:
16985
diff
changeset
|
54 float GetRelativeTime(void){ |
1 | 55 unsigned int t,r; |
56 t=GetTimer(); | |
57 // t*=16;printf("time=%ud\n",t); | |
58 r=t-RelativeTime; | |
59 RelativeTime=t; | |
60 return (float)r * 0.000001F; | |
61 } | |
62 | |
63 // Initialize timer, must be called at least once at start | |
17566
f580a7755ac5
Patch by Stefan Huehner / stefan % huehner ! org \
rathann
parents:
16985
diff
changeset
|
64 void InitTimer(void){ |
1 | 65 GetRelativeTime(); |
66 } | |
67 | |
68 | |
69 #if 0 | |
70 void main(){ | |
71 float t=0; | |
72 InitTimer(); | |
73 while(1){ t+=GetRelativeTime();printf("time= %10.6f\r",t);fflush(stdout); } | |
74 } | |
75 #endif | |
76 |