/linux/tools/memory-model/ |
A D | linux-kernel.def | 14 smp_load_acquire(X) __load{acquire}(*X) 33 xchg_acquire(X,V) __xchg{acquire}(X,V) 36 cmpxchg_acquire(X,V,W) __cmpxchg{acquire}(X,V,W) 74 atomic_fetch_add_acquire(V,X) __atomic_fetch_op{acquire}(X,+,V) 79 atomic_inc_return_acquire(X) __atomic_op_return{acquire}(X,+,1) 83 atomic_fetch_inc_acquire(X) __atomic_fetch_op{acquire}(X,+,1) 92 atomic_fetch_sub_acquire(V,X) __atomic_fetch_op{acquire}(X,-,V) 97 atomic_dec_return_acquire(X) __atomic_op_return{acquire}(X,-,1) 101 atomic_fetch_dec_acquire(X) __atomic_fetch_op{acquire}(X,-,1) 107 atomic_xchg_acquire(X,V) __xchg{acquire}(X,V) [all …]
|
A D | linux-kernel.bell | 18 'acquire (*smp_load_acquire*) || 20 instructions R[{'once,'acquire,'noreturn}] 22 instructions RMW[{'once,'acquire,'release}]
|
/linux/tools/memory-model/litmus-tests/ |
A D | ISA2+pooncerelease+poacquirerelease+poacquireonce.litmus | 6 * This litmus test demonstrates that a release-acquire chain suffices 8 * that the release-acquire chain suffices is because in all but one 11 * (AKA non-rf) link, so release-acquire is all that is needed.
|
A D | README | 46 and load-acquire replaced with READ_ONCE(). 49 Can a release-acquire chain order a prior store against 58 Does a release-acquire pair suffice for the load-buffering 64 and load-acquire replaced with READ_ONCE(). 71 in one process, and use an acquire load followed by a pair of 76 acquire load followed by a pair of spin_is_locked() calls 87 As below, but with a release-acquire chain. 126 As below, but without the smp_wmb() and acquire load. 129 Can a smp_wmb(), instead of a release, and an acquire order 149 Is the ordering provided by a release-acquire chain sufficient [all …]
|
A D | S+fencewmbonceonce+poacquireonce.litmus | 6 * Can a smp_wmb(), instead of a release, and an acquire order a prior
|
A D | LB+poacquireonce+pooncerelease.litmus | 6 * Does a release-acquire pair suffice for the load-buffering litmus
|
A D | S+poonceonces.litmus | 6 * Starting with a two-process release-acquire chain ordering P0()'s
|
/linux/Documentation/locking/ |
A D | futex-requeue-pi.rst | 91 to be able to acquire the rt_mutex before returning to user space. 93 acquire the rt_mutex as it would open a race window between the 99 allow the requeue code to acquire an uncontended rt_mutex on behalf 115 requeueing, futex_requeue() attempts to acquire the requeue target 127 tasks as it can acquire the lock for, which in the majority of cases 129 either pthread_cond_broadcast() or pthread_cond_signal() acquire the
|
A D | ww-mutex-design.rst | 64 trying to acquire locks doesn't grab a new reservation id, but keeps the one it 66 acquire context. Furthermore the acquire context keeps track of debugging state 67 to catch w/w mutex interface abuse. An acquire context is representing a 71 w/w mutexes, since it is required to initialize the acquire context. The lock 74 Furthermore there are three different class of w/w lock acquire functions: 99 * Functions to only acquire a single w/w mutex, which results in the exact same 103 Again this is not strictly required. But often you only want to acquire a 104 single lock in which case it's pointless to set up an acquire context (and so 119 Three different ways to acquire locks within the same w/w class. Common 344 (1) Waiters with an acquire context are sorted by stamp order; waiters [all …]
|
A D | preempt-locking.rst | 57 RULE #3: Lock acquire and release must be performed by same task 62 means you can't do oddball things like acquire a lock and go off to 64 like this, acquire and release the task in the same code path and
|
/linux/Documentation/litmus-tests/atomic/ |
A D | Atomic-RMW+mb__after_atomic-is-stronger-than-acquire.litmus | 1 C Atomic-RMW+mb__after_atomic-is-stronger-than-acquire 7 * stronger than a normal acquire: both the read and write parts of
|
/linux/drivers/net/ethernet/broadcom/bnx2x/ |
A D | bnx2x_vfpf.c | 1362 struct vfpf_acquire_tlv *acquire) in bnx2x_vf_mbx_is_windows_vm() argument 1369 if (!acquire->bulletin_addr || in bnx2x_vf_mbx_is_windows_vm() 1371 ((acquire->vfdev_info.vf_os & VF_OS_MASK) == in bnx2x_vf_mbx_is_windows_vm() 1400 struct vfpf_acquire_tlv *acquire = &mbx->msg->req.acquire; in bnx2x_vf_mbx_acquire() local 1405 vf->abs_vfid, acquire->vfdev_info.vf_id, acquire->vfdev_info.vf_os, in bnx2x_vf_mbx_acquire() 1406 acquire->resc_request.num_rxqs, acquire->resc_request.num_txqs, in bnx2x_vf_mbx_acquire() 1407 acquire->resc_request.num_sbs, acquire->resc_request.num_mac_filters, in bnx2x_vf_mbx_acquire() 1408 acquire->resc_request.num_vlan_filters, in bnx2x_vf_mbx_acquire() 1409 acquire->resc_request.num_mc_filters); in bnx2x_vf_mbx_acquire() 1427 vf->fp_hsi = acquire->vfdev_info.fp_hsi_ver; in bnx2x_vf_mbx_acquire() [all …]
|
/linux/drivers/net/ethernet/intel/igc/ |
A D | igc_i225.c | 193 status = hw->nvm.ops.acquire(hw); in igc_read_nvm_srrd_i225() 291 status = hw->nvm.ops.acquire(hw); in igc_write_nvm_srwr_i225() 317 status = hw->nvm.ops.acquire(hw); in igc_validate_nvm_checksum_i225() 412 ret_val = hw->nvm.ops.acquire(hw); in igc_update_nvm_checksum_i225() 471 nvm->ops.acquire = igc_acquire_nvm_i225; in igc_init_nvm_params_i225()
|
/linux/drivers/net/ethernet/intel/e1000e/ |
A D | phy.c | 250 ret_val = hw->phy.ops.acquire(hw); in e1000e_read_phy_reg_m88() 275 ret_val = hw->phy.ops.acquire(hw); in e1000e_write_phy_reg_m88() 322 if (!hw->phy.ops.acquire) in __e1000e_read_phy_reg_igp() 325 ret_val = hw->phy.ops.acquire(hw); in __e1000e_read_phy_reg_igp() 389 if (!hw->phy.ops.acquire) in __e1000e_write_phy_reg_igp() 392 ret_val = hw->phy.ops.acquire(hw); in __e1000e_write_phy_reg_igp() 457 if (!hw->phy.ops.acquire) in __e1000_read_kmrn_reg() 460 ret_val = hw->phy.ops.acquire(hw); in __e1000_read_kmrn_reg() 530 if (!hw->phy.ops.acquire) in __e1000_write_kmrn_reg() 533 ret_val = hw->phy.ops.acquire(hw); in __e1000_write_kmrn_reg() [all …]
|
A D | ich8lan.c | 216 hw->phy.ops.acquire(hw); in e1000_phy_is_accessible_pchlan() 307 ret_val = hw->phy.ops.acquire(hw); in e1000_init_phy_workarounds_pchlan() 836 ret_val = hw->phy.ops.acquire(hw); in e1000_set_eee_pchlan() 1141 ret_val = hw->phy.ops.acquire(hw); in e1000_enable_ulp_lpt_lp() 1304 ret_val = hw->phy.ops.acquire(hw); in e1000_disable_ulp_lpt_lp() 3292 nvm->ops.acquire(hw); in e1000_read_nvm_spt() 3383 nvm->ops.acquire(hw); in e1000_read_nvm_ich8lan() 3773 nvm->ops.acquire(hw); in e1000_write_nvm_ich8lan() 3811 nvm->ops.acquire(hw); in e1000_update_nvm_checksum_spt() 3972 nvm->ops.acquire(hw); in e1000_update_nvm_checksum_ich8lan() [all …]
|
/linux/Documentation/litmus-tests/ |
A D | README | 15 Atomic-RMW+mb__after_atomic-is-stronger-than-acquire.litmus 17 stronger than a normal acquire: both the read and write parts of
|
/linux/drivers/net/ethernet/intel/igb/ |
A D | e1000_i210.c | 200 if (!(hw->nvm.ops.acquire(hw))) { in igb_read_nvm_srrd_i210() 300 if (!(hw->nvm.ops.acquire(hw))) { in igb_write_nvm_srwr_i210() 543 if (!(hw->nvm.ops.acquire(hw))) { in igb_validate_nvm_checksum_i210() 589 if (!(hw->nvm.ops.acquire(hw))) { in igb_update_nvm_checksum_i210() 798 nvm->ops.acquire = igb_acquire_nvm_i210; in igb_init_nvm_params_i210()
|
/linux/Documentation/filesystems/ |
A D | directory-locking.rst | 11 always acquire the locks in order by increasing address. We'll call 75 attempts to acquire lock on B, A will remain the parent of B until we 76 acquire the lock on B. (Proof: only cross-directory rename can change 91 attempt to acquire some lock and already holds at least one lock. Let's 121 try to acquire lock on descendent before the lock on ancestor.
|
/linux/tools/memory-model/Documentation/ |
A D | glossary.txt | 31 An example special acquire operation is smp_load_acquire(), 33 acquire loads. 35 When an acquire load returns the value stored by a release store 36 to that same variable, (in other words, the acquire load "reads 38 store "happen before" any operations following that load acquire.
|
A D | recipes.txt | 195 load buffering, release-acquire chains, store buffering. 213 Release and acquire 237 The init_stack_slab() function in lib/stackdepot.c uses release-acquire 405 Release-acquire chains 408 Release-acquire chains are a low-overhead, flexible, and easy-to-use 464 is that in this version, CPU2() is not part of the release-acquire chain. 467 Despite this limitation, release-acquire chains are low-overhead as 559 release-acquire chain suffices. Both the MP and the ISA2 566 locking and in the release-acquire sections.
|
/linux/drivers/gpu/drm/nouveau/include/nvkm/core/ |
A D | memory.h | 36 void __iomem *(*acquire)(struct nvkm_memory *); member 70 #define nvkm_kmap(o) (o)->func->acquire(o)
|
/linux/Documentation/RCU/ |
A D | UP.rst | 60 callback function must acquire this same lock. In this case, if 120 like spin_lock_bh() to acquire the lock. Please note that 131 callbacks acquire locks directly. However, a great many RCU 132 callbacks do acquire locks *indirectly*, for example, via
|
/linux/Documentation/networking/ |
A D | xfrm_sysctl.rst | 11 default 30 - hard timeout in seconds for acquire requests
|
/linux/drivers/media/dvb-frontends/ |
A D | as102_fe.h | 14 int (*stream_ctrl)(void *priv, int acquire, uint32_t elna_cfg);
|
/linux/drivers/gpu/drm/nouveau/nvkm/core/ |
A D | gpuobj.c | 102 .acquire = nvkm_gpuobj_heap_acquire, 167 .acquire = nvkm_gpuobj_acquire,
|