]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/nfs/nfsproto.h
xnu-2050.24.15.tar.gz
[apple/xnu.git] / bsd / nfs / nfsproto.h
index 297a6b40e32f8575c7200a344ba42e70defaacba..ec6bc93111aec23f647e5ff5b4ad7fbc8b57e22f 100644 (file)
@@ -1,16 +1,19 @@
 /*
- * Copyright (c) 2000-2003 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2010 Apple Inc. All rights reserved.
  *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Copyright (c) 1999-2003 Apple Computer, Inc.  All Rights Reserved.
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ * 
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
  * 
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
@@ -20,7 +23,7 @@
  * Please see the License for the specific language governing rights and
  * limitations under the License.
  * 
- * @APPLE_LICENSE_HEADER_END@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /* Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved */
 /*
 #include <sys/appleapiopts.h>
 
 #ifdef __APPLE_API_PRIVATE
-/*
- * nfs definitions as per the Version 2 and 3 specs
- */
 
 /*
- * Constants as defined in the Sun NFS Version 2 and 3 specs.
- * "NFS: Network File System Protocol Specification" RFC1094
- * and in the "NFS: Network File System Version 3 Protocol
- * Specification"
+ * NFS definitions per the various NFS protocol specs:
+ * Version 2 (RFC 1094), Version 3 (RFC 1813), and Version 4 (RFC 3530)
+ * and various protocol-related implementation definitions.
  */
 
 /* Only define these if nfs_prot.h hasn't been included */
 #define        NFS_PROG        100003
 #define NFS_VER2       2
 #define        NFS_VER3        3
+#define        NFS_VER4        4
 #define NFS_V2MAXDATA  8192
 #define        NFS_MAXDGRAMDATA 16384
-#define        NFS_MAXDATA     (60*1024) // XXX not ready for 64K-128K
+#define        NFS_PREFDGRAMDATA 8192
+#define        NFS_MAXDATA     (64*1024) // XXX not ready for >64K
+#define        NFSRV_MAXDATA   (64*1024) // XXX not ready for >64K
 #define        NFS_MAXPATHLEN  1024
 #define        NFS_MAXNAMLEN   255
-#define        NFS_MAXPKTHDR   404
-#define NFS_MAXPACKET  (NFS_MAXPKTHDR + NFS_MAXDATA)
-#define        NFS_MINPACKET   20
-#define        NFS_MAXSOCKBUF  (224*1024)
+#define        NFS_MAXPACKET   (16*1024*1024)
+#define        NFS_UDPSOCKBUF  (224*1024)
 #define        NFS_FABLKSIZE   512     /* Size in bytes of a block wrt fa_blocks */
 
-/* Stat numbers for rpc returns (version 2 and 3) */
-#define        NFS_OK                  0
-#define        NFSERR_PERM             1
-#define        NFSERR_NOENT            2
-#define        NFSERR_IO               5
-#define        NFSERR_NXIO             6
-#define        NFSERR_ACCES            13
-#define        NFSERR_EXIST            17
-#define        NFSERR_XDEV             18      /* Version 3 only */
-#define        NFSERR_NODEV            19
-#define        NFSERR_NOTDIR           20
-#define        NFSERR_ISDIR            21
-#define        NFSERR_INVAL            22      /* Version 3 only */
-#define        NFSERR_FBIG             27
-#define        NFSERR_NOSPC            28
-#define        NFSERR_ROFS             30
-#define        NFSERR_MLINK            31      /* Version 3 only */
-#define        NFSERR_NAMETOL          63
-#define        NFSERR_NOTEMPTY         66
-#define        NFSERR_DQUOT            69
-#define        NFSERR_STALE            70
-#define        NFSERR_REMOTE           71      /* Version 3 only */
-#define        NFSERR_WFLUSH           99      /* Version 2 only */
-#define        NFSERR_BADHANDLE        10001   /* The rest Version 3 only */
-#define        NFSERR_NOT_SYNC         10002
-#define        NFSERR_BAD_COOKIE       10003
-#define        NFSERR_NOTSUPP          10004
-#define        NFSERR_TOOSMALL         10005
-#define        NFSERR_SERVERFAULT      10006
-#define        NFSERR_BADTYPE          10007
-#define        NFSERR_JUKEBOX          10008
-#define NFSERR_TRYLATER                NFSERR_JUKEBOX
-#define        NFSERR_STALEWRITEVERF   30001   /* Fake return for nfs_commit() */
+#define NFS4_CALLBACK_PROG             0x4E465343 /* "NFSC" */
+#define NFS4_CALLBACK_PROG_VERSION     1
+
+/* Stat numbers for NFS RPC returns */
+#define NFS_OK                         0
+#define NFSERR_PERM                    1
+#define NFSERR_NOENT                   2
+#define NFSERR_IO                      5
+#define NFSERR_NXIO                    6
+#define NFSERR_ACCES                   13
+#define NFSERR_EXIST                   17
+#define NFSERR_XDEV                    18      /* Version 3 only */
+#define NFSERR_NODEV                   19
+#define NFSERR_NOTDIR                  20
+#define NFSERR_ISDIR                   21
+#define NFSERR_INVAL                   22      /* Version 3 only */
+#define NFSERR_FBIG                    27
+#define NFSERR_NOSPC                   28
+#define NFSERR_ROFS                    30
+#define NFSERR_MLINK                   31      /* Version 3 only */
+#define NFSERR_NAMETOL                 63
+#define NFSERR_NOTEMPTY                        66
+#define NFSERR_DQUOT                   69
+#define NFSERR_STALE                   70
+#define NFSERR_REMOTE                  71      /* Version 3 only */
+#define NFSERR_WFLUSH                  99      /* Version 2 only */
+#define NFSERR_BADHANDLE               10001   /* The rest Version 3 only */
+#define NFSERR_NOT_SYNC                        10002
+#define NFSERR_BAD_COOKIE              10003
+#define NFSERR_NOTSUPP                 10004
+#define NFSERR_TOOSMALL                        10005
+#define NFSERR_SERVERFAULT             10006
+#define NFSERR_BADTYPE                 10007
+#define NFSERR_JUKEBOX                 10008
+#define NFSERR_TRYLATER                        NFSERR_JUKEBOX
+#define NFSERR_DELAY                   NFSERR_JUKEBOX
+#define NFSERR_SAME                    10009   /* The rest Version 4 only */
+#define NFSERR_DENIED                  10010
+#define NFSERR_EXPIRED                 10011
+#define NFSERR_LOCKED                  10012
+#define NFSERR_GRACE                   10013
+#define NFSERR_FHEXPIRED               10014
+#define NFSERR_SHARE_DENIED            10015
+#define NFSERR_WRONGSEC                        10016
+#define NFSERR_CLID_INUSE              10017
+#define NFSERR_RESOURCE                        10018
+#define NFSERR_MOVED                   10019
+#define NFSERR_NOFILEHANDLE            10020
+#define NFSERR_MINOR_VERS_MISMATCH     10021
+#define NFSERR_STALE_CLIENTID          10022
+#define NFSERR_STALE_STATEID           10023
+#define NFSERR_OLD_STATEID             10024
+#define NFSERR_BAD_STATEID             10025
+#define NFSERR_BAD_SEQID               10026
+#define NFSERR_NOT_SAME                        10027
+#define NFSERR_LOCK_RANGE              10028
+#define NFSERR_SYMLINK                 10029
+#define NFSERR_RESTOREFH               10030
+#define NFSERR_LEASE_MOVED             10031
+#define NFSERR_ATTRNOTSUPP             10032
+#define NFSERR_NO_GRACE                        10033
+#define NFSERR_RECLAIM_BAD             10034
+#define NFSERR_RECLAIM_CONFLICT                10035
+#define NFSERR_BADXDR                  10036
+#define NFSERR_LOCKS_HELD              10037
+#define NFSERR_OPENMODE                        10038
+#define NFSERR_BADOWNER                        10039
+#define NFSERR_BADCHAR                 10040
+#define NFSERR_BADNAME                 10041
+#define NFSERR_BAD_RANGE               10042
+#define NFSERR_LOCK_NOTSUPP            10043
+#define NFSERR_OP_ILLEGAL              10044
+#define NFSERR_DEADLOCK                        10045
+#define NFSERR_FILE_OPEN               10046
+#define NFSERR_ADMIN_REVOKED           10047
+#define NFSERR_CB_PATH_DOWN            10048
+
+#define NFSERR_STALEWRITEVERF          30001   /* Fake return for nfs_commit() */
+#define NFSERR_DIRBUFDROPPED           30002   /* Fake return for nfs*_readdir_rpc() */
+
+/*
+ * For gss we would like to return EAUTH when we don't have or can't get credentials,
+ * but some callers don't know what to do with it, so we define our own version
+ * of EAUTH to be EACCES
+ */
+#define NFSERR_EAUTH   EACCES
 
 #define NFSERR_RETVOID         0x20000000 /* Return void, not error */
 #define NFSERR_AUTHERR         0x40000000 /* Mark an authentication error */
 #define NFSX_V2STATFS  20
 
 /* specific to NFS Version 3 */
