summaryrefslogtreecommitdiff
path: root/system-linux.c
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2013-05-27 19:45:20 +0200
committerJo-Philipp Wich <jow@openwrt.org>2013-05-27 19:45:20 +0200
commit97e748de49c02f36a1e75bd9f9552311fb4051b4 (patch)
treecfbff63db1582f9801c3f3566132b776f158bd42 /system-linux.c
parent2f31bff38d4dc2f36006ded6b8a7d039cb569eaa (diff)
downloadnetifd-97e748de49c02f36a1e75bd9f9552311fb4051b4.tar.gz
Move initial iprule flushing to system_add_iprule() to not collide with generic multiwan support
Diffstat (limited to 'system-linux.c')
-rw-r--r--system-linux.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/system-linux.c b/system-linux.c
index f5c900d..76740f7 100644
--- a/system-linux.c
+++ b/system-linux.c
@@ -65,6 +65,8 @@ static void handle_hotplug_event(struct uloop_fd *u, unsigned int events);
static char dev_buf[256];
+static bool iprules_flushed = false;
+
static void
handler_nl_event(struct uloop_fd *u, unsigned int events)
{
@@ -1177,6 +1179,13 @@ static int system_iprule(struct iprule *rule, int cmd)
int system_add_iprule(struct iprule *rule)
{
+ /* trigger flush of existing rules when adding first rule the first time */
+ if (!iprules_flushed)
+ {
+ system_flush_iprules();
+ iprules_flushed = true;
+ }
+
return system_iprule(rule, RTM_NEWRULE);
}