Now that the lru list is per-bucket, we don't need a second list for searches. Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
		
			
				
	
	
		
			87 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Request reply cache. This was heavily inspired by the
 | |
|  * implementation in 4.3BSD/4.4BSD.
 | |
|  *
 | |
|  * Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de>
 | |
|  */
 | |
| 
 | |
| #ifndef NFSCACHE_H
 | |
| #define NFSCACHE_H
 | |
| 
 | |
| #include <linux/sunrpc/svc.h>
 | |
| 
 | |
| /*
 | |
|  * Representation of a reply cache entry.
 | |
|  *
 | |
|  * Note that we use a sockaddr_in6 to hold the address instead of the more
 | |
|  * typical sockaddr_storage. This is for space reasons, since sockaddr_storage
 | |
|  * is much larger than a sockaddr_in6.
 | |
|  */
 | |
| struct svc_cacherep {
 | |
| 	struct list_head	c_lru;
 | |
| 
 | |
| 	unsigned char		c_state,	/* unused, inprog, done */
 | |
| 				c_type,		/* status, buffer */
 | |
| 				c_secure : 1;	/* req came from port < 1024 */
 | |
| 	struct sockaddr_in6	c_addr;
 | |
| 	__be32			c_xid;
 | |
| 	u32			c_prot;
 | |
| 	u32			c_proc;
 | |
| 	u32			c_vers;
 | |
| 	unsigned int		c_len;
 | |
| 	__wsum			c_csum;
 | |
| 	unsigned long		c_timestamp;
 | |
| 	union {
 | |
| 		struct kvec	u_vec;
 | |
| 		__be32		u_status;
 | |
| 	}			c_u;
 | |
| };
 | |
| 
 | |
| #define c_replvec		c_u.u_vec
 | |
| #define c_replstat		c_u.u_status
 | |
| 
 | |
| /* cache entry states */
 | |
| enum {
 | |
| 	RC_UNUSED,
 | |
| 	RC_INPROG,
 | |
| 	RC_DONE
 | |
| };
 | |
| 
 | |
| /* return values */
 | |
| enum {
 | |
| 	RC_DROPIT,
 | |
| 	RC_REPLY,
 | |
| 	RC_DOIT
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Cache types.
 | |
|  * We may want to add more types one day, e.g. for diropres and
 | |
|  * attrstat replies. Using cache entries with fixed length instead
 | |
|  * of buffer pointers may be more efficient.
 | |
|  */
 | |
| enum {
 | |
| 	RC_NOCACHE,
 | |
| 	RC_REPLSTAT,
 | |
| 	RC_REPLBUFF,
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * If requests are retransmitted within this interval, they're dropped.
 | |
|  */
 | |
| #define RC_DELAY		(HZ/5)
 | |
| 
 | |
| /* Cache entries expire after this time period */
 | |
| #define RC_EXPIRE		(120 * HZ)
 | |
| 
 | |
| /* Checksum this amount of the request */
 | |
| #define RC_CSUMLEN		(256U)
 | |
| 
 | |
| int	nfsd_reply_cache_init(void);
 | |
| void	nfsd_reply_cache_shutdown(void);
 | |
| int	nfsd_cache_lookup(struct svc_rqst *);
 | |
| void	nfsd_cache_update(struct svc_rqst *, int, __be32 *);
 | |
| int	nfsd_reply_cache_stats_open(struct inode *, struct file *);
 | |
| 
 | |
| #endif /* NFSCACHE_H */
 |