Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 3 | * Request reply cache. This was heavily inspired by the |
| 4 | * implementation in 4.3BSD/4.4BSD. |
| 5 | * |
| 6 | * Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de> |
| 7 | */ |
| 8 | |
| 9 | #ifndef NFSCACHE_H |
| 10 | #define NFSCACHE_H |
| 11 | |
Boaz Harrosh | 72579ac | 2009-12-03 20:28:59 +0200 | [diff] [blame] | 12 | #include <linux/sunrpc/svc.h> |
J. Bruce Fields | 3ba7583 | 2019-05-17 09:03:38 -0400 | [diff] [blame] | 13 | #include "netns.h" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | |
| 15 | /* |
Greg Banks | fca4217 | 2009-04-01 07:28:13 +1100 | [diff] [blame] | 16 | * Representation of a reply cache entry. |
Jeff Layton | 7b9e852 | 2013-01-28 14:41:07 -0500 | [diff] [blame] | 17 | * |
| 18 | * Note that we use a sockaddr_in6 to hold the address instead of the more |
| 19 | * typical sockaddr_storage. This is for space reasons, since sockaddr_storage |
| 20 | * is much larger than a sockaddr_in6. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 21 | */ |
| 22 | struct svc_cacherep { |
Trond Myklebust | ed00c2f | 2018-10-03 13:11:51 -0400 | [diff] [blame] | 23 | struct { |
| 24 | /* Keep often-read xid, csum in the same cache line: */ |
| 25 | __be32 k_xid; |
| 26 | __wsum k_csum; |
| 27 | u32 k_proc; |
| 28 | u32 k_prot; |
| 29 | u32 k_vers; |
| 30 | unsigned int k_len; |
| 31 | struct sockaddr_in6 k_addr; |
| 32 | } c_key; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | |
Trond Myklebust | 736c662 | 2018-10-01 10:41:57 -0400 | [diff] [blame] | 34 | struct rb_node c_node; |
Trond Myklebust | ed00c2f | 2018-10-03 13:11:51 -0400 | [diff] [blame] | 35 | struct list_head c_lru; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 36 | unsigned char c_state, /* unused, inprog, done */ |
| 37 | c_type, /* status, buffer */ |
| 38 | c_secure : 1; /* req came from port < 1024 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 | unsigned long c_timestamp; |
| 40 | union { |
| 41 | struct kvec u_vec; |
Al Viro | c7afef1 | 2006-10-19 23:29:02 -0700 | [diff] [blame] | 42 | __be32 u_status; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 43 | } c_u; |
| 44 | }; |
| 45 | |
| 46 | #define c_replvec c_u.u_vec |
| 47 | #define c_replstat c_u.u_status |
| 48 | |
| 49 | /* cache entry states */ |
| 50 | enum { |
| 51 | RC_UNUSED, |
| 52 | RC_INPROG, |
| 53 | RC_DONE |
| 54 | }; |
| 55 | |
| 56 | /* return values */ |
| 57 | enum { |
| 58 | RC_DROPIT, |
| 59 | RC_REPLY, |
Jeff Layton | 09662d5 | 2013-01-28 14:41:09 -0500 | [diff] [blame] | 60 | RC_DOIT |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 61 | }; |
| 62 | |
| 63 | /* |
| 64 | * Cache types. |
| 65 | * We may want to add more types one day, e.g. for diropres and |
| 66 | * attrstat replies. Using cache entries with fixed length instead |
| 67 | * of buffer pointers may be more efficient. |
| 68 | */ |
| 69 | enum { |
| 70 | RC_NOCACHE, |
| 71 | RC_REPLSTAT, |
| 72 | RC_REPLBUFF, |
| 73 | }; |
| 74 | |
Jeff Layton | d1a0774 | 2013-01-28 14:41:13 -0500 | [diff] [blame] | 75 | /* Cache entries expire after this time period */ |
| 76 | #define RC_EXPIRE (120 * HZ) |
| 77 | |
Jeff Layton | 01a7dec | 2013-02-04 11:57:27 -0500 | [diff] [blame] | 78 | /* Checksum this amount of the request */ |
| 79 | #define RC_CSUMLEN (256U) |
| 80 | |
J. Bruce Fields | 3ba7583 | 2019-05-17 09:03:38 -0400 | [diff] [blame] | 81 | int nfsd_reply_cache_init(struct nfsd_net *); |
| 82 | void nfsd_reply_cache_shutdown(struct nfsd_net *); |
J. Bruce Fields | 1091006 | 2011-01-24 12:11:02 -0500 | [diff] [blame] | 83 | int nfsd_cache_lookup(struct svc_rqst *); |
Al Viro | c7afef1 | 2006-10-19 23:29:02 -0700 | [diff] [blame] | 84 | void nfsd_cache_update(struct svc_rqst *, int, __be32 *); |
Jeff Layton | a2f999a | 2013-03-27 10:15:38 -0400 | [diff] [blame] | 85 | int nfsd_reply_cache_stats_open(struct inode *, struct file *); |
Benny Halevy | 04826f4 | 2009-04-06 12:00:49 +0300 | [diff] [blame] | 86 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 87 | #endif /* NFSCACHE_H */ |