]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - net/dccp/ipv6.c
dccp: call inet_add_protocol after register_pernet_subsys in dccp_v6_init
[karo-tx-linux.git] / net / dccp / ipv6.c
index 992621172220d136a1114a58f1c0e75219c57ea4..4fccc0c37fbdb4406d1370802d57a8f0aa9d376f 100644 (file)
@@ -1098,33 +1098,33 @@ static int __init dccp_v6_init(void)
 {
        int err = proto_register(&dccp_v6_prot, 1);
 
-       if (err != 0)
+       if (err)
                goto out;
 
-       err = inet6_add_protocol(&dccp_v6_protocol, IPPROTO_DCCP);
-       if (err != 0)
-               goto out_unregister_proto;
-
        inet6_register_protosw(&dccp_v6_protosw);
 
        err = register_pernet_subsys(&dccp_v6_ops);
-       if (err != 0)
+       if (err)
                goto out_destroy_ctl_sock;
+
+       err = inet6_add_protocol(&dccp_v6_protocol, IPPROTO_DCCP);
+       if (err)
+               goto out_unregister_proto;
+
 out:
        return err;
-
+out_unregister_proto:
+       unregister_pernet_subsys(&dccp_v6_ops);
 out_destroy_ctl_sock:
-       inet6_del_protocol(&dccp_v6_protocol, IPPROTO_DCCP);
        inet6_unregister_protosw(&dccp_v6_protosw);
-out_unregister_proto:
        proto_unregister(&dccp_v6_prot);
        goto out;
 }
 
 static void __exit dccp_v6_exit(void)
 {
-       unregister_pernet_subsys(&dccp_v6_ops);
        inet6_del_protocol(&dccp_v6_protocol, IPPROTO_DCCP);
+       unregister_pernet_subsys(&dccp_v6_ops);
        inet6_unregister_protosw(&dccp_v6_protosw);
        proto_unregister(&dccp_v6_prot);
 }