-#define NFSX_V3FH              (sizeof (fhandle_t)) /* size this server uses */
 #define        NFSX_V3FHMAX            64      /* max. allowed by protocol */
 #define NFSX_V3FATTR           84
 #define NFSX_V3SATTR           60      /* max. all fields filled in */
-#define NFSX_V3SRVSATTR                (sizeof (struct nfsv3_sattr))
 #define NFSX_V3POSTOPATTR      (NFSX_V3FATTR + NFSX_UNSIGNED)
 #define NFSX_V3WCCDATA         (NFSX_V3POSTOPATTR + 8 * NFSX_UNSIGNED)
 #define NFSX_V3COOKIEVERF      8
 #define NFSX_V3FSINFO          48
 #define NFSX_V3PATHCONF                24
 
-/* variants for both versions */
-#define NFSX_FH(v3)            ((v3) ? (NFSX_V3FHMAX + NFSX_UNSIGNED) : \
-                                       NFSX_V2FH)
-#define NFSX_SRVFH(v3)         ((v3) ? NFSX_V3FH : NFSX_V2FH)
-#define        NFSX_FATTR(v3)          ((v3) ? NFSX_V3FATTR : NFSX_V2FATTR)
-#define NFSX_PREOPATTR(v3)     ((v3) ? (7 * NFSX_UNSIGNED) : 0)
-#define NFSX_POSTOPATTR(v3)    ((v3) ? (NFSX_V3FATTR + NFSX_UNSIGNED) : 0)
-#define NFSX_POSTOPORFATTR(v3) ((v3) ? (NFSX_V3FATTR + NFSX_UNSIGNED) : \
-                                       NFSX_V2FATTR)
-#define NFSX_WCCDATA(v3)       ((v3) ? NFSX_V3WCCDATA : 0)
-#define NFSX_WCCORFATTR(v3)    ((v3) ? NFSX_V3WCCDATA : NFSX_V2FATTR)
-#define        NFSX_SATTR(v3)          ((v3) ? NFSX_V3SATTR : NFSX_V2SATTR)
-#define        NFSX_COOKIEVERF(v3)     ((v3) ? NFSX_V3COOKIEVERF : 0)
-#define        NFSX_WRITEVERF(v3)      ((v3) ? NFSX_V3WRITEVERF : 0)
-#define NFSX_READDIR(v3)       ((v3) ? (5 * NFSX_UNSIGNED) : \
+/* specific to NFS Version 4 */
+#define NFS4_FHSIZE            128
+#define NFS4_VERIFIER_SIZE     8
+#define NFS4_OPAQUE_LIMIT      1024
+
+/* variants for multiple versions */
+#define NFSX_FH(V)             (((V) == NFS_VER2) ? NFSX_V2FH : (NFSX_UNSIGNED + \
+                                (((V) == NFS_VER3) ? NFSX_V3FHMAX : NFS4_FHSIZE)))
+#define NFSX_SRVFH(V,FH)       (((V) == NFS_VER2) ? NFSX_V2FH : (FH)->nfh_len)
+#define        NFSX_FATTR(V)           (((V) == NFS_VER3) ? NFSX_V3FATTR : NFSX_V2FATTR)
+#define NFSX_PREOPATTR(V)      (((V) == NFS_VER3) ? (7 * NFSX_UNSIGNED) : 0)
+#define NFSX_POSTOPATTR(V)     (((V) == NFS_VER3) ? (NFSX_V3FATTR + NFSX_UNSIGNED) : 0)
+#define NFSX_POSTOPORFATTR(V)  (((V) == NFS_VER3) ? (NFSX_V3FATTR + NFSX_UNSIGNED) : NFSX_V2FATTR)
+#define NFSX_WCCDATA(V)                (((V) == NFS_VER3) ? NFSX_V3WCCDATA : 0)
+#define NFSX_WCCORFATTR(V)     (((V) == NFS_VER3) ? NFSX_V3WCCDATA : NFSX_V2FATTR)
+#define        NFSX_SATTR(V)           (((V) == NFS_VER3) ? NFSX_V3SATTR : NFSX_V2SATTR)
+#define        NFSX_COOKIEVERF(V)      (((V) == NFS_VER3) ? NFSX_V3COOKIEVERF : 0)
+#define        NFSX_WRITEVERF(V)       (((V) == NFS_VER3) ? NFSX_V3WRITEVERF : 0)
+#define NFSX_READDIR(V)                (((V) == NFS_VER3) ? (5 * NFSX_UNSIGNED) : \
                                        (2 * NFSX_UNSIGNED))
