]> err.no Git - linux-2.6/commitdiff
nfsd: document open share bit tracking
authorJ. Bruce Fields <bfields@citi.umich.edu>
Mon, 7 Jul 2008 19:02:02 +0000 (15:02 -0400)
committerJ. Bruce Fields <bfields@citi.umich.edu>
Mon, 7 Jul 2008 19:04:50 +0000 (15:04 -0400)
It's not immediately obvious from the code why we're doing this.

Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
Cc: Benny Halevy <bhalevy@panasas.com>
fs/nfsd/nfs4state.c

index eca8aaa450f16adb25acb1c604bd5c6820a974aa..c29b6ed2a0bb41c254d804f24f87098d45d07b59 100644 (file)
@@ -1173,6 +1173,24 @@ static inline int deny_valid(u32 x)
        return x <= NFS4_SHARE_DENY_BOTH;
 }
 
+/*
+ * We store the NONE, READ, WRITE, and BOTH bits separately in the
+ * st_{access,deny}_bmap field of the stateid, in order to track not
+ * only what share bits are currently in force, but also what
+ * combinations of share bits previous opens have used.  This allows us
+ * to enforce the recommendation of rfc 3530 14.2.19 that the server
+ * return an error if the client attempt to downgrade to a combination
+ * of share bits not explicable by closing some of its previous opens.
+ *
+ * XXX: This enforcement is actually incomplete, since we don't keep
+ * track of access/deny bit combinations; so, e.g., we allow:
+ *
+ *     OPEN allow read, deny write
+ *     OPEN allow both, deny none
+ *     DOWNGRADE allow read, deny none
+ *
+ * which we should reject.
+ */
 static void
 set_access(unsigned int *access, unsigned long bmap) {
        int i;