Skip to content

Commit

Permalink
devlink: fix possible use-after-free and memory leaks in devlink_init()
Browse files Browse the repository at this point in the history
[ Upstream commit def689f ]

The pernet operations structure for the subsystem must be registered
before registering the generic netlink family.

Make an unregister in case of unsuccessful registration.

Fixes: 687125b ("devlink: split out core code")
Signed-off-by: Vasiliy Kovalev <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Paolo Abeni <[email protected]>
Signed-off-by: Sasha Levin <[email protected]>
  • Loading branch information
Vasiliy Kovalev authored and gregkh committed Mar 1, 2024
1 parent 9e02973 commit 919092b
Showing 1 changed file with 9 additions and 3 deletions.
12 changes: 9 additions & 3 deletions net/devlink/core.c
Original file line number Diff line number Diff line change
Expand Up @@ -308,14 +308,20 @@ static int __init devlink_init(void)
{
int err;

err = genl_register_family(&devlink_nl_family);
if (err)
goto out;
err = register_pernet_subsys(&devlink_pernet_ops);
if (err)
goto out;
err = genl_register_family(&devlink_nl_family);
if (err)
goto out_unreg_pernet_subsys;
err = register_netdevice_notifier(&devlink_port_netdevice_nb);
if (!err)
return 0;

genl_unregister_family(&devlink_nl_family);

out_unreg_pernet_subsys:
unregister_pernet_subsys(&devlink_pernet_ops);
out:
WARN_ON(err);
return err;
Expand Down

0 comments on commit 919092b

Please sign in to comment.