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