Provided by: manpages-ru-dev_4.19.0-7_all bug

ИМЯ

       statx - считывает состояние файла (расширенный вариант)

LIBRARY

       Standard C library (libc, -lc)

СИНТАКСИС

       #define _GNU_SOURCE          /* Смотрите feature_test_macros(7) */
       #include <fcntl.h>           /* Определение констант AT_* */
       #include <sys/stat.h>

       int statx(int dirfd, const char *restrict pathname, int flags,
                 unsigned int mask, struct statx *restrict statxbuf);

ОПИСАНИЕ

       Этот  системный  вызов  возвращает  информацию  о  файле, записывая её в буфер, на который
       указывает statxbuf. Возвращаемый буфер представляет собой структуру следующего вида:

           struct statx {
               __u32 stx_mask;        /* Mask of bits indicating
                                         filled fields */
               __u32 stx_blksize;     /* Block size for filesystem I/O */
               __u64 stx_attributes;  /* Extra file attribute indicators */
               __u32 stx_nlink;       /* Number of hard links */
               __u32 stx_uid;         /* User ID of owner */
               __u32 stx_gid;         /* Group ID of owner */
               __u16 stx_mode;        /* File type and mode */
               __u64 stx_ino;         /* Inode number */
               __u64 stx_size;        /* Total size in bytes */
               __u64 stx_blocks;      /* Number of 512B blocks allocated */
               __u64 stx_attributes_mask;
                                      /* Mask to show what's supported
                                         in stx_attributes */

               /* поля меток времени */
               struct statx_timestamp stx_atime;  /* последний доступ */
               struct statx_timestamp stx_btime;  /* создание */
               struct statx_timestamp stx_ctime;  /* последнее изменение состояния */
               struct statx_timestamp stx_mtime;  /* последнее изменение */

               /* если файл представляет устройство, то в следующих
                  полях содержится идентификатор устройства */
               __u32 stx_rdev_major;  /* основной идентификатор */
               __u32 stx_rdev_minor;  /* дополнительный идентификатор */

               /* поля идентификатора устройства с файловой системой,
                  в которой содержится файл */
               __u32 stx_dev_major;   /* основной идентификатор */
               __u32 stx_dev_minor;   /* дополнительный идентификатор */

               __u64 stx_mnt_id;      /* Mount ID */

               /* Direct I/O alignment restrictions */
               __u32 stx_dio_mem_align;
               __u32 stx_dio_offset_align;
           };

       Метки времени файла хранятся в структуре следующего вида:

           struct statx_timestamp {
               __s64 tv_sec;    /* количество секунд с начала Эпохи (время UNIX) */
               __u32 tv_nsec;   /* количество наносекунд, начиная с tv_sec */
           };

       (зарезервированное пространство и заполнители не показаны)

   При вызове statx():
       Для получения состояния файла не требуется иметь права доступа к самому файлу, но в случае
       указания  statx()  с  путём,  потребуются  права  выполнения  (поиска)  во всех каталогах,
       указанных в полном имени файла pathname.

       Вызов statx() для определения нужного файла использует pathname, dirfd и flags  следующими
       путями:

       Абсолютный путь
              Если  pathname начинается с косой черты, то целевой файла задан абсолютным путём. В
              этом случае значение dirfd игнорируется.

       Относительный путь
              Если pathname начинается не с косой черты  и  dirfd  равно  AT_FDCWD,  то  pathname
              рассматривается относительно текущего рабочего каталога процесса.

       Путь, задаваемый относительно каталога
              If  pathname  is a string that begins with a character other than a slash and dirfd
              is a file descriptor that refers to  a  directory,  then  pathname  is  a  relative
              pathname  that is interpreted relative to the directory referred to by dirfd.  (See
              openat(2)  for an explanation of why this is useful.)

       По файловому дескриптору
              Если значение pathname равно пустой строке и в flags (смотрите  ниже)  указан  флаг
              AT_EMPTY_PATH,  то  целевым  файлом  считается  тот,  на который указывает файловый
              дескриптор в dirfd.

       Значение flags можно использовать для уточнения поиска на основе пути. Оно составляется из
       побитно слагаемых следующих констант:

       AT_EMPTY_PATH
              Если  значение  pathname равно пустой строке, то вызов выполняет действие с файлом,
              на который ссылается dirfd (может быть получен с помощью open(2) с флагом  O_PATH).
              В этом случае dirfd может ссылаться на файл любого типа, а не только на каталог.

              Если dirfd равно AT_FDCWD, то вызов использует текущий рабочий каталог.

       AT_NO_AUTOMOUNT
              Don't  automount  the  terminal  ("basename")  component  of  pathname  if  it is a
              directory that is an automount point.  This allows the caller to gather  attributes
              of  an automount point (rather than the location it would mount).  This flag has no
              effect if the mount point has already been mounted over.

              The AT_NO_AUTOMOUNT flag can be used in tools  that  scan  directories  to  prevent
              mass-automounting of a directory of automount points.

              All of stat(2), lstat(2), and fstatat(2)  act as though AT_NO_AUTOMOUNT was set.

       AT_SYMLINK_NOFOLLOW
              Если  значение pathname является символьной ссылкой, не разыменовывать её, а выдать
              информацию о самой ссылке, подобно lstat(2).

       Значение flags  также  может  использоваться  для  контроля  типа  синхронизации,  которое
       выполняет ядро при опросе файла на удалённой файловой системе. Оно составляется из побитно
       слагаемых следующих значений:

       AT_STATX_SYNC_AS_STAT
              Работать подобно stat(2). Используется по умолчанию и  очень  зависит  от  файловой
              системы.

       AT_STATX_FORCE_SYNC
              Принудительно  синхронизировать  атрибуты  с сервером. Может потребовать от сетевой
              файловой системы выполнить запись данных для получения правильных меток времени.

       AT_STATX_DONT_SYNC
              Не выполнять синхронизацию, а использовать информацию  из  кэша  (если  есть).  Это
              может  означать,  что  полученная информация будет не точна, но в случае с сетевыми
              файловыми системами это позволяет не обращаться к серверу и даже может быть  разрыв
              соединения.

       Аргумент  mask в statx() используется для указания ядру какие поля поля нужны вызывающему.
       Значение mask представляет побитовую комбинацию (посредством OR) следующих констант:

           STATX_TYPE          Требуется stx_mode & S_IFMT
           STATX_MODE          Want stx_mode & ~S_IFMT
           STATX_NLINK         Требуется stx_nlink
           STATX_UID           Требуется stx_uid
           STATX_GID           Требуется stx_gid
           STATX_ATIME         Требуется stx_atime
           STATX_MTIME         Требуется stx_mtime
           STATX_CTIME         Требуется stx_ctime
           STATX_INO           Требуется stx_ino
           STATX_SIZE          Требуется stx_size
           STATX_BLOCKS        Требуется stx_blocks
           STATX_BASIC_STATS   [всё вышеперечисленное]
           STATX_BTIME         Требуется stx_btime
           STATX_ALL           The same as STATX_BASIC_STATS | STATX_BTIME.
                               It is deprecated and should not be used.
           STATX_MNT_ID        Want stx_mnt_id (since Linux 5.8)
           STATX_DIOALIGN      Want stx_dio_mem_align and stx_dio_offset_align
                               (since Linux 6.1; support varies by filesystem)

       Заметим в общем, что ядро не не отклоняет значения в mask, отличные  от  вышеперечисленных
       (исключение  из  правила  смотрите  в  описании  ошибки  EINVAL).  Вместо этого оно просто
       информирует вызывающего, какие значения поддерживаются ядром  и  файловой  системой  через
       поле  statx.stx_mask.  Поэтому  не устанавливайте значение mask в UINT_MAX (все биты), так
       как один или более бит в будущем могут использоваться для указания расширения буфера.

   Возвращаемая информация
       Информация о состоянии целевого файла возвращается в структуре statx, на которую указывает
       statxbuf.  Она  содержит stx_mask, в котором описывается возвращённая информация. Значение
       stx_mask имеет тот же формат, что и аргумент mask, и установленные в  нём  бит  показывают
       какие поля были заполнены.

       Стоит  упомянуть, что ядро может вернуть поля, которые не был запрошены и запрошенные поля
       могут быть не заполнены, в зависимости от поддержки в нижележащей файловой системе  (поля,
       которым были присвоены значение, но которые не были запрошены, можно игнорировать). В этих
       случаях stx_mask будет не равно mask.

       Если  файловая  система  не  поддерживает   поле   или   если   значение   поле   содержит
       непрезентабельное  значение  (например,  файл  экзотического  типа),  то  битовая  маска в
       stx_mask, соответствующая этому полю, будет очищена даже если пользователь запросил его, и
       в  целях  совместимости  в  качестве  значения,  если  возможно,  будет  помещена пустышка
       (например, в некоторых случаях пустышки UID и GID могут задаваться при монтировании).

       Файловая система также  может  заполнить  поля,  которые  вызывающий  не  запрашивал,  при
       условии,  что  их  значения  доступны  и  это ничего стоит. Если это выполняется, то будут
       установлены соответствующие биты в stx_mask.

       Замечание: с целью производительности и простоты различные поля в  структуре  statx  могут
       содержать  информацию  о  состоянии  из  различных  моментов выполнения системного вызова.
       Например, если  изменяется  stx_mode  или  stx_uid  другим  процессом  посредством  вызова
       chmod(2)  или  chown(2),  то  stat() может вернуть старое значение stx_mode вместе с новым
       stx_uid, или старое stx_uid вместе с новым stx_mode.

       Помимо полей stx_mask (описанной выше) структура statx имеет следующие поля:

       stx_blksize
              «Предпочтительный» размер блока для эффективного ввода/вывода  в  файловой  системе
              (запись   в   файл   более   мелкими   порциями  может  привести  к  неэффективному
              чтению/изменению/повторной записи).

       stx_attributes
              Дополнительная информация о состоянии файла (подробности ниже).

       stx_nlink
              Количество жёстких ссылок на файл.

       stx_uid
              Пользовательский идентификатор владельца файла.

       stx_gid
              Групповой идентификатор владельца файла.

       stx_mode
              Тип файла и режим. Дополнительную информацию смотрите в inode(7).

       stx_ino
              Номер иноды файла.

       stx_size
              Размер файла (если он обычный или является символьной  ссылкой)  в  байтах.  Размер
              символьной  ссылки  равен длине пути файла, на который она ссылается, без конечного
              нулевого байта.

       stx_blocks
              Количество блоков (по 512 байт), выделенных  для  файла  на  носителе  (может  быть
              меньше, чем stx_size/512, когда в файле есть пропуски (holes)).

       stx_attributes_mask
              Маска,  показывающая  какие  биты  в  stx_attributes  поддерживаются VFS и файловой
              системой.

       stx_atime
              Метка времени последнего доступа к файлу.

       stx_btime
              Метка времени создания файла.

       stx_ctime
              Метка времени последнего изменения состояния файла.

       stx_mtime
              Метка времени последнего изменения файла.

       stx_dev_major и stx_dev_minor
              Устройство, на котором находится файл (инода).

       stx_rdev_major и stx_rdev_minor
              Устройство, который этот файл (инода) представляет, если  файл  имеет  блочный  или
              символьный тип устройства.

       stx_mnt_id
              The mount ID of the mount containing the file.  This is the same number reported by
              name_to_handle_at(2)  and corresponds to the number in the first field  in  one  of
              the records in /proc/self/mountinfo.

       stx_dio_mem_align
              The alignment (in bytes) required for user memory buffers for direct I/O (O_DIRECT)
              on this file, or 0 if direct I/O is not supported on this file.

              STATX_DIOALIGN (stx_dio_mem_align and stx_dio_offset_align)  is supported on  block
              devices  since Linux 6.1.  The support on regular files varies by filesystem; it is
              supported by ext4, f2fs, and xfs since Linux 6.1.

       stx_dio_offset_align
              The alignment (in bytes) required for file offsets  and  I/O  segment  lengths  for
              direct  I/O  (O_DIRECT)   on this file, or 0 if direct I/O is not supported on this
              file.  This will only be nonzero if stx_dio_mem_align is nonzero, and vice versa.

       Дополнительную информацию об этих полях смотрите в inode(7).

   Атрибуты файла
       В поле stx_attributes содержится набор флагов (объединённых через ИЛИ), которые отображают
       дополнительные   атрибуты   файла.   Заметим,   что   для   атрибута,  не  указанного  как
       поддерживаемого в stx_attributes_mask, имеющееся здесь значение  является  не  корректным.
       Биты stx_attributes_mask точно бит в бит соответствуют битам поля stx_attributes.

       Флаги:

       STATX_ATTR_COMPRESSED
              Файл  сжат  файловой  системой  и  для  доступа  могут потребоваться дополнительные
              ресурсы.

       STATX_ATTR_IMMUTABLE
              Файл невозможно изменить: его нельзя переименовать или удалить, на этот файл нельзя
              создать жёсткую ссылку и в него нельзя выполнить запись данных. Смотрите chattr(1).

       STATX_ATTR_APPEND
              Файл может быть открыт только для записи в режиме добавления. Запись в произвольное
              место не разрешается. Смотрите chattr(1).

       STATX_ATTR_NODUMP
              Файл не предназначен для резервного копирования программой резервного  копирования,
              например dump(8). Смотрите chattr(1).

       STATX_ATTR_ENCRYPTED
              Для расшифровки файла файловой системой требуется ключ.

       STATX_ATTR_VERITY (начиная с Linux 5.5)
              The  file  has  fs-verity  enabled.  It cannot be written to, and all reads from it
              will be verified against a cryptographic hash that covers the  entire  file  (e.g.,
              via a Merkle tree).

       STATX_ATTR_DAX (начиная с Linux 5.8)
              The  file  is in the DAX (cpu direct access) state.  DAX state attempts to minimize
              software cache effects for both I/O and memory mappings of this file.  It  requires
              a file system which has been configured to support DAX.

              DAX  generally assumes all accesses are via CPU load / store instructions which can
              minimize overhead for small accesses, but may adversely affect CPU utilization  for
              large transfers.

              File  I/O  is done directly to/from user-space buffers and memory mapped I/O may be
              performed with direct memory mappings that bypass the kernel page cache.

              While the DAX property tends to result in data being transferred synchronously,  it
              does  not give the same guarantees as the O_SYNC flag (see open(2)), where data and
              the necessary metadata are transferred together.

              A DAX file may support being mapped with the MAP_SYNC flag, which enables a program
              to  use  CPU  cache  flush  instructions to persist CPU store operations without an
              explicit fsync(2).  See mmap(2)  for more information.

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

       On success, zero is returned.  On error, -1 is returned, and errno is set to indicate  the
       error.

