/linux/fs/ocfs2/dlm/ |
H A D | dlmthread.c | 40 /* will exit holding res->spinlock, but may drop in function */ 46 assert_spin_locked(&res->spinlock); in __dlm_wait_on_lockres_flags() 52 spin_unlock(&res->spinlock); in __dlm_wait_on_lockres_flags() 54 spin_lock(&res->spinlock); in __dlm_wait_on_lockres_flags() 78 assert_spin_locked(&res->spinlock); in __dlm_lockres_unused() 109 assert_spin_locked(&dlm->spinlock); in __dlm_lockres_calc_usage() 110 assert_spin_locked(&res->spinlock); in __dlm_lockres_calc_usage() 135 spin_lock(&dlm->spinlock); in dlm_lockres_calc_usage() 136 spin_lock(&res->spinlock); in dlm_lockres_calc_usage() 140 spin_unlock(&res->spinlock); in dlm_lockres_calc_usage() [all …]
|
H A D | dlmmaster.c | 22 #include <linux/spinlock.h> 151 * when it is created, and since the dlm->spinlock is held at 164 assert_spin_locked(&dlm->spinlock); in __dlm_mle_attach_hb_events() 181 spin_lock(&dlm->spinlock); in dlm_mle_detach_hb_events() 183 spin_unlock(&dlm->spinlock); in dlm_mle_detach_hb_events() 191 assert_spin_locked(&dlm->spinlock); in dlm_get_mle_inuse() 202 spin_lock(&dlm->spinlock); in dlm_put_mle_inuse() 207 spin_unlock(&dlm->spinlock); in dlm_put_mle_inuse() 217 assert_spin_locked(&dlm->spinlock); in __dlm_put_mle() 236 spin_lock(&dlm->spinlock); in dlm_put_mle() [all …]
|
H A D | dlmconvert.c | 21 #include <linux/spinlock.h> 37 * needs a spinlock held on entry (res->spinlock) and it is the 38 * only one that holds a lock on exit (res->spinlock). 55 * taken: takes and drops res->spinlock 66 spin_lock(&res->spinlock); in dlmconvert_master() 76 spin_unlock(&res->spinlock); in dlmconvert_master() 95 * caller needs: res->spinlock 96 * taken: takes and drops lock->spinlock 97 * held on exit: res->spinlock 111 assert_spin_locked(&res->spinlock); in __dlmconvert_master() [all …]
|
H A D | dlmrecovery.c | 103 assert_spin_locked(&dlm->spinlock); in dlm_set_reco_dead_node() 113 assert_spin_locked(&dlm->spinlock); in dlm_set_reco_master() 121 assert_spin_locked(&dlm->spinlock); in __dlm_reset_recovery() 309 spin_lock(&dlm->spinlock); in dlm_reco_master_ready() 311 spin_unlock(&dlm->spinlock); in dlm_reco_master_ready() 320 spin_lock(&dlm->spinlock); in dlm_is_node_dead() 322 spin_unlock(&dlm->spinlock); in dlm_is_node_dead() 331 spin_lock(&dlm->spinlock); in dlm_is_node_recovered() 333 spin_unlock(&dlm->spinlock); in dlm_is_node_recovered() 381 spin_lock(&dlm->spinlock); in dlm_in_recovery() [all …]
|
H A D | dlmdomain.c | 15 #include <linux/spinlock.h> 93 * spinlock lock ordering: if multiple locks are needed, obey this ordering: 95 * struct dlm_ctxt->spinlock 96 * struct dlm_lock_resource->spinlock 99 * dlm_master_list_entry->spinlock 100 * dlm_lock->spinlock 160 assert_spin_locked(&dlm->spinlock); in __dlm_insert_lockres() 183 assert_spin_locked(&dlm->spinlock); in __dlm_lookup_lockres_full() 215 assert_spin_locked(&dlm->spinlock); in __dlm_lookup_lockres() 219 spin_lock(&res->spinlock); in __dlm_lookup_lockres() [all …]
|
H A D | dlmunlock.c | 21 #include <linux/spinlock.h> 76 * taken: res->spinlock and lock->spinlock taken and dropped 114 spin_lock(&res->spinlock); in dlmunlock_common() 118 spin_unlock(&res->spinlock); in dlmunlock_common() 125 spin_lock(&lock->spinlock); in dlmunlock_common() 164 spin_unlock(&lock->spinlock); in dlmunlock_common() 165 spin_unlock(&res->spinlock); in dlmunlock_common() 168 spin_lock(&res->spinlock); in dlmunlock_common() 169 spin_lock(&lock->spinlock); in dlmunlock_common() 230 spin_unlock(&lock->spinlock); in dlmunlock_common() [all …]
|
/linux/include/asm-generic/ |
H A D | qspinlock.h | 3 * Queued spinlock 5 * A 'generic' spinlock implementation that is based on MCS locks. For an 6 * architecture that's looking for a 'generic' spinlock, please first consider 15 * qspinlock relies on a far greater (compared to asm-generic/spinlock.h) set 47 * queued_spin_is_locked - is the spinlock locked? 48 * @lock: Pointer to queued spinlock structure 62 * queued_spin_value_unlocked - is the spinlock structure unlocked? 63 * @lock: queued spinlock structure 78 * @lock : Pointer to queued spinlock structure 86 * queued_spin_trylock - try to acquire the queued spinlock [all …]
|
/linux/drivers/hwtracing/coresight/ |
H A D | coresight-etm3x-sysfs.c | 52 spin_lock_irqsave(&drvdata->spinlock, flags); in etmsr_show() 58 spin_unlock_irqrestore(&drvdata->spinlock, flags); in etmsr_show() 79 spin_lock(&drvdata->spinlock); in reset_store() 89 spin_unlock(&drvdata->spinlock); in reset_store() 120 spin_lock(&drvdata->spinlock); in mode_store() 171 spin_unlock(&drvdata->spinlock); in mode_store() 176 spin_unlock(&drvdata->spinlock); in mode_store() 299 * Use spinlock to ensure index doesn't change while it gets in addr_idx_store() 300 * dereferenced multiple times within a spinlock block elsewhere. in addr_idx_store() 302 spin_lock(&drvdata->spinlock); in addr_idx_store() [all …]
|
H A D | coresight-tmc-etf.c | 188 raw_spin_lock_irqsave(&drvdata->spinlock, flags); in tmc_enable_etf_sink_sysfs() 190 raw_spin_unlock_irqrestore(&drvdata->spinlock, flags); in tmc_enable_etf_sink_sysfs() 192 /* Allocating the memory here while outside of the spinlock */ in tmc_enable_etf_sink_sysfs() 198 raw_spin_lock_irqsave(&drvdata->spinlock, flags); in tmc_enable_etf_sink_sysfs() 240 raw_spin_unlock_irqrestore(&drvdata->spinlock, flags); in tmc_enable_etf_sink_sysfs() 242 /* Free memory outside the spinlock if need be */ in tmc_enable_etf_sink_sysfs() 258 raw_spin_lock_irqsave(&drvdata->spinlock, flags); in tmc_enable_etf_sink_perf() 301 raw_spin_unlock_irqrestore(&drvdata->spinlock, flags); in tmc_enable_etf_sink_perf() 336 raw_spin_lock_irqsave(&drvdata->spinlock, flags); in tmc_disable_etf_sink() 339 raw_spin_unlock_irqrestore(&drvdata->spinlock, flags); in tmc_disable_etf_sink() [all …]
|
H A D | coresight-cti-core.c | 20 #include <linux/spinlock.h> 60 /* write set of regs to hardware - call with spinlock claimed */ 96 raw_spin_lock_irqsave(&drvdata->spinlock, flags); in cti_enable_hw() 111 raw_spin_unlock_irqrestore(&drvdata->spinlock, flags); in cti_enable_hw() 119 raw_spin_unlock_irqrestore(&drvdata->spinlock, flags); in cti_enable_hw() 128 raw_spin_lock(&drvdata->spinlock); in cti_cpuhp_enable_hw() 141 raw_spin_unlock(&drvdata->spinlock); in cti_cpuhp_enable_hw() 146 raw_spin_unlock(&drvdata->spinlock); in cti_cpuhp_enable_hw() 156 raw_spin_lock(&drvdata->spinlock); in cti_disable_hw() 180 raw_spin_unlock(&drvdata->spinlock); in cti_disable_hw() [all …]
|
/linux/drivers/hwspinlock/ |
H A D | Kconfig | 7 bool "Hardware Spinlock drivers" 12 tristate "OMAP Hardware Spinlock device" 15 Say y here to support the OMAP Hardware Spinlock device (firstly 21 tristate "Qualcomm Hardware Spinlock device" 32 tristate "SPRD Hardware Spinlock device" 35 Say y here to support the SPRD Hardware Spinlock device. 40 tristate "STM32 Hardware Spinlock device" 43 Say y here to support the STM32 Hardware Spinlock device. 48 tristate "SUN6I Hardware Spinlock device" 51 Say y here to support the SUN6I Hardware Spinlock device which can be
|
/linux/sound/drivers/ |
H A D | mtpav.c | 128 spinlock_t spinlock; member 308 guard(spinlock_irqsave)(&mtp_card->spinlock); in snd_mtpav_output_write() 336 guard(spinlock_irqsave)(&mtp_card->spinlock); in snd_mtpav_input_open() 352 guard(spinlock_irqsave)(&mtp_card->spinlock); in snd_mtpav_input_close() 368 guard(spinlock_irqsave)(&mtp_card->spinlock); 385 guard(spinlock_irqsave)(&chip->spinlock); 396 /* spinlock held! */ in snd_mtpav_output_timer() 402 /* spinlock held! */ in snd_mtpav_output_timer() 416 guard(spinlock_irqsave)(&mtp_card->spinlock); in snd_mtpav_remove_output_timer() 430 guard(spinlock_irqsave)(&mtp_card->spinlock); in snd_mtpav_output_open() [all...] |
/linux/drivers/comedi/drivers/ |
H A D | das800.c | 236 spin_lock_irqsave(&dev->spinlock, irq_flags); in das800_enable() 244 spin_unlock_irqrestore(&dev->spinlock, irq_flags); in das800_enable() 251 spin_lock_irqsave(&dev->spinlock, irq_flags); in das800_disable() 254 spin_unlock_irqrestore(&dev->spinlock, irq_flags); in das800_disable() 379 spin_lock_irqsave(&dev->spinlock, irq_flags); in das800_ai_do_cmd() 382 spin_unlock_irqrestore(&dev->spinlock, irq_flags); in das800_ai_do_cmd() 403 spin_lock_irqsave(&dev->spinlock, irq_flags); in das800_ai_do_cmd() 405 spin_unlock_irqrestore(&dev->spinlock, irq_flags); in das800_ai_do_cmd() 442 spin_lock_irqsave(&dev->spinlock, irq_flags); in das800_interrupt() 445 * Don't release spinlock yet since we want to make sure in das800_interrupt() [all …]
|
/linux/drivers/gpio/ |
H A D | gpio-ml-ioh.c | 76 * @spinlock: Used for register access protection 87 spinlock_t spinlock; member 98 spin_lock_irqsave(&chip->spinlock, flags); in ioh_gpio_set() 106 spin_unlock_irqrestore(&chip->spinlock, flags); in ioh_gpio_set() 126 spin_lock_irqsave(&chip->spinlock, flags); in ioh_gpio_direction_output() 139 spin_unlock_irqrestore(&chip->spinlock, flags); in ioh_gpio_direction_output() 150 spin_lock_irqsave(&chip->spinlock, flags); in ioh_gpio_direction_input() 155 spin_unlock_irqrestore(&chip->spinlock, flags); in ioh_gpio_direction_input() 259 spin_lock_irqsave(&chip->spinlock, flags); in ioh_irq_type() 299 spin_unlock_irqrestore(&chip->spinlock, flags); in ioh_irq_type() [all …]
|
H A D | gpio-pch.c | 89 * @spinlock: Used for register access protection 99 spinlock_t spinlock; member 108 spin_lock_irqsave(&chip->spinlock, flags); in pch_gpio_set() 116 spin_unlock_irqrestore(&chip->spinlock, flags); in pch_gpio_set() 136 spin_lock_irqsave(&chip->spinlock, flags); in pch_gpio_direction_output() 150 spin_unlock_irqrestore(&chip->spinlock, flags); in pch_gpio_direction_output() 161 spin_lock_irqsave(&chip->spinlock, flags); in pch_gpio_direction_input() 166 spin_unlock_irqrestore(&chip->spinlock, flags); in pch_gpio_direction_input() 268 spin_lock_irqsave(&chip->spinlock, flags); in pch_irq_type() 280 spin_unlock_irqrestore(&chip->spinlock, flags); in pch_irq_type() [all …]
|
H A D | gpio-tqmx86.c | 53 raw_spinlock_t spinlock; member 71 __must_hold(&gpio->spinlock) in tqmx86_gpio_clrsetbits() 90 __must_hold(&gpio->spinlock) in _tqmx86_gpio_set() 101 guard(raw_spinlock_irqsave)(&gpio->spinlock); in tqmx86_gpio_set() 113 guard(raw_spinlock_irqsave)(&gpio->spinlock); in tqmx86_gpio_direction_input() 126 guard(raw_spinlock_irqsave)(&gpio->spinlock); in tqmx86_gpio_direction_output() 149 __must_hold(&gpio->spinlock) in tqmx86_gpio_irq_config() 174 scoped_guard(raw_spinlock_irqsave, &gpio->spinlock) { in tqmx86_gpio_irq_mask() 189 guard(raw_spinlock_irqsave)(&gpio->spinlock); in tqmx86_gpio_irq_unmask() 216 guard(raw_spinlock_irqsave)(&gpio->spinlock); in tqmx86_gpio_irq_set_type() [all …]
|
/linux/drivers/media/rc/ |
H A D | ite-cir.c | 175 * spinlock held */ 232 /* grab the spinlock */ in ite_cir_isr() 253 /* drop the spinlock, since the ir-core layer in ite_cir_isr() 261 /* reacquire the spinlock */ in ite_cir_isr() 278 /* drop the spinlock */ in ite_cir_isr() 415 /* drop the spinlock */ in ite_tx_ir() 422 /* get the spinlock again */ in ite_tx_ir() 448 /* drop the spinlock while we sleep */ in ite_tx_ir() 454 /* reacquire the spinlock */ in ite_tx_ir() 516 /* set the carrier parameters; to be called with the spinlock held */ [all …]
|
/linux/drivers/watchdog/ |
H A D | of_xilinx_wdt.c | 43 spinlock_t spinlock; /* spinlock for register handling */ member 60 spin_lock(&xdev->spinlock); in xilinx_wdt_start() 71 spin_unlock(&xdev->spinlock); in xilinx_wdt_start() 83 spin_lock(&xdev->spinlock); in xilinx_wdt_stop() 92 spin_unlock(&xdev->spinlock); in xilinx_wdt_stop() 106 spin_lock(&xdev->spinlock); in xilinx_wdt_keepalive() 112 spin_unlock(&xdev->spinlock); in xilinx_wdt_keepalive() 137 spin_lock(&xdev->spinlock); in xwdt_selftest() 148 spin_unlock(&xdev->spinlock); in xwdt_selftest() 218 spin_lock_init(&xdev->spinlock); in xwdt_probe()
|
H A D | xilinx_wwdt.c | 59 * @spinlock: spinlock for IO register access 68 spinlock_t spinlock; /* spinlock for register handling */ member 82 spin_lock(&xdev->spinlock); in xilinx_wwdt_start() 94 spin_unlock(&xdev->spinlock); in xilinx_wwdt_start() 106 spin_lock(&xdev->spinlock); in xilinx_wwdt_keepalive() 116 spin_unlock(&xdev->spinlock); in xilinx_wwdt_keepalive() 221 spin_lock_init(&xdev->spinlock); in xwwdt_probe()
|
/linux/lib/ |
H A D | refcount.c | 8 #include <linux/spinlock.h> 129 * refcount_dec_and_lock - return holding spinlock if able to decrement 132 * @lock: the spinlock to be locked 141 * Return: true and hold spinlock if able to decrement refcount to 0, false 160 * refcount_dec_and_lock_irqsave - return holding spinlock with disabled 163 * @lock: the spinlock to be locked 166 * Same as refcount_dec_and_lock() above except that the spinlock is acquired 169 * Return: true and hold spinlock if able to decrement refcount to 0, false
|
/linux/include/linux/ |
H A D | spinlock_types.h | 5 * include/linux/spinlock_types.h - generic spinlock type definitions 16 /* Non PREEMPT_RT kernels map spinlock to raw_spinlock */ 17 typedef struct spinlock { struct 47 /* PREEMPT_RT kernels map spinlock to rt_mutex */ 50 typedef struct spinlock { struct
|
H A D | lockref.h | 9 * are atomic with respect to the spinlock that goes with them. In 11 * the spinlock for the common decrement/increment operations, but they 13 * the spinlock had been taken (using a cmpxchg operation that covers 18 #include <linux/spinlock.h> 57 /* Must be called under spinlock for reliable results */
|
/linux/drivers/accessibility/speakup/ |
H A D | synth.c | 29 * This spinlock is used to protect the entire speakup machinery, and 38 * spinlock because speakup needs to disable the keyboard IRQ. 40 .spinlock = __SPIN_LOCK_UNLOCKED(speakup_info.spinlock), 71 spin_lock_irqsave(&speakup_info.spinlock, flags); in _spk_do_catch_up() 73 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in _spk_do_catch_up() 77 spin_lock_irqsave(&speakup_info.spinlock, flags); in _spk_do_catch_up() 80 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in _spk_do_catch_up() 87 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in _spk_do_catch_up() 93 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in _spk_do_catch_up() 105 spin_lock_irqsave(&speakup_info.spinlock, flags); in _spk_do_catch_up() [all …]
|
H A D | speakup_apollo.c | 153 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 155 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 159 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 165 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 171 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 177 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 185 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 189 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 199 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 201 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up()
|
H A D | speakup_decext.c | 167 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 169 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 173 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 176 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 182 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 188 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 196 spin_lock_irqsave(&speakup_info.spinlock, flags); in do_catch_up() 198 spin_unlock_irqrestore(&speakup_info.spinlock, flags); in do_catch_up() 210 spin_lock_irqsave(&speakup_info.spinlock, in do_catch_up() 214 spin_unlock_irqrestore(&speakup_info.spinlock, in do_catch_up()
|