1996-12-29 18:30:42 +00:00
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1996 Joerg Wunsch
|
|
|
|
.\"
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\" "
|
2018-06-02 22:40:16 +00:00
|
|
|
.Dd June 2, 2018
|
1996-12-29 18:30:42 +00:00
|
|
|
.Dt PTY 3
|
2010-04-14 19:08:06 +00:00
|
|
|
.Os
|
1996-12-29 18:30:42 +00:00
|
|
|
.Sh NAME
|
1996-12-30 21:08:45 +00:00
|
|
|
.Nm openpty ,
|
|
|
|
.Nm forkpty
|
1996-12-29 18:30:42 +00:00
|
|
|
.Nd auxiliary functions to obtain a pseudo-terminal
|
2000-04-22 16:17:00 +00:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libutil
|
1996-12-29 18:30:42 +00:00
|
|
|
.Sh SYNOPSIS
|
2001-10-01 16:09:29 +00:00
|
|
|
.In sys/types.h
|
|
|
|
.In sys/ioctl.h
|
|
|
|
.In termios.h
|
|
|
|
.In libutil.h
|
1996-12-29 18:30:42 +00:00
|
|
|
.Ft int
|
|
|
|
.Fn openpty "int *amaster" "int *aslave" "char *name" "struct termios *termp" "struct winsize *winp"
|
|
|
|
.Ft int
|
|
|
|
.Fn forkpty "int *amaster" "char *name" "struct termios *termp" "struct winsize *winp"
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The function
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn openpty
|
1996-12-29 18:30:42 +00:00
|
|
|
attempts to obtain the next available pseudo-terminal from the system (see
|
|
|
|
.Xr pty 4 ) .
|
2008-01-14 23:49:56 +00:00
|
|
|
If it successfully finds one, it subsequently changes the
|
1996-12-29 18:30:42 +00:00
|
|
|
ownership of the slave device to the real UID of the current process,
|
|
|
|
the group membership to the group
|
|
|
|
.Dq tty
|
|
|
|
(if such a group exists in the system), the access permissions for
|
2008-01-14 23:49:56 +00:00
|
|
|
reading and writing by the owner, and for writing by the group, and
|
|
|
|
invalidates any current use of the line by calling
|
1996-12-29 18:30:42 +00:00
|
|
|
.Xr revoke 2 .
|
|
|
|
.Pp
|
|
|
|
If the argument
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa name
|
1996-12-29 18:30:42 +00:00
|
|
|
is not
|
|
|
|
.Dv NULL ,
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn openpty
|
2004-07-02 23:52:20 +00:00
|
|
|
copies the pathname of the slave pty to this area.
|
|
|
|
The caller is
|
1997-01-01 03:29:33 +00:00
|
|
|
responsible for allocating the required space in this array.
|
1996-12-29 18:30:42 +00:00
|
|
|
.Pp
|
|
|
|
If the arguments
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa termp
|
1996-12-29 18:30:42 +00:00
|
|
|
or
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa winp
|
1996-12-29 18:30:42 +00:00
|
|
|
are not
|
|
|
|
.Dv NULL ,
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn openpty
|
1996-12-29 18:30:42 +00:00
|
|
|
initializes the termios and window size settings from the structures
|
1997-01-01 03:29:33 +00:00
|
|
|
these arguments point to, respectively.
|
1996-12-29 18:30:42 +00:00
|
|
|
.Pp
|
1996-12-30 21:08:45 +00:00
|
|
|
Upon return, the open file descriptors for the master and slave side
|
1996-12-29 18:30:42 +00:00
|
|
|
of the pty are returned in the locations pointed to by
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa amaster
|
1996-12-29 18:30:42 +00:00
|
|
|
and
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa aslave ,
|
1996-12-29 18:30:42 +00:00
|
|
|
respectively.
|
|
|
|
.Pp
|
2003-03-24 16:02:05 +00:00
|
|
|
The
|
|
|
|
.Fn forkpty
|
|
|
|
function first calls
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn openpty
|
2004-07-02 23:52:20 +00:00
|
|
|
to obtain the next available pseudo-terminal from the system.
|
|
|
|
Upon success,
|
|
|
|
it forks off a new process.
|
|
|
|
In the child process, it closes the descriptor
|
1996-12-29 18:30:42 +00:00
|
|
|
for the master side of the pty, and calls
|
|
|
|
.Xr login_tty 3
|
2004-07-02 23:52:20 +00:00
|
|
|
for the slave pty.
|
|
|
|
In the parent process, it closes the descriptor for the
|
|
|
|
slave side of the pty.
|
|
|
|
The arguments
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa amaster ,
|
|
|
|
.Fa name ,
|
|
|
|
.Fa termp ,
|
1996-12-29 18:30:42 +00:00
|
|
|
and
|
1997-01-09 07:12:09 +00:00
|
|
|
.Fa winp
|
1996-12-29 18:30:42 +00:00
|
|
|
have the same meaning as described for
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn openpty .
|
1996-12-29 18:30:42 +00:00
|
|
|
.Sh RETURN VALUES
|
2003-03-24 16:02:05 +00:00
|
|
|
The
|
|
|
|
.Fn openpty
|
|
|
|
function returns 0 on success, or -1 on failure.
|
1996-12-29 18:30:42 +00:00
|
|
|
.Pp
|
2003-03-24 16:02:05 +00:00
|
|
|
The
|
|
|
|
.Fn forkpty
|
|
|
|
function returns -1 on failure, 0 in the slave process, and the process ID of
|
|
|
|
the slave process in the parent process.
|
1996-12-29 18:30:42 +00:00
|
|
|
.Sh ERRORS
|
2008-01-14 23:49:56 +00:00
|
|
|
The
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn openpty
|
2008-01-14 23:49:56 +00:00
|
|
|
function may fail and set the global variable
|
1996-12-29 18:30:42 +00:00
|
|
|
.Dv errno
|
2008-01-14 23:49:56 +00:00
|
|
|
for any of the errors specified for the
|
|
|
|
.Xr grantpt 3 ,
|
2015-11-06 12:02:24 +00:00
|
|
|
.Xr posix_openpt 2 ,
|
2008-01-14 23:49:56 +00:00
|
|
|
.Xr ptsname 3 ,
|
|
|
|
and
|
|
|
|
.Xr unlockpt 3
|
|
|
|
functions and the
|
|
|
|
.Xr revoke 2
|
|
|
|
system call.
|
1996-12-29 18:30:42 +00:00
|
|
|
.Pp
|
|
|
|
In addition to this,
|
1996-12-30 21:08:45 +00:00
|
|
|
.Fn forkpty
|
1996-12-29 18:30:42 +00:00
|
|
|
may set it to any value as described for
|
|
|
|
.Xr fork 2 .
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr chmod 2 ,
|
|
|
|
.Xr chown 2 ,
|
|
|
|
.Xr fork 2 ,
|
|
|
|
.Xr getuid 2 ,
|
|
|
|
.Xr open 2 ,
|
|
|
|
.Xr revoke 2 ,
|
|
|
|
.Xr login_tty 3 ,
|
|
|
|
.Xr pty 4 ,
|
1999-08-14 07:52:29 +00:00
|
|
|
.Xr termios 4 ,
|
1996-12-29 18:30:42 +00:00
|
|
|
.Xr group 5
|
2018-06-02 22:40:16 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Fn openpty
|
|
|
|
and
|
|
|
|
.Fn forkpty
|
|
|
|
functions first appeared in
|
2022-08-07 14:30:24 +00:00
|
|
|
.Bx 4.3 Reno .
|
2018-06-02 22:40:16 +00:00
|
|
|
.Sh BUGS
|
|
|
|
.Fn openpty
|
|
|
|
writes the slave terminal's name to
|
|
|
|
.Fa name ,
|
|
|
|
but does not check that sufficient space is available.
|
|
|
|
It is advisable to use
|
|
|
|
.Xr ptsname 3
|
|
|
|
instead.
|