Commit cb21a718 authored by Trond Myklebust's avatar Trond Myklebust

RPCSEC_GSS: Move the gss sequence number history from the task

structure to the request structure, where it makes more sense.
In particular, when we start storing more sequence number
history (necessary to process responses to resent requests
correctly), this will make it easier to initialize the
necessary data structure in the right place (in
xprt_request_init).
parent 955ac351
...@@ -48,8 +48,6 @@ struct rpc_task { ...@@ -48,8 +48,6 @@ struct rpc_task {
__u8 tk_garb_retry, __u8 tk_garb_retry,
tk_cred_retry, tk_cred_retry,
tk_suid_retry; tk_suid_retry;
u32 tk_gss_seqno; /* rpcsec_gss sequence number
used on this request */
/* /*
* timeout_fn to be executed by timer bottom half * timeout_fn to be executed by timer bottom half
......
...@@ -95,6 +95,7 @@ struct rpc_rqst { ...@@ -95,6 +95,7 @@ struct rpc_rqst {
struct rpc_rqst * rq_next; /* free list */ struct rpc_rqst * rq_next; /* free list */
int rq_cong; /* has incremented xprt->cong */ int rq_cong; /* has incremented xprt->cong */
int rq_received; /* receive completed */ int rq_received; /* receive completed */
u32 rq_seqno; /* gss seq no. used on req. */
struct list_head rq_list; struct list_head rq_list;
......
...@@ -690,12 +690,12 @@ gss_marshal(struct rpc_task *task, u32 *p, int ruid) ...@@ -690,12 +690,12 @@ gss_marshal(struct rpc_task *task, u32 *p, int ruid)
goto out_put_ctx; goto out_put_ctx;
} }
spin_lock(&ctx->gc_seq_lock); spin_lock(&ctx->gc_seq_lock);
task->tk_gss_seqno = ctx->gc_seq++; req->rq_seqno = ctx->gc_seq++;
spin_unlock(&ctx->gc_seq_lock); spin_unlock(&ctx->gc_seq_lock);
*p++ = htonl((u32) RPC_GSS_VERSION); *p++ = htonl((u32) RPC_GSS_VERSION);
*p++ = htonl((u32) ctx->gc_proc); *p++ = htonl((u32) ctx->gc_proc);
*p++ = htonl((u32) task->tk_gss_seqno); *p++ = htonl((u32) req->rq_seqno);
*p++ = htonl((u32) service); *p++ = htonl((u32) service);
p = xdr_encode_netobj(p, &ctx->gc_wire_ctx); p = xdr_encode_netobj(p, &ctx->gc_wire_ctx);
*cred_len = htonl((p - (cred_len + 1)) << 2); *cred_len = htonl((p - (cred_len + 1)) << 2);
...@@ -766,7 +766,7 @@ gss_validate(struct rpc_task *task, u32 *p) ...@@ -766,7 +766,7 @@ gss_validate(struct rpc_task *task, u32 *p)
goto out_bad; goto out_bad;
if (flav != RPC_AUTH_GSS) if (flav != RPC_AUTH_GSS)
goto out_bad; goto out_bad;
seq = htonl(task->tk_gss_seqno); seq = htonl(task->tk_rqstp->rq_seqno);
iov.iov_base = &seq; iov.iov_base = &seq;
iov.iov_len = sizeof(seq); iov.iov_len = sizeof(seq);
xdr_buf_from_iov(&iov, &verf_buf); xdr_buf_from_iov(&iov, &verf_buf);
...@@ -832,7 +832,7 @@ gss_wrap_req(struct rpc_task *task, ...@@ -832,7 +832,7 @@ gss_wrap_req(struct rpc_task *task,
integ_len = p++; integ_len = p++;
offset = (u8 *)p - (u8 *)snd_buf->head[0].iov_base; offset = (u8 *)p - (u8 *)snd_buf->head[0].iov_base;
*p++ = htonl(task->tk_gss_seqno); *p++ = htonl(req->rq_seqno);
status = encode(rqstp, p, obj); status = encode(rqstp, p, obj);
if (status) if (status)
...@@ -909,7 +909,7 @@ gss_unwrap_resp(struct rpc_task *task, ...@@ -909,7 +909,7 @@ gss_unwrap_resp(struct rpc_task *task,
mic_offset = integ_len + data_offset; mic_offset = integ_len + data_offset;
if (mic_offset > rcv_buf->len) if (mic_offset > rcv_buf->len)
goto out; goto out;
if (ntohl(*p++) != task->tk_gss_seqno) if (ntohl(*p++) != req->rq_seqno)
goto out; goto out;
if (xdr_buf_subsegment(rcv_buf, &integ_buf, data_offset, if (xdr_buf_subsegment(rcv_buf, &integ_buf, data_offset,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment