1*83b51cadSriastradh /* $NetBSD: jiffies.h,v 1.14 2022/03/18 23:32:49 riastradh Exp $ */
22adb3a73Sriastradh
32adb3a73Sriastradh /*-
42adb3a73Sriastradh * Copyright (c) 2013 The NetBSD Foundation, Inc.
52adb3a73Sriastradh * All rights reserved.
62adb3a73Sriastradh *
72adb3a73Sriastradh * This code is derived from software contributed to The NetBSD Foundation
82adb3a73Sriastradh * by Taylor R. Campbell.
92adb3a73Sriastradh *
102adb3a73Sriastradh * Redistribution and use in source and binary forms, with or without
112adb3a73Sriastradh * modification, are permitted provided that the following conditions
122adb3a73Sriastradh * are met:
132adb3a73Sriastradh * 1. Redistributions of source code must retain the above copyright
142adb3a73Sriastradh * notice, this list of conditions and the following disclaimer.
152adb3a73Sriastradh * 2. Redistributions in binary form must reproduce the above copyright
162adb3a73Sriastradh * notice, this list of conditions and the following disclaimer in the
172adb3a73Sriastradh * documentation and/or other materials provided with the distribution.
182adb3a73Sriastradh *
192adb3a73Sriastradh * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
202adb3a73Sriastradh * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
212adb3a73Sriastradh * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
222adb3a73Sriastradh * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
232adb3a73Sriastradh * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
242adb3a73Sriastradh * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
252adb3a73Sriastradh * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
262adb3a73Sriastradh * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
272adb3a73Sriastradh * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
282adb3a73Sriastradh * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
292adb3a73Sriastradh * POSSIBILITY OF SUCH DAMAGE.
302adb3a73Sriastradh */
312adb3a73Sriastradh
322adb3a73Sriastradh #ifndef _LINUX_JIFFIES_H_
332adb3a73Sriastradh #define _LINUX_JIFFIES_H_
342adb3a73Sriastradh
352adb3a73Sriastradh #include <sys/param.h>
362adb3a73Sriastradh #include <sys/kernel.h>
372adb3a73Sriastradh
381b077480Smaya #include <asm/param.h> /* HZ */
391b077480Smaya
401b077480Smaya #include <linux/math64.h>
411b077480Smaya
42*83b51cadSriastradh #define jiffies getticks()
43*83b51cadSriastradh #define jiffies_64 getticks() /* XXX */
442adb3a73Sriastradh
45fceff80cSriastradh /* XXX Er, what? */
46fceff80cSriastradh #define MAX_JIFFY_OFFSET ((INT_MAX >> 1) - 1)
47fceff80cSriastradh
48d2707134Sriastradh static inline uint64_t
get_jiffies_64(void)4913491bfaSriastradh get_jiffies_64(void)
5013491bfaSriastradh {
5113491bfaSriastradh
52*83b51cadSriastradh return (uint64_t)(unsigned)getticks();
5313491bfaSriastradh }
5413491bfaSriastradh
5513491bfaSriastradh static inline uint64_t
nsecs_to_jiffies64(uint64_t nsec)56c3149878Sriastradh nsecs_to_jiffies64(uint64_t nsec)
57d2707134Sriastradh {
58c3149878Sriastradh
59c3149878Sriastradh /* XXX Arbitrary cutoff, should review the arithmetic. */
60c1c961b5Sriastradh if (((1000000000 % hz) == 0) || (nsec >= 20000000000ul))
61c3149878Sriastradh return (nsec/1000000000)*hz;
62c3149878Sriastradh else
63c3149878Sriastradh return (nsec*hz)/1000000000;
64d2707134Sriastradh }
65d2707134Sriastradh
662b452a32Sriastradh static inline uint32_t
nsecs_to_jiffies(uint64_t nsec)672b452a32Sriastradh nsecs_to_jiffies(uint64_t nsec)
682b452a32Sriastradh {
692b452a32Sriastradh
702b452a32Sriastradh /* XXX Not sure what else to do but truncate... */
712b452a32Sriastradh return (uint32_t)nsecs_to_jiffies64(nsec);
722b452a32Sriastradh }
732b452a32Sriastradh
742adb3a73Sriastradh static inline unsigned int
msecs_to_jiffies(unsigned int msec)752adb3a73Sriastradh msecs_to_jiffies(unsigned int msec)
762adb3a73Sriastradh {
772adb3a73Sriastradh return mstohz(msec);
782adb3a73Sriastradh }
792adb3a73Sriastradh
802adb3a73Sriastradh static inline unsigned int
jiffies_to_msecs(unsigned int j)812adb3a73Sriastradh jiffies_to_msecs(unsigned int j)
822adb3a73Sriastradh {
832adb3a73Sriastradh return hztoms(j);
842adb3a73Sriastradh }
852adb3a73Sriastradh
862adb3a73Sriastradh static inline unsigned int
usecs_to_jiffies(unsigned int usec)872adb3a73Sriastradh usecs_to_jiffies(unsigned int usec)
882adb3a73Sriastradh {
89d00c8d93Sriastradh const struct timeval tv = {
90d00c8d93Sriastradh .tv_sec = usec / 1000000,
91d00c8d93Sriastradh .tv_usec = usec % 1000000,
92d00c8d93Sriastradh };
9383a1b0a0Sriastradh
94d00c8d93Sriastradh return tvtohz(&tv);
952adb3a73Sriastradh }
962adb3a73Sriastradh
972adb3a73Sriastradh static inline unsigned int
jiffies_to_usecs(unsigned int j)981a9ee998Sriastradh jiffies_to_usecs(unsigned int j)
991a9ee998Sriastradh {
1001a9ee998Sriastradh
1011a9ee998Sriastradh /* XXX Do better arithmetic. */
1021a9ee998Sriastradh return (unsigned int)((unsigned long)j*1000000/hz);
1031a9ee998Sriastradh }
1041a9ee998Sriastradh
1051a9ee998Sriastradh static inline unsigned int
timespec_to_jiffies(const struct timespec * ts)1062adb3a73Sriastradh timespec_to_jiffies(const struct timespec *ts)
1072adb3a73Sriastradh {
1082adb3a73Sriastradh return tstohz(ts);
1092adb3a73Sriastradh }
1102adb3a73Sriastradh
1112adb3a73Sriastradh /* XXX long is the wrong type here times... */
1122adb3a73Sriastradh
1132adb3a73Sriastradh #define __linux_time_compare(A, OP, B) (((long)(A) - (long)(B)) OP 0)
1142adb3a73Sriastradh
1152adb3a73Sriastradh static inline bool
time_after(unsigned long a,unsigned long b)1162adb3a73Sriastradh time_after(unsigned long a, unsigned long b)
1172adb3a73Sriastradh {
1182adb3a73Sriastradh return __linux_time_compare(a, >, b);
1192adb3a73Sriastradh }
1202adb3a73Sriastradh
1212adb3a73Sriastradh static inline bool
time_after_eq(unsigned long a,unsigned long b)1222adb3a73Sriastradh time_after_eq(unsigned long a, unsigned long b)
1232adb3a73Sriastradh {
1242adb3a73Sriastradh return __linux_time_compare(a, >=, b);
1252adb3a73Sriastradh }
1262adb3a73Sriastradh
1272adb3a73Sriastradh static inline bool
time_before(unsigned long a,unsigned long b)1282adb3a73Sriastradh time_before(unsigned long a, unsigned long b)
1292adb3a73Sriastradh {
1302adb3a73Sriastradh return __linux_time_compare(a, <, b);
1312adb3a73Sriastradh }
1322adb3a73Sriastradh
1332adb3a73Sriastradh static inline bool
time_before_eq(unsigned long a,unsigned long b)1342adb3a73Sriastradh time_before_eq(unsigned long a, unsigned long b)
1352adb3a73Sriastradh {
1362adb3a73Sriastradh return __linux_time_compare(a, <=, b);
1372adb3a73Sriastradh }
1382adb3a73Sriastradh
1392adb3a73Sriastradh #endif /* _LINUX_JIFFIES_H_ */
140