net_sched: fix a missing refcnt in tcindex_init()
authorCong Wang <xiyou.wangcong@gmail.com>
Fri, 3 Apr 2020 03:58:51 +0000 (20:58 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 3 Apr 2020 23:00:08 +0000 (16:00 -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>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sched/cls_tcindex.c

index 065345832a69743fdd43090ead9971673134bfe8..61e95029c18f54f764df4f067a2530dbbd031798 100644 (file)
@@ -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;