Searched refs:idr_rt (Results 1 – 3 of 3) sorted by relevance
/Linux-v6.1/include/linux/ |
D | idr.h | 20 struct radix_tree_root idr_rt; member 36 .idr_rt = RADIX_TREE_INIT(name, IDR_RT_MARKER), \ 101 #define idr_lock(idr) xa_lock(&(idr)->idr_rt) 102 #define idr_unlock(idr) xa_unlock(&(idr)->idr_rt) 103 #define idr_lock_bh(idr) xa_lock_bh(&(idr)->idr_rt) 104 #define idr_unlock_bh(idr) xa_unlock_bh(&(idr)->idr_rt) 105 #define idr_lock_irq(idr) xa_lock_irq(&(idr)->idr_rt) 106 #define idr_unlock_irq(idr) xa_unlock_irq(&(idr)->idr_rt) 108 xa_lock_irqsave(&(idr)->idr_rt, flags) 110 xa_unlock_irqrestore(&(idr)->idr_rt, flags) [all …]
|
/Linux-v6.1/lib/ |
D | idr.c | 41 if (WARN_ON_ONCE(!(idr->idr_rt.xa_flags & ROOT_IS_IDR))) in idr_alloc_u32() 42 idr->idr_rt.xa_flags |= IDR_RT_MARKER; in idr_alloc_u32() 46 slot = idr_get_free(&idr->idr_rt, &iter, gfp, max - base); in idr_alloc_u32() 52 radix_tree_iter_replace(&idr->idr_rt, &iter, slot, ptr); in idr_alloc_u32() 53 radix_tree_iter_tag_clear(&idr->idr_rt, &iter, IDR_FREE); in idr_alloc_u32() 154 return radix_tree_delete_item(&idr->idr_rt, id - idr->idr_base, NULL); in idr_remove() 174 return radix_tree_lookup(&idr->idr_rt, id - idr->idr_base); in idr_find() 202 radix_tree_for_each_slot(slot, &idr->idr_rt, &iter, 0) { in idr_for_each() 236 radix_tree_for_each_slot(slot, &idr->idr_rt, &iter, id) { in idr_get_next_ul() 242 if (slot != &idr->idr_rt.xa_head && !xa_is_retry(entry)) in idr_get_next_ul() [all …]
|
D | radix-tree.c | 1560 struct radix_tree_node *node = rcu_dereference_raw(idr->idr_rt.xa_head); in idr_destroy() 1563 idr->idr_rt.xa_head = NULL; in idr_destroy() 1564 root_tag_set(&idr->idr_rt, IDR_FREE); in idr_destroy()
|