diff options
author | Ulrich Drepper <drepper@redhat.com> | 2009-06-15 22:56:51 -0700 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2009-06-15 22:56:51 -0700 |
commit | 292e3abebff9f94ca47c1a725a691cb6ed6cff5f (patch) | |
tree | c6ad0a749bdd53d1d021e8b5739a0d6580014bc0 | |
parent | 395a37e379bf900b2b6a25e17c44cde2d1c46c44 (diff) | |
download | glibc-292e3abebff9f94ca47c1a725a691cb6ed6cff5f.zip glibc-292e3abebff9f94ca47c1a725a691cb6ed6cff5f.tar.gz glibc-292e3abebff9f94ca47c1a725a691cb6ed6cff5f.tar.bz2 |
Fix permission of slave device on devpts if necessary.
If devptr is misconfigured the slave device permission after grantpt
might not be 0620. BZ #10166
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/grantpt.c | 13 |
2 files changed, 15 insertions, 3 deletions
@@ -1,5 +1,10 @@ 2009-06-15 Ulrich Drepper <drepper@redhat.com> + [BZ #10166] + * sysdeps/unix/sysv/linux/grantpt.c: If slave device is on devpts or + devfs, the mode might not be correct. Check it and return only if it + is correct. + [BZ #10183] * posix/tst-cpucount.c: Don't try more than CPU_SETSIZE bits. diff --git a/sysdeps/unix/sysv/linux/grantpt.c b/sysdeps/unix/sysv/linux/grantpt.c index b894b8b..c858f89 100644 --- a/sysdeps/unix/sysv/linux/grantpt.c +++ b/sysdeps/unix/sysv/linux/grantpt.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1998, 1999, 2001, 2002 Free Software Foundation, Inc. +/* Copyright (C) 1998, 1999, 2001, 2002, 2009 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -70,9 +70,16 @@ grantpt (int fd) return -1; /* If the slave pseudo terminal lives on a `devpts' filesystem, the - ownership and access permission are already set. */ + ownership is already set and the access permission might already + be set. */ if (fsbuf.f_type == DEVPTS_SUPER_MAGIC || fsbuf.f_type == DEVFS_SUPER_MAGIC) - return 0; + { + struct stat64 st; + + if (fstat (fd, &st) == 0 + && (st.st_mode & ACCESSPERMS) == (S_IRUSR|S_IWUSR|S_IWGRP)) + return 0; + } return __unix_grantpt (fd); } |