logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

getfsstat — get list of all mounted file systems

Description

The getfsstat() system call returns information about all mounted file systems. The buf argument is a pointer to statfs structures, as described in statfs(2). Fields that are undefined for a particular file system are set to -1. The buffer is filled with an array of statfs structures, one for each mounted file system up to the byte count specified by bufsize. Note, the bufsize argument is the number of bytes that buf can hold, not the count of statfs structures it will hold. If buf is given as NULL, getfsstat() returns just the number of mounted file systems. Normally mode should be specified as MNT_WAIT. If mode is set to MNT_NOWAIT, getfsstat() will return the information it has available without requesting an update from each file system. Thus, some of the information will be out of date, but getfsstat() will not block waiting for information from a file system that is unable to respond. It will also skip any file system that is in the process of being unmounted, even if the unmount would eventually fail.

Errors

The getfsstat() system call fails if one or more of the following are true: [EFAULT] The buf argument points to an invalid address. [EINVAL] mode is set to a value other than MNT_WAIT or MNT_NOWAIT. [EIO] An I/O error occurred while reading from or writing to the file system. [EINTEGRITY] Corrupted data was detected while reading from the file system.

History

The getfsstat() system call first appeared in 4.4BSD. Debian March 30, 2020 GETFSSTAT(2)

Library

Standard C Library (libc, -lc)

Name

getfsstat — get list of all mounted file systems

Return Values

Upon successful completion, the number of statfs structures is returned. Otherwise, -1 is returned and the global variable errno is set to indicate the error.

See Also

statfs(2), fstab(5), mount(8)

Synopsis

#include<sys/param.h>#include<sys/ucred.h>#include<sys/mount.h>intgetfsstat(structstatfs*buf, longbufsize, intmode);

See Also