diff mbox series

[net] net_sched: fix a missing refcnt in tcindex_init()

Message ID 20200403035851.31647-1-xiyou.wangcong@gmail.com
State Accepted
Delegated to: David Miller
Headers show
Series [net] net_sched: fix a missing refcnt in tcindex_init() | expand

Commit Message

Cong Wang April 3, 2020, 3:58 a.m. UTC
The initial refcnt of struct tcindex_data should be 1,
it is clear that I forgot to set it to 1 in tcindex_init().
This leads to a dec-after-zero warning.

Reported-by: syzbot+8325e509a1bf83ec741d@syzkaller.appspotmail.com
Fixes: 304e024216a8 ("net_sched: add a temporary refcnt for struct tcindex_data")
Cc: Jamal Hadi Salim <jhs@mojatatu.com>
Cc: Jiri Pirko <jiri@resnulli.us>
Cc: Paul E. McKenney <paulmck@kernel.org>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
---
 net/sched/cls_tcindex.c | 1 +
 1 file changed, 1 insertion(+)

Comments

David Miller April 3, 2020, 11:01 p.m. UTC | #1
From: Cong Wang <xiyou.wangcong@gmail.com>
Date: Thu,  2 Apr 2020 20:58:51 -0700

> The initial refcnt of struct tcindex_data should be 1,
> it is clear that I forgot to set it to 1 in tcindex_init().
> This leads to a dec-after-zero warning.
> 
> Reported-by: syzbot+8325e509a1bf83ec741d@syzkaller.appspotmail.com
> Fixes: 304e024216a8 ("net_sched: add a temporary refcnt for struct tcindex_data")
> Cc: Jamal Hadi Salim <jhs@mojatatu.com>
> Cc: Jiri Pirko <jiri@resnulli.us>
> Cc: Paul E. McKenney <paulmck@kernel.org>
> Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>

Applied, thanks Cong.
diff mbox series

Patch

diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c
index 065345832a69..61e95029c18f 100644
--- a/net/sched/cls_tcindex.c
+++ b/net/sched/cls_tcindex.c
@@ -151,6 +151,7 @@  static int tcindex_init(struct tcf_proto *tp)
 	p->mask = 0xffff;
 	p->hash = DEFAULT_HASH_SIZE;
 	p->fall_through = 1;
+	refcount_set(&p->refcnt, 1); /* Paired with tcindex_destroy_work() */
 
 	rcu_assign_pointer(tp->root, p);
 	return 0;