SUNRPC: introduce RPC_TASK_NULLCREDS to request auth_none
In almost all cases the credential stored in rpc_message.rpc_cred is a "generic" credential. One of the two expections is when an AUTH_NULL credential is used such as for RPC ping requests. To improve consistency, don't pass an explicit credential in these cases, but instead pass NULL and set a task flag, similar to RPC_TASK_ROOTCREDS, which requests that NULL credentials be used by default. Signed-off-by: NeilBrown <neilb@suse.com> Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
This commit is contained in:
parent
5e16923b43
commit
a68a72e135
|
@ -118,6 +118,7 @@ struct rpc_task_setup {
|
||||||
*/
|
*/
|
||||||
#define RPC_TASK_ASYNC 0x0001 /* is an async task */
|
#define RPC_TASK_ASYNC 0x0001 /* is an async task */
|
||||||
#define RPC_TASK_SWAPPER 0x0002 /* is swapping in/out */
|
#define RPC_TASK_SWAPPER 0x0002 /* is swapping in/out */
|
||||||
|
#define RPC_TASK_NULLCREDS 0x0010 /* Use AUTH_NULL credential */
|
||||||
#define RPC_CALL_MAJORSEEN 0x0020 /* major timeout seen */
|
#define RPC_CALL_MAJORSEEN 0x0020 /* major timeout seen */
|
||||||
#define RPC_TASK_ROOTCREDS 0x0040 /* force root creds */
|
#define RPC_TASK_ROOTCREDS 0x0040 /* force root creds */
|
||||||
#define RPC_TASK_DYNAMIC 0x0080 /* task was kmalloc'ed */
|
#define RPC_TASK_DYNAMIC 0x0080 /* task was kmalloc'ed */
|
||||||
|
|
|
@ -761,6 +761,8 @@ rpcauth_bindcred(struct rpc_task *task, struct rpc_cred *cred, int flags)
|
||||||
;
|
;
|
||||||
else if (cred == &machine_cred || (flags & RPC_TASK_ROOTCREDS))
|
else if (cred == &machine_cred || (flags & RPC_TASK_ROOTCREDS))
|
||||||
new = rpcauth_bind_root_cred(task, lookupflags);
|
new = rpcauth_bind_root_cred(task, lookupflags);
|
||||||
|
else if (flags & RPC_TASK_NULLCREDS)
|
||||||
|
new = authnull_ops.lookup_cred(NULL, NULL, 0);
|
||||||
else
|
else
|
||||||
new = rpcauth_bind_new_cred(task, lookupflags);
|
new = rpcauth_bind_new_cred(task, lookupflags);
|
||||||
if (IS_ERR(new))
|
if (IS_ERR(new))
|
||||||
|
|
|
@ -2522,9 +2522,8 @@ static int rpc_ping(struct rpc_clnt *clnt)
|
||||||
.rpc_proc = &rpcproc_null,
|
.rpc_proc = &rpcproc_null,
|
||||||
};
|
};
|
||||||
int err;
|
int err;
|
||||||
msg.rpc_cred = authnull_ops.lookup_cred(NULL, NULL, 0);
|
err = rpc_call_sync(clnt, &msg, RPC_TASK_SOFT | RPC_TASK_SOFTCONN |
|
||||||
err = rpc_call_sync(clnt, &msg, RPC_TASK_SOFT | RPC_TASK_SOFTCONN);
|
RPC_TASK_NULLCREDS);
|
||||||
put_rpccred(msg.rpc_cred);
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2594,7 +2593,6 @@ int rpc_clnt_test_and_add_xprt(struct rpc_clnt *clnt,
|
||||||
void *dummy)
|
void *dummy)
|
||||||
{
|
{
|
||||||
struct rpc_cb_add_xprt_calldata *data;
|
struct rpc_cb_add_xprt_calldata *data;
|
||||||
struct rpc_cred *cred;
|
|
||||||
struct rpc_task *task;
|
struct rpc_task *task;
|
||||||
|
|
||||||
data = kmalloc(sizeof(*data), GFP_NOFS);
|
data = kmalloc(sizeof(*data), GFP_NOFS);
|
||||||
|
@ -2603,11 +2601,9 @@ int rpc_clnt_test_and_add_xprt(struct rpc_clnt *clnt,
|
||||||
data->xps = xprt_switch_get(xps);
|
data->xps = xprt_switch_get(xps);
|
||||||
data->xprt = xprt_get(xprt);
|
data->xprt = xprt_get(xprt);
|
||||||
|
|
||||||
cred = authnull_ops.lookup_cred(NULL, NULL, 0);
|
task = rpc_call_null_helper(clnt, xprt, NULL,
|
||||||
task = rpc_call_null_helper(clnt, xprt, cred,
|
RPC_TASK_SOFT|RPC_TASK_SOFTCONN|RPC_TASK_ASYNC|RPC_TASK_NULLCREDS,
|
||||||
RPC_TASK_SOFT|RPC_TASK_SOFTCONN|RPC_TASK_ASYNC,
|
|
||||||
&rpc_cb_add_xprt_call_ops, data);
|
&rpc_cb_add_xprt_call_ops, data);
|
||||||
put_rpccred(cred);
|
|
||||||
if (IS_ERR(task))
|
if (IS_ERR(task))
|
||||||
return PTR_ERR(task);
|
return PTR_ERR(task);
|
||||||
rpc_put_task(task);
|
rpc_put_task(task);
|
||||||
|
@ -2638,7 +2634,6 @@ int rpc_clnt_setup_test_and_add_xprt(struct rpc_clnt *clnt,
|
||||||
struct rpc_xprt *xprt,
|
struct rpc_xprt *xprt,
|
||||||
void *data)
|
void *data)
|
||||||
{
|
{
|
||||||
struct rpc_cred *cred;
|
|
||||||
struct rpc_task *task;
|
struct rpc_task *task;
|
||||||
struct rpc_add_xprt_test *xtest = (struct rpc_add_xprt_test *)data;
|
struct rpc_add_xprt_test *xtest = (struct rpc_add_xprt_test *)data;
|
||||||
int status = -EADDRINUSE;
|
int status = -EADDRINUSE;
|
||||||
|
@ -2650,11 +2645,9 @@ int rpc_clnt_setup_test_and_add_xprt(struct rpc_clnt *clnt,
|
||||||
goto out_err;
|
goto out_err;
|
||||||
|
|
||||||
/* Test the connection */
|
/* Test the connection */
|
||||||
cred = authnull_ops.lookup_cred(NULL, NULL, 0);
|
task = rpc_call_null_helper(clnt, xprt, NULL,
|
||||||
task = rpc_call_null_helper(clnt, xprt, cred,
|
RPC_TASK_SOFT | RPC_TASK_SOFTCONN | RPC_TASK_NULLCREDS,
|
||||||
RPC_TASK_SOFT | RPC_TASK_SOFTCONN,
|
|
||||||
NULL, NULL);
|
NULL, NULL);
|
||||||
put_rpccred(cred);
|
|
||||||
if (IS_ERR(task)) {
|
if (IS_ERR(task)) {
|
||||||
status = PTR_ERR(task);
|
status = PTR_ERR(task);
|
||||||
goto out_err;
|
goto out_err;
|
||||||
|
|
Loading…
Reference in New Issue