| /linux/Documentation/translations/zh_CN/core-api/ |
| H A D | xarray.rst | 162 内部使用xa_lock: 186 假设进入时持有xa_lock: 195 如果你想利用锁来保护你存储在XArray中的数据结构,你可以在调用xa_load()之前调用xa_lock(),然后在 225 xa_lock(&foo->array); 234 上面的例子还显示了一个常见的模式,即希望在存储端扩展xa_lock的覆盖范围,以保护与数组相关的一些统计 238 在进程上下文中使用xa_lock_irq(),在中断处理程序中使用xa_lock()。一些更常见的模式有一些辅助函数, 242 意味着你有权使用像__xa_erase()这样的函数而不占用xa_lock;xa_lock是用来进行lockdep验证的,将来也 252 你需要在修改数组的时候使用xa_lock。在对数组进行只读操作时,你可以选择使用xa_lock或RCU锁。你可以在 267 存在xa_state中供下一次尝试。这个想法是,你拿着xa_lock,尝试操作,然后放弃锁。该操作试图在持有锁的情 295 - 这个条目目前正在被一个拥有xa_lock的线程修改。在这个RCU周期结束时,包含该条目的节点可能会被释放。 [all …]
|
| /linux/include/linux/ |
| H A D | xarray.h | 301 spinlock_t xa_lock; member 308 .xa_lock = __SPIN_LOCK_UNLOCKED(name.xa_lock), \ 384 spin_lock_init(&xa->xa_lock); in xa_init_flags() 535 #define xa_trylock(xa) spin_trylock(&(xa)->xa_lock) 536 #define xa_lock(xa) spin_lock(&(xa)->xa_lock) macro 537 #define xa_unlock(xa) spin_unlock(&(xa)->xa_lock) 538 #define xa_lock_bh(xa) spin_lock_bh(&(xa)->xa_lock) 539 #define xa_unlock_bh(xa) spin_unlock_bh(&(xa)->xa_lock) 540 #define xa_lock_irq(xa) spin_lock_irq(&(xa)->xa_lock) 541 #define xa_unlock_irq(xa) spin_unlock_irq(&(xa)->xa_lock) [all …]
|
| H A D | idr.h | 102 #define idr_lock(idr) xa_lock(&(idr)->idr_rt)
|
| /linux/tools/testing/radix-tree/ |
| H A D | regression1.c | 128 xa_lock(&mt_tree); in regression1_fn() 133 xa_lock(&mt_tree); in regression1_fn() 137 xa_lock(&mt_tree); in regression1_fn() 145 xa_lock(&mt_tree); in regression1_fn()
|
| /linux/drivers/gpu/drm/imagination/ |
| H A D | pvr_free_list.h | 142 xa_lock(&pvr_file->free_list_handles); in pvr_free_list_lookup() 165 xa_lock(&pvr_dev->free_list_ids); in pvr_free_list_lookup_id()
|
| H A D | pvr_hwrt.h | 104 xa_lock(&pvr_file->hwrt_handles); in pvr_hwrt_dataset_lookup()
|
| /linux/drivers/infiniband/core/ |
| H A D | ib_core_uverbs.c | 130 xa_lock(&ucontext->mmap_xa); in rdma_user_mmap_entry_get_pgoff() 195 xa_lock(&ucontext->mmap_xa); in rdma_user_mmap_entry_free() 243 xa_lock(&entry->ucontext->mmap_xa); in rdma_user_mmap_entry_remove() 312 xa_lock(&ucontext->mmap_xa); in rdma_user_mmap_entry_insert_range()
|
| H A D | restrack.c | 72 xa_lock(&rt->xa); in rdma_restrack_count() 251 xa_lock(&rt->xa); in rdma_restrack_get_byid()
|
| H A D | ucma.c | 145 xa_lock(&ctx_table); in ucma_get_ctx() 367 xa_lock(&ctx_table); in ucma_event_handler() 498 xa_lock(&multicast_table); in ucma_cleanup_multicast() 611 xa_lock(&ctx_table); in ucma_destroy_id() 1543 xa_lock(&multicast_table); in ucma_process_join() 1578 xa_lock(&multicast_table); in ucma_process_join() 1642 xa_lock(&multicast_table); in ucma_leave_multicast() 1712 xa_lock(&ctx_table); in ucma_migrate_id()
|
| /linux/drivers/iommu/amd/ |
| H A D | nested.c | 72 xa_lock(xa); in gdom_info_load_or_alloc_locked() 139 xa_lock(&aviommu->gdomid_array); in amd_iommu_alloc_domain_nested() 264 xa_lock(&aviommu->gdomid_array); in nested_domain_free()
|
| /linux/rust/helpers/ |
| H A D | xarray.c | 22 return xa_lock(xa); in rust_helper_xa_lock()
|
| /linux/fs/cachefiles/ |
| H A D | ondemand.c | 34 xa_lock(&cache->reqs); in cachefiles_ondemand_fd_release() 130 xa_lock(&cache->reqs); in cachefiles_ondemand_fd_ioctl() 191 xa_lock(&cache->reqs); in cachefiles_ondemand_copen() 423 xa_lock(&cache->reqs); in cachefiles_ondemand_daemon_read() 716 xa_lock(&cache->reqs); in cachefiles_ondemand_clean_object()
|
| /linux/drivers/iommu/iommufd/ |
| H A D | main.c | 108 xa_lock(&ictx->objects); in iommufd_object_finalize() 121 xa_lock(&ictx->objects); in iommufd_object_abort() 174 xa_lock(&ictx->objects); in iommufd_get_object() 235 xa_lock(&ictx->objects); in iommufd_object_remove()
|
| H A D | driver.c | 98 lockdep_assert_held(&viommu->vdevs.xa_lock); in iommufd_viommu_find_dev() 116 xa_lock(&viommu->vdevs); in iommufd_viommu_get_vdev_id()
|
| H A D | ioas.c | 412 xa_lock(&ictx->objects); in iommufd_take_all_iova_rwsem() 434 xa_lock(&ictx->objects); in iommufd_take_all_iova_rwsem() 603 xa_lock(&ictx->objects); in iommufd_option_rlimit_mode()
|
| /linux/arch/arm64/kernel/ |
| H A D | hibernate.c | 246 xa_lock(&mte_pages); in swsusp_mte_free_storage() 303 xa_lock(&mte_pages); in swsusp_mte_restore_tags()
|
| /linux/drivers/block/ |
| H A D | brd.c | 95 xa_lock(&brd->brd_pages); in brd_insert_page() 190 xa_lock(&brd->brd_pages); in brd_do_discard()
|
| /linux/drivers/infiniband/hw/mlx4/ |
| H A D | cm.c | 366 xa_lock(&sriov->xa_rej_tmout); in alloc_rej_tmout() 411 xa_lock(&sriov->xa_rej_tmout); in lookup_rej_tmout_slave() 501 xa_lock(&sriov->xa_rej_tmout); in rej_tmout_xa_cleanup()
|
| /linux/rust/kernel/ |
| H A D | xarray.rs | 137 unsafe { bindings::xa_lock(self.xa.get()) }; in lock()
|
| /linux/net/devlink/ |
| H A D | region.c | 283 xa_lock(&devlink->snapshot_ids); in __devlink_snapshot_id_increment() 325 xa_lock(&devlink->snapshot_ids); in __devlink_snapshot_id_decrement() 367 xa_lock(&devlink->snapshot_ids); in __devlink_snapshot_id_insert()
|
| /linux/lib/ |
| H A D | xarray.c | 329 __must_hold(xas->xa->xa_lock) in __xas_nomem() 1669 xa_lock(xa); in xa_erase() 1733 xa_lock(xa); in xa_store() 2148 xa_lock(xa); in xa_set_mark() 2166 xa_lock(xa); in xa_clear_mark()
|
| /linux/net/shaper/ |
| H A D | shaper.c | 432 xa_lock(&hierarchy->shapers); in net_shaper_commit() 458 xa_lock(&hierarchy->shapers); in net_shaper_rollback() 1475 xa_lock(&hierarchy->shapers); in net_shaper_flush()
|
| /linux/arch/arm64/kvm/vgic/ |
| H A D | vgic.c | 135 lockdep_assert_held(&dist->lpi_xa.xa_lock); in vgic_release_lpi_locked() 168 guard(spinlock_irqsave)(&dist->lpi_xa.xa_lock); in vgic_put_irq()
|
| /linux/drivers/tee/tstee/ |
| H A D | core.c | 175 xa_lock(&ctxdata->sess_list); in tstee_invoke_func()
|
| /linux/drivers/iommu/arm/arm-smmu-v3/ |
| H A D | arm-smmu-v3-iommufd.c | 284 xa_lock(&vsmmu->core.vdevs); in arm_vsmmu_vsid_to_sid()
|