Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | * Request reply cache. This was heavily inspired by the |
| 3 | * implementation in 4.3BSD/4.4BSD. |
| 4 | * |
| 5 | * Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de> |
| 6 | */ |
| 7 | |
| 8 | #ifndef NFSCACHE_H |
| 9 | #define NFSCACHE_H |
| 10 | |
Boaz Harrosh | 72579ac | 2009-12-03 20:28:59 +0200 | [diff] [blame] | 11 | #include <linux/sunrpc/svc.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | |
| 13 | /* |
Greg Banks | fca4217 | 2009-04-01 07:28:13 +1100 | [diff] [blame] | 14 | * Representation of a reply cache entry. |
Jeff Layton | 7b9e852 | 2013-01-28 14:41:07 -0500 | [diff] [blame] | 15 | * |
| 16 | * Note that we use a sockaddr_in6 to hold the address instead of the more |
| 17 | * typical sockaddr_storage. This is for space reasons, since sockaddr_storage |
| 18 | * is much larger than a sockaddr_in6. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | */ |
| 20 | struct svc_cacherep { |
| 21 | struct hlist_node c_hash; |
| 22 | struct list_head c_lru; |
| 23 | |
| 24 | unsigned char c_state, /* unused, inprog, done */ |
| 25 | c_type, /* status, buffer */ |
| 26 | c_secure : 1; /* req came from port < 1024 */ |
Jeff Layton | 7b9e852 | 2013-01-28 14:41:07 -0500 | [diff] [blame] | 27 | struct sockaddr_in6 c_addr; |
Al Viro | c7afef1 | 2006-10-19 23:29:02 -0700 | [diff] [blame] | 28 | __be32 c_xid; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 29 | u32 c_prot; |
| 30 | u32 c_proc; |
| 31 | u32 c_vers; |
| 32 | unsigned long c_timestamp; |
| 33 | union { |
| 34 | struct kvec u_vec; |
Al Viro | c7afef1 | 2006-10-19 23:29:02 -0700 | [diff] [blame] | 35 | __be32 u_status; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 36 | } c_u; |
| 37 | }; |
| 38 | |
| 39 | #define c_replvec c_u.u_vec |
| 40 | #define c_replstat c_u.u_status |
| 41 | |
| 42 | /* cache entry states */ |
| 43 | enum { |
| 44 | RC_UNUSED, |
| 45 | RC_INPROG, |
| 46 | RC_DONE |
| 47 | }; |
| 48 | |
| 49 | /* return values */ |
| 50 | enum { |
| 51 | RC_DROPIT, |
| 52 | RC_REPLY, |
Jeff Layton | 09662d5 | 2013-01-28 14:41:09 -0500 | [diff] [blame] | 53 | RC_DOIT |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 | }; |
| 55 | |
| 56 | /* |
| 57 | * Cache types. |
| 58 | * We may want to add more types one day, e.g. for diropres and |
| 59 | * attrstat replies. Using cache entries with fixed length instead |
| 60 | * of buffer pointers may be more efficient. |
| 61 | */ |
| 62 | enum { |
| 63 | RC_NOCACHE, |
| 64 | RC_REPLSTAT, |
| 65 | RC_REPLBUFF, |
| 66 | }; |
| 67 | |
| 68 | /* |
| 69 | * If requests are retransmitted within this interval, they're dropped. |
| 70 | */ |
| 71 | #define RC_DELAY (HZ/5) |
| 72 | |
J. Bruce Fields | d5c3428 | 2007-11-09 14:10:56 -0500 | [diff] [blame] | 73 | int nfsd_reply_cache_init(void); |
| 74 | void nfsd_reply_cache_shutdown(void); |
J. Bruce Fields | 1091006 | 2011-01-24 12:11:02 -0500 | [diff] [blame] | 75 | int nfsd_cache_lookup(struct svc_rqst *); |
Al Viro | c7afef1 | 2006-10-19 23:29:02 -0700 | [diff] [blame] | 76 | void nfsd_cache_update(struct svc_rqst *, int, __be32 *); |
Benny Halevy | 04826f4 | 2009-04-06 12:00:49 +0300 | [diff] [blame] | 77 | |
| 78 | #ifdef CONFIG_NFSD_V4 |
Andy Adamson | 074fe89 | 2009-04-03 08:28:15 +0300 | [diff] [blame] | 79 | void nfsd4_set_statp(struct svc_rqst *rqstp, __be32 *statp); |
Benny Halevy | 04826f4 | 2009-04-06 12:00:49 +0300 | [diff] [blame] | 80 | #else /* CONFIG_NFSD_V4 */ |
| 81 | static inline void nfsd4_set_statp(struct svc_rqst *rqstp, __be32 *statp) |
| 82 | { |
| 83 | } |
| 84 | #endif /* CONFIG_NFSD_V4 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 85 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 86 | #endif /* NFSCACHE_H */ |