aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ceph
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ceph')
-rw-r--r--fs/ceph/mds_client.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/fs/ceph/mds_client.c b/fs/ceph/mds_client.c
index 462281742aef..67938a9d049b 100644
--- a/fs/ceph/mds_client.c
+++ b/fs/ceph/mds_client.c
@@ -3395,15 +3395,20 @@ out:
3395/* 3395/*
3396 * authentication 3396 * authentication
3397 */ 3397 */
3398static int get_authorizer(struct ceph_connection *con, 3398
3399 void **buf, int *len, int *proto, 3399/*
3400 void **reply_buf, int *reply_len, int force_new) 3400 * Note: returned pointer is the address of a structure that's
3401 * managed separately. Caller must *not* attempt to free it.
3402 */
3403static struct ceph_auth_handshake *get_authorizer(struct ceph_connection *con,
3404 void **buf, int *len, int *proto,
3405 void **reply_buf, int *reply_len,
3406 int force_new)
3401{ 3407{
3402 struct ceph_mds_session *s = con->private; 3408 struct ceph_mds_session *s = con->private;
3403 struct ceph_mds_client *mdsc = s->s_mdsc; 3409 struct ceph_mds_client *mdsc = s->s_mdsc;
3404 struct ceph_auth_client *ac = mdsc->fsc->client->monc.auth; 3410 struct ceph_auth_client *ac = mdsc->fsc->client->monc.auth;
3405 struct ceph_auth_handshake *auth = &s->s_auth; 3411 struct ceph_auth_handshake *auth = &s->s_auth;
3406 int ret = 0;
3407 3412
3408 if (force_new && auth->authorizer) { 3413 if (force_new && auth->authorizer) {
3409 if (ac->ops && ac->ops->destroy_authorizer) 3414 if (ac->ops && ac->ops->destroy_authorizer)
@@ -3411,9 +3416,10 @@ static int get_authorizer(struct ceph_connection *con,
3411 auth->authorizer = NULL; 3416 auth->authorizer = NULL;
3412 } 3417 }
3413 if (!auth->authorizer && ac->ops && ac->ops->create_authorizer) { 3418 if (!auth->authorizer && ac->ops && ac->ops->create_authorizer) {
3414 ret = ac->ops->create_authorizer(ac, CEPH_ENTITY_TYPE_MDS, auth); 3419 int ret = ac->ops->create_authorizer(ac, CEPH_ENTITY_TYPE_MDS,
3420 auth);
3415 if (ret) 3421 if (ret)
3416 return ret; 3422 return ERR_PTR(ret);
3417 } 3423 }
3418 3424
3419 *proto = ac->protocol; 3425 *proto = ac->protocol;
@@ -3422,7 +3428,7 @@ static int get_authorizer(struct ceph_connection *con,
3422 *reply_buf = auth->authorizer_reply_buf; 3428 *reply_buf = auth->authorizer_reply_buf;
3423 *reply_len = auth->authorizer_reply_buf_len; 3429 *reply_len = auth->authorizer_reply_buf_len;
3424 3430
3425 return 0; 3431 return auth;
3426} 3432}
3427 3433
3428 3434