-#define        NFSX_STATFS(v3)         ((v3) ? NFSX_V3STATFS : NFSX_V2STATFS)
+#define        NFSX_STATFS(V)          (((V) == NFS_VER3) ? NFSX_V3STATFS : NFSX_V2STATFS)
 
 /* Only define these if nfs_prot.h hasn't been included */
 #ifndef NFS_PROGRAM
 
 #endif /* !NFS_PROGRAM */
 
-/* And leasing (nqnfs) procedure numbers (must be last) */
-#define        NQNFSPROC_GETLEASE      22
-#define        NQNFSPROC_VACATED       23
-#define        NQNFSPROC_EVICTED       24
-
-#define NFSPROC_NOOP           25
-#define        NFS_NPROCS              26
+#define NFSPROC_NOOP           22
+#define        NFS_NPROCS              23
 
 /* Actual Version 2 procedure numbers */
 #define        NFSV2PROC_NULL          0
 /*
  * Constants used by the Version 3 protocol for various RPCs
  */
-#define NFSV3SATTRTIME_DONTCHANGE      0
-#define NFSV3SATTRTIME_TOSERVER                1
-#define NFSV3SATTRTIME_TOCLIENT                2
-
-#define NFSV3ACCESS_READ               0x01
-#define NFSV3ACCESS_LOOKUP             0x02
-#define NFSV3ACCESS_MODIFY             0x04
-#define NFSV3ACCESS_EXTEND             0x08
-#define NFSV3ACCESS_DELETE             0x10
-#define NFSV3ACCESS_EXECUTE            0x20
-
-#define NFSV3WRITE_UNSTABLE            0
-#define NFSV3WRITE_DATASYNC            1
-#define NFSV3WRITE_FILESYNC            2
-
-#define NFSV3CREATE_UNCHECKED          0
-#define NFSV3CREATE_GUARDED            1
-#define NFSV3CREATE_EXCLUSIVE          2
 
 #define NFSV3FSINFO_LINK               0x01
 #define NFSV3FSINFO_SYMLINK            0x02
 #define NFSV3FSINFO_HOMOGENEOUS                0x08
 #define NFSV3FSINFO_CANSETTIME         0x10
 
-/* Conversion macros */
-#define        vtonfsv2_mode(t,m) \
-               txdr_unsigned(((t) == VFIFO) ? MAKEIMODE(VCHR, (m)) : \
-                               MAKEIMODE((t), (m)))
-#define vtonfsv3_mode(m)       txdr_unsigned((m) & 07777)
-#define        nfstov_mode(a)          (fxdr_unsigned(u_short, (a))&07777)
-#define        vtonfsv2_type(a)        txdr_unsigned(nfsv2_type[((long)(a))])
-#define        vtonfsv3_type(a)        txdr_unsigned(nfsv3_type[((long)(a))])
-#define        nfsv2tov_type(a)        nv2tov_type[fxdr_unsigned(u_long,(a))&0x7]
-#define        nfsv3tov_type(a)        nv3tov_type[fxdr_unsigned(u_long,(a))&0x7]
+/* time setting constants */
+#define NFS_TIME_DONT_CHANGE           0
+#define NFS_TIME_SET_TO_SERVER         1
+#define NFS_TIME_SET_TO_CLIENT         2
+#define NFS4_TIME_SET_TO_SERVER                0
+#define NFS4_TIME_SET_TO_CLIENT                1
+
+/* access() constants */
+#define NFS_ACCESS_READ                        0x01
+#define NFS_ACCESS_LOOKUP              0x02
+#define NFS_ACCESS_MODIFY              0x04
+#define NFS_ACCESS_EXTEND              0x08
+#define NFS_ACCESS_DELETE              0x10
+#define NFS_ACCESS_EXECUTE             0x20
+#define        NFS_ACCESS_ALL (NFS_ACCESS_READ | NFS_ACCESS_MODIFY             \
+                        | NFS_ACCESS_EXTEND | NFS_ACCESS_EXECUTE       \
+                        | NFS_ACCESS_DELETE | NFS_ACCESS_LOOKUP)
+
+/* NFS WRITE how constants */
+#define NFS_WRITE_UNSTABLE             0
+#define NFS_WRITE_DATASYNC             1
+#define NFS_WRITE_FILESYNC             2
+
+/* NFS CREATE types */
+#define NFS_CREATE_UNCHECKED           0
+#define NFS_CREATE_GUARDED             1
+#define NFS_CREATE_EXCLUSIVE           2
 
 /* Only define these if nfs_prot.h hasn't been included */
 #ifndef NFS_PROGRAM
