kernel_samsung_a53x/net/ceph
Ilya Dryomov 39abc4c848 libceph: fix race between delayed_work() and ceph_monc_stop()
commit 69c7b2fe4c9cc1d3b1186d1c5606627ecf0de883 upstream.

The way the delayed work is handled in ceph_monc_stop() is prone to
races with mon_fault() and possibly also finish_hunting().  Both of
these can requeue the delayed work which wouldn't be canceled by any of
the following code in case that happens after cancel_delayed_work_sync()
runs -- __close_session() doesn't mess with the delayed work in order
to avoid interfering with the hunting interval logic.  This part was
missed in commit b5d91704f53e ("libceph: behave in mon_fault() if
cur_mon < 0") and use-after-free can still ensue on monc and objects
that hang off of it, with monc->auth and monc->monmap being
particularly susceptible to quickly being reused.

To fix this:

- clear monc->cur_mon and monc->hunting as part of closing the session
  in ceph_monc_stop()
- bail from delayed_work() if monc->cur_mon is cleared, similar to how
  it's done in mon_fault() and finish_hunting() (based on monc->hunting)
- call cancel_delayed_work_sync() after the session is closed

Cc: stable@vger.kernel.org
Link: https://tracker.ceph.com/issues/66857
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Reviewed-by: Xiubo Li <xiubli@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2024-11-19 14:19:45 +01:00
..
crush Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
armor.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
auth.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
auth_none.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
auth_none.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
auth_x.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
auth_x.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
auth_x_protocol.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
buffer.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
ceph_common.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
ceph_hash.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
ceph_strings.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
cls_lock_client.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
crypto.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
crypto.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
debugfs.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
decode.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
Kconfig Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
Makefile Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
messenger.c libceph: use kernel_connect() 2024-11-08 11:25:50 +01:00
mon_client.c libceph: fix race between delayed_work() and ceph_monc_stop() 2024-11-19 14:19:45 +01:00
msgpool.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
osd_client.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
osdmap.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
pagelist.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
pagevec.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
snapshot.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
string_table.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
striper.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00