mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-23 00:20:52 -05:00
libceph: behave in mon_fault() if cur_mon < 0
This can happen if __close_session() in ceph_monc_stop() races with a connection reset. We need to ignore such faults, otherwise it's likely we would take !hunting, call __schedule_delayed() and end up with delayed_work() executing on invalid memory, among other things. The (two!) con->private tests are useless, as nothing ever clears con->private. Nuke them. Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
This commit is contained in:
parent
bee3a37c47
commit
b5d91704f5
1 changed files with 9 additions and 14 deletions
|
@ -1155,22 +1155,17 @@ static void mon_fault(struct ceph_connection *con)
|
||||||
{
|
{
|
||||||
struct ceph_mon_client *monc = con->private;
|
struct ceph_mon_client *monc = con->private;
|
||||||
|
|
||||||
if (!monc)
|
|
||||||
return;
|
|
||||||
|
|
||||||
dout("mon_fault\n");
|
|
||||||
mutex_lock(&monc->mutex);
|
mutex_lock(&monc->mutex);
|
||||||
if (!con->private)
|
dout("%s mon%d\n", __func__, monc->cur_mon);
|
||||||
goto out;
|
if (monc->cur_mon >= 0) {
|
||||||
|
if (!monc->hunting) {
|
||||||
if (!monc->hunting) {
|
dout("%s hunting for new mon\n", __func__);
|
||||||
dout("%s hunting for new mon\n", __func__);
|
reopen_session(monc);
|
||||||
reopen_session(monc);
|
__schedule_delayed(monc);
|
||||||
__schedule_delayed(monc);
|
} else {
|
||||||
} else {
|
dout("%s already hunting\n", __func__);
|
||||||
dout("%s already hunting\n", __func__);
|
}
|
||||||
}
|
}
|
||||||
out:
|
|
||||||
mutex_unlock(&monc->mutex);
|
mutex_unlock(&monc->mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue