1 1.8 riastrad /* $NetBSD: radix-tree.h,v 1.8 2021/12/19 11:51:51 riastradh Exp $ */ 2 1.2 riastrad 3 1.2 riastrad /*- 4 1.7 riastrad * Copyright (c) 2021 The NetBSD Foundation, Inc. 5 1.2 riastrad * All rights reserved. 6 1.2 riastrad * 7 1.2 riastrad * Redistribution and use in source and binary forms, with or without 8 1.2 riastrad * modification, are permitted provided that the following conditions 9 1.2 riastrad * are met: 10 1.2 riastrad * 1. Redistributions of source code must retain the above copyright 11 1.2 riastrad * notice, this list of conditions and the following disclaimer. 12 1.2 riastrad * 2. Redistributions in binary form must reproduce the above copyright 13 1.2 riastrad * notice, this list of conditions and the following disclaimer in the 14 1.2 riastrad * documentation and/or other materials provided with the distribution. 15 1.2 riastrad * 16 1.2 riastrad * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 17 1.2 riastrad * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 18 1.2 riastrad * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 19 1.2 riastrad * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 20 1.2 riastrad * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 1.2 riastrad * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 1.2 riastrad * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 1.2 riastrad * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 1.2 riastrad * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 1.2 riastrad * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.2 riastrad * POSSIBILITY OF SUCH DAMAGE. 27 1.2 riastrad */ 28 1.2 riastrad 29 1.2 riastrad #ifndef _LINUX_RADIX_TREE_H_ 30 1.2 riastrad #define _LINUX_RADIX_TREE_H_ 31 1.2 riastrad 32 1.7 riastrad #include <sys/radixtree.h> 33 1.8 riastrad #include <sys/lock.h> 34 1.7 riastrad 35 1.2 riastrad #include <linux/gfp.h> 36 1.2 riastrad 37 1.2 riastrad #define INIT_RADIX_TREE linux_INIT_RADIX_TREE 38 1.2 riastrad #define radix_tree_delete linux_radix_tree_delete 39 1.2 riastrad #define radix_tree_deref_slot linux_radix_tree_deref_slot 40 1.2 riastrad #define radix_tree_empty linux_radix_tree_empty 41 1.2 riastrad #define radix_tree_insert linux_radix_tree_insert 42 1.6 riastrad #define radix_tree_iter_delete linux_radix_tree_iter_delete 43 1.2 riastrad #define radix_tree_iter_init linux_radix_tree_iter_init 44 1.2 riastrad #define radix_tree_lookup linux_radix_tree_lookup 45 1.2 riastrad #define radix_tree_next_chunk linux_radix_tree_next_chunk 46 1.2 riastrad #define radix_tree_next_slot linux_radix_tree_next_slot 47 1.2 riastrad 48 1.2 riastrad struct radix_tree_root { 49 1.8 riastrad struct radix_tree rtr_tree; 50 1.8 riastrad __cpu_simple_lock_t rtr_lock; /* XXX lame-o */ 51 1.2 riastrad }; 52 1.2 riastrad 53 1.2 riastrad struct radix_tree_iter { 54 1.8 riastrad unsigned long index; 55 1.8 riastrad const struct radix_tree_root *rti_tree; 56 1.2 riastrad }; 57 1.2 riastrad 58 1.2 riastrad void INIT_RADIX_TREE(struct radix_tree_root *, gfp_t); 59 1.2 riastrad 60 1.4 riastrad int radix_tree_insert(struct radix_tree_root *, unsigned long, void *); 61 1.3 riastrad void * radix_tree_delete(struct radix_tree_root *, unsigned long); 62 1.2 riastrad 63 1.2 riastrad bool radix_tree_empty(struct radix_tree_root *); 64 1.2 riastrad void * radix_tree_lookup(const struct radix_tree_root *, unsigned long); 65 1.2 riastrad void * radix_tree_deref_slot(void **); 66 1.2 riastrad 67 1.2 riastrad void ** radix_tree_iter_init(struct radix_tree_iter *, unsigned long); 68 1.2 riastrad void ** radix_tree_next_chunk(const struct radix_tree_root *, 69 1.2 riastrad struct radix_tree_iter *, unsigned); 70 1.2 riastrad void ** radix_tree_next_slot(void **, struct radix_tree_iter *, unsigned); 71 1.7 riastrad void radix_tree_iter_delete(struct radix_tree_root *, 72 1.7 riastrad struct radix_tree_iter *, void **); 73 1.2 riastrad 74 1.2 riastrad #define radix_tree_for_each_slot(N, T, I, S) \ 75 1.2 riastrad for ((N) = radix_tree_iter_init((I), (S)); \ 76 1.2 riastrad (N) || ((N) = radix_tree_next_chunk((T), (I), 0)); \ 77 1.2 riastrad (N) = radix_tree_next_slot((N), (I), 0)) 78 1.2 riastrad 79 1.2 riastrad #endif /* _LINUX_RADIX_TREE_H_ */ 80