ceph: flush mdlog before umounting
[ Upstream commit d095559ce4100f0c02aea229705230deac329c97 ]
Signed-off-by: Xiubo Li <xiubli@redhat.com>
Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Stable-dep-of: 5bd76b8de5b7 ("ceph: fix NULL pointer dereference for req->r_session")
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
d94ba7b3b7
commit
78b2f546f7
|
|
@ -4664,6 +4664,30 @@ static void wait_requests(struct ceph_mds_client *mdsc)
|
||||||
dout("wait_requests done\n");
|
dout("wait_requests done\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void send_flush_mdlog(struct ceph_mds_session *s)
|
||||||
|
{
|
||||||
|
struct ceph_msg *msg;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Pre-luminous MDS crashes when it sees an unknown session request
|
||||||
|
*/
|
||||||
|
if (!CEPH_HAVE_FEATURE(s->s_con.peer_features, SERVER_LUMINOUS))
|
||||||
|
return;
|
||||||
|
|
||||||
|
mutex_lock(&s->s_mutex);
|
||||||
|
dout("request mdlog flush to mds%d (%s)s seq %lld\n", s->s_mds,
|
||||||
|
ceph_session_state_name(s->s_state), s->s_seq);
|
||||||
|
msg = ceph_create_session_msg(CEPH_SESSION_REQUEST_FLUSH_MDLOG,
|
||||||
|
s->s_seq);
|
||||||
|
if (!msg) {
|
||||||
|
pr_err("failed to request mdlog flush to mds%d (%s) seq %lld\n",
|
||||||
|
s->s_mds, ceph_session_state_name(s->s_state), s->s_seq);
|
||||||
|
} else {
|
||||||
|
ceph_con_send(&s->s_con, msg);
|
||||||
|
}
|
||||||
|
mutex_unlock(&s->s_mutex);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* called before mount is ro, and before dentries are torn down.
|
* called before mount is ro, and before dentries are torn down.
|
||||||
* (hmm, does this still race with new lookups?)
|
* (hmm, does this still race with new lookups?)
|
||||||
|
|
@ -4673,6 +4697,7 @@ void ceph_mdsc_pre_umount(struct ceph_mds_client *mdsc)
|
||||||
dout("pre_umount\n");
|
dout("pre_umount\n");
|
||||||
mdsc->stopping = 1;
|
mdsc->stopping = 1;
|
||||||
|
|
||||||
|
ceph_mdsc_iterate_sessions(mdsc, send_flush_mdlog, true);
|
||||||
ceph_mdsc_iterate_sessions(mdsc, lock_unlock_session, false);
|
ceph_mdsc_iterate_sessions(mdsc, lock_unlock_session, false);
|
||||||
ceph_flush_dirty_caps(mdsc);
|
ceph_flush_dirty_caps(mdsc);
|
||||||
wait_requests(mdsc);
|
wait_requests(mdsc);
|
||||||
|
|
|
||||||
|
|
@ -518,6 +518,7 @@ static inline void ceph_mdsc_put_request(struct ceph_mds_request *req)
|
||||||
kref_put(&req->r_kref, ceph_mdsc_release_request);
|
kref_put(&req->r_kref, ceph_mdsc_release_request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern void send_flush_mdlog(struct ceph_mds_session *s);
|
||||||
extern void ceph_mdsc_iterate_sessions(struct ceph_mds_client *mdsc,
|
extern void ceph_mdsc_iterate_sessions(struct ceph_mds_client *mdsc,
|
||||||
void (*cb)(struct ceph_mds_session *),
|
void (*cb)(struct ceph_mds_session *),
|
||||||
bool check_state);
|
bool check_state);
|
||||||
|
|
|
||||||
|
|
@ -46,6 +46,7 @@ const char *ceph_session_op_name(int op)
|
||||||
case CEPH_SESSION_FLUSHMSG_ACK: return "flushmsg_ack";
|
case CEPH_SESSION_FLUSHMSG_ACK: return "flushmsg_ack";
|
||||||
case CEPH_SESSION_FORCE_RO: return "force_ro";
|
case CEPH_SESSION_FORCE_RO: return "force_ro";
|
||||||
case CEPH_SESSION_REJECT: return "reject";
|
case CEPH_SESSION_REJECT: return "reject";
|
||||||
|
case CEPH_SESSION_REQUEST_FLUSH_MDLOG: return "flush_mdlog";
|
||||||
}
|
}
|
||||||
return "???";
|
return "???";
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -288,6 +288,7 @@ enum {
|
||||||
CEPH_SESSION_FLUSHMSG_ACK,
|
CEPH_SESSION_FLUSHMSG_ACK,
|
||||||
CEPH_SESSION_FORCE_RO,
|
CEPH_SESSION_FORCE_RO,
|
||||||
CEPH_SESSION_REJECT,
|
CEPH_SESSION_REJECT,
|
||||||
|
CEPH_SESSION_REQUEST_FLUSH_MDLOG,
|
||||||
};
|
};
|
||||||
|
|
||||||
extern const char *ceph_session_op_name(int op);
|
extern const char *ceph_session_op_name(int op);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue