Главная » 2017 » Ноябрь » 24 » man 2 statvfs
05:34
man 2 statvfs

SEO sprint - Всё для максимальной раскрутки!





ИМЯ


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 — битовая маска различных параметров, которые были указаны при
монтировании этой файловой системы. В нём содержится ноль или несколько следующих флагов:

ST_MANDLOCK
Разрешена обязательная (mandatory) блокировка файловой системы (смотрите fcntl(2)).

ST_NOATIME
Не обновлять времена доступа; смотрите mount(2).

ST_NODEV
Запретить доступ к специальным файлам устройств в этой файловой системе.

ST_NODIRATIME
Не обновлять времена доступа к каталогам; смотрите mount(2).

ST_NOEXEC
Исполнение программ в этой файловой системе запрещено.

ST_NOSUID
Биты set-user-ID и set-group-ID игнорируются в exec(3) для исполняемых файлов в этой
файловой системе.

ST_RDONLY
Файловая система смонтирована в режиме только для чтения.

осмысленные данные.

fstatvfs() возвращает такую же информацию об открытом файле через его ссылку на дескриптор
fd.



ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ


При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno
устанавливается в соответствующее значение.



ОШИБКИ


EACCES (statvfs()) Нет права на поиск одного из компонентов префикса пути path (см. также
path_resolution(7)).

EBADF (fstatvfs()) fd не является корректным открытым дескриптором файла.

EFAULT Buf или path указывает на неправильный адрес.

EINTR Данный вызов был прерван сигналом; смотрите signal(7).

EIO При чтении файловой системы произошла ошибка ввода-вывода.

ELOOP (statvfs()) Было обнаружено слишком много символьных ссылок при трансляции path.

ENAMETOOLONG
(statvfs()) Слишком длинное значение аргумента path.

ENOENT (statvfs()) Файл, указанный в path, не существует.

ENOMEM Недостаточное количество памяти ядра.

ENOSYS Файловая система не поддерживает данный вызов.

ENOTDIR
(statvfs()) Один из компонентов префикса пути path не является каталогом.

EOVERFLOW
Некоторые значения слишком велики, чтобы быть представленными в возвращаемой
структуре.



АТРИБУТЫ


Описание терминов данного раздела смотрите в 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).

pathconf(path, _PC_ALLOC_SIZE_MIN);
pathconf(path, _PC_REC_MIN_XFER_SIZE);

используют, соответственно, поля f_frsize, f_frsize и f_bsize, возвращаемые вызовом
statvfs() с аргументом path.



СМОТРИТЕ ТАКЖЕ


statfs(2)



Категория: (2) Системные вызовы ядра (функции языка Си) | Просмотров: 504 | Добавил: Администратор | Рейтинг: 0.0/0
Всего комментариев: 0
avatar