aboutsummaryrefslogtreecommitdiff
path: root/time
diff options
context:
space:
mode:
Diffstat (limited to 'time')
-rw-r--r--time/Makefile5
-rw-r--r--time/time.h48
2 files changed, 51 insertions, 2 deletions
diff --git a/time/Makefile b/time/Makefile
index c0cbb91..8986e96 100644
--- a/time/Makefile
+++ b/time/Makefile
@@ -28,7 +28,10 @@ routines := offtime asctime clock ctime ctime_r difftime \
gettimeofday settimeofday adjtime tzset \
tzfile getitimer setitimer \
stime dysize timegm ftime \
- strptime getdate wcsftime
+ strptime getdate wcsftime \
+ clock_getres clock_gettime clock_setres \
+ timer_create timer_delete timer_getoverr \
+ timer_gettime timer_settime
tests := test_time clocktest tst-posixtz tst-strptime tst_wcsftime
diff --git a/time/time.h b/time/time.h
index 0871561..7479e8f 100644
--- a/time/time.h
+++ b/time/time.h
@@ -78,7 +78,7 @@ typedef __time_t time_t;
((defined _TIME_H && defined __USE_POSIX199309) || defined __need_timespec)
# define __timespec_defined 1
-/* POSIX.4 structure for a time value. This is like a `struct timeval' but
+/* POSIX.1b structure for a time value. This is like a `struct timeval' but
has nanoseconds instead of microseconds. */
struct timespec
{
@@ -114,6 +114,22 @@ struct tm
};
+#ifdef __USE_POSIX199309
+/* Clock ID used in clock and timer functions. */
+typedef __clockid_t clockid_t;
+
+/* Timer ID returned by `timer_create'. */
+typedef __timer_t timer_t;
+
+/* POSIX.1b structure for timer start values and intervals. */
+struct itimerspec
+ {
+ struct timespec it_interval;
+ struct timespec it_value;
+ };
+#endif /* POSIX.1b */
+
+
/* Time used by the program so far (user time + system time).
The result / CLOCKS_PER_SECOND is program time in seconds. */
extern clock_t clock __P ((void));
@@ -239,6 +255,36 @@ extern int dysize __P ((int __year));
/* Pause execution for a number of nanoseconds. */
extern int nanosleep __P ((__const struct timespec *__requested_time,
struct timespec *__remaining));
+
+
+/* Get resolution of clock CLOCK_ID. */
+extern int clock_getres __P ((clockid_t __clock_id, struct timespec *__res));
+
+/* Get current value of clock CLOCK_ID and store it in TP. */
+extern int clock_gettime __P ((clockid_t __clock_id, struct timespec *__tp));
+
+/* Set clock CLOCK_ID to value TP. */
+extern int clock_settime __P ((clockid_t __clock_id,
+ __const struct timespec *__tp));
+
+
+/* Create new per-process timer using CLOCK_ID. */
+extern int timer_create __P ((clockid_t __clock_id, struct sigevent *__evp,
+ timer_t *__timerid));
+
+/* Delete timer TIMERID. */
+extern int timer_delete __P ((timer_t __timerid));
+
+/* Set timer TIMERID to VALUE, returning old value in OVLAUE. */
+extern int timer_settime __P ((timer_t __timerid, int __flags,
+ __const struct itimerspec *__value,
+ struct itimerspec *__ovalue));
+
+/* Get current value of timer TIMERID and store it in VLAUE. */
+extern int timer_gettime __P ((timer_t __timerid, struct itimerspec *__value));
+
+/* Get expiration overrun for timer TIMERID. */
+extern int timer_getoverrun __P ((timer_t __timerid));
# endif