diff options
Diffstat (limited to 'include/linux/sunrpc/auth.h')
| -rw-r--r-- | include/linux/sunrpc/auth.h | 51 | 
1 files changed, 4 insertions, 47 deletions
| diff --git a/include/linux/sunrpc/auth.h b/include/linux/sunrpc/auth.h index c4db9424b63b..eed3cb16ccf1 100644 --- a/include/linux/sunrpc/auth.h +++ b/include/linux/sunrpc/auth.h @@ -37,21 +37,9 @@  struct rpcsec_gss_info; -/* auth_cred ac_flags bits */ -enum { -	RPC_CRED_KEY_EXPIRE_SOON = 1, /* underlying cred key will expire soon */ -	RPC_CRED_NOTIFY_TIMEOUT = 2,   /* nofity generic cred when underlying -					key will expire soon */ -}; - -/* Work around the lack of a VFS credential */  struct auth_cred { -	kuid_t	uid; -	kgid_t	gid; -	struct group_info *group_info; -	const char *principal; -	unsigned long ac_flags; -	unsigned char machine_cred : 1; +	const struct cred *cred; +	const char *principal;	/* If present, this is a machine credential */  };  /* @@ -68,8 +56,7 @@ struct rpc_cred {  	unsigned long		cr_expire;	/* when to gc */  	unsigned long		cr_flags;	/* various flags */  	refcount_t		cr_count;	/* ref count */ - -	kuid_t			cr_uid; +	const struct cred	*cr_cred;  	/* per-flavor data */  }; @@ -78,8 +65,7 @@ struct rpc_cred {  #define RPCAUTH_CRED_HASHED	2  #define RPCAUTH_CRED_NEGATIVE	3 -/* rpc_auth au_flags */ -#define RPCAUTH_AUTH_NO_CRKEY_TIMEOUT	0x0001 /* underlying cred has no key timeout */ +const struct cred *rpc_machine_cred(void);  /*   * Client authentication handle @@ -116,7 +102,6 @@ struct rpc_auth_create_args {  /* Flags for rpcauth_lookupcred() */  #define RPCAUTH_LOOKUP_NEW		0x01	/* Accept an uninitialised cred */ -#define RPCAUTH_LOOKUP_RCU		0x02	/* lock-less lookup */  /*   * Client authentication ops @@ -146,7 +131,6 @@ struct rpc_credops {  	void			(*crdestroy)(struct rpc_cred *);  	int			(*crmatch)(struct auth_cred *, struct rpc_cred *, int); -	struct rpc_cred *	(*crbind)(struct rpc_task *, struct rpc_cred *, int);  	__be32 *		(*crmarshal)(struct rpc_task *, __be32 *);  	int			(*crrefresh)(struct rpc_task *);  	__be32 *		(*crvalidate)(struct rpc_task *, __be32 *); @@ -155,7 +139,6 @@ struct rpc_credops {  	int			(*crunwrap_resp)(struct rpc_task *, kxdrdproc_t,  						void *, __be32 *, void *);  	int			(*crkey_timeout)(struct rpc_cred *); -	bool			(*crkey_to_expire)(struct rpc_cred *);  	char *			(*crstringify_acceptor)(struct rpc_cred *);  	bool			(*crneed_reencode)(struct rpc_task *);  }; @@ -164,16 +147,10 @@ extern const struct rpc_authops	authunix_ops;  extern const struct rpc_authops	authnull_ops;  int __init		rpc_init_authunix(void); -int __init		rpc_init_generic_auth(void);  int __init		rpcauth_init_module(void);  void			rpcauth_remove_module(void); -void			rpc_destroy_generic_auth(void);  void 			rpc_destroy_authunix(void); -struct rpc_cred *	rpc_lookup_cred(void); -struct rpc_cred *	rpc_lookup_cred_nonblock(void); -struct rpc_cred *	rpc_lookup_generic_cred(struct auth_cred *, int, gfp_t); -struct rpc_cred *	rpc_lookup_machine_cred(const char *service_name);  int			rpcauth_register(const struct rpc_authops *);  int			rpcauth_unregister(const struct rpc_authops *);  struct rpc_auth *	rpcauth_create(const struct rpc_auth_create_args *, @@ -187,7 +164,6 @@ int			rpcauth_list_flavors(rpc_authflavor_t *, int);  struct rpc_cred *	rpcauth_lookup_credcache(struct rpc_auth *, struct auth_cred *, int, gfp_t);  void			rpcauth_init_cred(struct rpc_cred *, const struct auth_cred *, struct rpc_auth *, const struct rpc_credops *);  struct rpc_cred *	rpcauth_lookupcred(struct rpc_auth *, int); -struct rpc_cred *	rpcauth_generic_bind_cred(struct rpc_task *, struct rpc_cred *, int);  void			put_rpccred(struct rpc_cred *);  __be32 *		rpcauth_marshcred(struct rpc_task *, __be32 *);  __be32 *		rpcauth_checkverf(struct rpc_task *, __be32 *); @@ -200,9 +176,6 @@ int			rpcauth_uptodatecred(struct rpc_task *);  int			rpcauth_init_credcache(struct rpc_auth *);  void			rpcauth_destroy_credcache(struct rpc_auth *);  void			rpcauth_clear_credcache(struct rpc_cred_cache *); -int			rpcauth_key_timeout_notify(struct rpc_auth *, -						struct rpc_cred *); -bool			rpcauth_cred_key_to_expire(struct rpc_auth *, struct rpc_cred *);  char *			rpcauth_stringify_acceptor(struct rpc_cred *);  static inline @@ -213,21 +186,5 @@ struct rpc_cred *get_rpccred(struct rpc_cred *cred)  	return NULL;  } -/** - * get_rpccred_rcu - get a reference to a cred using rcu-protected pointer - * @cred: cred of which to take a reference - * - * In some cases, we may have a pointer to a credential to which we - * want to take a reference, but don't already have one. Because these - * objects are freed using RCU, we can access the cr_count while its - * on its way to destruction and only take a reference if it's not already - * zero. - */ -static inline struct rpc_cred * -get_rpccred_rcu(struct rpc_cred *cred) -{ -	return get_rpccred(cred); -} -  #endif /* __KERNEL__ */  #endif /* _LINUX_SUNRPC_AUTH_H */ | 
