summaryrefslogtreecommitdiff
path: root/sbin
diff options
context:
space:
mode:
Diffstat (limited to 'sbin')
-rw-r--r--sbin/isakmpd/isakmpd.c47
1 files changed, 45 insertions, 2 deletions
diff --git a/sbin/isakmpd/isakmpd.c b/sbin/isakmpd/isakmpd.c
index 93de2c7f0ac..f33424a7c06 100644
--- a/sbin/isakmpd/isakmpd.c
+++ b/sbin/isakmpd/isakmpd.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: isakmpd.c,v 1.11 1999/06/02 06:28:34 niklas Exp $ */
-/* $EOM: isakmpd.c,v 1.33 1999/05/21 14:18:14 ho Exp $ */
+/* $OpenBSD: isakmpd.c,v 1.12 1999/07/07 22:11:45 niklas Exp $ */
+/* $EOM: isakmpd.c,v 1.35 1999/06/26 23:30:38 ho Exp $ */
/*
* Copyright (c) 1998, 1999 Niklas Hallqvist. All rights reserved.
@@ -54,6 +54,10 @@
#include "udp.h"
#include "ui.h"
+#ifdef USE_KEYNOTE
+#include "policy.h"
+#endif
+
/*
* Set if -d is given, currently just for running in the foreground and log
* to stderr instead of syslog.
@@ -79,6 +83,13 @@ static int sighupped = 0;
static int sigusr1ed = 0;
static char *report_file = "/var/run/isakmpd.report";
+/*
+ * If we receive a USR2 signal, this flag gets set to show we need to
+ * rehash our SA soft expiration timers to a uniform distribution.
+ * XXX Perhaps this is a really bad idea?
+ */
+static int sigusr2ed = 0;
+
static void
usage ()
{
@@ -158,6 +169,11 @@ reinit (void)
/* Reread config file. */
conf_init ();
+#ifdef USE_KEYNOTE
+ /* Reread the policies. */
+ policy_init ();
+#endif
+
/* Reinitalize our connection list. */
connection_reinit ();
@@ -212,6 +228,26 @@ sigusr1 (int sig)
sigusr1ed = 1;
}
+/* Rehash soft expiration timers on SIGUSR2. */
+static void
+rehash_timers (void)
+{
+#if 0
+ /* XXX - not yet */
+ log_print ("SIGUSR2 received, rehasing soft expiration timers.");
+
+ timer_rehash_timers ();
+#endif
+
+ sigusr2ed = 0;
+}
+
+static void
+sigusr2 (int sig)
+{
+ sigusr2ed = 1;
+}
+
int
main (int argc, char *argv[])
{
@@ -236,6 +272,9 @@ main (int argc, char *argv[])
/* Report state on USR1 reception. */
signal (SIGUSR1, sigusr1);
+ /* Rehash soft expiration timers on USR2 reception. */
+ signal (SIGUSR2, sigusr2);
+
/* Allocate the file descriptor sets just big enough. */
n = getdtablesize ();
mask_size = howmany (n, NFDBITS) * sizeof (fd_mask);
@@ -256,6 +295,10 @@ main (int argc, char *argv[])
if (sigusr1ed)
report ();
+ /* and if someone sent SIGUSR2, do a timer rehash. */
+ if (sigusr2ed)
+ rehash_timers ();
+
/* Setup the descriptors to look for incoming messages at. */
memset (rfds, 0, mask_size);
n = transport_fd_set (rfds);