| /linux/tools/testing/radix-tree/ |
| H A D | idr-test.c | 25 void item_idr_remove(struct idr *idr, int id) in item_idr_remove() argument 27 struct item *item = idr_find(idr, id); in item_idr_remove() 29 idr_remove(idr, id); in item_idr_remove() 36 DEFINE_IDR(idr); in idr_alloc_test() 38 assert(idr_alloc_cyclic(&idr, DUMMY_PTR, 0, 0x4000, GFP_KERNEL) == 0); in idr_alloc_test() 39 assert(idr_alloc_cyclic(&idr, DUMMY_PTR, 0x3ffd, 0x4000, GFP_KERNEL) == 0x3ffd); in idr_alloc_test() 40 idr_remove(&idr, 0x3ffd); in idr_alloc_test() 41 idr_remove(&idr, 0); in idr_alloc_test() 52 id = idr_alloc_cyclic(&idr, item, 1, 0x4000, GFP_KERNEL); in idr_alloc_test() 56 idr_for_each(&idr, item_idr_free, &idr); in idr_alloc_test() [all …]
|
| H A D | Makefile | 5 TARGETS = main idr-test multiorder xarray maple 8 regression3.o regression4.o tag_check.o multiorder.o idr-test.o \ 18 idr-test.o: ../../../lib/test_ida.c 19 idr-test: idr-test.o $(CORE_OFILES) 28 $(RM) $(TARGETS) *.o radix-tree.c idr.c generated/*
|
| H A D | .gitignore | 5 idr.c 6 idr-test
|
| /linux/include/linux/ |
| H A D | idr.h | 20 struct idr { struct 57 #define DEFINE_IDR(name) struct idr name = IDR_INIT(name) 67 static inline unsigned int idr_get_cursor(const struct idr *idr) in idr_get_cursor() argument 69 return READ_ONCE(idr->idr_next); in idr_get_cursor() 80 static inline void idr_set_cursor(struct idr *idr, unsigned int val) in idr_set_cursor() argument 82 WRITE_ONCE(idr->idr_next, val); in idr_set_cursor() 102 #define idr_lock(idr) xa_lock(&(idr)->idr_rt) argument 103 #define idr_unlock(idr) xa_unlock(&(idr)->idr_rt) argument 104 #define idr_lock_bh(idr) xa_lock_bh(&(idr)->idr_rt) argument 105 #define idr_unlock_bh(idr) xa_unlock_bh(&(idr)->idr_rt) argument [all …]
|
| H A D | powercap.h | 66 struct idr idr; member 143 struct idr idr; member 144 struct idr *parent_idr;
|
| /linux/lib/ |
| H A D | idr.c | 33 int idr_alloc_u32(struct idr *idr, void *ptr, u32 *nextid, in idr_alloc_u32() argument 38 unsigned int base = idr->idr_base; in idr_alloc_u32() 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() 79 int idr_alloc(struct idr *idr, void *ptr, int start, int end, gfp_t gfp) in idr_alloc() argument 87 ret = idr_alloc_u32(idr, ptr, &id, end > 0 ? end - 1 : INT_MAX, gfp); in idr_alloc() 117 int idr_alloc_cyclic(struct idr *idr, void *ptr, int start, int end, gfp_t gfp) in idr_alloc_cyclic() argument [all …]
|
| /linux/Documentation/translations/zh_CN/core-api/ |
| H A D | idr.rst | 5 :Original: Documentation/core-api/idr.rst 66 IDR同步的相关内容请见include/linux/idr.h文件中的“DOC: idr sync”。 71 IDA的用法的相关内容请见lib/idr.c文件中的“DOC: IDA description”。 78 include/linux/idr.h 80 lib/idr.c
|
| /linux/drivers/reset/ |
| H A D | reset-ti-sci.c | 40 struct idr idr; member 72 control = idr_find(&data->idr, id); in ti_sci_reset_set() 153 control = idr_find(&data->idr, id); in ti_sci_reset_status() 201 return idr_alloc(&data->idr, control, 0, 0, GFP_KERNEL); in ti_sci_reset_of_xlate() 231 idr_init(&data->idr); in ti_sci_reset_probe() 244 idr_destroy(&data->idr); in ti_sci_reset_remove()
|
| /linux/fs/smb/server/ |
| H A D | vfs_cache.c | 290 idr_remove(global_ft.idr, fp->persistent_id); in __ksmbd_remove_durable_fd() 312 idr_remove(ft->idr, fp->volatile_id); in __ksmbd_remove_fd() 370 fp = idr_find(ft->idr, id); in __ksmbd_lookup_fd() 406 fp = idr_find(ft->idr, id); in ksmbd_close_fd() 519 idr_for_each_entry(global_ft.idr, fp, id) { in ksmbd_lookup_fd_cguid() 582 ret = idr_alloc_cyclic(ft->idr, fp, 0, INT_MAX - 1, GFP_NOWAIT); in __open_id() 670 fp = idr_get_next(ft->idr, &id); in __close_file_table_ids() 684 idr_remove(ft->idr, fp->volatile_id); in __close_file_table_ids() 741 if (idr_is_empty(global_ft.idr)) in ksmbd_durable_scavenger_alive() 785 idr_for_each_entry(global_ft.idr, fp, id) { in ksmbd_durable_scavenger() [all …]
|
| /linux/fs/notify/inotify/ |
| H A D | inotify_user.c | 346 idr_set_cursor(&data->idr, (unsigned int)arg); in inotify_ioctl() 394 static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, in inotify_add_to_idr() argument 402 ret = idr_alloc_cyclic(idr, i_mark, 1, 0, GFP_NOWAIT); in inotify_add_to_idr() 417 struct idr *idr = &group->inotify_data.idr; in inotify_idr_find_locked() local 423 i_mark = idr_find(idr, wd); in inotify_idr_find_locked() 455 struct idr *idr = &group->inotify_data.idr; in inotify_remove_from_idr() local 506 idr_remove(idr, wd); in inotify_remove_from_idr() 596 struct idr *idr = &group->inotify_data.idr; in inotify_new_watch() local 608 ret = inotify_add_to_idr(idr, idr_lock, tmp_i_mark); in inotify_new_watch() 679 idr_init(&group->inotify_data.idr); in inotify_new_group()
|
| /linux/sound/soc/qcom/qdsp6/ |
| H A D | q6apm.h | 64 struct idr graph_idr; 65 struct idr graph_info_idr; 66 struct idr sub_graphs_idr; 67 struct idr containers_idr; 68 struct idr modules_idr;
|
| /linux/include/drm/ |
| H A D | drm_auth.h | 64 struct idr magic_map; 121 struct idr leases; 129 struct idr lessee_idr;
|
| /linux/drivers/irqchip/ |
| H A D | irq-gic-v5-irs.c | 685 u32 idr, spi_count; in gicv5_irs_init() local 710 idr = irs_readl_relaxed(irs_data, GICV5_IRS_IDR1); in gicv5_irs_init() 711 iaffid_bits = FIELD_GET(GICV5_IRS_IDR1_IAFFID_BITS, idr) + 1; in gicv5_irs_init() 719 idr = irs_readl_relaxed(irs_data, GICV5_IRS_IDR2); in gicv5_irs_init() 720 if (WARN(!FIELD_GET(GICV5_IRS_IDR2_LPI, idr), in gicv5_irs_init() 726 idr = irs_readl_relaxed(irs_data, GICV5_IRS_IDR7); in gicv5_irs_init() 727 irs_data->spi_min = FIELD_GET(GICV5_IRS_IDR7_SPI_BASE, idr); in gicv5_irs_init() 729 idr = irs_readl_relaxed(irs_data, GICV5_IRS_IDR6); in gicv5_irs_init() 730 irs_data->spi_range = FIELD_GET(GICV5_IRS_IDR6_SPI_IRS_RANGE, idr); in gicv5_irs_init() 747 idr = irs_readl_relaxed(irs_data, GICV5_IRS_IDR1); in gicv5_irs_init() [all …]
|
| /linux/drivers/tee/optee/ |
| H A D | supp.c | 27 idr_init(&supp->idr); in optee_supp_init() 35 idr_destroy(&supp->idr); in optee_supp_uninit() 47 idr_for_each_entry(&supp->idr, req, id) { in optee_supp_release() 48 idr_remove(&supp->idr, id); in optee_supp_release() 156 *id = idr_alloc(&supp->idr, req, 1, 0, GFP_KERNEL); in supp_pop_entry() 296 req = idr_find(&supp->idr, id); in supp_pop_req() 303 idr_remove(&supp->idr, id); in supp_pop_req()
|
| /linux/drivers/gpu/drm/vc4/ |
| H A D | vc4_perfmon.c | 97 perfmon = idr_find(&vc4file->perfmon.idr, id); in vc4_perfmon_find() 112 idr_init_base(&vc4file->perfmon.idr, VC4_PERFMONID_MIN); in vc4_perfmon_open_file() 138 idr_for_each(&vc4file->perfmon.idr, vc4_perfmon_idr_del, vc4); in vc4_perfmon_close_file() 139 idr_destroy(&vc4file->perfmon.idr); in vc4_perfmon_close_file() 187 ret = idr_alloc(&vc4file->perfmon.idr, perfmon, VC4_PERFMONID_MIN, in vc4_perfmon_create_ioctl() 217 perfmon = idr_remove(&vc4file->perfmon.idr, req->id); in vc4_perfmon_destroy_ioctl()
|
| /linux/tools/testing/shared/ |
| H A D | shared.mk | 11 SHARED_OFILES = xarray-shared.o radix-tree.o idr.o linux.o $(LIBS) 22 ../../../include/linux/idr.h \ 50 idr.c: ../../../lib/idr.c
|
| /linux/drivers/gpu/drm/vmwgfx/ |
| H A D | ttm_object.c | 97 struct idr idr; member 203 ret = idr_alloc(&tdev->idr, base, 1, 0, GFP_NOWAIT); in ttm_base_object_init() 219 idr_remove(&tdev->idr, base->handle); in ttm_base_object_init() 231 idr_remove(&tdev->idr, base->handle); in ttm_release_base() 281 base = idr_find(&tdev->idr, key); in ttm_base_object_lookup_for_ref() 440 idr_init_base(&tdev->idr, VMWGFX_NUM_MOB + 1); in ttm_object_device_init() 453 WARN_ON_ONCE(!idr_is_empty(&tdev->idr)); in ttm_object_device_release() 454 idr_destroy(&tdev->idr); in ttm_object_device_release()
|
| H A D | vmwgfx_resource.c | 105 struct idr *idr = &dev_priv->res_idr[res->func->res_type]; in vmw_resource_release_id() local 109 idr_remove(idr, res->id); in vmw_resource_release_id() 121 struct idr *idr = &dev_priv->res_idr[res->func->res_type]; in vmw_resource_release() local 164 idr_remove(idr, id); in vmw_resource_release() 189 struct idr *idr = &dev_priv->res_idr[res->func->res_type]; in vmw_resource_alloc_id() local 196 ret = idr_alloc(idr, res, 1, 0, GFP_NOWAIT); in vmw_resource_alloc_id()
|
| /linux/kernel/ |
| H A D | pid.c | 75 .idr = IDR_INIT(init_pid_ns.idr), 143 idr_remove(&ns->idr, upid->nr); in free_pid() 217 nr = idr_alloc(&tmp->idr, NULL, tid, in alloc_pid() 231 if (idr_get_cursor(&tmp->idr) > RESERVED_PIDS) in alloc_pid() 238 nr = idr_alloc_cyclic(&tmp->idr, NULL, pid_min, in alloc_pid() 281 idr_replace(&upid->ns->idr, pid, upid->nr); in alloc_pid() 298 idr_remove(&upid->ns->idr, upid->nr); in alloc_pid() 303 idr_set_cursor(&ns->idr, 0); in alloc_pid() 320 return idr_find(&ns->idr, nr); in find_pid_ns() 539 return idr_get_next(&ns->idr, &nr); in find_ge_pid() [all …]
|
| H A D | pid_namespace.c | 100 idr_init(&ns->idr); in create_pid_namespace() 132 idr_destroy(&ns->idr); in create_pid_namespace() 157 idr_destroy(&ns->idr); in destroy_pid_namespace() 228 idr_for_each_entry_continue(&pid_ns->idr, pid, nr) { in zap_pid_ns_processes() 296 next = idr_get_cursor(&pid_ns->idr) - 1; in pid_ns_ctl_handler() 302 idr_set_cursor(&pid_ns->idr, next + 1); in pid_ns_ctl_handler()
|
| /linux/drivers/infiniband/core/ |
| H A D | rdma_core.c | 304 return xa_alloc(&uobj->ufile->idr, &uobj->id, NULL, xa_limit_32b, in idr_add_uobj() 326 uobj = xa_load(&ufile->idr, id); in lookup_get_idr_uobject() 447 xa_erase(&attrs->ufile->idr, uobj->id); in alloc_begin_idr_uobject() 529 xa_erase(&uobj->ufile->idr, uobj->id); in alloc_abort_idr_uobject() 555 xa_erase(&uobj->ufile->idr, uobj->id); in remove_handle_idr_uobject() 595 old = xa_store(&ufile->idr, uobj->id, uobj, GFP_KERNEL); in alloc_commit_idr_uobject() 609 old = xa_cmpxchg(&ufile->idr, obj_old->id, obj_old, XA_ZERO_ENTRY, in swap_idr_uobjects() 616 old = xa_cmpxchg(&ufile->idr, obj_old->id, NULL, obj_old, GFP_KERNEL); in swap_idr_uobjects() 769 xa_init_flags(&ufile->idr, XA_FLAGS_ALLOC); in setup_ufile_idr_uobject() 785 xa_for_each(&ufile->idr, id, entry) { in release_ufile_idr_uobject() [all …]
|
| /linux/drivers/gpu/drm/v3d/ |
| H A D | v3d_perfmon.c | 294 perfmon = idr_find(&v3d_priv->perfmon.idr, id); in v3d_perfmon_find() 304 idr_init_base(&v3d_priv->perfmon.idr, 1); in v3d_perfmon_open_file() 329 idr_for_each(&v3d_priv->perfmon.idr, v3d_perfmon_idr_del, v3d); in v3d_perfmon_close_file() 330 idr_destroy(&v3d_priv->perfmon.idr); in v3d_perfmon_close_file() 370 ret = idr_alloc(&v3d_priv->perfmon.idr, perfmon, V3D_PERFMONID_MIN, in v3d_perfmon_create_ioctl() 394 perfmon = idr_remove(&v3d_priv->perfmon.idr, req->id); in v3d_perfmon_destroy_ioctl()
|
| /linux/Documentation/core-api/ |
| H A D | idr.rst | 69 .. kernel-doc:: include/linux/idr.h 70 :doc: idr sync 75 .. kernel-doc:: lib/idr.c 81 .. kernel-doc:: include/linux/idr.h 83 .. kernel-doc:: lib/idr.c
|
| /linux/drivers/tee/ |
| H A D | tee_shm.c | 163 id = idr_alloc(&teedev->idr, NULL, 1, 0, GFP_KERNEL); in tee_shm_alloc_user_buf() 171 idr_remove(&teedev->idr, id); in tee_shm_alloc_user_buf() 177 ret = idr_replace(&teedev->idr, shm, id); in tee_shm_alloc_user_buf() 241 ref->shm.id = idr_alloc(&ref->shm.ctx->teedev->idr, &ref->shm, in tee_shm_register_fd() 537 id = idr_alloc(&teedev->idr, NULL, 1, 0, GFP_KERNEL); in tee_shm_register_user_buf() 546 idr_remove(&teedev->idr, id); in tee_shm_register_user_buf() 552 ret = idr_replace(&teedev->idr, shm, id); in tee_shm_register_user_buf() 701 shm = idr_find(&teedev->idr, id); in tee_shm_get_from_id() 738 idr_remove(&teedev->idr, shm->id); in tee_shm_put()
|
| /linux/drivers/gpu/drm/nouveau/nvkm/subdev/gsp/rm/ |
| H A D | client.c | 20 idr_remove(&gsp->client_id.idr, id); in nvkm_gsp_client_dtor() 35 id = idr_alloc(&gsp->client_id.idr, client, 0, NVKM_RM_CLIENT_MASK + 1, GFP_KERNEL); in nvkm_gsp_client_ctor()
|