ceph: reinitialize mds feature bit even when session in open
Following along the same lines as per the user-space fix. Right now this isn't really an issue with the ceph kernel driver because of the feature bit laginess, however, that can change over time (when the new snaprealm info type is ported to the kernel driver) and depending on the MDS version that's being upgraded can cause message decoding issues - so, fix that early on. Link: http://tracker.ceph.com/issues/63188 Signed-off-by: Venky Shankar <vshankar@redhat.com> Reviewed-by: Xiubo Li <xiubli@redhat.com> Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
This commit is contained in:
parent
cbcb358b74
commit
f48e0342a7
@ -4128,12 +4128,12 @@ static void handle_session(struct ceph_mds_session *session,
|
|||||||
pr_info_client(cl, "mds%d reconnect success\n",
|
pr_info_client(cl, "mds%d reconnect success\n",
|
||||||
session->s_mds);
|
session->s_mds);
|
||||||
|
|
||||||
|
session->s_features = features;
|
||||||
if (session->s_state == CEPH_MDS_SESSION_OPEN) {
|
if (session->s_state == CEPH_MDS_SESSION_OPEN) {
|
||||||
pr_notice_client(cl, "mds%d is already opened\n",
|
pr_notice_client(cl, "mds%d is already opened\n",
|
||||||
session->s_mds);
|
session->s_mds);
|
||||||
} else {
|
} else {
|
||||||
session->s_state = CEPH_MDS_SESSION_OPEN;
|
session->s_state = CEPH_MDS_SESSION_OPEN;
|
||||||
session->s_features = features;
|
|
||||||
renewed_caps(mdsc, session, 0);
|
renewed_caps(mdsc, session, 0);
|
||||||
if (test_bit(CEPHFS_FEATURE_METRIC_COLLECT,
|
if (test_bit(CEPHFS_FEATURE_METRIC_COLLECT,
|
||||||
&session->s_features))
|
&session->s_features))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user