-
-/* File types */
+/* NFS object types */
 typedef enum { NFNON=0, NFREG=1, NFDIR=2, NFBLK=3, NFCHR=4, NFLNK=5,
-       NFSOCK=6, NFFIFO=7 } nfstype;
+       NFSOCK=6, NFFIFO=7, NFATTRDIR=8, NFNAMEDATTR=9 } nfstype;
 #endif /* !NFS_PROGRAM */
 
-/* Structs for common parts of the rpc's */
 /*
- * File Handle (32 bytes for version 2), variable up to 64 for version 3.
+ * File Handle (32 bytes for version 2), variable up to 64 for version 3
+ * and variable up to 128 bytes for version 4.
  * File Handles of up to NFS_SMALLFH in size are stored directly in the
  * nfs node, whereas larger ones are malloc'd. (This never happens when
- * NFS_SMALLFH is set to 64.)
+ * NFS_SMALLFH is set to the largest size.)
  * NFS_SMALLFH should be in the range of 32 to 64 and be divisible by 4.
  */
 #ifndef NFS_SMALLFH
 #define NFS_SMALLFH    64
 #endif
-union nfsfh {
-       fhandle_t       fh_generic;
-       u_char          fh_bytes[NFS_SMALLFH];
-};
-typedef union nfsfh nfsfh_t;
 
