summaryrefslogtreecommitdiff
path: root/libexec
diff options
context:
space:
mode:
Diffstat (limited to 'libexec')
-rw-r--r--libexec/ftpd/ftpcmd.y8
-rw-r--r--libexec/ftpd/ftpd.c16
2 files changed, 15 insertions, 9 deletions
diff --git a/libexec/ftpd/ftpcmd.y b/libexec/ftpd/ftpcmd.y
index 1ec6ab95af2..ea8a0614168 100644
--- a/libexec/ftpd/ftpcmd.y
+++ b/libexec/ftpd/ftpcmd.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: ftpcmd.y,v 1.24 2000/11/14 20:27:01 itojun Exp $ */
+/* $OpenBSD: ftpcmd.y,v 1.25 2001/11/05 09:51:13 deraadt Exp $ */
/* $NetBSD: ftpcmd.y,v 1.7 1996/04/08 19:03:11 jtc Exp $ */
/*
@@ -47,7 +47,7 @@
#if 0
static char sccsid[] = "@(#)ftpcmd.y 8.3 (Berkeley) 4/6/94";
#else
-static char rcsid[] = "$OpenBSD: ftpcmd.y,v 1.24 2000/11/14 20:27:01 itojun Exp $";
+static char rcsid[] = "$OpenBSD: ftpcmd.y,v 1.25 2001/11/05 09:51:13 deraadt Exp $";
#endif
#endif /* not lint */
@@ -1164,11 +1164,13 @@ void
toolong(signo)
int signo;
{
+ struct syslog_data sdata = SYSLOG_DATA_INIT;
+ /* XXX signal races */
reply(421,
"Timeout (%d seconds): closing control connection.", timeout);
if (logging)
- syslog(LOG_INFO, "User %s timed out after %d seconds",
+ syslog_r(LOG_INFO, &sdata, "User %s timed out after %d seconds",
(pw ? pw -> pw_name : "unknown"), timeout);
dologout(1);
}
diff --git a/libexec/ftpd/ftpd.c b/libexec/ftpd/ftpd.c
index 68f93e9e114..b035ad50078 100644
--- a/libexec/ftpd/ftpd.c
+++ b/libexec/ftpd/ftpd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ftpd.c,v 1.105 2001/10/02 17:43:47 wilfried Exp $ */
+/* $OpenBSD: ftpd.c,v 1.106 2001/11/05 09:51:13 deraadt Exp $ */
/* $NetBSD: ftpd.c,v 1.15 1995/06/03 22:46:47 mycroft Exp $ */
/*
@@ -73,7 +73,7 @@ static char copyright[] =
#if 0
static char sccsid[] = "@(#)ftpd.c 8.4 (Berkeley) 4/16/94";
#else
-static char rcsid[] = "$OpenBSD: ftpd.c,v 1.105 2001/10/02 17:43:47 wilfried Exp $";
+static char rcsid[] = "$OpenBSD: ftpd.c,v 1.106 2001/11/05 09:51:13 deraadt Exp $";
#endif
#endif /* not lint */
@@ -620,21 +620,23 @@ static void
lostconn(signo)
int signo;
{
+ struct syslog_data sdata = SYSLOG_DATA_INIT;
sigprocmask(SIG_BLOCK, &allsigs, NULL);
if (debug)
- syslog(LOG_DEBUG, "lost connection");
- dologout(1);
+ syslog_r(LOG_DEBUG, &sdata, "lost connection");
+ dologout(1); /* XXX signal race? */
}
static void
sigquit(signo)
int signo;
{
+ struct syslog_data sdata = SYSLOG_DATA_INIT;
sigprocmask(SIG_BLOCK, &allsigs, NULL);
- syslog(LOG_ERR, "got signal %s", sys_signame[signo]);
- dologout(1);
+ syslog_r(LOG_ERR, &sdata, "got signal %s", sys_signame[signo]);
+ dologout(1); /* XXX signal race? */
}
/*
@@ -2112,6 +2114,8 @@ myoob(signo)
char *cp;
int save_errno = errno;
+ /* XXX signal races GALORE */
+
/* only process if transfer occurring */
if (!transflag)
return;