aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorSage Weil <sage@newdream.net>2010-02-16 22:01:03 -0800
committerSage Weil <sage@newdream.net>2010-02-16 22:01:03 -0800
commite2663ab60de59d20fa33da3528f6d5359f8eb003 (patch)
treef167aba83280b6767e1f9bdf2e67e4ac48a85c68 /fs
parent153a008bf7915ea9127341409170cb197d111282 (diff)
downloadkernel_samsung_smdk4412-e2663ab60de59d20fa33da3528f6d5359f8eb003.zip
kernel_samsung_smdk4412-e2663ab60de59d20fa33da3528f6d5359f8eb003.tar.gz
kernel_samsung_smdk4412-e2663ab60de59d20fa33da3528f6d5359f8eb003.tar.bz2
ceph: allow connection to be reopened by fault callback
Fix the messenger to allow a ceph_con_open() during the fault callback. Previously the work wasn't getting queued on the connection because the fault path avoids requeued work (normally spurious). Loop on reopening by checking for the OPENING state bit. This fixes OSD reconnects when a TCP connection drops. Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs')
-rw-r--r--fs/ceph/messenger.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/ceph/messenger.c b/fs/ceph/messenger.c
index 44bdaf4..acf383f 100644
--- a/fs/ceph/messenger.c
+++ b/fs/ceph/messenger.c
@@ -1808,7 +1808,7 @@ done:
clear_bit(BUSY, &con->state);
dout("con->state=%lu\n", con->state);
if (test_bit(QUEUED, &con->state)) {
- if (!backoff) {
+ if (!backoff || test_bit(OPENING, &con->state)) {
dout("con_work %p QUEUED reset, looping\n", con);
goto more;
}