Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 372159
b: refs/heads/master
c: 9dc5614
h: refs/heads/master
i:
  372157: dc2bc53
  372155: 4530bb8
  372151: 6270679
  372143: 99b6ba1
  372127: 4bfaccd
  372095: add6ba4
v: v3
  • Loading branch information
Jeff Layton authored and J. Bruce Fields committed Apr 3, 2013
1 parent bf978b2 commit e2c2b44
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 12 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 0b9ea37f24e247ed69baabf27fb211aa6a3e7622
refs/heads/master: 9dc56143c298692276231735ec6546c1fac596e0
46 changes: 35 additions & 11 deletions trunk/fs/nfsd/nfscache.c
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,21 @@
static struct hlist_head * cache_hash;
static struct list_head lru_head;
static struct kmem_cache *drc_slab;
static unsigned int num_drc_entries;

/* max number of entries allowed in the cache */
static unsigned int max_drc_entries;

/*
* Stats and other tracking of on the duplicate reply cache. All of these and
* the "rc" fields in nfsdstats are protected by the cache_lock
*/

/* total number of entries */
static unsigned int num_drc_entries;

/* cache misses due only to checksum comparison failures */
static unsigned int payload_misses;

/*
* Calculate the hash index from an XID.
*/
Expand Down Expand Up @@ -273,6 +285,26 @@ nfsd_cache_csum(struct svc_rqst *rqstp)
return csum;
}

static bool
nfsd_cache_match(struct svc_rqst *rqstp, __wsum csum, struct svc_cacherep *rp)
{
/* Check RPC header info first */
if (rqstp->rq_xid != rp->c_xid || rqstp->rq_proc != rp->c_proc ||
rqstp->rq_prot != rp->c_prot || rqstp->rq_vers != rp->c_vers ||
rqstp->rq_arg.len != rp->c_len ||
!rpc_cmp_addr(svc_addr(rqstp), (struct sockaddr *)&rp->c_addr) ||
rpc_get_port(svc_addr(rqstp)) != rpc_get_port((struct sockaddr *)&rp->c_addr))
return false;

/* compare checksum of NFS data */
if (csum != rp->c_csum) {
++payload_misses;
return false;
}

return true;
}

/*
* Search the request hash for an entry that matches the given rqstp.
* Must be called with cache_lock held. Returns the found entry or
Expand All @@ -283,18 +315,10 @@ nfsd_cache_search(struct svc_rqst *rqstp, __wsum csum)
{
struct svc_cacherep *rp;
struct hlist_head *rh;
__be32 xid = rqstp->rq_xid;
u32 proto = rqstp->rq_prot,
vers = rqstp->rq_vers,
proc = rqstp->rq_proc;

rh = &cache_hash[request_hash(xid)];
rh = &cache_hash[request_hash(rqstp->rq_xid)];
hlist_for_each_entry(rp, rh, c_hash) {
if (xid == rp->c_xid && proc == rp->c_proc &&
proto == rp->c_prot && vers == rp->c_vers &&
rqstp->rq_arg.len == rp->c_len && csum == rp->c_csum &&
rpc_cmp_addr(svc_addr(rqstp), (struct sockaddr *)&rp->c_addr) &&
rpc_get_port(svc_addr(rqstp)) == rpc_get_port((struct sockaddr *)&rp->c_addr))
if (nfsd_cache_match(rqstp, csum, rp))
return rp;
}
return NULL;
Expand Down

0 comments on commit e2c2b44

Please sign in to comment.