Skip to Content
UNIX Filesystems: Evolution, Design, and Implementation
book

UNIX Filesystems: Evolution, Design, and Implementation

by Steve D. Pate
January 2003
Intermediate to advanced content levelIntermediate to advanced
480 pages
13h 22m
English
Wiley
Content preview from UNIX Filesystems: Evolution, Design, and Implementation

Per Filesystem Statistics

In the same way that the stat() system call can be called to obtain per-file related information, the statvfs() system call can be invoked to obtain per-filesystem information. Note that this information will differ for each different mounted filesystem so that the information obtained for, say, one VxFS filesystem, will not necessarily be the same for other VxFS filesystems.

#include <sys/types.h>
#include <sys/statvfs.h>

int statvfs(const char *path, struct statvfs *buf);
int fstatvfs(int fildes, struct statvfs *buf);

Both functions operate on the statvfs structure, which contains a number of filesystem-specific fields including the following:

u_long      f_bsize;              /* file system block size */
u_long      f_frsize;             /* fundamental filesystem block
                                     (size if supported) */
fsblkcnt_t f_blocks;              /* total # of blocks on file system
                                     in units of f_frsize */
fsblkcnt_t f_bfree;               /* total # of free blocks */
fsblkcnt_t f_bavail;              /* # of free blocks avail to
                                     non-super-user */
fsfilcnt_t f_files;               /* total # of file nodes (inodes) */
fsfilcnt_t f_ffree;               /* total # of free file nodes */
fsfilcnt_t f_favail;              /* # of inodes avail to non-suser*/
u_long      f_fsid;               /* file system id (dev for now) */
char        f_basetype[FSTYPSZ];  /* fs name null-terminated */
u_long      f_flag;               /* bit mask of flags */
u_long      f_namemax;            /* maximum file name length */
char        f_fstr[32];           /* file system specific string */

The statvfs(L) function is not available on Linux. In its place is the statfs(L) function that ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

Design and Implementation of the FreeBSD Operating System, 2nd Edition

Design and Implementation of the FreeBSD Operating System, 2nd Edition

Marshall Kirk McKusick, George V. Neville-Neil, Robert N.M. Watson

Publisher Resources

ISBN: 9780471456759Purchase book