diff options
author | Cong Wang <xiyou.wangcong@gmail.com> | 2018-04-07 03:19:41 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2018-04-07 19:36:45 +0300 |
commit | f12c643209db0626f2f54780d86bb93bfa7a9c2d (patch) | |
tree | c67e80ab3ed11ee28606b96475c72e8ac0e3b4d1 /net/sched/cls_u32.c | |
parent | dd9a122ae99ae471beed4d4f8073d71e8d31ffa6 (diff) | |
download | linux-f12c643209db0626f2f54780d86bb93bfa7a9c2d.tar.xz |
net_sched: fix a missing idr_remove() in u32_delete_key()
When we delete a u32 key via u32_delete_key(), we forget to
call idr_remove() to remove its handle from IDR.
Fixes: e7614370d6f0 ("net_sched: use idr to allocate u32 filter handles")
Reported-by: Marcin Kabiesz <admin@hostcenter.eu>
Tested-by: Marcin Kabiesz <admin@hostcenter.eu>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sched/cls_u32.c')
-rw-r--r-- | net/sched/cls_u32.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/net/sched/cls_u32.c b/net/sched/cls_u32.c index ed8b6a24b9e9..bac47b5d18fd 100644 --- a/net/sched/cls_u32.c +++ b/net/sched/cls_u32.c @@ -489,6 +489,7 @@ static int u32_delete_key(struct tcf_proto *tp, struct tc_u_knode *key) RCU_INIT_POINTER(*kp, key->next); tcf_unbind_filter(tp, &key->res); + idr_remove(&ht->handle_idr, key->handle); tcf_exts_get_net(&key->exts); call_rcu(&key->rcu, u32_delete_key_freepf_rcu); return 0; |