xref: /f-stack/freebsd/sys/types.h (revision 22ce4aff)
1a9643ea8Slogwang /*-
2*22ce4affSfengbojiang  * SPDX-License-Identifier: BSD-3-Clause
3*22ce4affSfengbojiang  *
4a9643ea8Slogwang  * Copyright (c) 1982, 1986, 1991, 1993, 1994
5a9643ea8Slogwang  *	The Regents of the University of California.  All rights reserved.
6a9643ea8Slogwang  * (c) UNIX System Laboratories, Inc.
7a9643ea8Slogwang  * All or some portions of this file are derived from material licensed
8a9643ea8Slogwang  * to the University of California by American Telephone and Telegraph
9a9643ea8Slogwang  * Co. or Unix System Laboratories, Inc. and are reproduced herein with
10a9643ea8Slogwang  * the permission of UNIX System Laboratories, Inc.
11a9643ea8Slogwang  *
12a9643ea8Slogwang  * Redistribution and use in source and binary forms, with or without
13a9643ea8Slogwang  * modification, are permitted provided that the following conditions
14a9643ea8Slogwang  * are met:
15a9643ea8Slogwang  * 1. Redistributions of source code must retain the above copyright
16a9643ea8Slogwang  *    notice, this list of conditions and the following disclaimer.
17a9643ea8Slogwang  * 2. Redistributions in binary form must reproduce the above copyright
18a9643ea8Slogwang  *    notice, this list of conditions and the following disclaimer in the
19a9643ea8Slogwang  *    documentation and/or other materials provided with the distribution.
20*22ce4affSfengbojiang  * 3. Neither the name of the University nor the names of its contributors
21a9643ea8Slogwang  *    may be used to endorse or promote products derived from this software
22a9643ea8Slogwang  *    without specific prior written permission.
23a9643ea8Slogwang  *
24a9643ea8Slogwang  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
25a9643ea8Slogwang  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26a9643ea8Slogwang  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27a9643ea8Slogwang  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28a9643ea8Slogwang  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29a9643ea8Slogwang  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30a9643ea8Slogwang  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31a9643ea8Slogwang  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32a9643ea8Slogwang  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33a9643ea8Slogwang  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34a9643ea8Slogwang  * SUCH DAMAGE.
35a9643ea8Slogwang  *
36a9643ea8Slogwang  *	@(#)types.h	8.6 (Berkeley) 2/19/95
37a9643ea8Slogwang  * $FreeBSD$
38a9643ea8Slogwang  */
39a9643ea8Slogwang 
40a9643ea8Slogwang #ifndef _SYS_TYPES_H_
41a9643ea8Slogwang #define	_SYS_TYPES_H_
42a9643ea8Slogwang 
43a9643ea8Slogwang #include <sys/cdefs.h>
44a9643ea8Slogwang 
45a9643ea8Slogwang /* Machine type dependent parameters. */
46a9643ea8Slogwang #include <machine/endian.h>
47a9643ea8Slogwang #include <sys/_types.h>
48a9643ea8Slogwang 
49a9643ea8Slogwang #include <sys/_pthreadtypes.h>
50a9643ea8Slogwang 
51a9643ea8Slogwang #if __BSD_VISIBLE
52a9643ea8Slogwang typedef	unsigned char	u_char;
53a9643ea8Slogwang typedef	unsigned short	u_short;
54a9643ea8Slogwang typedef	unsigned int	u_int;
55a9643ea8Slogwang typedef	unsigned long	u_long;
56a9643ea8Slogwang #ifndef _KERNEL
57a9643ea8Slogwang typedef	unsigned short	ushort;		/* Sys V compatibility */
58a9643ea8Slogwang typedef	unsigned int	uint;		/* Sys V compatibility */
59a9643ea8Slogwang #endif
60a9643ea8Slogwang #endif
61a9643ea8Slogwang 
62a9643ea8Slogwang /*
63a9643ea8Slogwang  * XXX POSIX sized integrals that should appear only in <sys/stdint.h>.
64a9643ea8Slogwang  */
65a9643ea8Slogwang #include <sys/_stdint.h>
66a9643ea8Slogwang 
67a9643ea8Slogwang typedef __uint8_t	u_int8_t;	/* unsigned integrals (deprecated) */
68a9643ea8Slogwang typedef __uint16_t	u_int16_t;
69a9643ea8Slogwang typedef __uint32_t	u_int32_t;
70a9643ea8Slogwang typedef __uint64_t	u_int64_t;
71a9643ea8Slogwang 
72a9643ea8Slogwang typedef	__uint64_t	u_quad_t;	/* quads (deprecated) */
73a9643ea8Slogwang typedef	__int64_t	quad_t;
74a9643ea8Slogwang typedef	quad_t *	qaddr_t;
75a9643ea8Slogwang 
76a9643ea8Slogwang typedef	char *		caddr_t;	/* core address */
77a9643ea8Slogwang typedef	const char *	c_caddr_t;	/* core address, pointer to const */
78a9643ea8Slogwang 
79a9643ea8Slogwang #ifndef _BLKSIZE_T_DECLARED
80a9643ea8Slogwang typedef	__blksize_t	blksize_t;
81a9643ea8Slogwang #define	_BLKSIZE_T_DECLARED
82a9643ea8Slogwang #endif
83a9643ea8Slogwang 
84a9643ea8Slogwang typedef	__cpuwhich_t	cpuwhich_t;
85a9643ea8Slogwang typedef	__cpulevel_t	cpulevel_t;
86a9643ea8Slogwang typedef	__cpusetid_t	cpusetid_t;
87a9643ea8Slogwang 
88a9643ea8Slogwang #ifndef _BLKCNT_T_DECLARED
89a9643ea8Slogwang typedef	__blkcnt_t	blkcnt_t;
90a9643ea8Slogwang #define	_BLKCNT_T_DECLARED
91a9643ea8Slogwang #endif
92a9643ea8Slogwang 
93a9643ea8Slogwang #ifndef _CLOCK_T_DECLARED
94a9643ea8Slogwang typedef	__clock_t	clock_t;
95a9643ea8Slogwang #define	_CLOCK_T_DECLARED
96a9643ea8Slogwang #endif
97a9643ea8Slogwang 
98a9643ea8Slogwang #ifndef _CLOCKID_T_DECLARED
99a9643ea8Slogwang typedef	__clockid_t	clockid_t;
100a9643ea8Slogwang #define	_CLOCKID_T_DECLARED
101a9643ea8Slogwang #endif
102a9643ea8Slogwang 
103a9643ea8Slogwang typedef	__critical_t	critical_t;	/* Critical section value */
104*22ce4affSfengbojiang typedef	__daddr_t	daddr_t;	/* disk address */
105a9643ea8Slogwang 
106a9643ea8Slogwang #ifndef _DEV_T_DECLARED
107a9643ea8Slogwang typedef	__dev_t		dev_t;		/* device number or struct cdev */
108a9643ea8Slogwang #define	_DEV_T_DECLARED
109a9643ea8Slogwang #endif
110a9643ea8Slogwang 
111a9643ea8Slogwang #ifndef _FFLAGS_T_DECLARED
112a9643ea8Slogwang typedef	__fflags_t	fflags_t;	/* file flags */
113a9643ea8Slogwang #define	_FFLAGS_T_DECLARED
114a9643ea8Slogwang #endif
115a9643ea8Slogwang 
116a9643ea8Slogwang typedef	__fixpt_t	fixpt_t;	/* fixed point number */
117a9643ea8Slogwang 
118a9643ea8Slogwang #ifndef _FSBLKCNT_T_DECLARED		/* for statvfs() */
119a9643ea8Slogwang typedef	__fsblkcnt_t	fsblkcnt_t;
120a9643ea8Slogwang typedef	__fsfilcnt_t	fsfilcnt_t;
121a9643ea8Slogwang #define	_FSBLKCNT_T_DECLARED
122a9643ea8Slogwang #endif
123a9643ea8Slogwang 
124a9643ea8Slogwang #ifndef _GID_T_DECLARED
125a9643ea8Slogwang typedef	__gid_t		gid_t;		/* group id */
126a9643ea8Slogwang #define	_GID_T_DECLARED
127a9643ea8Slogwang #endif
128a9643ea8Slogwang 
129a9643ea8Slogwang #ifndef _IN_ADDR_T_DECLARED
130a9643ea8Slogwang typedef	__uint32_t	in_addr_t;	/* base type for internet address */
131a9643ea8Slogwang #define	_IN_ADDR_T_DECLARED
132a9643ea8Slogwang #endif
133a9643ea8Slogwang 
134a9643ea8Slogwang #ifndef _IN_PORT_T_DECLARED
135a9643ea8Slogwang typedef	__uint16_t	in_port_t;
136a9643ea8Slogwang #define	_IN_PORT_T_DECLARED
137a9643ea8Slogwang #endif
138a9643ea8Slogwang 
139a9643ea8Slogwang #ifndef _ID_T_DECLARED
140a9643ea8Slogwang typedef	__id_t		id_t;		/* can hold a uid_t or pid_t */
141a9643ea8Slogwang #define	_ID_T_DECLARED
142a9643ea8Slogwang #endif
143a9643ea8Slogwang 
144a9643ea8Slogwang #ifndef _INO_T_DECLARED
145a9643ea8Slogwang typedef	__ino_t		ino_t;		/* inode number */
146a9643ea8Slogwang #define	_INO_T_DECLARED
147a9643ea8Slogwang #endif
148a9643ea8Slogwang 
149a9643ea8Slogwang #ifndef _KEY_T_DECLARED
150a9643ea8Slogwang typedef	__key_t		key_t;		/* IPC key (for Sys V IPC) */
151a9643ea8Slogwang #define	_KEY_T_DECLARED
152a9643ea8Slogwang #endif
153a9643ea8Slogwang 
154a9643ea8Slogwang #ifndef _LWPID_T_DECLARED
155a9643ea8Slogwang typedef	__lwpid_t	lwpid_t;	/* Thread ID (a.k.a. LWP) */
156a9643ea8Slogwang #define	_LWPID_T_DECLARED
157a9643ea8Slogwang #endif
158a9643ea8Slogwang 
159a9643ea8Slogwang #ifndef _MODE_T_DECLARED
160a9643ea8Slogwang typedef	__mode_t	mode_t;		/* permissions */
161a9643ea8Slogwang #define	_MODE_T_DECLARED
162a9643ea8Slogwang #endif
163a9643ea8Slogwang 
164a9643ea8Slogwang #ifndef _ACCMODE_T_DECLARED
165a9643ea8Slogwang typedef	__accmode_t	accmode_t;	/* access permissions */
166a9643ea8Slogwang #define	_ACCMODE_T_DECLARED
167a9643ea8Slogwang #endif
168a9643ea8Slogwang 
169a9643ea8Slogwang #ifndef _NLINK_T_DECLARED
170a9643ea8Slogwang typedef	__nlink_t	nlink_t;	/* link count */
171a9643ea8Slogwang #define	_NLINK_T_DECLARED
172a9643ea8Slogwang #endif
173a9643ea8Slogwang 
174a9643ea8Slogwang #ifndef _OFF_T_DECLARED
175a9643ea8Slogwang typedef	__off_t		off_t;		/* file offset */
176a9643ea8Slogwang #define	_OFF_T_DECLARED
177a9643ea8Slogwang #endif
178a9643ea8Slogwang 
179a9643ea8Slogwang #ifndef _OFF64_T_DECLARED
180a9643ea8Slogwang typedef	__off64_t	off64_t;	/* file offset (alias) */
181a9643ea8Slogwang #define	_OFF64_T_DECLARED
182a9643ea8Slogwang #endif
183a9643ea8Slogwang 
184a9643ea8Slogwang #ifndef _PID_T_DECLARED
185a9643ea8Slogwang typedef	__pid_t		pid_t;		/* process id */
186a9643ea8Slogwang #define	_PID_T_DECLARED
187a9643ea8Slogwang #endif
188a9643ea8Slogwang 
189a9643ea8Slogwang typedef	__register_t	register_t;
190a9643ea8Slogwang 
191a9643ea8Slogwang #ifndef _RLIM_T_DECLARED
192a9643ea8Slogwang typedef	__rlim_t	rlim_t;		/* resource limit */
193a9643ea8Slogwang #define	_RLIM_T_DECLARED
194a9643ea8Slogwang #endif
195a9643ea8Slogwang 
196a9643ea8Slogwang typedef	__int64_t	sbintime_t;
197a9643ea8Slogwang 
198a9643ea8Slogwang typedef	__segsz_t	segsz_t;	/* segment size (in pages) */
199a9643ea8Slogwang 
200a9643ea8Slogwang #ifndef _SIZE_T_DECLARED
201a9643ea8Slogwang typedef	__size_t	size_t;
202a9643ea8Slogwang #define	_SIZE_T_DECLARED
203a9643ea8Slogwang #endif
204a9643ea8Slogwang 
205a9643ea8Slogwang #ifndef _SSIZE_T_DECLARED
206a9643ea8Slogwang typedef	__ssize_t	ssize_t;
207a9643ea8Slogwang #define	_SSIZE_T_DECLARED
208a9643ea8Slogwang #endif
209a9643ea8Slogwang 
210a9643ea8Slogwang #ifndef _SUSECONDS_T_DECLARED
211a9643ea8Slogwang typedef	__suseconds_t	suseconds_t;	/* microseconds (signed) */
212a9643ea8Slogwang #define	_SUSECONDS_T_DECLARED
213a9643ea8Slogwang #endif
214a9643ea8Slogwang 
215a9643ea8Slogwang #ifndef _TIME_T_DECLARED
216a9643ea8Slogwang typedef	__time_t	time_t;
217a9643ea8Slogwang #define	_TIME_T_DECLARED
218a9643ea8Slogwang #endif
219a9643ea8Slogwang 
220a9643ea8Slogwang #ifndef _TIMER_T_DECLARED
221a9643ea8Slogwang typedef	__timer_t	timer_t;
222a9643ea8Slogwang #define	_TIMER_T_DECLARED
223a9643ea8Slogwang #endif
224a9643ea8Slogwang 
225a9643ea8Slogwang #ifndef _MQD_T_DECLARED
226a9643ea8Slogwang typedef	__mqd_t	mqd_t;
227a9643ea8Slogwang #define	_MQD_T_DECLARED
228a9643ea8Slogwang #endif
229a9643ea8Slogwang 
230a9643ea8Slogwang typedef	__u_register_t	u_register_t;
231a9643ea8Slogwang 
232a9643ea8Slogwang #ifndef _UID_T_DECLARED
233a9643ea8Slogwang typedef	__uid_t		uid_t;		/* user id */
234a9643ea8Slogwang #define	_UID_T_DECLARED
235a9643ea8Slogwang #endif
236a9643ea8Slogwang 
237a9643ea8Slogwang #ifndef _USECONDS_T_DECLARED
238a9643ea8Slogwang typedef	__useconds_t	useconds_t;	/* microseconds (unsigned) */
239a9643ea8Slogwang #define	_USECONDS_T_DECLARED
240a9643ea8Slogwang #endif
241a9643ea8Slogwang 
242a9643ea8Slogwang #ifndef _CAP_IOCTL_T_DECLARED
243a9643ea8Slogwang #define	_CAP_IOCTL_T_DECLARED
244a9643ea8Slogwang typedef	unsigned long	cap_ioctl_t;
245a9643ea8Slogwang #endif
246a9643ea8Slogwang 
247a9643ea8Slogwang #ifndef _CAP_RIGHTS_T_DECLARED
248a9643ea8Slogwang #define	_CAP_RIGHTS_T_DECLARED
249a9643ea8Slogwang struct cap_rights;
250a9643ea8Slogwang 
251a9643ea8Slogwang typedef	struct cap_rights	cap_rights_t;
252a9643ea8Slogwang #endif
253a9643ea8Slogwang 
254*22ce4affSfengbojiang /*
255*22ce4affSfengbojiang  * Types suitable for exporting physical addresses, virtual addresses
256*22ce4affSfengbojiang  * (pointers), and memory object sizes from the kernel independent of native
257*22ce4affSfengbojiang  * word size.  These should be used in place of vm_paddr_t, (u)intptr_t, and
258*22ce4affSfengbojiang  * size_t in structs which contain such types that are shared with userspace.
259*22ce4affSfengbojiang  */
260*22ce4affSfengbojiang typedef	__uint64_t	kpaddr_t;
261*22ce4affSfengbojiang typedef	__uint64_t	kvaddr_t;
262*22ce4affSfengbojiang typedef	__uint64_t	ksize_t;
263*22ce4affSfengbojiang typedef	__int64_t	kssize_t;
264*22ce4affSfengbojiang 
265a9643ea8Slogwang typedef	__vm_offset_t	vm_offset_t;
266*22ce4affSfengbojiang typedef	__uint64_t	vm_ooffset_t;
267a9643ea8Slogwang typedef	__vm_paddr_t	vm_paddr_t;
268*22ce4affSfengbojiang typedef	__uint64_t	vm_pindex_t;
269a9643ea8Slogwang typedef	__vm_size_t	vm_size_t;
270a9643ea8Slogwang 
271a9643ea8Slogwang typedef __rman_res_t    rman_res_t;
272a9643ea8Slogwang 
273a9643ea8Slogwang #ifdef _KERNEL
274a9643ea8Slogwang typedef	int		boolean_t;
275a9643ea8Slogwang typedef	struct device	*device_t;
276a9643ea8Slogwang typedef	__intfptr_t	intfptr_t;
277a9643ea8Slogwang 
278a9643ea8Slogwang /*
279a9643ea8Slogwang  * XXX this is fixed width for historical reasons.  It should have had type
280a9643ea8Slogwang  * __int_fast32_t.  Fixed-width types should not be used unless binary
281a9643ea8Slogwang  * compatibility is essential.  Least-width types should be used even less
282a9643ea8Slogwang  * since they provide smaller benefits.
283a9643ea8Slogwang  *
284a9643ea8Slogwang  * XXX should be MD.
285a9643ea8Slogwang  *
286a9643ea8Slogwang  * XXX this is bogus in -current, but still used for spl*().
287a9643ea8Slogwang  */
288a9643ea8Slogwang typedef	__uint32_t	intrmask_t;	/* Interrupt mask (spl, xxx_imask...) */
289a9643ea8Slogwang 
290a9643ea8Slogwang typedef	__uintfptr_t	uintfptr_t;
291a9643ea8Slogwang typedef	__uint64_t	uoff_t;
292a9643ea8Slogwang typedef	char		vm_memattr_t;	/* memory attribute codes */
293a9643ea8Slogwang typedef	struct vm_page	*vm_page_t;
294a9643ea8Slogwang 
295*22ce4affSfengbojiang #define offsetof(type, field) __offsetof(type, field)
296*22ce4affSfengbojiang #endif /* _KERNEL */
297*22ce4affSfengbojiang 
298*22ce4affSfengbojiang #if	defined(_KERNEL) || defined(_STANDALONE)
299a9643ea8Slogwang #if !defined(__bool_true_false_are_defined) && !defined(__cplusplus)
300a9643ea8Slogwang #define	__bool_true_false_are_defined	1
301a9643ea8Slogwang #define	false	0
302a9643ea8Slogwang #define	true	1
303a9643ea8Slogwang typedef	_Bool	bool;
304a9643ea8Slogwang #endif /* !__bool_true_false_are_defined && !__cplusplus */
305*22ce4affSfengbojiang #endif /* KERNEL || _STANDALONE */
306a9643ea8Slogwang 
307a9643ea8Slogwang /*
308a9643ea8Slogwang  * The following are all things that really shouldn't exist in this header,
309a9643ea8Slogwang  * since its purpose is to provide typedefs, not miscellaneous doodads.
310a9643ea8Slogwang  */
311a9643ea8Slogwang 
312a9643ea8Slogwang #ifdef __POPCNT__
313a9643ea8Slogwang #define	__bitcount64(x)	__builtin_popcountll((__uint64_t)(x))
314a9643ea8Slogwang #define	__bitcount32(x)	__builtin_popcount((__uint32_t)(x))
315a9643ea8Slogwang #define	__bitcount16(x)	__builtin_popcount((__uint16_t)(x))
316a9643ea8Slogwang #define	__bitcountl(x)	__builtin_popcountl((unsigned long)(x))
317a9643ea8Slogwang #define	__bitcount(x)	__builtin_popcount((unsigned int)(x))
318a9643ea8Slogwang #else
319a9643ea8Slogwang /*
320a9643ea8Slogwang  * Population count algorithm using SWAR approach
321a9643ea8Slogwang  * - "SIMD Within A Register".
322a9643ea8Slogwang  */
323a9643ea8Slogwang static __inline __uint16_t
__bitcount16(__uint16_t _x)324a9643ea8Slogwang __bitcount16(__uint16_t _x)
325a9643ea8Slogwang {
326a9643ea8Slogwang 
327a9643ea8Slogwang 	_x = (_x & 0x5555) + ((_x & 0xaaaa) >> 1);
328a9643ea8Slogwang 	_x = (_x & 0x3333) + ((_x & 0xcccc) >> 2);
329a9643ea8Slogwang 	_x = (_x + (_x >> 4)) & 0x0f0f;
330a9643ea8Slogwang 	_x = (_x + (_x >> 8)) & 0x00ff;
331a9643ea8Slogwang 	return (_x);
332a9643ea8Slogwang }
333a9643ea8Slogwang 
334a9643ea8Slogwang static __inline __uint32_t
__bitcount32(__uint32_t _x)335a9643ea8Slogwang __bitcount32(__uint32_t _x)
336a9643ea8Slogwang {
337a9643ea8Slogwang 
338a9643ea8Slogwang 	_x = (_x & 0x55555555) + ((_x & 0xaaaaaaaa) >> 1);
339a9643ea8Slogwang 	_x = (_x & 0x33333333) + ((_x & 0xcccccccc) >> 2);
340a9643ea8Slogwang 	_x = (_x + (_x >> 4)) & 0x0f0f0f0f;
341a9643ea8Slogwang 	_x = (_x + (_x >> 8));
342a9643ea8Slogwang 	_x = (_x + (_x >> 16)) & 0x000000ff;
343a9643ea8Slogwang 	return (_x);
344a9643ea8Slogwang }
345a9643ea8Slogwang 
346a9643ea8Slogwang #ifdef __LP64__
347a9643ea8Slogwang static __inline __uint64_t
__bitcount64(__uint64_t _x)348a9643ea8Slogwang __bitcount64(__uint64_t _x)
349a9643ea8Slogwang {
350a9643ea8Slogwang 
351a9643ea8Slogwang 	_x = (_x & 0x5555555555555555) + ((_x & 0xaaaaaaaaaaaaaaaa) >> 1);
352a9643ea8Slogwang 	_x = (_x & 0x3333333333333333) + ((_x & 0xcccccccccccccccc) >> 2);
353a9643ea8Slogwang 	_x = (_x + (_x >> 4)) & 0x0f0f0f0f0f0f0f0f;
354a9643ea8Slogwang 	_x = (_x + (_x >> 8));
355a9643ea8Slogwang 	_x = (_x + (_x >> 16));
356a9643ea8Slogwang 	_x = (_x + (_x >> 32)) & 0x000000ff;
357a9643ea8Slogwang 	return (_x);
358a9643ea8Slogwang }
359a9643ea8Slogwang 
360a9643ea8Slogwang #define	__bitcountl(x)	__bitcount64((unsigned long)(x))
361a9643ea8Slogwang #else
362a9643ea8Slogwang static __inline __uint64_t
__bitcount64(__uint64_t _x)363a9643ea8Slogwang __bitcount64(__uint64_t _x)
364a9643ea8Slogwang {
365a9643ea8Slogwang 
366a9643ea8Slogwang 	return (__bitcount32(_x >> 32) + __bitcount32(_x));
367a9643ea8Slogwang }
368a9643ea8Slogwang 
369a9643ea8Slogwang #define	__bitcountl(x)	__bitcount32((unsigned long)(x))
370a9643ea8Slogwang #endif
371a9643ea8Slogwang #define	__bitcount(x)	__bitcount32((unsigned int)(x))
372a9643ea8Slogwang #endif
373a9643ea8Slogwang 
374a9643ea8Slogwang #if __BSD_VISIBLE
375a9643ea8Slogwang 
376a9643ea8Slogwang #include <sys/select.h>
377a9643ea8Slogwang 
378a9643ea8Slogwang /*
379*22ce4affSfengbojiang  * The major and minor numbers are encoded in dev_t as MMMmmmMm (where
380*22ce4affSfengbojiang  * letters correspond to bytes).  The encoding of the lower 4 bytes is
381*22ce4affSfengbojiang  * constrained by compatibility with 16-bit and 32-bit dev_t's.  The
382*22ce4affSfengbojiang  * encoding of of the upper 4 bytes is the least unnatural one consistent
383*22ce4affSfengbojiang  * with this and other constraints.  Also, the decoding of the m bytes by
384*22ce4affSfengbojiang  * minor() is unnatural to maximize compatibility subject to not discarding
385*22ce4affSfengbojiang  * bits.  The upper m byte is shifted into the position of the lower M byte
386*22ce4affSfengbojiang  * instead of shifting 3 upper m bytes to close the gap.  Compatibility for
387*22ce4affSfengbojiang  * minor() is achieved iff the upper m byte is 0.
388a9643ea8Slogwang  */
389*22ce4affSfengbojiang #define	major(d)	__major(d)
390*22ce4affSfengbojiang static __inline int
__major(dev_t _d)391*22ce4affSfengbojiang __major(dev_t _d)
392*22ce4affSfengbojiang {
393*22ce4affSfengbojiang 	return (((_d >> 32) & 0xffffff00) | ((_d >> 8) & 0xff));
394*22ce4affSfengbojiang }
395*22ce4affSfengbojiang #define	minor(d)	__minor(d)
396*22ce4affSfengbojiang static __inline int
__minor(dev_t _d)397*22ce4affSfengbojiang __minor(dev_t _d)
398*22ce4affSfengbojiang {
399*22ce4affSfengbojiang 	return (((_d >> 24) & 0xff00) | (_d & 0xffff00ff));
400*22ce4affSfengbojiang }
401*22ce4affSfengbojiang #define	makedev(M, m)	__makedev((M), (m))
402*22ce4affSfengbojiang static __inline dev_t
__makedev(int _Major,int _Minor)403*22ce4affSfengbojiang __makedev(int _Major, int _Minor)
404*22ce4affSfengbojiang {
405*22ce4affSfengbojiang 	return (((dev_t)(_Major & 0xffffff00) << 32) | ((_Major & 0xff) << 8) |
406*22ce4affSfengbojiang 	    ((dev_t)(_Minor & 0xff00) << 24) | (_Minor & 0xffff00ff));
407*22ce4affSfengbojiang }
408a9643ea8Slogwang 
409a9643ea8Slogwang /*
410a9643ea8Slogwang  * These declarations belong elsewhere, but are repeated here and in
411a9643ea8Slogwang  * <stdio.h> to give broken programs a better chance of working with
412a9643ea8Slogwang  * 64-bit off_t's.
413a9643ea8Slogwang  */
414a9643ea8Slogwang #ifndef _KERNEL
415a9643ea8Slogwang __BEGIN_DECLS
416a9643ea8Slogwang #ifndef _FTRUNCATE_DECLARED
417a9643ea8Slogwang #define	_FTRUNCATE_DECLARED
418a9643ea8Slogwang int	 ftruncate(int, off_t);
419a9643ea8Slogwang #endif
420a9643ea8Slogwang #ifndef _LSEEK_DECLARED
421a9643ea8Slogwang #define	_LSEEK_DECLARED
422a9643ea8Slogwang off_t	 lseek(int, off_t, int);
423a9643ea8Slogwang #endif
424a9643ea8Slogwang #ifndef _MMAP_DECLARED
425a9643ea8Slogwang #define	_MMAP_DECLARED
426a9643ea8Slogwang void *	 mmap(void *, size_t, int, int, int, off_t);
427a9643ea8Slogwang #endif
428a9643ea8Slogwang #ifndef _TRUNCATE_DECLARED
429a9643ea8Slogwang #define	_TRUNCATE_DECLARED
430a9643ea8Slogwang int	 truncate(const char *, off_t);
431a9643ea8Slogwang #endif
432a9643ea8Slogwang __END_DECLS
433a9643ea8Slogwang #endif /* !_KERNEL */
434a9643ea8Slogwang 
435a9643ea8Slogwang #endif /* __BSD_VISIBLE */
436a9643ea8Slogwang 
437a9643ea8Slogwang #endif /* !_SYS_TYPES_H_ */
438