]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - net/ipv6/af_inet6.c
Merge branch 'x86/um-header' of git://git.kernel.org/pub/scm/linux/kernel/git/tip...
[linux-2.6-omap-h63xx.git] / net / ipv6 / af_inet6.c
index 127b240d2d8161f918d6c5cdbeb15f7208e5cbf2..01edac888510cb7f4efb0c1ff994c4978a11bfaf 100644 (file)
@@ -795,45 +795,31 @@ static void ipv6_packet_cleanup(void)
        dev_remove_pack(&ipv6_packet_type);
 }
 
-static int __init init_ipv6_mibs(void)
+static int __net_init ipv6_init_mibs(struct net *net)
 {
-       if (snmp_mib_init((void **)ipv6_statistics,
+       if (snmp_mib_init((void **)net->mib.udp_stats_in6,
+                         sizeof (struct udp_mib)) < 0)
+               return -ENOMEM;
+       if (snmp_mib_init((void **)net->mib.udplite_stats_in6,
+                         sizeof (struct udp_mib)) < 0)
+               goto err_udplite_mib;
+       if (snmp_mib_init((void **)net->mib.ipv6_statistics,
                          sizeof(struct ipstats_mib)) < 0)
                goto err_ip_mib;
-       if (snmp_mib_init((void **)icmpv6_statistics,
+       if (snmp_mib_init((void **)net->mib.icmpv6_statistics,
                          sizeof(struct icmpv6_mib)) < 0)
                goto err_icmp_mib;
-       if (snmp_mib_init((void **)icmpv6msg_statistics,
+       if (snmp_mib_init((void **)net->mib.icmpv6msg_statistics,
                          sizeof(struct icmpv6msg_mib)) < 0)
                goto err_icmpmsg_mib;
        return 0;
 
 err_icmpmsg_mib:
-       snmp_mib_free((void **)icmpv6_statistics);
+       snmp_mib_free((void **)net->mib.icmpv6_statistics);
 err_icmp_mib:
-       snmp_mib_free((void **)ipv6_statistics);
+       snmp_mib_free((void **)net->mib.ipv6_statistics);
 err_ip_mib:
-       return -ENOMEM;
-
-}
-
-static void cleanup_ipv6_mibs(void)
-{
-       snmp_mib_free((void **)ipv6_statistics);
-       snmp_mib_free((void **)icmpv6_statistics);
-       snmp_mib_free((void **)icmpv6msg_statistics);
-}
-
-static int __net_init ipv6_init_mibs(struct net *net)
-{
-       if (snmp_mib_init((void **)net->mib.udp_stats_in6,
-                         sizeof (struct udp_mib)) < 0)
-               return -ENOMEM;
-       if (snmp_mib_init((void **)net->mib.udplite_stats_in6,
-                         sizeof (struct udp_mib)) < 0)
-               goto err_udplite_mib;
-       return 0;
-
+       snmp_mib_free((void **)net->mib.udplite_stats_in6);
 err_udplite_mib:
        snmp_mib_free((void **)net->mib.udp_stats_in6);
        return -ENOMEM;
@@ -843,9 +829,12 @@ static void __net_exit ipv6_cleanup_mibs(struct net *net)
 {
        snmp_mib_free((void **)net->mib.udp_stats_in6);
        snmp_mib_free((void **)net->mib.udplite_stats_in6);
+       snmp_mib_free((void **)net->mib.ipv6_statistics);
+       snmp_mib_free((void **)net->mib.icmpv6_statistics);
+       snmp_mib_free((void **)net->mib.icmpv6msg_statistics);
 }
 
-static int inet6_net_init(struct net *net)
+static int __net_init inet6_net_init(struct net *net)
 {
        int err = 0;
 
@@ -937,11 +926,6 @@ static int __init inet6_init(void)
        if (err)
                goto out_sock_register_fail;
 
-       /* Initialise ipv6 mibs */
-       err = init_ipv6_mibs();
-       if (err)
-               goto out_unregister_sock;
-
 #ifdef CONFIG_SYSCTL
        err = ipv6_static_sysctl_register();
        if (err)
@@ -1075,8 +1059,6 @@ register_pernet_fail:
        ipv6_static_sysctl_unregister();
 static_sysctl_fail:
 #endif
-       cleanup_ipv6_mibs();
-out_unregister_sock:
        sock_unregister(PF_INET6);
        rtnl_unregister_all(PF_INET6);
 out_sock_register_fail:
@@ -1133,7 +1115,6 @@ static void __exit inet6_exit(void)
 #ifdef CONFIG_SYSCTL
        ipv6_static_sysctl_unregister();
 #endif
-       cleanup_ipv6_mibs();
        proto_unregister(&rawv6_prot);
        proto_unregister(&udplitev6_prot);
        proto_unregister(&udpv6_prot);