table of contents
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() могут возникнуть следующие ошибки:
ВЕРСИИ¶
Вызов mknodat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.
СООТВЕТСТВИЕ СТАНДАРТАМ¶
POSIX.1-2008.
ЗАМЕЧАНИЯ¶
Смотрите в openat(2) объяснение необходимости mknodat().
СМОТРИТЕ ТАКЖЕ¶
2012-05-04 | Linux |