summaryrefslogtreecommitdiff
path: root/sys/nfs/nfsm_subs.h
diff options
context:
space:
mode:
authorThordur I. Bjornsson <thib@cvs.openbsd.org>2009-01-24 23:30:43 +0000
committerThordur I. Bjornsson <thib@cvs.openbsd.org>2009-01-24 23:30:43 +0000
commit86832ad61e0ff002c49152ecaf00eb1aa87d21bb (patch)
treedbd48c51d10c5b6cdf3f3f8919970708427ee95c /sys/nfs/nfsm_subs.h
parentd62304bc585972214cce753b7c807f6da7195dc7 (diff)
Use a timespec instead of a time_t for the clients nfsnode
mtime, gives us better granularity, helps with cache consistency. Idea lifted from NetBSD. OK blambert@
Diffstat (limited to 'sys/nfs/nfsm_subs.h')
-rw-r--r--sys/nfs/nfsm_subs.h37
1 files changed, 21 insertions, 16 deletions
diff --git a/sys/nfs/nfsm_subs.h b/sys/nfs/nfsm_subs.h
index 54014291aca..7015b6278eb 100644
--- a/sys/nfs/nfsm_subs.h
+++ b/sys/nfs/nfsm_subs.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: nfsm_subs.h,v 1.32 2008/12/24 16:53:20 thib Exp $ */
+/* $OpenBSD: nfsm_subs.h,v 1.33 2009/01/24 23:30:42 thib Exp $ */
/* $NetBSD: nfsm_subs.h,v 1.10 1996/03/20 21:59:56 fvdl Exp $ */
/*
@@ -170,21 +170,26 @@
#define NFSV3_WCCRATTR 0
#define NFSV3_WCCCHK 1
-#define nfsm_wcc_data(v, f) \
- { int ttattrf, ttretf = 0; \
- nfsm_dissect(tl, u_int32_t *, NFSX_UNSIGNED); \
- if (*tl == nfs_true) { \
- nfsm_dissect(tl, u_int32_t *, 6 * NFSX_UNSIGNED); \
- if (f) \
- ttretf = (VTONFS(v)->n_mtime == \
- fxdr_unsigned(u_int32_t, *(tl + 2))); \
- } \
- nfsm_postop_attr((v), ttattrf); \
- if (f) { \
- (f) = ttretf; \
- } else { \
- (f) = ttattrf; \
- } }
+#define nfsm_wcc_data(v, f) do { \
+ struct timespec _mtime; \
+ int ttattrf, ttretf = 0; \
+ \
+ nfsm_dissect(tl, u_int32_t *, NFSX_UNSIGNED); \
+ if (*tl == nfs_true) { \
+ nfsm_dissect(tl, u_int32_t *, 6 * NFSX_UNSIGNED); \
+ fxdr_nfsv3time(tl + 2, &_mtime); \
+ if (f) { \
+ ttretf = timespeccmp(&VTONFS(v)->n_mtime, \
+ &_mtime, !=); \
+ } \
+ } \
+ nfsm_postop_attr((v), ttattrf); \
+ if (f) { \
+ (f) = ttretf; \
+ } else { \
+ (f) = ttattrf; \
+ } \
+} while (0)
#define nfsm_strsiz(s,m) \
{ nfsm_dissect(tl,u_int32_t *,NFSX_UNSIGNED); \