summaryrefslogtreecommitdiff
path: root/net/sched
diff options
context:
space:
mode:
authorYueHaibing <yuehaibing@huawei.com>2019-10-09 11:10:52 +0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2020-01-27 14:51:18 +0100
commit5c1b003d22aba2ff0853f0e775c3cfa7e42522cd (patch)
treea61335e9ed7acd51629e56260c9381cb8dc689fb /net/sched
parente4bf36f1e698c8c25a40774f7075a5b346030d7a (diff)
act_mirred: Fix mirred_init_module error handling
[ Upstream commit 11c9a7d38af524217efb7a176ad322b97ac2f163 ] If tcf_register_action failed, mirred_device_notifier should be unregistered. Fixes: 3b87956ea645 ("net sched: fix race in mirred device removal") Signed-off-by: YueHaibing <yuehaibing@huawei.com> Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'net/sched')
-rw-r--r--net/sched/act_mirred.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/net/sched/act_mirred.c b/net/sched/act_mirred.c
index 399e3beae6cf..a30c17a28281 100644
--- a/net/sched/act_mirred.c
+++ b/net/sched/act_mirred.c
@@ -445,7 +445,11 @@ static int __init mirred_init_module(void)
return err;
pr_info("Mirror/redirect action on\n");
- return tcf_register_action(&act_mirred_ops, &mirred_net_ops);
+ err = tcf_register_action(&act_mirred_ops, &mirred_net_ops);
+ if (err)
+ unregister_netdevice_notifier(&mirred_device_notifier);
+
+ return err;
}
static void __exit mirred_cleanup_module(void)