diff options
Diffstat (limited to 'fs/nfs/write.c')
| -rw-r--r-- | fs/nfs/write.c | 26 | 
1 files changed, 22 insertions, 4 deletions
| diff --git a/fs/nfs/write.c b/fs/nfs/write.c index 586726a590d8..5a0bbf917a32 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c @@ -1233,9 +1233,12 @@ int  nfs_key_timeout_notify(struct file *filp, struct inode *inode)  {  	struct nfs_open_context *ctx = nfs_file_open_context(filp); -	struct rpc_auth *auth = NFS_SERVER(inode)->client->cl_auth; -	return rpcauth_key_timeout_notify(auth, ctx->cred); +	if (nfs_ctx_key_to_expire(ctx, inode) && +	    !ctx->ll_cred) +		/* Already expired! */ +		return -EACCES; +	return 0;  }  /* @@ -1244,8 +1247,23 @@ nfs_key_timeout_notify(struct file *filp, struct inode *inode)  bool nfs_ctx_key_to_expire(struct nfs_open_context *ctx, struct inode *inode)  {  	struct rpc_auth *auth = NFS_SERVER(inode)->client->cl_auth; +	struct rpc_cred *cred = ctx->ll_cred; +	struct auth_cred acred = { +		.cred = ctx->cred, +	}; -	return rpcauth_cred_key_to_expire(auth, ctx->cred); +	if (cred && !cred->cr_ops->crmatch(&acred, cred, 0)) { +		put_rpccred(cred); +		ctx->ll_cred = NULL; +		cred = NULL; +	} +	if (!cred) +		cred = auth->au_ops->lookup_cred(auth, &acred, 0); +	if (!cred || IS_ERR(cred)) +		return true; +	ctx->ll_cred = cred; +	return !!(cred->cr_ops->crkey_timeout && +		  cred->cr_ops->crkey_timeout(cred));  }  /* @@ -2121,7 +2139,7 @@ int __init nfs_init_writepagecache(void)  	 * This allows larger machines to have larger/more transfers.  	 * Limit the default to 256M  	 */ -	nfs_congestion_kb = (16*int_sqrt(totalram_pages)) << (PAGE_SHIFT-10); +	nfs_congestion_kb = (16*int_sqrt(totalram_pages())) << (PAGE_SHIFT-10);  	if (nfs_congestion_kb > 256*1024)  		nfs_congestion_kb = 256*1024; | 
