jiffies.h revision 1.11 1 /* $NetBSD: jiffies.h,v 1.11 2018/08/27 07:05:13 riastradh Exp $ */
2
3 /*-
4 * Copyright (c) 2013 The NetBSD Foundation, Inc.
5 * All rights reserved.
6 *
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Taylor R. Campbell.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 #ifndef _LINUX_JIFFIES_H_
33 #define _LINUX_JIFFIES_H_
34
35 #include <sys/param.h>
36 #include <sys/kernel.h>
37
38 #define jiffies hardclock_ticks
39 #define jiffies_64 hardclock_ticks /* XXX */
40
41 /* XXX Er, what? */
42 #define MAX_JIFFY_OFFSET ((INT_MAX >> 1) - 1)
43
44 static inline uint64_t
45 get_jiffies_64(void)
46 {
47
48 return (uint64_t)(unsigned)hardclock_ticks;
49 }
50
51 static inline uint64_t
52 nsecs_to_jiffies64(uint64_t nsec)
53 {
54
55 /* XXX Arbitrary cutoff, should review the arithmetic. */
56 if (((1000000000 % hz) == 0) || (nsec >= 20000000000ul))
57 return (nsec/1000000000)*hz;
58 else
59 return (nsec*hz)/1000000000;
60 }
61
62 static inline unsigned int
63 msecs_to_jiffies(unsigned int msec)
64 {
65 return mstohz(msec);
66 }
67
68 static inline unsigned int
69 jiffies_to_msecs(unsigned int j)
70 {
71 return hztoms(j);
72 }
73
74 static inline unsigned int
75 usecs_to_jiffies(unsigned int usec)
76 {
77 const struct timeval tv = {
78 .tv_sec = usec / 1000000,
79 .tv_usec = usec % 1000000,
80 };
81
82 return tvtohz(&tv);
83 }
84
85 static inline unsigned int
86 jiffies_to_usecs(unsigned int j)
87 {
88
89 /* XXX Do better arithmetic. */
90 return (unsigned int)((unsigned long)j*1000000/hz);
91 }
92
93 static inline unsigned int
94 timespec_to_jiffies(const struct timespec *ts)
95 {
96 return tstohz(ts);
97 }
98
99 /* XXX long is the wrong type here times... */
100
101 #define __linux_time_compare(A, OP, B) (((long)(A) - (long)(B)) OP 0)
102
103 static inline bool
104 time_after(unsigned long a, unsigned long b)
105 {
106 return __linux_time_compare(a, >, b);
107 }
108
109 static inline bool
110 time_after_eq(unsigned long a, unsigned long b)
111 {
112 return __linux_time_compare(a, >=, b);
113 }
114
115 static inline bool
116 time_before(unsigned long a, unsigned long b)
117 {
118 return __linux_time_compare(a, <, b);
119 }
120
121 static inline bool
122 time_before_eq(unsigned long a, unsigned long b)
123 {
124 return __linux_time_compare(a, <=, b);
125 }
126
127 #endif /* _LINUX_JIFFIES_H_ */
128