1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _LINUX_LOCAL_LOCK_H
3 #define _LINUX_LOCAL_LOCK_H
5 #include <linux/local_lock_internal.h>
8 * local_lock_init - Runtime initialize a lock instance
10 #define local_lock_init(lock) __local_lock_init(lock)
13 * local_lock - Acquire a per CPU local lock
14 * @lock: The lock variable
16 #define local_lock(lock) __local_lock(lock)
19 * local_lock_irq - Acquire a per CPU local lock and disable interrupts
20 * @lock: The lock variable
22 #define local_lock_irq(lock) __local_lock_irq(lock)
25 * local_lock_irqsave - Acquire a per CPU local lock, save and disable
27 * @lock: The lock variable
28 * @flags: Storage for interrupt flags
30 #define local_lock_irqsave(lock, flags) \
31 __local_lock_irqsave(lock, flags)
34 * local_unlock - Release a per CPU local lock
35 * @lock: The lock variable
37 #define local_unlock(lock) __local_unlock(lock)
40 * local_unlock_irq - Release a per CPU local lock and enable interrupts
41 * @lock: The lock variable
43 #define local_unlock_irq(lock) __local_unlock_irq(lock)
46 * local_unlock_irqrestore - Release a per CPU local lock and restore
48 * @lock: The lock variable
49 * @flags: Interrupt flags to restore
51 #define local_unlock_irqrestore(lock, flags) \
52 __local_unlock_irqrestore(lock, flags)
54 DEFINE_GUARD(local_lock
, local_lock_t __percpu
*,
57 DEFINE_GUARD(local_lock_irq
, local_lock_t __percpu
*,
60 DEFINE_LOCK_GUARD_1(local_lock_irqsave
, local_lock_t __percpu
,
61 local_lock_irqsave(_T
->lock
, _T
->flags
),
62 local_unlock_irqrestore(_T
->lock
, _T
->flags
),
65 #define local_lock_nested_bh(_lock) \
66 __local_lock_nested_bh(_lock)
68 #define local_unlock_nested_bh(_lock) \
69 __local_unlock_nested_bh(_lock)
71 DEFINE_GUARD(local_lock_nested_bh
, local_lock_t __percpu
*,
72 local_lock_nested_bh(_T
),
73 local_unlock_nested_bh(_T
))