From: Tobias Brunner Date: Tue, 16 Apr 2013 11:54:25 +0000 (+0200) Subject: kernel-netlink: Add an option to disable roam events X-Git-Tag: 5.1.0dr1~171 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=37873f9994a8c5e470969c6c906669df1cbdddf6;p=thirdparty%2Fstrongswan.git kernel-netlink: Add an option to disable roam events --- diff --git a/man/strongswan.conf.5.in b/man/strongswan.conf.5.in index 44fe330e85..e4b7e49d4e 100644 --- a/man/strongswan.conf.5.in +++ b/man/strongswan.conf.5.in @@ -595,6 +595,9 @@ Number of ipsecN devices .BR charon.plugins.kernel-klips.ipsec_dev_mtu " [0]" Set MTU of ipsecN device .TP +.BR charon.plugins.kernel-netlink.roam_events " [yes]" +Whether to trigger roam events when interfaces, addresses or routes change +.TP .BR charon.plugins.load-tester Section to configure the load-tester plugin, see LOAD TESTS .TP diff --git a/src/libhydra/plugins/kernel_netlink/kernel_netlink_net.c b/src/libhydra/plugins/kernel_netlink/kernel_netlink_net.c index 9586fa47da..739a1f4077 100644 --- a/src/libhydra/plugins/kernel_netlink/kernel_netlink_net.c +++ b/src/libhydra/plugins/kernel_netlink/kernel_netlink_net.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2008-2012 Tobias Brunner + * Copyright (C) 2008-2013 Tobias Brunner * Copyright (C) 2005-2008 Martin Willi * Hochschule fuer Technik Rapperswil * @@ -435,6 +435,11 @@ struct private_kernel_netlink_net_t { */ bool process_route; + /** + * whether to trigger roam events + */ + bool roam_events; + /** * whether to actually install virtual IPs */ @@ -703,6 +708,11 @@ static void fire_roam_event(private_kernel_netlink_net_t *this, bool address) timeval_t now; job_t *job; + if (!this->roam_events) + { + return; + } + time_monotonic(&now); this->roam_lock->lock(this->roam_lock); if (!timercmp(&now, &this->next_roam, >)) @@ -2235,6 +2245,8 @@ kernel_netlink_net_t *kernel_netlink_net_create() "%s.install_virtual_ip", TRUE, hydra->daemon), .install_virtual_ip_on = lib->settings->get_str(lib->settings, "%s.install_virtual_ip_on", NULL, hydra->daemon), + .roam_events = lib->settings->get_bool(lib->settings, + "%s.plugins.kernel-netlink.roam_events", TRUE, hydra->daemon), ); timerclear(&this->last_route_reinstall); timerclear(&this->next_roam);