#include <sys/vfs.h>
int statfs(path, buf) char *path; struct statfs *buf;
int fstatfs(fd, buf) int fd; struct statfs *buf;
statfs() returns information about a mounted file system. path is the path name of any file within the mounted filesystem. buf is a pointer to a statfs() structure defined as follows:
typedef struct { long val[2]; } fsid_t; struct statfs { long f_type; /* type of info, zero for now */ long f_bsize; /* fundamental file system block size */ long f_blocks; /* total blocks in file system */ long f_bfree; /* free blocks */ long f_bavail; /* free blocks available to non-super-user */ long f_files; /* total file nodes in file system */ long f_ffree; /* free file nodes in fs */ fsid_t f_fsid; /* file system id */ long f_spare[7]; /* spare for later */ };
Fields that are undefined for a particular file system are set to -1. fstatfs() returns the same information about an open file referenced by descriptor fd.
statfs() and fstatfs() return:
statfs() fails if one or more of the following are true:
A pathname component is longer than {NAME_MAX} (see sysconf.2v while {_POSIX_NO_TRUNC} is in effect (see pathconf.2v
fstatfs() fails if one or more of the following are true:
The NFS revision 2 protocol does not permit the number of free files to be provided to the client; thus, when statfs() or fstatfs() are done on a file on an NFS file system, f_files and f_ffree are always -1.
Created by unroff & hp-tools. © somebody (See intro for details). All Rights Reserved. Last modified 11/5/97