- Make sure __down_read_common() is always inlined so that the callers'

names land in traceevents output instead and thus the blocked function
   can be identified
 -----BEGIN PGP SIGNATURE-----
 
 iQIzBAABCgAdFiEEzv7L6UO9uDPlPSfHEsHwGGHeVUoFAmRg0vIACgkQEsHwGGHe
 VUqyhw//V27hy1LQObFH86sPFUf5DU5mcpF6ymZ1ww0rNNIGPJh9DUDG0krV5c8s
 cmB2bJMh7SbPc0z8PTQ9Qmj7wzWzrO52OeITvzj4n3oPsHGFcoAyqNIxh5qZLWD2
 2hFuuLpwuNv7nAISd275gWU2uUkhviYZMiaBaFpysM3jxQGuAsEx+lw1zIYmCkR8
 hTL4m9k71S4UBvPmgas1C3s/JClzO3OKHSoiphtb872RdemO/alhfS2YHH+kkEUL
 9v5fyH+1zznisOu7XbBhLK2e8Tgj6GT0v80hzG6ySRMHs1C+mg1ZyvvnUaSZ6hIr
 FXGsOH9qtI5CT/vZspJUEl9Ew1SHjO5TQlb7A+sL1TZXRuwRP3pNsryZSO8kJkag
 7yVmywWCO8pngxyD7tj2tLsO8b5tQ/0Cq9w43I21kTjxpKvdJ9dixBFQCGc9IJVB
 C/wD7JiiALXcN5uDrn+l2TPRBdbzM1UAommbCE9ugfs/6h20EU0Tku4qfKQSuzyD
 1wX6DtAr7u5tOP10+Chapj/+BGGSiAFaTc1uQLsnf13+AvXRnyMXSHNdOouGc19E
 flkZrR4ap8x1iDp9OijtU56iUjKcJkp7kGeBptFEZNbtm+iks7s7aNCnz0uHERAy
 KuHoxJ0lcsefOOp5qoKa+63wbS9ooM5ErStnETpXp4X+YWg+A0k=
 =otoJ
 -----END PGP SIGNATURE-----

Merge tag 'locking_urgent_for_v6.4_rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull locking fix from Borislav Petkov:

 - Make sure __down_read_common() is always inlined so that the callers'
   names land in traceevents output and thus the blocked function can be
   identified

* tag 'locking_urgent_for_v6.4_rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  locking/rwsem: Add __always_inline annotation to __down_read_common() and inlined callers
This commit is contained in:
Linus Torvalds 2023-05-14 08:00:46 -07:00
commit 31f4104e39

View File

@ -1240,7 +1240,7 @@ static struct rw_semaphore *rwsem_downgrade_wake(struct rw_semaphore *sem)
/* /*
* lock for reading * lock for reading
*/ */
static inline int __down_read_common(struct rw_semaphore *sem, int state) static __always_inline int __down_read_common(struct rw_semaphore *sem, int state)
{ {
int ret = 0; int ret = 0;
long count; long count;
@ -1258,17 +1258,17 @@ static inline int __down_read_common(struct rw_semaphore *sem, int state)
return ret; return ret;
} }
static inline void __down_read(struct rw_semaphore *sem) static __always_inline void __down_read(struct rw_semaphore *sem)
{ {
__down_read_common(sem, TASK_UNINTERRUPTIBLE); __down_read_common(sem, TASK_UNINTERRUPTIBLE);
} }
static inline int __down_read_interruptible(struct rw_semaphore *sem) static __always_inline int __down_read_interruptible(struct rw_semaphore *sem)
{ {
return __down_read_common(sem, TASK_INTERRUPTIBLE); return __down_read_common(sem, TASK_INTERRUPTIBLE);
} }
static inline int __down_read_killable(struct rw_semaphore *sem) static __always_inline int __down_read_killable(struct rw_semaphore *sem)
{ {
return __down_read_common(sem, TASK_KILLABLE); return __down_read_common(sem, TASK_KILLABLE);
} }