grantpt

GRANTPT(3)                 Linux Programmer's Manual                GRANTPT(3)

NAME
       grantpt - grant access to the slave pseudoterminal

SYNOPSIS
       #include <stdlib.h>

       int grantpt(int fd);

   Feature Test Macro Requirements for glibc (see feature_test_macros(7)):

       grantpt():
           Since glibc 2.24:
               _XOPEN_SOURCE >= 500 ||
                   (_XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED)
           Glibc 2.23 and earlier:
               _XOPEN_SOURCE

DESCRIPTION
       The  grantpt()  function  changes the mode and owner of the slave pseu-
       doterminal device corresponding to the master  pseudoterminal  referred
       to by fd.  The user ID of the slave is set to the real UID of the call-
       ing process.  The group ID is set to an unspecified value (e.g.,  tty).
       The mode of the slave is set to 0620 (crw--w----).

       The  behavior  of  grantpt()  is unspecified if a signal handler is in-
       stalled to catch SIGCHLD signals.

RETURN VALUE
       When successful, grantpt() returns 0.  Otherwise,  it  returns  -1  and
       sets errno appropriately.

ERRORS
       EACCES The corresponding slave pseudoterminal could not be accessed.

       EBADF  The fd argument is not a valid open file descriptor.

       EINVAL The  fd argument is valid but not associated with a master pseu-
              doterminal.

VERSIONS
       grantpt() is provided in glibc since version 2.1.

ATTRIBUTES
       For an  explanation  of  the  terms  used  in  this  section,  see  at-
       tributes(7).

       +----------+---------------+----------------+
       |Interface | Attribute     | Value          |
       +----------+---------------+----------------+
       |grantpt() | Thread safety | MT-Safe locale |
       +----------+---------------+----------------+

CONFORMING TO
       POSIX.1-2001, POSIX.1-2008.

NOTES
       This is part of the UNIX 98 pseudoterminal support, see pts(4).

       Many  systems  implement  this function via a set-user-ID helper binary
       called "pt_chown".  On Linux systems with a devpts filesystem  (present
       since  Linux  2.2),  the kernel normally sets the correct ownership and
       permissions for the pseudoterminal slave  when  the  master  is  opened
       (posix_openpt(3)), so that nothing must be done by grantpt().  Thus, no
       such helper binary is required (and indeed it is configured to  be  ab-
       sent during the glibc build that is typical on many systems).

SEE ALSO
       open(2), posix_openpt(3), ptsname(3), unlockpt(3), pts(4), pty(7)

COLOPHON
       This  page  is  part of release 5.05 of the Linux man-pages project.  A
       description of the project, information about reporting bugs,  and  the
       latest     version     of     this    page,    can    be    found    at
       https://www.kernel.org/doc/man-pages/.

GNU                               2017-09-15                        GRANTPT(3)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025 Hurricane Electric. All Rights Reserved.