From b12d1fc09f41633ab8ba21dac353c82bae478e0e Mon Sep 17 00:00:00 2001 From: YueHaibing Date: Wed, 27 Nov 2019 15:33:23 +0800 Subject: [PATCH] net/sched: cbs: Fix error path of cbs_module_init mainline inclusion from mainline-v5.2-rc7 commit 45d5cb137c3638b3a310f41b31d8e79daf647f14 category: bugfix bugzilla: 16960 CVE: NA ------------------------------------- If register_qdisc fails, we should unregister netdevice notifier. Reported-by: Hulk Robot Fixes: e0a7683d30e9 ("net/sched: cbs: fix port_rate miscalculation") Signed-off-by: YueHaibing Signed-off-by: David S. Miller Signed-off-by: guodeqing Reviewed-by: Wenan Mao Signed-off-by: Yang Yingliang --- net/sched/sch_cbs.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/net/sched/sch_cbs.c b/net/sched/sch_cbs.c index 0edd1a6cdea3..8a33e50ace2e 100644 --- a/net/sched/sch_cbs.c +++ b/net/sched/sch_cbs.c @@ -553,12 +553,17 @@ static struct notifier_block cbs_device_notifier = { static int __init cbs_module_init(void) { - int err = register_netdevice_notifier(&cbs_device_notifier); + int err; + err = register_netdevice_notifier(&cbs_device_notifier); if (err) return err; - return register_qdisc(&cbs_qdisc_ops); + err = register_qdisc(&cbs_qdisc_ops); + if (err) + unregister_netdevice_notifier(&cbs_device_notifier); + + return err; } static void __exit cbs_module_exit(void) -- GitLab