xref: /openbsd-src/sys/dev/usb/dwc2/bitmap.h (revision c2d5a92f8c738e820d1d6fa2ca6890039072a151)
1*c2d5a92fSmglocker /*	$OpenBSD: bitmap.h,v 1.1 2022/09/08 18:16:26 mglocker Exp $ */
2*c2d5a92fSmglocker 
3*c2d5a92fSmglocker /*
4*c2d5a92fSmglocker  * Copyright 2004 Eric Anholt
5*c2d5a92fSmglocker  * All Rights Reserved.
6*c2d5a92fSmglocker  *
7*c2d5a92fSmglocker  * Permission is hereby granted, free of charge, to any person obtaining a
8*c2d5a92fSmglocker  * copy of this software and associated documentation files (the "Software"),
9*c2d5a92fSmglocker  * to deal in the Software without restriction, including without limitation
10*c2d5a92fSmglocker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11*c2d5a92fSmglocker  * and/or sell copies of the Software, and to permit persons to whom the
12*c2d5a92fSmglocker  * Software is furnished to do so, subject to the following conditions:
13*c2d5a92fSmglocker  *
14*c2d5a92fSmglocker  * The above copyright notice and this permission notice (including the next
15*c2d5a92fSmglocker  * paragraph) shall be included in all copies or substantial portions of the
16*c2d5a92fSmglocker  * Software.
17*c2d5a92fSmglocker  *
18*c2d5a92fSmglocker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19*c2d5a92fSmglocker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20*c2d5a92fSmglocker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
21*c2d5a92fSmglocker  * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
22*c2d5a92fSmglocker  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
23*c2d5a92fSmglocker  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
24*c2d5a92fSmglocker  * OTHER DEALINGS IN THE SOFTWARE.
25*c2d5a92fSmglocker  */
26*c2d5a92fSmglocker 
27*c2d5a92fSmglocker static inline void
__clear_bit(u_int b,volatile void * p)28*c2d5a92fSmglocker __clear_bit(u_int b, volatile void *p)
29*c2d5a92fSmglocker {
30*c2d5a92fSmglocker 	volatile u_int *ptr = (volatile u_int *)p;
31*c2d5a92fSmglocker 	ptr[b >> 5] &= ~(1 << (b & 0x1f));
32*c2d5a92fSmglocker }
33*c2d5a92fSmglocker 
34*c2d5a92fSmglocker static inline void
__set_bit(u_int b,volatile void * p)35*c2d5a92fSmglocker __set_bit(u_int b, volatile void *p)
36*c2d5a92fSmglocker {
37*c2d5a92fSmglocker 	volatile u_int *ptr = (volatile u_int *)p;
38*c2d5a92fSmglocker 	ptr[b >> 5] |= (1 << (b & 0x1f));
39*c2d5a92fSmglocker }
40*c2d5a92fSmglocker 
41*c2d5a92fSmglocker static inline int
find_next_zero_bit(volatile void * p,int max,int b)42*c2d5a92fSmglocker find_next_zero_bit(volatile void *p, int max, int b)
43*c2d5a92fSmglocker {
44*c2d5a92fSmglocker 	volatile u_int *ptr = (volatile u_int *)p;
45*c2d5a92fSmglocker 
46*c2d5a92fSmglocker 	for (; b < max; b += 32) {
47*c2d5a92fSmglocker 		if (ptr[b >> 5] != ~0) {
48*c2d5a92fSmglocker 			for (;;) {
49*c2d5a92fSmglocker 				if ((ptr[b >> 5] & (1 << (b & 0x1f))) == 0)
50*c2d5a92fSmglocker 					return b;
51*c2d5a92fSmglocker 				b++;
52*c2d5a92fSmglocker 			}
53*c2d5a92fSmglocker 		}
54*c2d5a92fSmglocker 	}
55*c2d5a92fSmglocker 	return max;
56*c2d5a92fSmglocker }
57*c2d5a92fSmglocker 
58*c2d5a92fSmglocker static inline int
find_next_bit(volatile void * p,int max,int b)59*c2d5a92fSmglocker find_next_bit(volatile void *p, int max, int b)
60*c2d5a92fSmglocker {
61*c2d5a92fSmglocker 	volatile u_int *ptr = (volatile u_int *)p;
62*c2d5a92fSmglocker 
63*c2d5a92fSmglocker 	for (; b < max; b+= 32) {
64*c2d5a92fSmglocker 		if (ptr[b >> 5] != 0) {
65*c2d5a92fSmglocker 			for (;;) {
66*c2d5a92fSmglocker 				if (ptr[b >> 5] & (1 << (b & 0x1f)))
67*c2d5a92fSmglocker 					return b;
68*c2d5a92fSmglocker 				b++;
69*c2d5a92fSmglocker 			}
70*c2d5a92fSmglocker 		}
71*c2d5a92fSmglocker 	}
72*c2d5a92fSmglocker 	return max;
73*c2d5a92fSmglocker }
74*c2d5a92fSmglocker 
75*c2d5a92fSmglocker /*
76*c2d5a92fSmglocker  * Copyright (c) 2013, 2014, 2015 Mark Kettenis
77*c2d5a92fSmglocker  *
78*c2d5a92fSmglocker  * Permission to use, copy, modify, and distribute this software for any
79*c2d5a92fSmglocker  * purpose with or without fee is hereby granted, provided that the above
80*c2d5a92fSmglocker  * copyright notice and this permission notice appear in all copies.
81*c2d5a92fSmglocker  *
82*c2d5a92fSmglocker  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
83*c2d5a92fSmglocker  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
84*c2d5a92fSmglocker  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
85*c2d5a92fSmglocker  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
86*c2d5a92fSmglocker  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
87*c2d5a92fSmglocker  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
88*c2d5a92fSmglocker  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
89*c2d5a92fSmglocker  */
90*c2d5a92fSmglocker 
91*c2d5a92fSmglocker static inline void
bitmap_set(void * p,int b,u_int n)92*c2d5a92fSmglocker bitmap_set(void *p, int b, u_int n)
93*c2d5a92fSmglocker {
94*c2d5a92fSmglocker 	u_int end = b + n;
95*c2d5a92fSmglocker 
96*c2d5a92fSmglocker 	for (; b < end; b++)
97*c2d5a92fSmglocker 		__set_bit(b, p);
98*c2d5a92fSmglocker }
99*c2d5a92fSmglocker 
100*c2d5a92fSmglocker static inline void
bitmap_clear(void * p,int b,u_int n)101*c2d5a92fSmglocker bitmap_clear(void *p, int b, u_int n)
102*c2d5a92fSmglocker {
103*c2d5a92fSmglocker 	u_int end = b + n;
104*c2d5a92fSmglocker 
105*c2d5a92fSmglocker 	for (; b < end; b++)
106*c2d5a92fSmglocker 		__clear_bit(b, p);
107*c2d5a92fSmglocker }
108*c2d5a92fSmglocker 
109*c2d5a92fSmglocker static inline u_long
bitmap_find_next_zero_area_off(void * p,u_long size,u_long start,u_long n,u_long align_mask,u_long align_offset)110*c2d5a92fSmglocker bitmap_find_next_zero_area_off(void *p, u_long size, u_long start, u_long n,
111*c2d5a92fSmglocker     u_long align_mask, u_long align_offset)
112*c2d5a92fSmglocker {
113*c2d5a92fSmglocker 	u_long index, end, i;
114*c2d5a92fSmglocker 
115*c2d5a92fSmglocker 	while (1) {
116*c2d5a92fSmglocker 		index = (((find_next_zero_bit(p, size, start) +
117*c2d5a92fSmglocker 		    align_offset) + align_mask) & ~align_mask) - align_offset;
118*c2d5a92fSmglocker 
119*c2d5a92fSmglocker 		end = index + n;
120*c2d5a92fSmglocker 		if (end > size)
121*c2d5a92fSmglocker 			return end;
122*c2d5a92fSmglocker 
123*c2d5a92fSmglocker 		i = find_next_bit(p, end, index);
124*c2d5a92fSmglocker 		if (i >= end)
125*c2d5a92fSmglocker 			break;
126*c2d5a92fSmglocker 		start = i + 1;
127*c2d5a92fSmglocker 	}
128*c2d5a92fSmglocker 
129*c2d5a92fSmglocker 	return index;
130*c2d5a92fSmglocker }
131*c2d5a92fSmglocker 
132*c2d5a92fSmglocker static inline unsigned long
bitmap_find_next_zero_area(void * p,u_long size,u_long start,u_long n,u_long align_mask)133*c2d5a92fSmglocker bitmap_find_next_zero_area(void *p, u_long size, u_long start, u_long n,
134*c2d5a92fSmglocker     u_long align_mask)
135*c2d5a92fSmglocker {
136*c2d5a92fSmglocker 	return bitmap_find_next_zero_area_off(p, size, start, n, align_mask, 0);
137*c2d5a92fSmglocker }
138