Optimize pt_chown.
authorUlrich Drepper <drepper@redhat.com>
Tue, 16 Jun 2009 05:58:21 +0000 (22:58 -0700)
committerUlrich Drepper <drepper@redhat.com>
Tue, 16 Jun 2009 05:58:21 +0000 (22:58 -0700)
Don't call chown and chmod if not necessary.

ChangeLog
login/programs/pt_chown.c

index 812fbdf..00b651f 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2009-06-15  Ulrich Drepper  <drepper@redhat.com>
 
+       * sysdeps/unix/sysv/linux/grantpt.c (grantpt): Only call chown and
+       chmod if it is necessary.
+
        [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
index 485edda..5167b29 100644 (file)
@@ -1,5 +1,5 @@
 /* pt_chmod - helper program for `grantpt'.
-   Copyright (C) 1998, 1999 Free Software Foundation, Inc.
+   Copyright (C) 1998, 1999, 2009 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by C. Scott Ananian <cananian@alumni.princeton.edu>, 1998.
 
@@ -119,12 +119,13 @@ do_pt_chown (void)
 
   /* Set the owner to the real user ID, and the group to that special
      group ID.  */
-  if (chown (pty, getuid (), gid) < 0)
+  if (st.st_gid != gid && chown (pty, getuid (), gid) < 0)
     return FAIL_EACCES;
 
   /* Set the permission mode to readable and writable by the owner,
      and writable by the group.  */
-  if (chmod (pty, S_IRUSR|S_IWUSR|S_IWGRP) < 0)
+  if ((st.st_mode & ACCESSPERMS) != (S_IRUSR|S_IWUSR|S_IWGRP)
+      && chmod (pty, S_IRUSR|S_IWUSR|S_IWGRP) < 0)
     return FAIL_EACCES;
 
   return 0;