blob: 7b4dc36532bb192a1689dc84fb6da7fa97ab8dd7 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _LINUX_TIME_H
2#define _LINUX_TIME_H
3
4#include <linux/types.h>
5
6#ifdef __KERNEL__
Ingo Molnar57a55872006-01-09 20:52:26 -08007# include <linux/seqlock.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07008#endif
9
10#ifndef _STRUCT_TIMESPEC
11#define _STRUCT_TIMESPEC
12struct timespec {
13 time_t tv_sec; /* seconds */
14 long tv_nsec; /* nanoseconds */
15};
Ingo Molnar57a55872006-01-09 20:52:26 -080016#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070017
18struct timeval {
19 time_t tv_sec; /* seconds */
20 suseconds_t tv_usec; /* microseconds */
21};
22
23struct timezone {
24 int tz_minuteswest; /* minutes west of Greenwich */
25 int tz_dsttime; /* type of dst correction */
26};
27
28#ifdef __KERNEL__
29
Ingo Molnar57a55872006-01-09 20:52:26 -080030/* Parameters used to convert the timespec values: */
31#define MSEC_PER_SEC 1000L
32#define USEC_PER_SEC 1000000L
33#define NSEC_PER_SEC 1000000000L
34#define NSEC_PER_USEC 1000L
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
Ingo Molnar57a55872006-01-09 20:52:26 -080036static __inline__ int timespec_equal(struct timespec *a, struct timespec *b)
37{
Linus Torvalds1da177e2005-04-16 15:20:36 -070038 return (a->tv_sec == b->tv_sec) && (a->tv_nsec == b->tv_nsec);
Ingo Molnar57a55872006-01-09 20:52:26 -080039}
Linus Torvalds1da177e2005-04-16 15:20:36 -070040
Ingo Molnarf4818902006-01-09 20:52:23 -080041extern unsigned long mktime(const unsigned int year, const unsigned int mon,
42 const unsigned int day, const unsigned int hour,
43 const unsigned int min, const unsigned int sec);
44
45extern void set_normalized_timespec(struct timespec *ts, time_t sec, long nsec);
Linus Torvalds1da177e2005-04-16 15:20:36 -070046
Thomas Gleixner5f82b2b2006-01-09 20:52:29 -080047/*
48 * Returns true if the timespec is norm, false if denorm:
49 */
50#define timespec_valid(ts) \
Chris Wrightbd3f8f22006-01-31 19:10:23 -080051 (((ts)->tv_sec >= 0) && (((unsigned long) (ts)->tv_nsec) < NSEC_PER_SEC))
Thomas Gleixner5f82b2b2006-01-09 20:52:29 -080052
Thomas Gleixnerf8f46da2006-01-09 20:52:30 -080053/*
54 * 64-bit nanosec type. Large enough to span 292+ years in nanosecond
55 * resolution. Ought to be enough for a while.
56 */
57typedef s64 nsec_t;
58
Linus Torvalds1da177e2005-04-16 15:20:36 -070059extern struct timespec xtime;
60extern struct timespec wall_to_monotonic;
61extern seqlock_t xtime_lock;
62
63static inline unsigned long get_seconds(void)
Ingo Molnar57a55872006-01-09 20:52:26 -080064{
Linus Torvalds1da177e2005-04-16 15:20:36 -070065 return xtime.tv_sec;
66}
67
68struct timespec current_kernel_time(void);
69
Ingo Molnar57a55872006-01-09 20:52:26 -080070#define CURRENT_TIME (current_kernel_time())
71#define CURRENT_TIME_SEC ((struct timespec) { xtime.tv_sec, 0 })
Linus Torvalds1da177e2005-04-16 15:20:36 -070072
73extern void do_gettimeofday(struct timeval *tv);
74extern int do_settimeofday(struct timespec *tv);
75extern int do_sys_settimeofday(struct timespec *tv, struct timezone *tz);
Thomas Gleixnerbecf8b52006-01-09 20:52:38 -080076#define do_posix_clock_monotonic_gettime(ts) ktime_get_ts(ts)
Ulrich Drepper5590ff02006-01-18 17:43:53 -080077extern long do_utimes(int dfd, char __user *filename, struct timeval *times);
Linus Torvalds1da177e2005-04-16 15:20:36 -070078struct itimerval;
Ingo Molnar57a55872006-01-09 20:52:26 -080079extern int do_setitimer(int which, struct itimerval *value,
80 struct itimerval *ovalue);
Linus Torvalds1da177e2005-04-16 15:20:36 -070081extern int do_getitimer(int which, struct itimerval *value);
Ingo Molnar57a55872006-01-09 20:52:26 -080082extern void getnstimeofday(struct timespec *tv);
Linus Torvalds1da177e2005-04-16 15:20:36 -070083
84extern struct timespec timespec_trunc(struct timespec t, unsigned gran);
85
Thomas Gleixnerf8f46da2006-01-09 20:52:30 -080086/**
87 * timespec_to_ns - Convert timespec to nanoseconds
88 * @ts: pointer to the timespec variable to be converted
89 *
90 * Returns the scalar nanosecond representation of the timespec
91 * parameter.
92 */
93static inline nsec_t timespec_to_ns(const struct timespec *ts)
94{
95 return ((nsec_t) ts->tv_sec * NSEC_PER_SEC) + ts->tv_nsec;
96}
97
98/**
99 * timeval_to_ns - Convert timeval to nanoseconds
100 * @ts: pointer to the timeval variable to be converted
101 *
102 * Returns the scalar nanosecond representation of the timeval
103 * parameter.
104 */
105static inline nsec_t timeval_to_ns(const struct timeval *tv)
106{
107 return ((nsec_t) tv->tv_sec * NSEC_PER_SEC) +
108 tv->tv_usec * NSEC_PER_USEC;
109}
110
111/**
112 * ns_to_timespec - Convert nanoseconds to timespec
113 * @nsec: the nanoseconds value to be converted
114 *
115 * Returns the timespec representation of the nsec parameter.
116 */
117extern struct timespec ns_to_timespec(const nsec_t nsec);
118
119/**
120 * ns_to_timeval - Convert nanoseconds to timeval
121 * @nsec: the nanoseconds value to be converted
122 *
123 * Returns the timeval representation of the nsec parameter.
124 */
125extern struct timeval ns_to_timeval(const nsec_t nsec);
126
Linus Torvalds1da177e2005-04-16 15:20:36 -0700127#endif /* __KERNEL__ */
128
129#define NFDBITS __NFDBITS
130
131#define FD_SETSIZE __FD_SETSIZE
132#define FD_SET(fd,fdsetp) __FD_SET(fd,fdsetp)
133#define FD_CLR(fd,fdsetp) __FD_CLR(fd,fdsetp)
134#define FD_ISSET(fd,fdsetp) __FD_ISSET(fd,fdsetp)
135#define FD_ZERO(fdsetp) __FD_ZERO(fdsetp)
136
137/*
138 * Names of the interval timers, and structure
Ingo Molnar57a55872006-01-09 20:52:26 -0800139 * defining a timer setting:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700140 */
Ingo Molnar57a55872006-01-09 20:52:26 -0800141#define ITIMER_REAL 0
142#define ITIMER_VIRTUAL 1
143#define ITIMER_PROF 2
Linus Torvalds1da177e2005-04-16 15:20:36 -0700144
Ingo Molnar57a55872006-01-09 20:52:26 -0800145struct itimerspec {
146 struct timespec it_interval; /* timer period */
147 struct timespec it_value; /* timer expiration */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700148};
149
Ingo Molnar57a55872006-01-09 20:52:26 -0800150struct itimerval {
151 struct timeval it_interval; /* timer interval */
152 struct timeval it_value; /* current value */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700153};
154
Linus Torvalds1da177e2005-04-16 15:20:36 -0700155/*
Ingo Molnar57a55872006-01-09 20:52:26 -0800156 * The IDs of the various system clocks (for POSIX.1b interval timers):
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157 */
Ingo Molnar1ad106c2006-01-09 20:52:25 -0800158#define CLOCK_REALTIME 0
159#define CLOCK_MONOTONIC 1
160#define CLOCK_PROCESS_CPUTIME_ID 2
161#define CLOCK_THREAD_CPUTIME_ID 3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700162
163/*
Ingo Molnar57a55872006-01-09 20:52:26 -0800164 * The IDs of various hardware clocks:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700165 */
Ingo Molnar1ad106c2006-01-09 20:52:25 -0800166#define CLOCK_SGI_CYCLE 10
167#define MAX_CLOCKS 16
168#define CLOCKS_MASK (CLOCK_REALTIME | CLOCK_MONOTONIC)
169#define CLOCKS_MONO CLOCK_MONOTONIC
Linus Torvalds1da177e2005-04-16 15:20:36 -0700170
171/*
Ingo Molnar57a55872006-01-09 20:52:26 -0800172 * The various flags for setting POSIX.1b interval timers:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700173 */
Ingo Molnar1ad106c2006-01-09 20:52:25 -0800174#define TIMER_ABSTIME 0x01
Linus Torvalds1da177e2005-04-16 15:20:36 -0700175
176#endif