Scroll to navigation

MKNODAT(2) Руководство программиста Linux MKNODAT(2)

ИМЯ

mknodat - создаёт специальный или обычный файл, определяемого относительно файлового дескриптора каталога

ОБЗОР

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

int mknodat(int dirfd, const char *pathname, mode_t mode, dev_t dev);


Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

mknodat():

Начиная с glibc 2.10:

_XOPEN_SOURCE >= 700
До glibc 2.10:
_ATFILE_SOURCE

ОПИСАНИЕ

Системный вызов mknodat() работает также как системный вызов mknod(2), за исключением случаев, описанных в данной справочной странице.

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

Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как mknod(2)).

Если в pathname задан абсолютный путь, то dirfd игнорируется.

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

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

ОШИБКИ

В mknodat() могут возникнуть те же ошибки, что и в mknod(2). Также, в mknodat() могут возникнуть следующие ошибки:

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

ВЕРСИИ

Вызов mknodat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.

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

POSIX.1-2008.

ЗАМЕЧАНИЯ

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

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

mknod(2), openat(2), path_resolution(7)

2012-05-04 Linux