summaryrefslogtreecommitdiffstats
path: root/net/sched
diff options
context:
space:
mode:
authorJamal Hadi Salim <hadi@cyberus.ca>2008-08-07 20:37:22 -0700
committerDavid S. Miller <davem@davemloft.net>2008-08-07 20:37:22 -0700
commit76aab2c1eae491a5d73ac83deec97dd28ebac584 (patch)
treeba680489b5dc20cc1afad6c5c0fef36b31918d9a /net/sched
parent4ab84d450e24b3a309608182a8d8e30626b46f8f (diff)
downloadlinux-stable-76aab2c1eae491a5d73ac83deec97dd28ebac584.tar.gz
linux-stable-76aab2c1eae491a5d73ac83deec97dd28ebac584.tar.bz2
linux-stable-76aab2c1eae491a5d73ac83deec97dd28ebac584.zip
pkt_sched: Fix actions referencing
When an action is added several times with the same exact index it gets deleted on every even-numbered attempt. This fixes that issue. Signed-off-by: Jamal Hadi Salim <hadi@cyberus.ca> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sched')
-rw-r--r--net/sched/act_api.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/net/sched/act_api.c b/net/sched/act_api.c
index d308c19aa3f9..26c7e1f9a350 100644
--- a/net/sched/act_api.c
+++ b/net/sched/act_api.c
@@ -205,10 +205,9 @@ struct tcf_common *tcf_hash_check(u32 index, struct tc_action *a, int bind,
{
struct tcf_common *p = NULL;
if (index && (p = tcf_hash_lookup(index, hinfo)) != NULL) {
- if (bind) {
+ if (bind)
p->tcfc_bindcnt++;
- p->tcfc_refcnt++;
- }
+ p->tcfc_refcnt++;
a->priv = p;
}
return p;