-struct nfsv2_time {
-       u_long  nfsv2_sec;
-       u_long  nfsv2_usec;
-};
-typedef struct nfsv2_time      nfstime2;
+/*
+ * NFS attribute management stuff
+ */
+#define NFS_ATTR_BITMAP_LEN    2
+#define NFS_BITMAP_SET(B, I)   (((uint32_t *)(B))[(I)/32] |= 1<<((I)%32))
+#define NFS_BITMAP_CLR(B, I)   (((uint32_t *)(B))[(I)/32] &= ~(1<<((I)%32)))
+#define NFS_BITMAP_ISSET(B, I) (((uint32_t *)(B))[(I)/32] & (1<<((I)%32)))
+#define NFS_BITMAP_ZERO(B, L) \
+       do { \
+               int __i; \
+               for (__i=0; __i < (L); __i++) \
+                       ((uint32_t*)(B))[__i] = 0; \
+       } while (0)
+
+__private_extern__ uint32_t nfs_fs_attr_bitmap[NFS_ATTR_BITMAP_LEN];
+__private_extern__ uint32_t nfs_object_attr_bitmap[NFS_ATTR_BITMAP_LEN];
+__private_extern__ uint32_t nfs_getattr_bitmap[NFS_ATTR_BITMAP_LEN];
+
+#define NFS_CLEAR_ATTRIBUTES(A)        NFS_BITMAP_ZERO((A), NFS_ATTR_BITMAP_LEN)
+#define NFS_COPY_ATTRIBUTES(SRC, DST) \
+       do { \
+       int __i; \
+       for (__i=0; __i < NFS_ATTR_BITMAP_LEN; __i++) \
+               ((uint32_t*)(DST))[__i] = ((uint32_t*)(SRC))[__i]; \
+       } while (0)
+
+/* NFS attributes */
+#define NFS_FATTR_SUPPORTED_ATTRS              0
+#define NFS_FATTR_TYPE                         1
+#define NFS_FATTR_FH_EXPIRE_TYPE               2
+#define NFS_FATTR_CHANGE                       3
+#define NFS_FATTR_SIZE                         4
+#define NFS_FATTR_LINK_SUPPORT                 5
+#define NFS_FATTR_SYMLINK_SUPPORT              6
+#define NFS_FATTR_NAMED_ATTR                   7
+#define NFS_FATTR_FSID                         8
+#define NFS_FATTR_UNIQUE_HANDLES               9
+#define NFS_FATTR_LEASE_TIME                   10
+#define NFS_FATTR_RDATTR_ERROR                 11
+#define NFS_FATTR_FILEHANDLE                   19
+#define NFS_FATTR_ACL                          12
+#define NFS_FATTR_ACLSUPPORT                   13
+#define NFS_FATTR_ARCHIVE                      14
+#define NFS_FATTR_CANSETTIME                   15
+#define NFS_FATTR_CASE_INSENSITIVE             16
+#define NFS_FATTR_CASE_PRESERVING              17
+#define NFS_FATTR_CHOWN_RESTRICTED             18
+#define NFS_FATTR_FILEID                       20
+#define NFS_FATTR_FILES_AVAIL                  21
+#define NFS_FATTR_FILES_FREE                   22
+#define NFS_FATTR_FILES_TOTAL                  23
+#define NFS_FATTR_FS_LOCATIONS                 24
+#define NFS_FATTR_HIDDEN                       25
+#define NFS_FATTR_HOMOGENEOUS                  26
+#define NFS_FATTR_MAXFILESIZE                  27
+#define NFS_FATTR_MAXLINK                      28
+#define NFS_FATTR_MAXNAME                      29
+#define NFS_FATTR_MAXREAD                      30
+#define NFS_FATTR_MAXWRITE                     31
+#define NFS_FATTR_MIMETYPE                     32
+#define NFS_FATTR_MODE                         33
+#define NFS_FATTR_NO_TRUNC                     34
+#define NFS_FATTR_NUMLINKS                     35
+#define NFS_FATTR_OWNER                                36
+#define NFS_FATTR_OWNER_GROUP                  37
+#define NFS_FATTR_QUOTA_AVAIL_HARD             38
+#define NFS_FATTR_QUOTA_AVAIL_SOFT             39
+#define NFS_FATTR_QUOTA_USED                   40
+#define NFS_FATTR_RAWDEV                       41
+#define NFS_FATTR_SPACE_AVAIL                  42
+#define NFS_FATTR_SPACE_FREE                   43
+#define NFS_FATTR_SPACE_TOTAL                  44
+#define NFS_FATTR_SPACE_USED                   45
+#define NFS_FATTR_SYSTEM                       46
+#define NFS_FATTR_TIME_ACCESS                  47
+#define NFS_FATTR_TIME_ACCESS_SET              48
+#define NFS_FATTR_TIME_BACKUP                  49
+#define NFS_FATTR_TIME_CREATE                  50
+#define NFS_FATTR_TIME_DELTA                   51
+#define NFS_FATTR_TIME_METADATA                        52
+#define NFS_FATTR_TIME_MODIFY                  53
+#define NFS_FATTR_TIME_MODIFY_SET              54
+#define NFS_FATTR_MOUNTED_ON_FILEID            55
+
+#define NFS4_ALL_ATTRIBUTES(A) \
+       do { \
+       /* required: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_SUPPORTED_ATTRS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FH_EXPIRE_TYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CHANGE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SIZE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_LINK_SUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SYMLINK_SUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NAMED_ATTR); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FSID); \
+       NFS_BITMAP_SET((A), NFS_FATTR_UNIQUE_HANDLES); \
+       NFS_BITMAP_SET((A), NFS_FATTR_LEASE_TIME); \
+       NFS_BITMAP_SET((A), NFS_FATTR_RDATTR_ERROR); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILEHANDLE); \
+       /* optional: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_ACL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_ACLSUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_ARCHIVE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CANSETTIME); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CASE_INSENSITIVE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CASE_PRESERVING); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CHOWN_RESTRICTED); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILEID); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_TOTAL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FS_LOCATIONS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_HIDDEN); \
+       NFS_BITMAP_SET((A), NFS_FATTR_HOMOGENEOUS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXFILESIZE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXLINK); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXNAME); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXREAD); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXWRITE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MIMETYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MODE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NO_TRUNC); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NUMLINKS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_OWNER); \
+       NFS_BITMAP_SET((A), NFS_FATTR_OWNER_GROUP); \
+       NFS_BITMAP_SET((A), NFS_FATTR_QUOTA_AVAIL_HARD); \
+       NFS_BITMAP_SET((A), NFS_FATTR_QUOTA_AVAIL_SOFT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_QUOTA_USED); \
+       NFS_BITMAP_SET((A), NFS_FATTR_RAWDEV); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_TOTAL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_USED); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SYSTEM); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_ACCESS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_ACCESS_SET); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_BACKUP); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_CREATE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_DELTA); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_METADATA); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_MODIFY); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_MODIFY_SET); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MOUNTED_ON_FILEID); \
+       } while (0)
+
+#define NFS4_PER_OBJECT_ATTRIBUTES(A) \
+       do { \
+       /* required: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_TYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CHANGE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SIZE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NAMED_ATTR); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FSID); \
+       NFS_BITMAP_SET((A), NFS_FATTR_RDATTR_ERROR); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILEHANDLE); \
+       /* optional: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_ACL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_ARCHIVE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILEID); \
+       NFS_BITMAP_SET((A), NFS_FATTR_HIDDEN); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXLINK); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MIMETYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MODE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NUMLINKS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_OWNER); \
+       NFS_BITMAP_SET((A), NFS_FATTR_OWNER_GROUP); \
+       NFS_BITMAP_SET((A), NFS_FATTR_RAWDEV); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_USED); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SYSTEM); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_ACCESS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_BACKUP); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_CREATE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_METADATA); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_MODIFY); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MOUNTED_ON_FILEID); \
+       } while (0)
+
+#define NFS4_PER_FS_ATTRIBUTES(A) \
+       do { \
+       /* required: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_SUPPORTED_ATTRS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FH_EXPIRE_TYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_LINK_SUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SYMLINK_SUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_UNIQUE_HANDLES); \
+       NFS_BITMAP_SET((A), NFS_FATTR_LEASE_TIME); \
+       /* optional: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_ACLSUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CANSETTIME); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CASE_INSENSITIVE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CASE_PRESERVING); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CHOWN_RESTRICTED); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_TOTAL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FS_LOCATIONS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_HOMOGENEOUS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXFILESIZE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXNAME); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXREAD); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXWRITE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NO_TRUNC); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_TOTAL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_DELTA); \
+       } while (0)
+
+#define NFS4_DEFAULT_ATTRIBUTES(A) \
+       do { \
+       /* required: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_SUPPORTED_ATTRS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FH_EXPIRE_TYPE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CHANGE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SIZE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_LINK_SUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SYMLINK_SUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NAMED_ATTR); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FSID); \
+       NFS_BITMAP_SET((A), NFS_FATTR_UNIQUE_HANDLES); \
+       NFS_BITMAP_SET((A), NFS_FATTR_LEASE_TIME); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_RDATTR_ERROR); */ \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_FILEHANDLE); */ \
+       /* optional: */ \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_ACL); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_ACLSUPPORT); \
+       NFS_BITMAP_SET((A), NFS_FATTR_ARCHIVE); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_CANSETTIME); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_CASE_INSENSITIVE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CASE_PRESERVING); \
+       NFS_BITMAP_SET((A), NFS_FATTR_CHOWN_RESTRICTED); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILEID); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_TOTAL); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_FS_LOCATIONS); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_HIDDEN); \
+       NFS_BITMAP_SET((A), NFS_FATTR_HOMOGENEOUS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXFILESIZE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXLINK); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXNAME); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXREAD); \
+       NFS_BITMAP_SET((A), NFS_FATTR_MAXWRITE); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_MIMETYPE); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_MODE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NO_TRUNC); \
+       NFS_BITMAP_SET((A), NFS_FATTR_NUMLINKS); \
+       NFS_BITMAP_SET((A), NFS_FATTR_OWNER); \
+       NFS_BITMAP_SET((A), NFS_FATTR_OWNER_GROUP); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_QUOTA_AVAIL_HARD); */ \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_QUOTA_AVAIL_SOFT); */ \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_QUOTA_USED); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_RAWDEV); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_TOTAL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_USED); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_SYSTEM); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_ACCESS); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_TIME_ACCESS_SET); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_BACKUP); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_CREATE); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_TIME_DELTA); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_METADATA); \
+       NFS_BITMAP_SET((A), NFS_FATTR_TIME_MODIFY); \
+       /* NFS_BITMAP_SET((A), NFS_FATTR_TIME_MODIFY_SET); */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_MOUNTED_ON_FILEID); \
+       } while (0)
+
+/* attributes requested when we want to do a "statfs" */
+#define NFS4_STATFS_ATTRIBUTES(A) \
+       do { \
+       /* optional: */ \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_FILES_TOTAL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_AVAIL); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_FREE); \
+       NFS_BITMAP_SET((A), NFS_FATTR_SPACE_TOTAL); \
+       } while (0)
+
+/*
+ * NFS OPEN constants
+ */
+/* open type */
+#define NFS_OPEN_NOCREATE                      0
+#define NFS_OPEN_CREATE                                1
+/* delegation space limit */
+#define NFS_LIMIT_SIZE                         1
+#define NFS_LIMIT_BLOCKS                       2
+/* access/deny modes */
+#define NFS_OPEN_SHARE_ACCESS_NONE             0x00000000
+#define NFS_OPEN_SHARE_ACCESS_READ             0x00000001
+#define NFS_OPEN_SHARE_ACCESS_WRITE            0x00000002
+#define NFS_OPEN_SHARE_ACCESS_BOTH             0x00000003
+#define NFS_OPEN_SHARE_DENY_NONE               0x00000000
+#define NFS_OPEN_SHARE_DENY_READ               0x00000001
+#define NFS_OPEN_SHARE_DENY_WRITE              0x00000002
+#define NFS_OPEN_SHARE_DENY_BOTH               0x00000003
+/* delegation types */
+#define NFS_OPEN_DELEGATE_NONE                 0
+#define NFS_OPEN_DELEGATE_READ                 1
+#define NFS_OPEN_DELEGATE_WRITE                        2
+/* delegation claim types */
+#define NFS_CLAIM_NULL                         0
+#define NFS_CLAIM_PREVIOUS                     1
+#define NFS_CLAIM_DELEGATE_CUR                 2
+#define NFS_CLAIM_DELEGATE_PREV                        3
+/* open result flags */
+#define NFS_OPEN_RESULT_CONFIRM                        0x00000002
+#define NFS_OPEN_RESULT_LOCKTYPE_POSIX         0x00000004
+/* NFS lock types */
+#define NFS_LOCK_TYPE_READ                     1
+#define NFS_LOCK_TYPE_WRITE                    2
+#define NFS_LOCK_TYPE_READW                    3 /* "blocking" */
+#define NFS_LOCK_TYPE_WRITEW                   4 /* "blocking" */
+
+/* NFSv4 RPC procedures */
+#define NFSPROC4_NULL                          0
+#define NFSPROC4_COMPOUND                      1
+#define NFSPROC4_CB_NULL                       0
+#define NFSPROC4_CB_COMPOUND                   1
+
+/* NFSv4 opcodes */
+#define NFS_OP_ACCESS                          3
+#define NFS_OP_CLOSE                           4
+#define NFS_OP_COMMIT                          5
+#define NFS_OP_CREATE                          6
+#define NFS_OP_DELEGPURGE                      7
+#define NFS_OP_DELEGRETURN                     8
+#define NFS_OP_GETATTR                         9
+#define NFS_OP_GETFH                           10
+#define NFS_OP_LINK                            11
+#define NFS_OP_LOCK                            12
+#define NFS_OP_LOCKT                           13
+#define NFS_OP_LOCKU                           14
+#define NFS_OP_LOOKUP                          15
+#define NFS_OP_LOOKUPP                         16
+#define NFS_OP_NVERIFY                         17
+#define NFS_OP_OPEN                            18
+#define NFS_OP_OPENATTR                                19
+#define NFS_OP_OPEN_CONFIRM                    20
+#define NFS_OP_OPEN_DOWNGRADE                  21
+#define NFS_OP_PUTFH                           22
+#define NFS_OP_PUTPUBFH                                23
+#define NFS_OP_PUTROOTFH                       24
+#define NFS_OP_READ                            25
+#define NFS_OP_READDIR                         26
+#define NFS_OP_READLINK                                27
+#define NFS_OP_REMOVE                          28
+#define NFS_OP_RENAME                          29
+#define NFS_OP_RENEW                           30
+#define NFS_OP_RESTOREFH                       31
+#define NFS_OP_SAVEFH                          32
+#define NFS_OP_SECINFO                         33
+#define NFS_OP_SETATTR                         34
+#define NFS_OP_SETCLIENTID                     35
+#define NFS_OP_SETCLIENTID_CONFIRM             36
+#define NFS_OP_VERIFY                          37
+#define NFS_OP_WRITE                           38
+#define NFS_OP_RELEASE_LOCKOWNER               39
+#define NFS_OP_ILLEGAL                         10044
+/* NFSv4 callback opcodes */
+#define NFS_OP_CB_GETATTR                      3
+#define NFS_OP_CB_RECALL                       4
+#define NFS_OP_CB_ILLEGAL                      10044
+
+/* NFSv4 file handle type flags */
+#define NFS_FH_PERSISTENT                      0x00000000
+#define NFS_FH_NOEXPIRE_WITH_OPEN              0x00000001
+#define NFS_FH_VOLATILE_ANY                    0x00000002
+#define NFS_FH_VOL_MIGRATION                   0x00000004
+#define NFS_FH_VOL_RENAME                      0x00000008
+
+/*
+ * NFSv4 ACL constants
+ */
+/* ACE support mask bits */
+#define NFS_ACL_SUPPORT_ALLOW_ACL              0x00000001
+#define NFS_ACL_SUPPORT_DENY_ACL               0x00000002
+#define NFS_ACL_SUPPORT_AUDIT_ACL              0x00000004
+#define NFS_ACL_SUPPORT_ALARM_ACL              0x00000008
+/* ACE types */
+#define NFS_ACE_ACCESS_ALLOWED_ACE_TYPE                0x00000000
+#define NFS_ACE_ACCESS_DENIED_ACE_TYPE         0x00000001
+#define NFS_ACE_SYSTEM_AUDIT_ACE_TYPE          0x00000002
+#define NFS_ACE_SYSTEM_ALARM_ACE_TYPE          0x00000003
+/* ACE flags */
+#define NFS_ACE_FILE_INHERIT_ACE               0x00000001
+#define NFS_ACE_DIRECTORY_INHERIT_ACE          0x00000002
+#define NFS_ACE_NO_PROPAGATE_INHERIT_ACE       0x00000004
+#define NFS_ACE_INHERIT_ONLY_ACE               0x00000008
+#define NFS_ACE_SUCCESSFUL_ACCESS_ACE_FLAG     0x00000010
+#define NFS_ACE_FAILED_ACCESS_ACE_FLAG         0x00000020
+#define NFS_ACE_IDENTIFIER_GROUP               0x00000040
+#define NFS_ACE_INHERITED_ACE                  0x00000080
+/* ACE mask flags */
+#define NFS_ACE_READ_DATA                      0x00000001
+#define NFS_ACE_LIST_DIRECTORY                 0x00000001
+#define NFS_ACE_WRITE_DATA                     0x00000002
+#define NFS_ACE_ADD_FILE                       0x00000002
+#define NFS_ACE_APPEND_DATA                    0x00000004
+#define NFS_ACE_ADD_SUBDIRECTORY               0x00000004
+#define NFS_ACE_READ_NAMED_ATTRS               0x00000008
+#define NFS_ACE_WRITE_NAMED_ATTRS              0x00000010
+#define NFS_ACE_EXECUTE                                0x00000020
+#define NFS_ACE_DELETE_CHILD                   0x00000040
+#define NFS_ACE_READ_ATTRIBUTES                        0x00000080
+#define NFS_ACE_WRITE_ATTRIBUTES               0x00000100
+#define NFS_ACE_DELETE                         0x00010000
+#define NFS_ACE_READ_ACL                       0x00020000
+#define NFS_ACE_WRITE_ACL                      0x00040000
+#define NFS_ACE_WRITE_OWNER                    0x00080000
+#define NFS_ACE_SYNCHRONIZE                    0x00100000
+#define NFS_ACE_GENERIC_READ                   0x00120081
+#define NFS_ACE_GENERIC_WRITE                  0x00160106
+#define NFS_ACE_GENERIC_EXECUTE                        0x001200A0
 
