mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-29 11:41:21 +03:00
Update.
1998-09-17 19:34 Ulrich Drepper <drepper@cygnus.com> * sysdeps/unix/sysv/sysv4/bits/utsname.h: Fix typo. Patch by John Tobey <jtobey@banta-im.com>. 1998-09-17 Mark Kettenis <kettenis@phys.uva.nl> * login/pty-internal.h: Removed. Moved constants related to the `grantpt' helper program protocol to ... * login/pty-private.h: ... here. New file. * sysdeps/unix/sysv/linux/ptsname.c (ptsname): Reimplementation to make the function work with kernels >= 2.1.115. * sysdeps/unix/sysv/linux/getpt.c (getpt): Reimplement to call BSD version if using the cloning device fails. * sysdeps/unix/sysv/linux/grantpt.c: New file. * sysdeps/unix/sysv/linux/unlockpt.c: General cleanup. * sysdeps/unix/bsd/getpt.c (__getpt): Largely rewritten to allow use by Linux specific code. * sysdeps/unix/bsd/unlockpt.c: General cleanup. * sysdeps/unix/grantpt.c: Largely rewritten. (pts_name): New function. (grantpt): Use pts_name, check group and permission mode in addition to owner. Try to set the owner, group and permission mode first without invoking the helper program. * login/programs/pt_chown.c: Largely rewritten. Add argp and internationalization support. Use symbolic constants instead of hardwired numbers for permission mode. * sysdeps/unix/bsd/ptsname.c: New file. 1998-09-17 22:04 Tim Waugh <tim@cyberelk.demon.co.uk> * posix/wordexp-test.c: Undo last change. * posix/wordexp.c: Undo last change.
This commit is contained in:
@ -17,25 +17,21 @@
|
||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
Boston, MA 02111-1307, USA. */
|
||||
|
||||
#include <paths.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "pty-internal.h"
|
||||
|
||||
/* Given a fd on a master pseudoterminal, clear a kernel lock so that
|
||||
the slave can be opened. This is to avoid a race between opening the
|
||||
master and calling grantpt() to take possession of the slave.
|
||||
|
||||
BSD doesn't have this lock, but what it does have is revoke(). */
|
||||
|
||||
/* Unlock the slave pseudo terminal associated with the master pseudo
|
||||
terminal specified by FD. */
|
||||
int
|
||||
unlockpt (fd)
|
||||
int fd;
|
||||
unlockpt (int fd)
|
||||
{
|
||||
char buf[PTYNAMELEN];
|
||||
char buf[sizeof (_PATH_TTY) + 2];
|
||||
|
||||
if (__ptsname_r (fd, buf, PTYNAMELEN))
|
||||
/* BSD doesn't have a lock, but it does have `revoke'. */
|
||||
if (__ptsname_r (fd, buf, sizeof (buf)))
|
||||
return -1;
|
||||
|
||||
return revoke (buf);
|
||||
}
|
||||
|
Reference in New Issue
Block a user