Include <memcopy.h> and use reg_char for character to search, to help the compiler.
[kopensolaris-gnu/glibc.git] / shadow / lckpwdf.c
index 707c009..861e0e0 100644 (file)
@@ -1,25 +1,25 @@
-/* lckpwdf - handle locking of password file.
-Copyright (C) 1996 Free Software Foundation, Inc.
-This file is part of the GNU C Library.
-Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
-
-The GNU C Library is free software; you can redistribute it and/or
-modify it under the terms of the GNU Library General Public License as
-published by the Free Software Foundation; either version 2 of the
-License, or (at your option) any later version.
-
-The GNU C Library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-Library General Public License for more details.
-
-You should have received a copy of the GNU Library General Public
-License along with the GNU C Library; see the file COPYING.LIB.  If
-not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-Boston, MA 02111-1307, USA.  */
+/* Handle locking of password file.
+   Copyright (C) 1996, 1998 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+   Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
 
 #include <fcntl.h>
-#include <libc-lock.h>
+#include <bits/libc-lock.h>
 #include <shadow.h>
 #include <signal.h>
 #include <string.h>
@@ -28,7 +28,7 @@ Boston, MA 02111-1307, USA.  */
 
 
 /* Name of the lock file.  */
-#define PWD_LOCKFILE "/etc/lock.pwd"
+#define PWD_LOCKFILE "/etc/.pwd.lock"
 
 /* How long to wait for getting the lock before returning with an
    error.  */
@@ -52,7 +52,7 @@ static void noop_handler __P ((int __sig));
   do {                                                                       \
     if ((code) < 0 && lock_fd >= 0)                                          \
       {                                                                              \
-       close (lock_fd);                                                      \
+       __close (lock_fd);                                                    \
        lock_fd = -1;                                                         \
       }                                                                              \
     __libc_lock_unlock (lock);                                               \
@@ -63,7 +63,7 @@ static void noop_handler __P ((int __sig));
   do {                                                                       \
     /* Restore old action handler for alarm.  We don't need to know          \
        about the current one.  */                                            \
-    sigaction (SIGALRM, &saved_act, NULL);                                   \
+    __sigaction (SIGALRM, &saved_act, NULL);                                 \
     RETURN_CLOSE_FD (code);                                                  \
   } while (0)
 
@@ -73,7 +73,7 @@ static void noop_handler __P ((int __sig));
     alarm (0);                                                               \
     /* Restore old set of handled signals.  We don't need to know            \
        about the current one.*/                                                      \
-    sigprocmask (SIG_SETMASK, &saved_set, NULL);                             \
+    __sigprocmask (SIG_SETMASK, &saved_set, NULL);                           \
     RETURN_RESTORE_HANDLER (code);                                           \
   } while (0)
 
@@ -86,6 +86,7 @@ __lckpwdf ()
   struct sigaction saved_act;          /* Saved signal action.  */
   sigset_t new_set;                    /* New set of caught signals.  */
   struct sigaction new_act;            /* New signal action.  */
+  struct flock fl;                     /* Information struct for locking.  */
   int result;
 
   if (lock_fd != -1)
@@ -95,18 +96,18 @@ __lckpwdf ()
   /* Prevent problems caused by multiple threads.  */
   __libc_lock_lock (lock);
 
-  lock_fd = open (PWD_LOCKFILE, O_WRONLY | O_CREAT, 0600);
+  lock_fd = __open (PWD_LOCKFILE, O_WRONLY | O_CREAT, 0600);
   if (lock_fd == -1)
     /* Cannot create lock file.  */
     RETURN_CLOSE_FD (-1);
 
   /* Make sure file gets correctly closed when process finished.  */
-  flags = fcntl (lock_fd, F_GETFD, 0);
+  flags = __fcntl (lock_fd, F_GETFD, 0);
   if (flags == -1)
     /* Cannot get file flags.  */
     RETURN_CLOSE_FD (-1);
   flags |= FD_CLOEXEC;         /* Close on exit.  */
-  if (fcntl (lock_fd, F_SETFD, flags) < 0)
+  if (__fcntl (lock_fd, F_SETFD, flags) < 0)
     /* Cannot set new flags.  */
     RETURN_CLOSE_FD (-1);
 
@@ -124,14 +125,14 @@ __lckpwdf ()
   new_act.sa_flags = 0ul;
 
   /* Install new action handler for alarm and save old.  */
-  if (sigaction (SIGALRM, &new_act, &saved_act) < 0)
+  if (__sigaction (SIGALRM, &new_act, &saved_act) < 0)
     /* Cannot install signal handler.  */
     RETURN_CLOSE_FD (-1);
 
   /* Now make sure the alarm signal is not blocked.  */
   sigemptyset (&new_set);
   sigaddset (&new_set, SIGALRM);
-  if (sigprocmask (SIG_UNBLOCK, &new_set, &saved_set) < 0)
+  if (__sigprocmask (SIG_UNBLOCK, &new_set, &saved_set) < 0)
     RETURN_RESTORE_HANDLER (-1);
 
   /* Start timer.  If we cannot get the lock in the specified time we
@@ -139,7 +140,10 @@ __lckpwdf ()
   alarm (TIMEOUT);
 
   /* Try to get the lock.  */
-  result = flock (lock_fd, LOCK_EX);
+  memset (&fl, '\0', sizeof (struct flock));
+  fl.l_type = F_WRLCK;
+  fl.l_whence = SEEK_SET;
+  result = __fcntl (lock_fd, F_SETLKW, &fl);
 
   RETURN_CLEAR_ALARM (result);
 }
@@ -159,7 +163,7 @@ __ulckpwdf ()
       /* Prevent problems caused by multiple threads.  */
       __libc_lock_lock (lock);
 
-      result = close (lock_fd);
+      result = __close (lock_fd);
 
       /* Mark descriptor as unused.  */
       lock_fd = -1;
@@ -177,5 +181,5 @@ static void
 noop_handler (sig)
      int sig;
 {
-  /* We simply return which makes the `flock' call return with an error.  */
+  /* We simply return which makes the `fcntl' call return with an error.  */
 }