aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/ceph/mds_client.c27
-rw-r--r--include/linux/ceph/auth.h4
-rw-r--r--net/ceph/auth_none.c15
-rw-r--r--net/ceph/auth_x.c15
-rw-r--r--net/ceph/osd_client.c28
5 files changed, 39 insertions, 50 deletions
diff --git a/fs/ceph/mds_client.c b/fs/ceph/mds_client.c
index 42013c620488..b71ffd2c8094 100644
--- a/fs/ceph/mds_client.c
+++ b/fs/ceph/mds_client.c
@@ -3402,31 +3402,28 @@ static int get_authorizer(struct ceph_connection *con,
3402 struct ceph_mds_session *s = con->private; 3402 struct ceph_mds_session *s = con->private;
3403 struct ceph_mds_client *mdsc = s->s_mdsc; 3403 struct ceph_mds_client *mdsc = s->s_mdsc;
3404 struct ceph_auth_client *ac = mdsc->fsc->client->monc.auth; 3404 struct ceph_auth_client *ac = mdsc->fsc->client->monc.auth;
3405 struct ceph_auth_handshake *auth = &s->s_auth;
3405 int ret = 0; 3406 int ret = 0;
3406 3407
3407 if (force_new && s->s_auth.authorizer) { 3408 if (force_new && auth->authorizer) {
3408 ac->ops->destroy_authorizer(ac, s->s_auth.authorizer); 3409 ac->ops->destroy_authorizer(ac, auth->authorizer);
3409 s->s_auth.authorizer = NULL; 3410 auth->authorizer = NULL;
3410 } 3411 }
3411 if (s->s_auth.authorizer == NULL) { 3412 if (auth->authorizer == NULL) {
3412 if (ac->ops->create_authorizer) { 3413 if (ac->ops->create_authorizer) {
3413 ret = ac->ops->create_authorizer( 3414 ret = ac->ops->create_authorizer(ac,
3414 ac, CEPH_ENTITY_TYPE_MDS, 3415 CEPH_ENTITY_TYPE_MDS, auth);
3415 &s->s_auth.authorizer,
3416 &s->s_auth.authorizer_buf,
3417 &s->s_auth.authorizer_buf_len,
3418 &s->s_auth.authorizer_reply_buf,
3419 &s->s_auth.authorizer_reply_buf_len);
3420 if (ret) 3416 if (ret)
3421 return ret; 3417 return ret;
3422 } 3418 }
3423 } 3419 }
3424 3420
3425 *proto = ac->protocol; 3421 *proto = ac->protocol;
3426 *buf = s->s_auth.authorizer_buf; 3422 *buf = auth->authorizer_buf;
3427 *len = s->s_auth.authorizer_buf_len; 3423 *len = auth->authorizer_buf_len;
3428 *reply_buf = s->s_auth.authorizer_reply_buf; 3424 *reply_buf = auth->authorizer_reply_buf;
3429 *reply_len = s->s_auth.authorizer_reply_buf_len; 3425 *reply_len = auth->authorizer_reply_buf_len;
3426
3430 return 0; 3427 return 0;
3431} 3428}
3432 3429
diff --git a/include/linux/ceph/auth.h b/include/linux/ceph/auth.h
index 5b774d141e09..d4080f309b56 100644
--- a/include/linux/ceph/auth.h
+++ b/include/linux/ceph/auth.h
@@ -51,9 +51,7 @@ struct ceph_auth_client_ops {
51 * the response to authenticate the service. 51 * the response to authenticate the service.
52 */ 52 */
53 int (*create_authorizer)(struct ceph_auth_client *ac, int peer_type, 53 int (*create_authorizer)(struct ceph_auth_client *ac, int peer_type,
54 struct ceph_authorizer **a, 54 struct ceph_auth_handshake *auth);
55 void **buf, size_t *len,
56 void **reply_buf, size_t *reply_len);
57 int (*verify_authorizer_reply)(struct ceph_auth_client *ac, 55 int (*verify_authorizer_reply)(struct ceph_auth_client *ac,
58 struct ceph_authorizer *a, size_t len); 56 struct ceph_authorizer *a, size_t len);
59 void (*destroy_authorizer)(struct ceph_auth_client *ac, 57 void (*destroy_authorizer)(struct ceph_auth_client *ac,
diff --git a/net/ceph/auth_none.c b/net/ceph/auth_none.c
index 214c2bb43d62..925ca583c09c 100644
--- a/net/ceph/auth_none.c
+++ b/net/ceph/auth_none.c
@@ -59,9 +59,7 @@ static int handle_reply(struct ceph_auth_client *ac, int result,
59 */ 59 */
60static int ceph_auth_none_create_authorizer( 60static int ceph_auth_none_create_authorizer(
61 struct ceph_auth_client *ac, int peer_type, 61 struct ceph_auth_client *ac, int peer_type,
62 struct ceph_authorizer **a, 62 struct ceph_auth_handshake *auth)
63 void **buf, size_t *len,
64 void **reply_buf, size_t *reply_len)
65{ 63{
66 struct ceph_auth_none_info *ai = ac->private; 64 struct ceph_auth_none_info *ai = ac->private;
67 struct ceph_none_authorizer *au = &ai->au; 65 struct ceph_none_authorizer *au = &ai->au;
@@ -82,11 +80,12 @@ static int ceph_auth_none_create_authorizer(
82 dout("built authorizer len %d\n", au->buf_len); 80 dout("built authorizer len %d\n", au->buf_len);
83 } 81 }
84 82
85 *a = (struct ceph_authorizer *)au; 83 auth->authorizer = (struct ceph_authorizer *) au;
86 *buf = au->buf; 84 auth->authorizer_buf = au->buf;
87 *len = au->buf_len; 85 auth->authorizer_buf_len = au->buf_len;
88 *reply_buf = au->reply_buf; 86 auth->authorizer_reply_buf = au->reply_buf;
89 *reply_len = sizeof(au->reply_buf); 87 auth->authorizer_reply_buf_len = sizeof (au->reply_buf);
88
90 return 0; 89 return 0;
91 90
92bad2: 91bad2:
diff --git a/net/ceph/auth_x.c b/net/ceph/auth_x.c
index 1587dc6010c6..a16bf14eb027 100644
--- a/net/ceph/auth_x.c
+++ b/net/ceph/auth_x.c
@@ -526,9 +526,7 @@ static int ceph_x_handle_reply(struct ceph_auth_client *ac, int result,
526 526
527static int ceph_x_create_authorizer( 527static int ceph_x_create_authorizer(
528 struct ceph_auth_client *ac, int peer_type, 528 struct ceph_auth_client *ac, int peer_type,
529 struct ceph_authorizer **a, 529 struct ceph_auth_handshake *auth)
530 void **buf, size_t *len,
531 void **reply_buf, size_t *reply_len)
532{ 530{
533 struct ceph_x_authorizer *au; 531 struct ceph_x_authorizer *au;
534 struct ceph_x_ticket_handler *th; 532 struct ceph_x_ticket_handler *th;
@@ -548,11 +546,12 @@ static int ceph_x_create_authorizer(
548 return ret; 546 return ret;
549 } 547 }
550 548
551 *a = (struct ceph_authorizer *)au; 549 auth->authorizer = (struct ceph_authorizer *) au;
552 *buf = au->buf->vec.iov_base; 550 auth->authorizer_buf = au->buf->vec.iov_base;
553 *len = au->buf->vec.iov_len; 551 auth->authorizer_buf_len = au->buf->vec.iov_len;
554 *reply_buf = au->reply_buf; 552 auth->authorizer_reply_buf = au->reply_buf;
555 *reply_len = sizeof(au->reply_buf); 553 auth->authorizer_reply_buf_len = sizeof (au->reply_buf);
554
556 return 0; 555 return 0;
557} 556}
558 557
diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c
index 66b09d6a1531..2da4b9e97dc1 100644
--- a/net/ceph/osd_client.c
+++ b/net/ceph/osd_client.c
@@ -2115,29 +2115,25 @@ static int get_authorizer(struct ceph_connection *con,
2115 struct ceph_osd *o = con->private; 2115 struct ceph_osd *o = con->private;
2116 struct ceph_osd_client *osdc = o->o_osdc; 2116 struct ceph_osd_client *osdc = o->o_osdc;
2117 struct ceph_auth_client *ac = osdc->client->monc.auth; 2117 struct ceph_auth_client *ac = osdc->client->monc.auth;
2118 struct ceph_auth_handshake *auth = &o->o_auth;
2118 int ret = 0; 2119 int ret = 0;
2119 2120
2120 if (force_new && o->o_auth.authorizer) { 2121 if (force_new && auth->authorizer) {
2121 ac->ops->destroy_authorizer(ac, o->o_auth.authorizer); 2122 ac->ops->destroy_authorizer(ac, auth->authorizer);
2122 o->o_auth.authorizer = NULL; 2123 auth->authorizer = NULL;
2123 } 2124 }
2124 if (o->o_auth.authorizer == NULL) { 2125 if (auth->authorizer == NULL) {
2125 ret = ac->ops->create_authorizer( 2126 ret = ac->ops->create_authorizer(ac, CEPH_ENTITY_TYPE_OSD, auth);
2126 ac, CEPH_ENTITY_TYPE_OSD,
2127 &o->o_auth.authorizer,
2128 &o->o_auth.authorizer_buf,
2129 &o->o_auth.authorizer_buf_len,
2130 &o->o_auth.authorizer_reply_buf,
2131 &o->o_auth.authorizer_reply_buf_len);
2132 if (ret) 2127 if (ret)
2133 return ret; 2128 return ret;
2134 } 2129 }
2135 2130
2136 *proto = ac->protocol; 2131 *proto = ac->protocol;
2137 *buf = o->o_auth.authorizer_buf; 2132 *buf = auth->authorizer_buf;
2138 *len = o->o_auth.authorizer_buf_len; 2133 *len = auth->authorizer_buf_len;
2139 *reply_buf = o->o_auth.authorizer_reply_buf; 2134 *reply_buf = auth->authorizer_reply_buf;
2140 *reply_len = o->o_auth.authorizer_reply_buf_len; 2135 *reply_len = auth->authorizer_reply_buf_len;
2136
2141 return 0; 2137 return 0;
2142} 2138}
2143 2139