netifd: Do not add local/source policy rules multiple times
authorKristian Evensen <kristian.evensen@gmail.com>
Thu, 7 Jan 2016 13:46:04 +0000 (14:46 +0100)
committerFelix Fietkau <nbd@openwrt.org>
Sun, 17 Jan 2016 10:50:44 +0000 (11:50 +0100)
commit49c8ab4ed307e4de016e92d3ffc84cd0ab50d56c
treed771c2732a09cced693c465abe0b95ac3fdab8ea
parentb8438154804c3fe105d41ecbd00a597315506f30
netifd: Do not add local/source policy rules multiple times

interface_ip_set_enabled() is usually called two times right after one another,
once to handle config_ip and once to handle proto_ip. As long as
ip->iface->l3_dev.dev is set, the local/source policy rules are updated.

This value is in several cases set on both config_ip and proto_ip, causing the
rules to be added multiple time. The reason is that the kernel does not respect
the NLM_F_* flag for rules. In other words, the rule state has to be managed by
the routing daemon.

Since the local/source policy rules are bound to iface, this commit solves the
problem by adding a flag to interface which stores the current rule state. The
flag follows the enabled-paramter passed to interface_ip_set_enabled(), similar
to route-> and addr->enabled. The flag breaks the alignment of the interface
struct, but based on earlier commits this seems to be ok.

I have tested the patch in different configurations and have not found any
regression.

Signed-off-by: Kristian Evensen <kristian.evensen@gmail.com>
interface-ip.c
interface.h
system-linux.c