Deleted Added
full compact
idr.h (290135) idr.h (290335)
1/*-
2 * Copyright (c) 2010 Isilon Systems, Inc.
3 * Copyright (c) 2010 iX Systems, Inc.
4 * Copyright (c) 2010 Panasas, Inc.
5 * Copyright (c) 2013 Mellanox Technologies, Ltd.
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 * notice unmodified, this list of conditions, and the following
13 * disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 *
1/*-
2 * Copyright (c) 2010 Isilon Systems, Inc.
3 * Copyright (c) 2010 iX Systems, Inc.
4 * Copyright (c) 2010 Panasas, Inc.
5 * Copyright (c) 2013 Mellanox Technologies, Ltd.
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 * notice unmodified, this list of conditions, and the following
13 * disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 *
29 * $FreeBSD: head/sys/compat/linuxkpi/common/include/linux/idr.h 290135 2015-10-29 08:28:39Z hselasky $
29 * $FreeBSD: head/sys/compat/linuxkpi/common/include/linux/idr.h 290335 2015-11-03 12:37:55Z hselasky $
30 */
31#ifndef _LINUX_IDR_H_
32#define _LINUX_IDR_H_
33
30 */
31#ifndef _LINUX_IDR_H_
32#define _LINUX_IDR_H_
33
34#include <sys/kernel.h>
34#include <sys/param.h>
35#include <sys/lock.h>
36#include <sys/mutex.h>
35
37
38#include <linux/types.h>
39
36#define IDR_BITS 5
37#define IDR_SIZE (1 << IDR_BITS)
38#define IDR_MASK (IDR_SIZE - 1)
39
40#define MAX_ID_SHIFT ((sizeof(int) * NBBY) - 1)
41#define MAX_ID_BIT (1U << MAX_ID_SHIFT)
42#define MAX_ID_MASK (MAX_ID_BIT - 1)
43#define MAX_LEVEL (MAX_ID_SHIFT + IDR_BITS - 1) / IDR_BITS
44
45#define MAX_IDR_SHIFT (sizeof(int)*8 - 1)
46#define MAX_IDR_BIT (1U << MAX_IDR_SHIFT)
47#define MAX_IDR_MASK (MAX_IDR_BIT - 1)
48
49struct idr_layer {
50 unsigned long bitmap;
51 struct idr_layer *ary[IDR_SIZE];
52};
53
54struct idr {
55 struct mtx lock;
56 struct idr_layer *top;
57 struct idr_layer *free;
58 int layers;
59};
60
61#define DEFINE_IDR(name) \
62 struct idr name; \
63 SYSINIT(name##_idr_sysinit, SI_SUB_DRIVERS, SI_ORDER_FIRST, \
64 idr_init, &(name));
65
66void *idr_find(struct idr *idp, int id);
67int idr_pre_get(struct idr *idp, gfp_t gfp_mask);
68int idr_get_new(struct idr *idp, void *ptr, int *id);
69int idr_get_new_above(struct idr *idp, void *ptr, int starting_id, int *id);
70void *idr_replace(struct idr *idp, void *ptr, int id);
71void idr_remove(struct idr *idp, int id);
72void idr_remove_all(struct idr *idp);
73void idr_destroy(struct idr *idp);
74void idr_init(struct idr *idp);
75
76#endif /* _LINUX_IDR_H_ */
40#define IDR_BITS 5
41#define IDR_SIZE (1 << IDR_BITS)
42#define IDR_MASK (IDR_SIZE - 1)
43
44#define MAX_ID_SHIFT ((sizeof(int) * NBBY) - 1)
45#define MAX_ID_BIT (1U << MAX_ID_SHIFT)
46#define MAX_ID_MASK (MAX_ID_BIT - 1)
47#define MAX_LEVEL (MAX_ID_SHIFT + IDR_BITS - 1) / IDR_BITS
48
49#define MAX_IDR_SHIFT (sizeof(int)*8 - 1)
50#define MAX_IDR_BIT (1U << MAX_IDR_SHIFT)
51#define MAX_IDR_MASK (MAX_IDR_BIT - 1)
52
53struct idr_layer {
54 unsigned long bitmap;
55 struct idr_layer *ary[IDR_SIZE];
56};
57
58struct idr {
59 struct mtx lock;
60 struct idr_layer *top;
61 struct idr_layer *free;
62 int layers;
63};
64
65#define DEFINE_IDR(name) \
66 struct idr name; \
67 SYSINIT(name##_idr_sysinit, SI_SUB_DRIVERS, SI_ORDER_FIRST, \
68 idr_init, &(name));
69
70void *idr_find(struct idr *idp, int id);
71int idr_pre_get(struct idr *idp, gfp_t gfp_mask);
72int idr_get_new(struct idr *idp, void *ptr, int *id);
73int idr_get_new_above(struct idr *idp, void *ptr, int starting_id, int *id);
74void *idr_replace(struct idr *idp, void *ptr, int id);
75void idr_remove(struct idr *idp, int id);
76void idr_remove_all(struct idr *idp);
77void idr_destroy(struct idr *idp);
78void idr_init(struct idr *idp);
79
80#endif /* _LINUX_IDR_H_ */