-struct nfsv3_time {
-       u_long  nfsv3_sec;
-       u_long  nfsv3_nsec;
-};
-typedef struct nfsv3_time      nfstime3;
 
 /*
- * Quads are defined as arrays of 2 longs to ensure dense packing for the
- * protocol and to facilitate xdr conversion.
+ * Quads are defined as arrays of 2 32-bit values to ensure dense packing
+ * for the protocol and to facilitate xdr conversion.
  */
 struct nfs_uquad {
-       u_long  nfsuquad[2];
+       u_int32_t       nfsuquad[2];
 };
 typedef        struct nfs_uquad        nfsuint64;
 
 /*
- * Used to convert between two u_longs and a u_quad_t.
+ * Used to convert between two u_int32_ts and a u_quad_t.
  */
 union nfs_quadconvert {
-       u_long          lval[2];
+       u_int32_t               lval[2];
        u_quad_t        qval;
 };
 typedef union nfs_quadconvert  nfsquad_t;
 
 /*
- * NFS Version 3 special file number.
+ * special data/attribute associated with NFBLK/NFCHR
  */
-struct nfsv3_spec {
-       u_long  specdata1;
-       u_long  specdata2;
+struct nfs_specdata {
+       uint32_t specdata1;     /* major device number */
+       uint32_t specdata2;     /* minor device number */
 };
-typedef        struct nfsv3_spec       nfsv3spec;
+typedef struct nfs_specdata nfs_specdata;
 
 /*
- * File attributes and setable attributes. These structures cover both
- * NFS version 2 and the version 3 protocol. Note that the union is only
- * used so that one pointer can refer to both variants. These structures
- * go out on the wire and must be densely packed, so no quad data types
- * are used. (all fields are longs or u_longs or structures of same)
- * NB: You can't do sizeof(struct nfs_fattr), you must use the
- *     NFSX_FATTR(v3) macro.
+ * an "fsid" large enough to hold an NFSv4 fsid.
  */
-struct nfs_fattr {
-       u_long  fa_type;
-       u_long  fa_mode;
-       u_long  fa_nlink;
-       u_long  fa_uid;
-       u_long  fa_gid;
-       union {
-               struct {
-                       u_long          nfsv2fa_size;
-                       u_long          nfsv2fa_blocksize;
-                       u_long          nfsv2fa_rdev;
-                       u_long          nfsv2fa_blocks;
-                       u_long          nfsv2fa_fsid;
-                       u_long          nfsv2fa_fileid;
-                       nfstime2        nfsv2fa_atime;
-                       nfstime2        nfsv2fa_mtime;
-                       nfstime2        nfsv2fa_ctime;
-               } fa_nfsv2;
-               struct {
-                       nfsuint64       nfsv3fa_size;
-                       nfsuint64       nfsv3fa_used;
-                       nfsv3spec       nfsv3fa_rdev;
-                       nfsuint64       nfsv3fa_fsid;
-                       nfsuint64       nfsv3fa_fileid;
-                       nfstime3        nfsv3fa_atime;
-                       nfstime3        nfsv3fa_mtime;
-                       nfstime3        nfsv3fa_ctime;
-               } fa_nfsv3;
-       } fa_un;
-};
-
-/* and some ugly defines for accessing union components */
-#define        fa2_size                fa_un.fa_nfsv2.nfsv2fa_size
-#define        fa2_blocksize           fa_un.fa_nfsv2.nfsv2fa_blocksize
-#define        fa2_rdev                fa_un.fa_nfsv2.nfsv2fa_rdev
-#define        fa2_blocks              fa_un.fa_nfsv2.nfsv2fa_blocks
-#define        fa2_fsid                fa_un.fa_nfsv2.nfsv2fa_fsid
-#define        fa2_fileid              fa_un.fa_nfsv2.nfsv2fa_fileid
-#define        fa2_atime               fa_un.fa_nfsv2.nfsv2fa_atime
-#define        fa2_mtime               fa_un.fa_nfsv2.nfsv2fa_mtime
-#define        fa2_ctime               fa_un.fa_nfsv2.nfsv2fa_ctime
-#define        fa3_size                fa_un.fa_nfsv3.nfsv3fa_size
-#define        fa3_used                fa_un.fa_nfsv3.nfsv3fa_used
-#define        fa3_rdev                fa_un.fa_nfsv3.nfsv3fa_rdev
-#define        fa3_fsid                fa_un.fa_nfsv3.nfsv3fa_fsid
-#define        fa3_fileid              fa_un.fa_nfsv3.nfsv3fa_fileid
-#define        fa3_atime               fa_un.fa_nfsv3.nfsv3fa_atime
-#define        fa3_mtime               fa_un.fa_nfsv3.nfsv3fa_mtime
-#define        fa3_ctime               fa_un.fa_nfsv3.nfsv3fa_ctime
-
-struct nfsv2_sattr {
-       u_long          sa_mode;
-       u_long          sa_uid;
-       u_long          sa_gid;
-       u_long          sa_size;
-       nfstime2        sa_atime;
-       nfstime2        sa_mtime;
+struct nfs_fsid {
+       uint64_t major;
+       uint64_t minor;
 };
+typedef struct nfs_fsid nfs_fsid;
 
 /*
- * NFS Version 3 sattr structure for the new node creation case.
+ * NFSv4 stateid structure
  */
-struct nfsv3_sattr {
-       u_long          sa_modetrue;
-       u_long          sa_mode;
-       u_long          sa_uidtrue;
-       u_long          sa_uid;
-       u_long          sa_gidtrue;
-       u_long          sa_gid;
-       u_long          sa_sizefalse;
-       u_long          sa_atimetype;
-       u_long          sa_mtimetype;
-};
-
-struct nfs_statfs {
-       union {
-               struct {
-                       u_long          nfsv2sf_tsize;
-                       u_long          nfsv2sf_bsize;
-                       u_long          nfsv2sf_blocks;
-                       u_long          nfsv2sf_bfree;
-                       u_long          nfsv2sf_bavail;
-               } sf_nfsv2;
-               struct {
-                       nfsuint64       nfsv3sf_tbytes;
-                       nfsuint64       nfsv3sf_fbytes;
-                       nfsuint64       nfsv3sf_abytes;
-                       nfsuint64       nfsv3sf_tfiles;
-                       nfsuint64       nfsv3sf_ffiles;
-                       nfsuint64       nfsv3sf_afiles;
-                       u_long          nfsv3sf_invarsec;
-               } sf_nfsv3;
-       } sf_un;
-};
-
-#define sf_tsize       sf_un.sf_nfsv2.nfsv2sf_tsize
-#define sf_bsize       sf_un.sf_nfsv2.nfsv2sf_bsize
-#define sf_blocks      sf_un.sf_nfsv2.nfsv2sf_blocks
-#define sf_bfree       sf_un.sf_nfsv2.nfsv2sf_bfree
-#define sf_bavail      sf_un.sf_nfsv2.nfsv2sf_bavail
-#define sf_tbytes      sf_un.sf_nfsv3.nfsv3sf_tbytes
-#define sf_fbytes      sf_un.sf_nfsv3.nfsv3sf_fbytes
-#define sf_abytes      sf_un.sf_nfsv3.nfsv3sf_abytes
-#define sf_tfiles      sf_un.sf_nfsv3.nfsv3sf_tfiles
-#define sf_ffiles      sf_un.sf_nfsv3.nfsv3sf_ffiles
-#define sf_afiles      sf_un.sf_nfsv3.nfsv3sf_afiles
-#define sf_invarsec    sf_un.sf_nfsv3.nfsv3sf_invarsec
-
-struct nfsv3_fsinfo {
-       u_long          fs_rtmax;
-       u_long          fs_rtpref;
-       u_long          fs_rtmult;
-       u_long          fs_wtmax;
-       u_long          fs_wtpref;
-       u_long          fs_wtmult;
-       u_long          fs_dtpref;
-       nfsuint64       fs_maxfilesize;
-       nfstime3        fs_timedelta;
-       u_long          fs_properties;
-};
-
-struct nfsv3_pathconf {
-       u_long          pc_linkmax;
-       u_long          pc_namemax;
-       u_long          pc_notrunc;
-       u_long          pc_chownrestricted;
-       u_long          pc_caseinsensitive;
-       u_long          pc_casepreserving;
+struct nfs_stateid {
+       uint32_t        seqid;
+       uint32_t        other[3];
 };
+typedef struct nfs_stateid nfs_stateid;
 
 #endif /* __APPLE_API_PRIVATE */
 #endif /* _NFS_NFSPROTO_H_ */