ОШИБКИ

       EACCES Запрещён   поиск   в   одном   из   каталогов   пути   pathname   (смотрите   также
              path_resolution(7)).

       EBADF  В pathname содержится относительный путь, но значение dirfd не равно AT_FDCWD и  не
              является правильным файловым дескриптором.

       EFAULT Значение  pathname  или  statxbuf  равно  NULL  или  указывает  на расположение вне
              доступного процессу адресного пространства.

       EINVAL Указано неверное значение в flags.

       EINVAL В mask указан зарезервированный флаг (в настоящее время есть только один флаг,  для
              него определена константа STATX__RESERVED со значением 0x80000000U).

       ELOOP  Во время определения пути встретилось слишком много символьных ссылок.

       ENAMETOOLONG
              Слишком длинное значение аргумента pathname.

       ENOENT Компонент  пути  pathname  не  существует  или в pathname указана пустая строка и в
              flags не указан AT_EMPTY_PATH.

       ENOMEM Не хватает памяти (например, памяти ядра).

       ENOTDIR
              Компонент префикса пути pathname  содержит  относительный  путь  и  dirfd  содержит
              файловый дескриптор, указывающий на файл, а не на каталог.

ВЕРСИИ

       statx()  was added in Linux 4.11; library support was added in glibc 2.28.

СТАНДАРТЫ

       Вызов statx() есть только в Linux.

СМ. ТАКЖЕ

       ls(1), stat(1), access(2), chmod(2), chown(2), name_to_handle_at(2), readlink(2), stat(2),
       utime(2), proc(5), capabilities(7), inode(7), symlink(7)

ПЕРЕВОД

       Русский   перевод   этой   страницы   руководства    был    сделан    Alexander    Golubev
       <fatzer2@gmail.com>,   Azamat   Hackimov  <azamat.hackimov@gmail.com>,  Hotellook,  Nikita
       <zxcvbnm3230@mail.ru>,       Spiros       Georgaras       <sng@hellug.gr>,       Vladislav
       <ivladislavefimov@gmail.com>,    Yuri    Kozlov   <yuray@komyakino.ru>   и   Иван   Павлов
       <pavia00@gmail.com>

       Этот  перевод  является  бесплатной  документацией;  прочитайте  Стандартную  общественную
       лицензию GNU версии 3 ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩ или более позднюю, чтобы
       узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.

       Если вы обнаружите ошибки в переводе  этой  страницы  руководства,  пожалуйста,  отправьте
       электронное письмо на ⟨man-pages-ru-talks@lists.sourceforge.net⟩.