GRANTPT(3) | Руководство программиста Linux | GRANTPT(3) |
grantpt - разрешает доступ для подчинённому псевдотерминалу
#include <stdlib.h>
int grantpt(int fd);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
grantpt():
Функция grantpt() изменяет режим и владельца для устройства подчинённого псевдотерминала, соответствующего основному псевдотерминалу, на который ссылается fd. Идентификатор пользователя подчинённого устанавливается в действительный UID вызывающего процесса. Идентификатор группы устанавливается в неопределенное значение (например, tty). Права доступа к подчинённому псевдотерминала назначаются как 0620 (crw--w----).
Поведение grantpt() не определено, если установлен обработчик сигналов для перехвата сигналов SIGCHLD.
При успешном выполнении grantpt() возвращает 0. Иначе возвращается -1 и переменная errno устанавливается соответствующим образом.
Функция grantpt() появилась в glibc начиная с версии 2.1.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
grantpt() | Безвредность в нитях | MT-Safe locale |
POSIX.1-2001, POSIX.1-2008.
Является частью поддержки псевдотерминалов UNIX 98 (смотрите pts(4)).
Многие системы реализуют эту функцию через вспомогательный исполняемый файл с установленным битом SUID, называемый «pt_chown». Благодаря файловой системе Linux devpts (начиная с Linux 2.2), ядро обычным образом устанавливает корректные значения владельца и права на подчинённый псевдотерминал когда открывается основной (posix_openpt(3)), поэтому grantpt() делать ничего не нужно. Таким образом, подобный вспомогательный файл не требуется (и действительно, это значение пусто при сборке glibc, которая используется во многих системах).
open(2), posix_openpt(3), ptsname(3), unlockpt(3), pts(4), pty(7)
2017-09-15 | GNU |