STATVFS(3) | Руководство программиста Linux | STATVFS(3) |
statvfs, fstatvfs - получение статистики по файловой системе
#include <sys/statvfs.h>
int statvfs(const char *path, struct statvfs *buf); int fstatvfs(int fd, struct statvfs *buf);
Функция statvfs() возвращает информацию о смонтированной файловой системе. path является путём любого файла, расположенного в смонтированной файловой системе. buf является указателем на структуру statvfs, определённую примерно следующим образом:
struct statvfs { unsigned long f_bsize; /* размер блока файловой системы */ unsigned long f_frsize; /* размер фрагмента */ fsblkcnt_t f_blocks; /* размер ФС в единицах f_frsize */ fsblkcnt_t f_bfree; /* количество свободных блоков */ fsblkcnt_t f_bavail; /* количество свободных блоков для непривилегированных пользователей */ fsfilcnt_t f_files; /* количество inodes */ fsfilcnt_t f_ffree; /* количество свободных inodes */ fsfilcnt_t f_favail; /* количество свободных inodes для непривилегированных пользователей */ unsigned long f_fsid; /* идентификатор файловой системы */ unsigned long f_flag; /* параметры монтирования */ unsigned long f_namemax; /* максимальная длина имени файла */ };
Типы fsblkcnt_t и fsfilcnt_t определены в файле <sys/types.h>. Для их определения используется тип unsigned long.
Значение поля f_flag — битовая маска различных параметров, которые были указаны при монтировании этой файловой системы. В нём содержится ноль или несколько следующих флагов:
Не указывается, будут ли при любых файловых системах членам возвращаемой структуры присвоены осмысленные данные.
fstatvfs() возвращает такую же информацию об открытом файле через его ссылку на дескриптор fd.
При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
statvfs(), fstatvfs() | Безвредность в нитях | MT-Safe |
POSIX.1-2001, POSIX.1-2008.
В POSIX.1 в поле f_flag определены только флаги ST_NOSUID и ST_RDONLY. Чтобы получить определения остальных флагов нужно определить _GNU_SOURCE.
Для поддержки данной библиотечной функции в ядре Linux есть системные вызовы statfs(2) и fstatfs(2).
В версиях glibc до 2.13, statvfs() заполняла биты поля f_flag сканируя параметры монтирования в /proc/mounts. Однако начиная с Linux 2.6.36, нижележащий системный вызов statfs(2) предоставляет необходимую информацию через поле f_flags, и начиная с glibc версии 2.13, функция statvfs() будет использовать информацию из этого поля, а не сканируя /proc/mounts.
Реализации функций в glibc
pathconf(path, _PC_REC_XFER_ALIGN); pathconf(path, _PC_ALLOC_SIZE_MIN); pathconf(path, _PC_REC_MIN_XFER_SIZE);
используют, соответственно, поля f_frsize, f_frsize и f_bsize, возвращаемые вызовом statvfs() с аргументом path.
2017-09-15 | Linux |