[PATCH] VFS: Permit filesystem to perform statfs with a known root dentry
[deliverable/linux.git] / include / linux / time.h
CommitLineData
1da177e4
LT
1#ifndef _LINUX_TIME_H
2#define _LINUX_TIME_H
3
4#include <linux/types.h>
5
6#ifdef __KERNEL__
57a55875 7# include <linux/seqlock.h>
1da177e4
LT
8#endif
9
10#ifndef _STRUCT_TIMESPEC
11#define _STRUCT_TIMESPEC
12struct timespec {
13 time_t tv_sec; /* seconds */
14 long tv_nsec; /* nanoseconds */
15};
57a55875 16#endif
1da177e4
LT
17
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
57a55875
IM
30/* 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
1da177e4 35
643a6545 36static inline int timespec_equal(struct timespec *a, struct timespec *b)
57a55875 37{
1da177e4 38 return (a->tv_sec == b->tv_sec) && (a->tv_nsec == b->tv_nsec);
57a55875 39}
1da177e4 40
643a6545
AM
41/*
42 * lhs < rhs: return <0
43 * lhs == rhs: return 0
44 * lhs > rhs: return >0
45 */
46static inline int timespec_compare(struct timespec *lhs, struct timespec *rhs)
47{
48 if (lhs->tv_sec < rhs->tv_sec)
49 return -1;
50 if (lhs->tv_sec > rhs->tv_sec)
51 return 1;
52 return lhs->tv_nsec - rhs->tv_nsec;
53}
54
55static inline int timeval_compare(struct timeval *lhs, struct timeval *rhs)
56{
57 if (lhs->tv_sec < rhs->tv_sec)
58 return -1;
59 if (lhs->tv_sec > rhs->tv_sec)
60 return 1;
61 return lhs->tv_usec - rhs->tv_usec;
62}
63
f4818900
IM
64extern unsigned long mktime(const unsigned int year, const unsigned int mon,
65 const unsigned int day, const unsigned int hour,
66 const unsigned int min, const unsigned int sec);
67
68extern void set_normalized_timespec(struct timespec *ts, time_t sec, long nsec);
1da177e4 69
5f82b2b7
TG
70/*
71 * Returns true if the timespec is norm, false if denorm:
72 */
73#define timespec_valid(ts) \
bd3f8f2b 74 (((ts)->tv_sec >= 0) && (((unsigned long) (ts)->tv_nsec) < NSEC_PER_SEC))
5f82b2b7 75
1da177e4
LT
76extern struct timespec xtime;
77extern struct timespec wall_to_monotonic;
78extern seqlock_t xtime_lock;
79
80static inline unsigned long get_seconds(void)
57a55875 81{
1da177e4
LT
82 return xtime.tv_sec;
83}
84
85struct timespec current_kernel_time(void);
86
57a55875
IM
87#define CURRENT_TIME (current_kernel_time())
88#define CURRENT_TIME_SEC ((struct timespec) { xtime.tv_sec, 0 })
1da177e4
LT
89
90extern void do_gettimeofday(struct timeval *tv);
91extern int do_settimeofday(struct timespec *tv);
92extern int do_sys_settimeofday(struct timespec *tv, struct timezone *tz);
becf8b5d 93#define do_posix_clock_monotonic_gettime(ts) ktime_get_ts(ts)
5590ff0d 94extern long do_utimes(int dfd, char __user *filename, struct timeval *times);
1da177e4 95struct itimerval;
57a55875
IM
96extern int do_setitimer(int which, struct itimerval *value,
97 struct itimerval *ovalue);
c08b8a49 98extern unsigned int alarm_setitimer(unsigned int seconds);
1da177e4 99extern int do_getitimer(int which, struct itimerval *value);
57a55875 100extern void getnstimeofday(struct timespec *tv);
1da177e4
LT
101
102extern struct timespec timespec_trunc(struct timespec t, unsigned gran);
103
f8f46da3
TG
104/**
105 * timespec_to_ns - Convert timespec to nanoseconds
106 * @ts: pointer to the timespec variable to be converted
107 *
108 * Returns the scalar nanosecond representation of the timespec
109 * parameter.
110 */
df869b63 111static inline s64 timespec_to_ns(const struct timespec *ts)
f8f46da3 112{
df869b63 113 return ((s64) ts->tv_sec * NSEC_PER_SEC) + ts->tv_nsec;
f8f46da3
TG
114}
115
116/**
117 * timeval_to_ns - Convert timeval to nanoseconds
118 * @ts: pointer to the timeval variable to be converted
119 *
120 * Returns the scalar nanosecond representation of the timeval
121 * parameter.
122 */
df869b63 123static inline s64 timeval_to_ns(const struct timeval *tv)
f8f46da3 124{
df869b63 125 return ((s64) tv->tv_sec * NSEC_PER_SEC) +
f8f46da3
TG
126 tv->tv_usec * NSEC_PER_USEC;
127}
128
129/**
130 * ns_to_timespec - Convert nanoseconds to timespec
131 * @nsec: the nanoseconds value to be converted
132 *
133 * Returns the timespec representation of the nsec parameter.
134 */
df869b63 135extern struct timespec ns_to_timespec(const s64 nsec);
f8f46da3
TG
136
137/**
138 * ns_to_timeval - Convert nanoseconds to timeval
139 * @nsec: the nanoseconds value to be converted
140 *
141 * Returns the timeval representation of the nsec parameter.
142 */
df869b63 143extern struct timeval ns_to_timeval(const s64 nsec);
f8f46da3 144
1da177e4
LT
145#endif /* __KERNEL__ */
146
147#define NFDBITS __NFDBITS
148
149#define FD_SETSIZE __FD_SETSIZE
150#define FD_SET(fd,fdsetp) __FD_SET(fd,fdsetp)
151#define FD_CLR(fd,fdsetp) __FD_CLR(fd,fdsetp)
152#define FD_ISSET(fd,fdsetp) __FD_ISSET(fd,fdsetp)
153#define FD_ZERO(fdsetp) __FD_ZERO(fdsetp)
154
155/*
156 * Names of the interval timers, and structure
57a55875 157 * defining a timer setting:
1da177e4 158 */
57a55875
IM
159#define ITIMER_REAL 0
160#define ITIMER_VIRTUAL 1
161#define ITIMER_PROF 2
1da177e4 162
57a55875
IM
163struct itimerspec {
164 struct timespec it_interval; /* timer period */
165 struct timespec it_value; /* timer expiration */
1da177e4
LT
166};
167
57a55875
IM
168struct itimerval {
169 struct timeval it_interval; /* timer interval */
170 struct timeval it_value; /* current value */
1da177e4
LT
171};
172
1da177e4 173/*
57a55875 174 * The IDs of the various system clocks (for POSIX.1b interval timers):
1da177e4 175 */
1ad106ca
IM
176#define CLOCK_REALTIME 0
177#define CLOCK_MONOTONIC 1
178#define CLOCK_PROCESS_CPUTIME_ID 2
179#define CLOCK_THREAD_CPUTIME_ID 3
1da177e4
LT
180
181/*
57a55875 182 * The IDs of various hardware clocks:
1da177e4 183 */
1ad106ca
IM
184#define CLOCK_SGI_CYCLE 10
185#define MAX_CLOCKS 16
186#define CLOCKS_MASK (CLOCK_REALTIME | CLOCK_MONOTONIC)
187#define CLOCKS_MONO CLOCK_MONOTONIC
1da177e4
LT
188
189/*
57a55875 190 * The various flags for setting POSIX.1b interval timers:
1da177e4 191 */
1ad106ca 192#define TIMER_ABSTIME 0x01
1da177e4
LT
193
194#endif
This page took 0.179882 seconds and 5 git commands to generate.