Linux repositories inspector

mkfifoat(3) - Russkiy

Linux
2009-12-13

man-pages-ru

Russian man pages from the Linux Documentation Project

man-pages

Linux kernel and C library user-space interface documentation

ИМЯ

mkfifoat - создание FIFO (именованного канала) относительно файлового дескриптора каталога

ОБЗОР

#include <fcntl.h> /* определения констант AT_* */
#include <sys/stat.h>

int mkfifoat(int dirfd, const char *pathname, mode_t mode);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
mkfifoat():
Начиная с glibc 2.10:
_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
До glibc 2.10:
_ATFILE_SOURCE

ОПИСАНИЕ

Системный вызов mkfifoat() работает также как mkfifo(3), за исключением описанных, описанных в данной справочной странице.
Если в pathname задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор dirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в mkfifo(3)).
Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как mkfifo(3)).
Если в pathname задан абсолютный путь, то dirfd игнорируется.

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

При успешном выполнении mkfifoat() возвращается 0. При ошибке возвращается -1, а в errno содержится код ошибки.

ОШИБКИ

В fifoat() могут возникнуть те же ошибки, что и в mkfifo(3). Также, в mkfifoat() могут возникнуть следующие ошибки:
EBADF dirfd не является правильным файловым дескриптором.
ENOTDIR
pathname является относительным путем, а dirfd является файловым дескриптором, указывающим на файл, отличный от каталога.

ВЕРСИИ

mkfifoat() была добавлена в glibc 2.4. Она реализована с помощью mknod(2), которая доступна в ядре Linux начиная с 2.6.16.

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2008.

ЗАМЕЧАНИЯ

Смотрите в openat(2) объяснение необходимости mkfifoat().

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

REFERENCED BY

⇧ Top