4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 /* Copyright (c) 1988 AT&T */
28 /* All Rights Reserved */
30 #pragma ident "%Z%%M% %I% %E% SMI"
33 #include <sys/types.h>
43 #define LOCKFILE "/etc/.pwd.lock"
46 static struct flock flock
= {
56 * lckpwdf() returns a 0 for a successful lock within W_WAITTIME
57 * seconds and -1 otherwise. We stand on our head to make it MT-safe.
60 static pid_t lck_pid
= 0; /* process's pid at last lock */
61 static thread_t lck_tid
= 0; /* thread that holds the lock */
62 static int fildes
= -1;
63 static mutex_t lck_lock
= DEFAULTMUTEX
;
70 lmutex_lock(&lck_lock
);
72 if (lck_pid
!= 0 && lck_pid
!= getpid()) {
78 if ((fildes
= creat(LOCKFILE
, 0600)) == -1)
80 flock
.l_type
= F_WRLCK
;
81 if (fcntl(fildes
, F_SETLK
, &flock
) != -1) {
84 lmutex_unlock(&lck_lock
);
90 if (seconds
++ >= S_WAITTIME
) {
92 * For compatibility with the past, pretend
93 * that we were interrupted by SIGALRM.
98 lmutex_unlock(&lck_lock
);
100 lmutex_lock(&lck_lock
);
102 lmutex_unlock(&lck_lock
);
107 * ulckpwdf() returns 0 for a successful unlock and -1 otherwise
112 lmutex_lock(&lck_lock
);
113 if (lck_tid
== thr_self() && fildes
>= 0) {
114 flock
.l_type
= F_UNLCK
;
115 (void) fcntl(fildes
, F_SETLK
, &flock
);
116 (void) close(fildes
);
120 lmutex_unlock(&lck_lock
);
123 lmutex_unlock(&lck_lock
);