]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/man/man2/getfsstat.2
xnu-2782.30.5.tar.gz
[apple/xnu.git] / bsd / man / man2 / getfsstat.2
index cdc2e2586994b682edba162a227dcb2fef3dd3b8..99e2abaf6a07ebb2d9edc8d51cc3f3f9641b3aae 100644 (file)
@@ -33,7 +33,7 @@
 .\"
 .\"    @(#)getfsstat.2 8.1 (Berkeley) 6/9/93
 .\"
 .\"
 .\"    @(#)getfsstat.2 8.1 (Berkeley) 6/9/93
 .\"
-.Dd June 9, 1993
+.Dd Oct 28, 2008
 .Dt GETFSSTAT 2
 .Os
 .Sh NAME
 .Dt GETFSSTAT 2
 .Os
 .Sh NAME
 .Fd #include <sys/mount.h>
 .Ft int
 .Fn getfsstat "struct statfs *buf" "int bufsize" "int flags"
 .Fd #include <sys/mount.h>
 .Ft int
 .Fn getfsstat "struct statfs *buf" "int bufsize" "int flags"
+.Sh TRANSITIIONAL SYNOPSIS (NOW DEPRECATED)
+.Ft int
+.br
+.Fn getfsstat64 "struct statfs64 *buf" "int bufsize" "int flags" ;
 .Sh DESCRIPTION
 .Sh DESCRIPTION
-.Fn Getfsstat
-returns information about all mounted file systems.
-.Fa Buf
-is a pointer to an array of
-.Xr statfs
-structures defined as follows:
-.Bd -literal
-typedef struct { int32_t val[2]; } fsid_t;
-
-#define MFSNAMELEN   15 /* length of fs type name, not inc. nul */
-#define MNAMELEN     90        /* length of buffer for returned name */
-
-struct statfs {
-    short   f_otype;   /* type of file system (reserved: zero) */
-    short   f_oflags;  /* copy of mount flags (reserved: zero) */
-    long    f_bsize;   /* fundamental file system block size */
-    long    f_iosize;  /* optimal transfer block size */
-    long    f_blocks;  /* total data blocks in file system */
-    long    f_bfree;   /* free blocks in fs */
-    long    f_bavail;  /* free blocks avail to non-superuser */
-    long    f_files;   /* total file nodes in file system */
-    long    f_ffree;   /* free file nodes in fs */
-    fsid_t  f_fsid;    /* file system id (super-user only) */
-    uid_t   f_owner;   /* user that mounted the file system */
-    short   f_reserved1;       /* reserved for future use */
-    short   f_type;    /* type of file system (reserved) */
-    long    f_flags;   /* copy of mount flags (reserved) */
-    long    f_reserved2[2];    /* reserved for future use */
-    char    f_fstypename[MFSNAMELEN]; /* fs type name */
-    char    f_mntonname[MNAMELEN];    /* directory on which mounted */
-    char    f_mntfromname[MNAMELEN];  /* mounted file system */
-    char    f_reserved3;       /* reserved for future use */
-    long    f_reserved4[4];    /* reserved for future use */
-};
-.Ed
+The
+.Fn getfsstat
+function returns information about all mounted file systems.
+The
+.Fa buf
+argument is a pointer to an array of
+.Fa statfs
+structures (see 
+.Xr statfs 2 ) .
+As
+.Xr statfs 2
+indicates, the structure is defined differently depending on
+whether the macro _DARWIN_FEATURE_64_BIT_INODE is defined (see
+.Xr stat 2
+for more information on this macro).
 .Pp
 Fields that are undefined for a particular file system are set to -1.
 The buffer is filled with an array of
 .Pp
 Fields that are undefined for a particular file system are set to -1.
 The buffer is filled with an array of
@@ -107,6 +91,8 @@ Some of the information returned may be out of date, however; if
 .Fa flags
 is set to
 .Dv MNT_WAIT
 .Fa flags
 is set to
 .Dv MNT_WAIT
+or
+.Dv MNT_DWAIT
 instead,
 .Fn getfsstat
 will request updated information from each mounted filesystem before
 instead,
 .Fn getfsstat
 will request updated information from each mounted filesystem before
@@ -123,14 +109,25 @@ is set to indicate the error.
 fails if one or more of the following are true:
 .Bl -tag -width Er
 .It Bq Er EFAULT
 fails if one or more of the following are true:
 .Bl -tag -width Er
 .It Bq Er EFAULT
-.Fa Buf
-points to an invalid address.
+The
+.Fa buf
+argument points to an invalid address.
 .It Bq Er EIO
 An
 .Tn I/O
 error occurred while reading from or writing to the file system.
 .El
 .It Bq Er EIO
 An
 .Tn I/O
 error occurred while reading from or writing to the file system.
 .El
+.Sh TRANSITIONAL DESCRIPTION (NOW DEPRECATED)
+The
+.Fn getfsstat64
+routine is equivalent to the default
+.Fn getfstat
+(when
+.Dv _DARWIN_FEATURE_64_BIT_INODE
+is defined), so there is no longer any reason to use it (it will be removed
+in the future).
 .Sh SEE ALSO
 .Sh SEE ALSO
+.Xr stat 2 ,
 .Xr statfs 2 ,
 .Xr fstab 5 ,
 .Xr mount 8
 .Xr statfs 2 ,
 .Xr fstab 5 ,
 .Xr mount 8