Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7882a26d authored by Ilya Dryomov's avatar Ilya Dryomov
Browse files

libceph: rename and align ceph_x_authorizer::reply_buf



It's going to be used as a temporary buffer for in-place en/decryption
with ceph_crypt() instead of on-stack buffers, so rename to enc_buf.
Ensure alignment to avoid GFP_ATOMIC allocations in the crypto stack.

Signed-off-by: default avatarIlya Dryomov <idryomov@gmail.com>
Reviewed-by: default avatarSage Weil <sage@redhat.com>
parent a45f795c
Loading
Loading
Loading
Loading
+5 −5
Original line number Diff line number Diff line
@@ -603,8 +603,8 @@ static int ceph_x_create_authorizer(
	auth->authorizer = (struct ceph_authorizer *) au;
	auth->authorizer_buf = au->buf->vec.iov_base;
	auth->authorizer_buf_len = au->buf->vec.iov_len;
	auth->authorizer_reply_buf = au->reply_buf;
	auth->authorizer_reply_buf_len = sizeof (au->reply_buf);
	auth->authorizer_reply_buf = au->enc_buf;
	auth->authorizer_reply_buf_len = CEPHX_AU_ENC_BUF_LEN;
	auth->sign_message = ac->ops->sign_message;
	auth->check_message_signature = ac->ops->check_message_signature;

@@ -638,10 +638,10 @@ static int ceph_x_verify_authorizer_reply(struct ceph_auth_client *ac,
	int ret = 0;
	struct ceph_x_authorize_reply reply;
	void *preply = &reply;
	void *p = au->reply_buf;
	void *end = p + sizeof(au->reply_buf);
	void *p = au->enc_buf;

	ret = ceph_x_decrypt(&au->session_key, &p, end, &preply, sizeof(reply));
	ret = ceph_x_decrypt(&au->session_key, &p, p + CEPHX_AU_ENC_BUF_LEN,
			     &preply, sizeof(reply));
	if (ret < 0)
		return ret;
	if (ret != sizeof(reply))
+2 −1
Original line number Diff line number Diff line
@@ -24,6 +24,7 @@ struct ceph_x_ticket_handler {
	unsigned long renew_after, expires;
};

#define CEPHX_AU_ENC_BUF_LEN	128  /* big enough for encrypted blob */

struct ceph_x_authorizer {
	struct ceph_authorizer base;
@@ -32,7 +33,7 @@ struct ceph_x_authorizer {
	unsigned int service;
	u64 nonce;
	u64 secret_id;
	char reply_buf[128];  /* big enough for encrypted blob */
	char enc_buf[CEPHX_AU_ENC_BUF_LEN] __aligned(8);
};

struct ceph_x_info {