math64.h revision 1.12 1 1.12 riastrad /* $NetBSD: math64.h,v 1.12 2021/12/19 11:48:34 riastradh Exp $ */
2 1.2 riastrad
3 1.2 riastrad /*-
4 1.2 riastrad * Copyright (c) 2013 The NetBSD Foundation, Inc.
5 1.2 riastrad * All rights reserved.
6 1.2 riastrad *
7 1.2 riastrad * This code is derived from software contributed to The NetBSD Foundation
8 1.2 riastrad * by Taylor R. Campbell.
9 1.2 riastrad *
10 1.2 riastrad * Redistribution and use in source and binary forms, with or without
11 1.2 riastrad * modification, are permitted provided that the following conditions
12 1.2 riastrad * are met:
13 1.2 riastrad * 1. Redistributions of source code must retain the above copyright
14 1.2 riastrad * notice, this list of conditions and the following disclaimer.
15 1.2 riastrad * 2. Redistributions in binary form must reproduce the above copyright
16 1.2 riastrad * notice, this list of conditions and the following disclaimer in the
17 1.2 riastrad * documentation and/or other materials provided with the distribution.
18 1.2 riastrad *
19 1.2 riastrad * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.2 riastrad * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.2 riastrad * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.2 riastrad * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.2 riastrad * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.2 riastrad * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.2 riastrad * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.2 riastrad * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.2 riastrad * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.2 riastrad * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.2 riastrad * POSSIBILITY OF SUCH DAMAGE.
30 1.2 riastrad */
31 1.2 riastrad
32 1.2 riastrad #ifndef _LINUX_MATH64_H_
33 1.2 riastrad #define _LINUX_MATH64_H_
34 1.2 riastrad
35 1.2 riastrad #include <sys/types.h>
36 1.2 riastrad
37 1.3 riastrad #include <asm/div64.h>
38 1.3 riastrad
39 1.8 riastrad #include <linux/types.h>
40 1.8 riastrad
41 1.2 riastrad static inline int64_t
42 1.5 riastrad div64_u64(int64_t dividend, uint64_t divisor)
43 1.2 riastrad {
44 1.5 riastrad return dividend / divisor;
45 1.2 riastrad }
46 1.2 riastrad
47 1.2 riastrad static inline int64_t
48 1.5 riastrad div_u64(int64_t dividend, uint32_t divisor)
49 1.2 riastrad {
50 1.5 riastrad return dividend / divisor;
51 1.2 riastrad }
52 1.2 riastrad
53 1.3 riastrad static inline int64_t
54 1.5 riastrad div64_s64(int64_t dividend, int64_t divisor)
55 1.3 riastrad {
56 1.5 riastrad return dividend / divisor;
57 1.3 riastrad }
58 1.3 riastrad
59 1.11 riastrad static inline uint64_t
60 1.11 riastrad DIV64_U64_ROUND_UP(uint64_t dividend, uint64_t divisor)
61 1.11 riastrad {
62 1.11 riastrad return (dividend + (divisor - 1))/divisor;
63 1.11 riastrad }
64 1.11 riastrad
65 1.6 riastrad static inline int64_t
66 1.6 riastrad div_s64(int64_t dividend, int32_t divisor)
67 1.6 riastrad {
68 1.6 riastrad return dividend / divisor;
69 1.6 riastrad }
70 1.6 riastrad
71 1.10 riastrad static inline uint32_t
72 1.10 riastrad div_u64_rem(uint64_t dividend, uint32_t divisor, uint32_t *rem)
73 1.10 riastrad {
74 1.10 riastrad *rem = dividend % divisor;
75 1.10 riastrad return dividend / divisor;
76 1.10 riastrad }
77 1.10 riastrad
78 1.4 riastrad static inline uint64_t
79 1.5 riastrad div64_u64_rem(uint64_t dividend, uint64_t divisor, uint64_t *rem)
80 1.4 riastrad {
81 1.5 riastrad *rem = dividend % divisor;
82 1.5 riastrad return dividend / divisor;
83 1.4 riastrad }
84 1.4 riastrad
85 1.7 riastrad static inline uint64_t
86 1.7 riastrad mul_u32_u32(uint32_t a, uint32_t b)
87 1.7 riastrad {
88 1.7 riastrad return (uint64_t)a * (uint64_t)b;
89 1.7 riastrad }
90 1.7 riastrad
91 1.12 riastrad static inline uint64_t
92 1.12 riastrad mul_u64_u32_div(uint64_t a, uint32_t b, uint32_t div)
93 1.12 riastrad {
94 1.12 riastrad /* XXX implement to account for overflow */
95 1.12 riastrad return (a * b) / div;
96 1.12 riastrad }
97 1.12 riastrad
98 1.9 riastrad /* return floor((a*b) / 2^c) */
99 1.9 riastrad static inline uint64_t
100 1.9 riastrad mul_u64_u32_shr(uint64_t a, uint32_t b, unsigned c)
101 1.9 riastrad {
102 1.9 riastrad /* 2^32 a_hi + a_lo := a */
103 1.9 riastrad uint64_t a_hi = a >> 32;
104 1.9 riastrad uint64_t a_lo = a & 0xffffffffU;
105 1.9 riastrad
106 1.9 riastrad if (c >= 32) {
107 1.9 riastrad /* (a*b) / 2^c = (a_hi b + a_lo b / 2^32) / 2^{c - 32} */
108 1.9 riastrad return ((a_hi * b) + ((a_lo * b) >> 32)) >> (c - 32);
109 1.9 riastrad } else {
110 1.9 riastrad /* (a*b) / 2^c = 2^{32 - c} a_hi b + a_lo b / 2^c */
111 1.9 riastrad return ((a_hi * b) << (32 - c)) + ((a_lo * b) >> c);
112 1.9 riastrad }
113 1.9 riastrad }
114 1.9 riastrad
115 1.2 riastrad #endif /* _LINUX_MATH64_H_ */
116