blob: 1201155b220264deb3d8259c0cd91fc684d37b63 [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) \
51 (((ts)->tv_sec >= 0) && (((unsigned) (ts)->tv_nsec) < NSEC_PER_SEC))
52
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)
Ingo Molnar57a55872006-01-09 20:52:26 -080077extern long do_utimes(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);
Matt Helsley64123fd2005-12-12 00:37:09 -080083extern void getnstimestamp(struct timespec *ts);
Linus Torvalds1da177e2005-04-16 15:20:36 -070084
85extern struct timespec timespec_trunc(struct timespec t, unsigned gran);
86
Thomas Gleixnerf8f46da2006-01-09 20:52:30 -080087/**
88 * timespec_to_ns - Convert timespec to nanoseconds
89 * @ts: pointer to the timespec variable to be converted
90 *
91 * Returns the scalar nanosecond representation of the timespec
92 * parameter.
93 */
94static inline nsec_t timespec_to_ns(const struct timespec *ts)
95{
96 return ((nsec_t) ts->tv_sec * NSEC_PER_SEC) + ts->tv_nsec;
97}
98
99/**
100 * timeval_to_ns - Convert timeval to nanoseconds
101 * @ts: pointer to the timeval variable to be converted
102 *
103 * Returns the scalar nanosecond representation of the timeval
104 * parameter.
105 */
106static inline nsec_t timeval_to_ns(const struct timeval *tv)
107{
108 return ((nsec_t) tv->tv_sec * NSEC_PER_SEC) +
109 tv->tv_usec * NSEC_PER_USEC;
110}
111
112/**
113 * ns_to_timespec - Convert nanoseconds to timespec
114 * @nsec: the nanoseconds value to be converted
115 *
116 * Returns the timespec representation of the nsec parameter.
117 */
118extern struct timespec ns_to_timespec(const nsec_t nsec);
119
120/**
121 * ns_to_timeval - Convert nanoseconds to timeval
122 * @nsec: the nanoseconds value to be converted
123 *
124 * Returns the timeval representation of the nsec parameter.
125 */
126extern struct timeval ns_to_timeval(const nsec_t nsec);
127
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128#endif /* __KERNEL__ */
129
130#define NFDBITS __NFDBITS
131
132#define FD_SETSIZE __FD_SETSIZE
133#define FD_SET(fd,fdsetp) __FD_SET(fd,fdsetp)
134#define FD_CLR(fd,fdsetp) __FD_CLR(fd,fdsetp)
135#define FD_ISSET(fd,fdsetp) __FD_ISSET(fd,fdsetp)
136#define FD_ZERO(fdsetp) __FD_ZERO(fdsetp)
137
138/*
139 * Names of the interval timers, and structure
Ingo Molnar57a55872006-01-09 20:52:26 -0800140 * defining a timer setting:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700141 */
Ingo Molnar57a55872006-01-09 20:52:26 -0800142#define ITIMER_REAL 0
143#define ITIMER_VIRTUAL 1
144#define ITIMER_PROF 2
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145
Ingo Molnar57a55872006-01-09 20:52:26 -0800146struct itimerspec {
147 struct timespec it_interval; /* timer period */
148 struct timespec it_value; /* timer expiration */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149};
150
Ingo Molnar57a55872006-01-09 20:52:26 -0800151struct itimerval {
152 struct timeval it_interval; /* timer interval */
153 struct timeval it_value; /* current value */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700154};
155
Linus Torvalds1da177e2005-04-16 15:20:36 -0700156/*
Ingo Molnar57a55872006-01-09 20:52:26 -0800157 * The IDs of the various system clocks (for POSIX.1b interval timers):
Linus Torvalds1da177e2005-04-16 15:20:36 -0700158 */
Ingo Molnar1ad106c2006-01-09 20:52:25 -0800159#define CLOCK_REALTIME 0
160#define CLOCK_MONOTONIC 1
161#define CLOCK_PROCESS_CPUTIME_ID 2
162#define CLOCK_THREAD_CPUTIME_ID 3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700163
164/*
Ingo Molnar57a55872006-01-09 20:52:26 -0800165 * The IDs of various hardware clocks:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700166 */
Ingo Molnar1ad106c2006-01-09 20:52:25 -0800167#define CLOCK_SGI_CYCLE 10
168#define MAX_CLOCKS 16
169#define CLOCKS_MASK (CLOCK_REALTIME | CLOCK_MONOTONIC)
170#define CLOCKS_MONO CLOCK_MONOTONIC
Linus Torvalds1da177e2005-04-16 15:20:36 -0700171
172/*
Ingo Molnar57a55872006-01-09 20:52:26 -0800173 * The various flags for setting POSIX.1b interval timers:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700174 */
Ingo Molnar1ad106c2006-01-09 20:52:25 -0800175#define TIMER_ABSTIME 0x01
Linus Torvalds1da177e2005-04-16 15:20:36 -0700176
177#endif