summaryrefslogtreecommitdiff
path: root/net
diff options
context:
space:
mode:
authorYan, Zheng <zheng.z.yan@intel.com>2011-10-17 15:20:28 +0000
committerDavid S. Miller <davem@davemloft.net>2011-10-19 19:17:41 -0400
commitafaef734e5f0004916d07ecf7d86292cdd00d59b (patch)
tree9ea614b4a5d7457f56fe0b776aef70f3a137cd79 /net
parent1b23a3e3d1b969e285c57a2d38f3739283ecfb80 (diff)
downloadlinux-3.10-afaef734e5f0004916d07ecf7d86292cdd00d59b.tar.gz
linux-3.10-afaef734e5f0004916d07ecf7d86292cdd00d59b.tar.bz2
linux-3.10-afaef734e5f0004916d07ecf7d86292cdd00d59b.zip
fib_rules: fix unresolved_rules counting
we should decrease ops->unresolved_rules when deleting a unresolved rule. Signed-off-by: Zheng Yan <zheng.z.yan@intel.com> Acked-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r--net/core/fib_rules.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/net/core/fib_rules.c b/net/core/fib_rules.c
index 3231b468bb7..27071ee2a4e 100644
--- a/net/core/fib_rules.c
+++ b/net/core/fib_rules.c
@@ -475,8 +475,11 @@ static int fib_nl_delrule(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
list_del_rcu(&rule->list);
- if (rule->action == FR_ACT_GOTO)
+ if (rule->action == FR_ACT_GOTO) {
ops->nr_goto_rules--;
+ if (rtnl_dereference(rule->ctarget) == NULL)
+ ops->unresolved_rules--;
+ }
/*
* Check if this rule is a target to any of them. If so,