From 31375ee367ec60a2f2316627480388c8b55741a3 Mon Sep 17 00:00:00 2001 From: deraadt Date: Fri, 6 Dec 1996 01:54:58 +0000 Subject: [PATCH] vfork w/ exit botch --- lib/libutil/passwd.c | 4 ++-- libexec/rpc.yppasswdd/yppasswdd_mkpw.c | 7 +++++-- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/lib/libutil/passwd.c b/lib/libutil/passwd.c index 8df9b382a14..a982a9449c2 100644 --- a/lib/libutil/passwd.c +++ b/lib/libutil/passwd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: passwd.c,v 1.4 1996/06/19 12:36:01 deraadt Exp $ */ +/* $OpenBSD: passwd.c,v 1.5 1996/12/06 01:55:33 deraadt Exp $ */ /* * Copyright (c) 1987, 1993, 1994, 1995 * The Regents of the University of California. All rights reserved. @@ -86,7 +86,7 @@ pw_mkdb() if (pid == 0) { execl(_PATH_PWD_MKDB, "pwd_mkdb", "-p", _PATH_MASTERPASSWD_LOCK, NULL); - exit(1); + _exit(1); } pid = waitpid(pid, &pstat, 0); if (pid == -1 || !WIFEXITED(pstat) || WEXITSTATUS(pstat) != 0) diff --git a/libexec/rpc.yppasswdd/yppasswdd_mkpw.c b/libexec/rpc.yppasswdd/yppasswdd_mkpw.c index 08ba14529b5..62345eb9efe 100644 --- a/libexec/rpc.yppasswdd/yppasswdd_mkpw.c +++ b/libexec/rpc.yppasswdd/yppasswdd_mkpw.c @@ -30,7 +30,7 @@ */ #ifndef LINT -static char rcsid[] = "$Id: yppasswdd_mkpw.c,v 1.8 1996/08/31 13:54:13 deraadt Exp $"; +static char rcsid[] = "$Id: yppasswdd_mkpw.c,v 1.9 1996/12/06 01:54:58 deraadt Exp $"; #endif #include @@ -143,7 +143,10 @@ do_mkdb() (void)fflush(stdout); if (!(pid = vfork())) { execl(_PATH_PWD_MKDB, "pwd_mkdb", "-p", tempname, NULL); - pw_error(_PATH_PWD_MKDB, 1, 1); + warn(_PATH_PWD_MKDB); + warnx("%s: unchanged", _PATH_MASTERPASSWD); + pw_abort(); + _exit(1); } pid = waitpid(pid, &pstat, 0); if (pid == -1 || !WIFEXITED(pstat) || WEXITSTATUS(pstat) != 0) -- 2.20.1