STATFS(2)
НАЗВАНИЕ 
statfs, fstatfs - получение информации о файловой  системе
 СИНТАКСИС
 
        #include <sys/types.h>
        #include <sys/statfs.h>
        
        int statfs (path, buf, len, fstyp)
        char *path;
        struct statfs *buf;
        int len, fstyp;
        
        int fstatfs (fildes, buf, len, fstyp)
        int fildes;
        struct statfs *buf;
        int len, fstyp;
ОПИСАНИЕ 
Системный вызов statfs возвращает "родовой  суперблок",
описывающий файловую систему. Вызов может использоваться для запроса информации как о смонтированной, так и о
несмонтированной файловой системе; использование вызова
несколько различается в этих двух случаях. В обоих случаях аргумент  buf  является  указателем  на  структуру
(описываемую ниже), поля которой заполняются в  результате выполнения системного вызова, а аргумент len задает количество байт информации, которые  система  должна
поместить в структуру. Значение len не должно превышать
размер структуры: sizeof (struct statfs) и  обычно  len
содержит именно этот размер; если аргумент len содержит
меньшее значение, то система поместит в структуру ровно
заданное количество байт, что дает возможность в  более
поздних версиях добавлять к структуре statfs новые поля
без перетрансляции старых программ.
 
Если исследуемая  файловая  система  в  текущий  момент
смонтирована, то маршрутное имя path должно быть именем
файла, который располагается в данной файловой системе.
В этом случае тип файловой системы известен ОС, и аргумент fstyp должен быть  нулевым.  Для  несмонтированной
файловой системы маршрутное имя path должно быть именем
специального блочного файла, содержащего ее, и аргумент
fstyp должен содержать (ненулевой) тип файловой  системы. В обоих случаях право доступа на чтение, запись или
выполнение названного файла не требуется, но все  каталоги, перечисленные в  маршрутном  имени,  должны  быть
доступны на поиск.
 
Структура statfs, на которую  указывает  аргумент  buf,
состоит из следующих полей:
 
	short f_fstyp;     /* Тип файловой системы */
	short f_bsize;     /* Размер блока */
	short f_frsize;    /* Размер сегмента */
	long  f_blocks;    /* Общее количество блоков */
	long  f_bfree;     /* Счетчик свободных блоков */
	long  f_files;     /* Общее кол-во описателей файлов */
	long  f_ffree;     /* Счетчик свобод. описат. файлов */
	char  f_fname [6]; /* Имя тома */
	char  f_fpack [6]; /* Имя пакета */
 
Системный  вызов  fstatfs  отличается  от statfs только
тем, что файл идентифицируется не маршрутным именем,  а
дескриптором  открытого  файла fildes, сформированным в
результате успешного завершения следующих системных вызовов: open(2), creat(2), dup(2), fcntl(2) или pipe(2).
 
Системный вызов statfs является более поздним вариантом
системного вызова ustat(2) и в новых  программах  предпочтение следует отдавать statfs.
 
Системные вызовы statfs и fstatfs завершаются неудачей,
если выполнено хотя бы одно из следующих условий:
 
- [ENOTDIR]
 - Компонент маршрута не является каталогом.
 - [ENOENT]
 - Заданный файл не существует.
 - [EACCES]
 - Нет права на поиск для компонента маршрута.
 - [EFAULT]
 - Аргументы buf или path указывают за пределы
отведенного процессу адресного  пространства.
 - [EBADF]
 - Аргумент  fildes  не  является   корректным
дескриптором открытого файла.
 - [EINVAL]
 - Аргумент fstyp  содержит  некорректный  тип
файловой системы; path задает не  специальный блочный файл и аргумент fstyp не  равен
0; аргумент len отрицателен  или  превышает
sizeof (struct statfs).
 - [ENOLINK]
 - Маршрутное имя path указывает на  удаленный
компьютер, связи с которым в данный  момент
нет.
 - [EMULTIHOP] Компоненты path требуют многократного обращения к удаленным компьютерам.
  
СМ. ТАКЖЕ 
chmod(2),  chown(2),   creat(2),   link(2),   mknod(2),
pipe(2),   read(2),   time(2),   unlink(2),   utime(2),
ustat(2), write(2), fs(4).
 ДИАГНОСТИКА 
При успешном завершении результат  равен  0;  в  случае
ошибки возвращается -1, а переменной errno присваивается код ошибки.
 
 |