summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpyr <pyr@openbsd.org>2007-12-10 20:31:56 +0000
committerpyr <pyr@openbsd.org>2007-12-10 20:31:56 +0000
commit0f06fac84d4fd14a028be439c3cb77ede21afbf0 (patch)
tree7a92044d0e91295f5562958c080bc2f453db6dd7
parentzap field nothing uses. (diff)
downloadwireguard-openbsd-0f06fac84d4fd14a028be439c3cb77ede21afbf0.tar.xz
wireguard-openbsd-0f06fac84d4fd14a028be439c3cb77ede21afbf0.zip
Warn the user when reloading a new configuration fails instead of killing
the daemon. ok reyk@
-rw-r--r--usr.sbin/relayd/relayd.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/usr.sbin/relayd/relayd.c b/usr.sbin/relayd/relayd.c
index f65a25a2b72..c3a9504b8e2 100644
--- a/usr.sbin/relayd/relayd.c
+++ b/usr.sbin/relayd/relayd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: relayd.c,v 1.64 2007/12/08 20:36:36 pyr Exp $ */
+/* $OpenBSD: relayd.c,v 1.65 2007/12/10 20:31:56 pyr Exp $ */
/*
* Copyright (c) 2006 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -390,8 +390,12 @@ reconfigure(void)
struct host *host;
log_info("reloading configuration");
- if ((new_env = parse_config(env->confpath, env->opts)) == NULL)
- exit(1);
+ if ((new_env = parse_config(env->confpath, env->opts)) == NULL) {
+ purge_config(new_env, PURGE_EVERYTHING);
+ free(new_env);
+ log_warnx("configuration reloading FAILED");
+ return;
+ }
purge_config(env, PURGE_EVERYTHING);
merge_config(env, new_env);