summaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/sunrpc/auth_gss/auth_gss.c18
-rw-r--r--net/sunrpc/auth_null.c1
-rw-r--r--net/sunrpc/auth_unix.c1
-rw-r--r--net/sunrpc/clnt.c2
4 files changed, 16 insertions, 6 deletions
diff --git a/net/sunrpc/auth_gss/auth_gss.c b/net/sunrpc/auth_gss/auth_gss.c
index 731e7a482e18..c67e2ad151ae 100644
--- a/net/sunrpc/auth_gss/auth_gss.c
+++ b/net/sunrpc/auth_gss/auth_gss.c
@@ -1017,6 +1017,7 @@ gss_create_new(const struct rpc_auth_create_args *args, struct rpc_clnt *clnt)
1017 auth->au_cslack = GSS_CRED_SLACK >> 2; 1017 auth->au_cslack = GSS_CRED_SLACK >> 2;
1018 auth->au_rslack = GSS_VERF_SLACK >> 2; 1018 auth->au_rslack = GSS_VERF_SLACK >> 2;
1019 auth->au_verfsize = GSS_VERF_SLACK >> 2; 1019 auth->au_verfsize = GSS_VERF_SLACK >> 2;
1020 auth->au_ralign = GSS_VERF_SLACK >> 2;
1020 auth->au_flags = 0; 1021 auth->au_flags = 0;
1021 auth->au_ops = &authgss_ops; 1022 auth->au_ops = &authgss_ops;
1022 auth->au_flavor = flavor; 1023 auth->au_flavor = flavor;
@@ -1891,7 +1892,10 @@ out:
1891static int 1892static int
1892gss_unwrap_resp_auth(struct rpc_cred *cred) 1893gss_unwrap_resp_auth(struct rpc_cred *cred)
1893{ 1894{
1894 cred->cr_auth->au_rslack = cred->cr_auth->au_verfsize; 1895 struct rpc_auth *auth = cred->cr_auth;
1896
1897 auth->au_rslack = auth->au_verfsize;
1898 auth->au_ralign = auth->au_verfsize;
1895 return 0; 1899 return 0;
1896} 1900}
1897 1901
@@ -1902,6 +1906,7 @@ gss_unwrap_resp_integ(struct rpc_task *task, struct rpc_cred *cred,
1902{ 1906{
1903 struct xdr_buf integ_buf, *rcv_buf = &rqstp->rq_rcv_buf; 1907 struct xdr_buf integ_buf, *rcv_buf = &rqstp->rq_rcv_buf;
1904 u32 data_offset, mic_offset, integ_len, maj_stat; 1908 u32 data_offset, mic_offset, integ_len, maj_stat;
1909 struct rpc_auth *auth = cred->cr_auth;
1905 struct xdr_netobj mic; 1910 struct xdr_netobj mic;
1906 __be32 *p; 1911 __be32 *p;
1907 1912
@@ -1928,8 +1933,8 @@ gss_unwrap_resp_integ(struct rpc_task *task, struct rpc_cred *cred,
1928 if (maj_stat != GSS_S_COMPLETE) 1933 if (maj_stat != GSS_S_COMPLETE)
1929 goto bad_mic; 1934 goto bad_mic;
1930 1935
1931 cred->cr_auth->au_rslack = cred->cr_auth->au_verfsize + 2 + 1936 auth->au_rslack = auth->au_verfsize + 2 + 1 + XDR_QUADLEN(mic.len);
1932 1 + XDR_QUADLEN(mic.len); 1937 auth->au_ralign = auth->au_verfsize + 2;
1933 return 0; 1938 return 0;
1934unwrap_failed: 1939unwrap_failed:
1935 trace_rpcgss_unwrap_failed(task); 1940 trace_rpcgss_unwrap_failed(task);
@@ -1949,6 +1954,7 @@ gss_unwrap_resp_priv(struct rpc_task *task, struct rpc_cred *cred,
1949{ 1954{
1950 struct xdr_buf *rcv_buf = &rqstp->rq_rcv_buf; 1955 struct xdr_buf *rcv_buf = &rqstp->rq_rcv_buf;
1951 struct kvec *head = rqstp->rq_rcv_buf.head; 1956 struct kvec *head = rqstp->rq_rcv_buf.head;
1957 struct rpc_auth *auth = cred->cr_auth;
1952 unsigned int savedlen = rcv_buf->len; 1958 unsigned int savedlen = rcv_buf->len;
1953 u32 offset, opaque_len, maj_stat; 1959 u32 offset, opaque_len, maj_stat;
1954 __be32 *p; 1960 __be32 *p;
@@ -1976,8 +1982,10 @@ gss_unwrap_resp_priv(struct rpc_task *task, struct rpc_cred *cred,
1976 */ 1982 */
1977 xdr_init_decode(xdr, rcv_buf, p, rqstp); 1983 xdr_init_decode(xdr, rcv_buf, p, rqstp);
1978 1984
1979 cred->cr_auth->au_rslack = cred->cr_auth->au_verfsize + 2 + 1985 auth->au_rslack = auth->au_verfsize + 2 +
1980 XDR_QUADLEN(savedlen - rcv_buf->len); 1986 XDR_QUADLEN(savedlen - rcv_buf->len);
1987 auth->au_ralign = auth->au_verfsize + 2 +
1988 XDR_QUADLEN(savedlen - rcv_buf->len);
1981 return 0; 1989 return 0;
1982unwrap_failed: 1990unwrap_failed:
1983 trace_rpcgss_unwrap_failed(task); 1991 trace_rpcgss_unwrap_failed(task);
diff --git a/net/sunrpc/auth_null.c b/net/sunrpc/auth_null.c
index 9ae08248a9e1..41a633a4049e 100644
--- a/net/sunrpc/auth_null.c
+++ b/net/sunrpc/auth_null.c
@@ -115,6 +115,7 @@ struct rpc_auth null_auth = {
115 .au_cslack = NUL_CALLSLACK, 115 .au_cslack = NUL_CALLSLACK,
116 .au_rslack = NUL_REPLYSLACK, 116 .au_rslack = NUL_REPLYSLACK,
117 .au_verfsize = NUL_REPLYSLACK, 117 .au_verfsize = NUL_REPLYSLACK,
118 .au_ralign = NUL_REPLYSLACK,
118 .au_ops = &authnull_ops, 119 .au_ops = &authnull_ops,
119 .au_flavor = RPC_AUTH_NULL, 120 .au_flavor = RPC_AUTH_NULL,
120 .au_count = REFCOUNT_INIT(1), 121 .au_count = REFCOUNT_INIT(1),
diff --git a/net/sunrpc/auth_unix.c b/net/sunrpc/auth_unix.c
index a93c56442487..c048eb6deaaf 100644
--- a/net/sunrpc/auth_unix.c
+++ b/net/sunrpc/auth_unix.c
@@ -187,6 +187,7 @@ unx_validate(struct rpc_task *task, struct xdr_stream *xdr)
187 187
188 auth->au_verfsize = XDR_QUADLEN(size) + 2; 188 auth->au_verfsize = XDR_QUADLEN(size) + 2;
189 auth->au_rslack = XDR_QUADLEN(size) + 2; 189 auth->au_rslack = XDR_QUADLEN(size) + 2;
190 auth->au_ralign = XDR_QUADLEN(size) + 2;
190 return 0; 191 return 0;
191} 192}
192 193
diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
index 4ea38b029e2f..99bfeb17367c 100644
--- a/net/sunrpc/clnt.c
+++ b/net/sunrpc/clnt.c
@@ -1180,7 +1180,7 @@ void rpc_prepare_reply_pages(struct rpc_rqst *req, struct page **pages,
1180 /* Subtract one to force an extra word of buffer space for the 1180 /* Subtract one to force an extra word of buffer space for the
1181 * payload's XDR pad to fall into the rcv_buf's tail iovec. 1181 * payload's XDR pad to fall into the rcv_buf's tail iovec.
1182 */ 1182 */
1183 hdrsize += RPC_REPHDRSIZE + req->rq_cred->cr_auth->au_rslack - 1; 1183 hdrsize += RPC_REPHDRSIZE + req->rq_cred->cr_auth->au_ralign - 1;
1184 1184
1185 xdr_inline_pages(&req->rq_rcv_buf, hdrsize << 2, pages, base, len); 1185 xdr_inline_pages(&req->rq_rcv_buf, hdrsize << 2, pages, base, len);
1186 trace_rpc_reply_pages(req); 1186 trace_rpc_reply_pages(req);