net: fib_rules ordering fixes.
authorEric W. Biederman <ebiederm@maxwell.aristanetworks.com>
Sat, 8 Nov 2008 06:52:34 +0000 (22:52 -0800)
committerDavid S. Miller <davem@davemloft.net>
Sat, 8 Nov 2008 06:52:34 +0000 (22:52 -0800)
We need to setup the network namespace state before we register
the notifier.  Otherwise if a network device is already registered
we get a nasty NULL pointer dereference.

Signed-off-by: Eric W. Biederman <ebiederm@maxwell.aristanetworks.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/fib_rules.c

index 79de3b14a8d13256f54aaea43d1e3c6c9092833c..32b3a0152d7adba2079e5a1bc5f5ba9001037996 100644 (file)
@@ -664,17 +664,18 @@ static int __init fib_rules_init(void)
        rtnl_register(PF_UNSPEC, RTM_DELRULE, fib_nl_delrule, NULL);
        rtnl_register(PF_UNSPEC, RTM_GETRULE, NULL, fib_nl_dumprule);
 
-       err = register_netdevice_notifier(&fib_rules_notifier);
+       err = register_pernet_subsys(&fib_rules_net_ops);
        if (err < 0)
                goto fail;
 
-       err = register_pernet_subsys(&fib_rules_net_ops);
+       err = register_netdevice_notifier(&fib_rules_notifier);
        if (err < 0)
                goto fail_unregister;
+
        return 0;
 
 fail_unregister:
-       unregister_netdevice_notifier(&fib_rules_notifier);
+       unregister_pernet_subsys(&fib_rules_net_ops);
 fail:
        rtnl_unregister(PF_UNSPEC, RTM_NEWRULE);
        rtnl_unregister(PF_UNSPEC, RTM_DELRULE);