diff options
| author | Cong Wang <xiyou.wangcong@gmail.com> | 2018-08-14 18:21:31 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2018-08-16 15:14:42 -0400 |
| commit | ff93bca769925a2d8fd7f910cdf543d992e17f07 (patch) | |
| tree | bab8928bc5d1fe07c2c206c5462e1b1aef8b8c74 /include/linux | |
| parent | 32039eac4c48f70dfaad36a84f30356ededc7ea8 (diff) | |
ila: make lockdep happy again
Previously, alloc_ila_locks() and bucket_table_alloc() call
spin_lock_init() separately, therefore they have two different
lock names and lock class keys. However, after commit b893281715ab
("ila: Call library function alloc_bucket_locks") they both call
helper alloc_bucket_spinlocks() which now only has one lock
name and lock class key. This causes a few bogus lockdep warnings
as reported by syzbot.
Fix this by making alloc_bucket_locks() a macro and pass declaration
name as lock name and a static lock class key inside the macro.
Fixes: b893281715ab ("ila: Call library function alloc_bucket_locks")
Reported-by: <syzbot+b66a5a554991a8ed027c@syzkaller.appspotmail.com>
Cc: Tom Herbert <tom@quantonium.net>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/spinlock.h | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/include/linux/spinlock.h b/include/linux/spinlock.h index 3190997df9ca..e089157dcf97 100644 --- a/include/linux/spinlock.h +++ b/include/linux/spinlock.h | |||
| @@ -451,9 +451,20 @@ extern int _atomic_dec_and_lock_irqsave(atomic_t *atomic, spinlock_t *lock, | |||
| 451 | #define atomic_dec_and_lock_irqsave(atomic, lock, flags) \ | 451 | #define atomic_dec_and_lock_irqsave(atomic, lock, flags) \ |
| 452 | __cond_lock(lock, _atomic_dec_and_lock_irqsave(atomic, lock, &(flags))) | 452 | __cond_lock(lock, _atomic_dec_and_lock_irqsave(atomic, lock, &(flags))) |
| 453 | 453 | ||
| 454 | int alloc_bucket_spinlocks(spinlock_t **locks, unsigned int *lock_mask, | 454 | int __alloc_bucket_spinlocks(spinlock_t **locks, unsigned int *lock_mask, |
| 455 | size_t max_size, unsigned int cpu_mult, | 455 | size_t max_size, unsigned int cpu_mult, |
| 456 | gfp_t gfp); | 456 | gfp_t gfp, const char *name, |
| 457 | struct lock_class_key *key); | ||
| 458 | |||
| 459 | #define alloc_bucket_spinlocks(locks, lock_mask, max_size, cpu_mult, gfp) \ | ||
| 460 | ({ \ | ||
| 461 | static struct lock_class_key key; \ | ||
| 462 | int ret; \ | ||
| 463 | \ | ||
| 464 | ret = __alloc_bucket_spinlocks(locks, lock_mask, max_size, \ | ||
| 465 | cpu_mult, gfp, #locks, &key); \ | ||
| 466 | ret; \ | ||
| 467 | }) | ||
| 457 | 468 | ||
| 458 | void free_bucket_spinlocks(spinlock_t *locks); | 469 | void free_bucket_spinlocks(spinlock_t *locks); |
| 459 | 470 | ||
