]> git.baikalelectronics.ru Git - kernel.git/commit
locking/futex: Allow low-level atomic operations to return -EAGAIN
authorWill Deacon <will.deacon@arm.com>
Thu, 28 Feb 2019 11:58:08 +0000 (11:58 +0000)
committerWill Deacon <will.deacon@arm.com>
Fri, 26 Apr 2019 12:57:31 +0000 (13:57 +0100)
commit8beb1141694127f9e2ddb9a7a3b27a9d7a60446f
tree761a0f8703cae2a6a138fb7e8d096146d45b3c2d
parent21a7936344236e3c868f46f446ca8999c5cd1560
locking/futex: Allow low-level atomic operations to return -EAGAIN

Some futex() operations, including FUTEX_WAKE_OP, require the kernel to
perform an atomic read-modify-write of the futex word via the userspace
mapping. These operations are implemented by each architecture in
arch_futex_atomic_op_inuser() and futex_atomic_cmpxchg_inatomic(), which
are called in atomic context with the relevant hash bucket locks held.

Although these routines may return -EFAULT in response to a page fault
generated when accessing userspace, they are expected to succeed (i.e.
return 0) in all other cases. This poses a problem for architectures
that do not provide bounded forward progress guarantees or fairness of
contended atomic operations and can lead to starvation in some cases.

In these problematic scenarios, we must return back to the core futex
code so that we can drop the hash bucket locks and reschedule if
necessary, much like we do in the case of a page fault.

Allow architectures to return -EAGAIN from their implementations of
arch_futex_atomic_op_inuser() and futex_atomic_cmpxchg_inatomic(), which
will cause the core futex code to reschedule if necessary and return
back to the architecture code later on.

Cc: <stable@kernel.org>
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
kernel/futex.c