OSDN Git Service

net_sched: return correct value for *notify* functions
authorZhike Wang <wangzhike@jd.com>
Mon, 11 Mar 2019 10:15:54 +0000 (03:15 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 13 Mar 2019 20:48:27 +0000 (13:48 -0700)
commit5b5f99b186906d198f4455b3add911c87ab361fc
tree7d68f218de2af85d7273d4092e75016551c0ebcd
parentdeb6bfabdbb634e91f36a4e9cb00a7137d72d886
net_sched: return correct value for *notify* functions

It is confusing to directly use return value of netlink_send()/
netlink_unicast() as the return value of *notify*, as it may be not
error at all.

Example: in tc_del_tfilter(), after calling tfilter_del_notify(), it will
goto errout if (err). However, the netlink_send()/netlink_unicast() will
return positive value even for successful case. So it may not call
tcf_chain_tp_remove() and so on to clean up the resource, as a result,
resource is leaked.

It may be easier to only check the return value of tfilter_del_nofiy(),
but it is more clean to correct all related functions.

Co-developed-by: Zengmo Gao <gaozengmo@jd.com>
Signed-off-by: Zhike Wang <wangzhike@jd.com>
Acked-by: Cong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sched/cls_api.c
net/sched/sch_api.c