diff options
Diffstat (limited to 'include/linux/sunrpc/auth.h')
| -rw-r--r-- | include/linux/sunrpc/auth.h | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/include/linux/sunrpc/auth.h b/include/linux/sunrpc/auth.h index 16bd8f8fef8c..6f36b2bf3e05 100644 --- a/include/linux/sunrpc/auth.h +++ b/include/linux/sunrpc/auth.h | |||
| @@ -206,5 +206,23 @@ struct rpc_cred * get_rpccred(struct rpc_cred *cred) | |||
| 206 | return cred; | 206 | return cred; |
| 207 | } | 207 | } |
| 208 | 208 | ||
| 209 | /** | ||
| 210 | * get_rpccred_rcu - get a reference to a cred using rcu-protected pointer | ||
| 211 | * @cred: cred of which to take a reference | ||
| 212 | * | ||
| 213 | * In some cases, we may have a pointer to a credential to which we | ||
| 214 | * want to take a reference, but don't already have one. Because these | ||
| 215 | * objects are freed using RCU, we can access the cr_count while its | ||
| 216 | * on its way to destruction and only take a reference if it's not already | ||
| 217 | * zero. | ||
| 218 | */ | ||
| 219 | static inline struct rpc_cred * | ||
| 220 | get_rpccred_rcu(struct rpc_cred *cred) | ||
| 221 | { | ||
| 222 | if (atomic_inc_not_zero(&cred->cr_count)) | ||
| 223 | return cred; | ||
| 224 | return NULL; | ||
| 225 | } | ||
| 226 | |||
| 209 | #endif /* __KERNEL__ */ | 227 | #endif /* __KERNEL__ */ |
| 210 | #endif /* _LINUX_SUNRPC_AUTH_H */ | 228 | #endif /* _LINUX_SUNRPC_AUTH_H */ |
