diff options
-rw-r--r-- | drivers/net/pppol2tp.c | 36 |
1 files changed, 7 insertions, 29 deletions
diff --git a/drivers/net/pppol2tp.c b/drivers/net/pppol2tp.c index c58b50f8ba3b..9fbb2eba9a06 100644 --- a/drivers/net/pppol2tp.c +++ b/drivers/net/pppol2tp.c | |||
@@ -2605,53 +2605,31 @@ static struct pppox_proto pppol2tp_proto = { | |||
2605 | 2605 | ||
2606 | static __net_init int pppol2tp_init_net(struct net *net) | 2606 | static __net_init int pppol2tp_init_net(struct net *net) |
2607 | { | 2607 | { |
2608 | struct pppol2tp_net *pn; | 2608 | struct pppol2tp_net *pn = pppol2tp_pernet(net); |
2609 | struct proc_dir_entry *pde; | 2609 | struct proc_dir_entry *pde; |
2610 | int err; | ||
2611 | |||
2612 | pn = kzalloc(sizeof(*pn), GFP_KERNEL); | ||
2613 | if (!pn) | ||
2614 | return -ENOMEM; | ||
2615 | 2610 | ||
2616 | INIT_LIST_HEAD(&pn->pppol2tp_tunnel_list); | 2611 | INIT_LIST_HEAD(&pn->pppol2tp_tunnel_list); |
2617 | rwlock_init(&pn->pppol2tp_tunnel_list_lock); | 2612 | rwlock_init(&pn->pppol2tp_tunnel_list_lock); |
2618 | 2613 | ||
2619 | err = net_assign_generic(net, pppol2tp_net_id, pn); | ||
2620 | if (err) | ||
2621 | goto out; | ||
2622 | |||
2623 | pde = proc_net_fops_create(net, "pppol2tp", S_IRUGO, &pppol2tp_proc_fops); | 2614 | pde = proc_net_fops_create(net, "pppol2tp", S_IRUGO, &pppol2tp_proc_fops); |
2624 | #ifdef CONFIG_PROC_FS | 2615 | #ifdef CONFIG_PROC_FS |
2625 | if (!pde) { | 2616 | if (!pde) |
2626 | err = -ENOMEM; | 2617 | return -ENOMEM; |
2627 | goto out; | ||
2628 | } | ||
2629 | #endif | 2618 | #endif |
2630 | 2619 | ||
2631 | return 0; | 2620 | return 0; |
2632 | |||
2633 | out: | ||
2634 | kfree(pn); | ||
2635 | return err; | ||
2636 | } | 2621 | } |
2637 | 2622 | ||
2638 | static __net_exit void pppol2tp_exit_net(struct net *net) | 2623 | static __net_exit void pppol2tp_exit_net(struct net *net) |
2639 | { | 2624 | { |
2640 | struct pppoe_net *pn; | ||
2641 | |||
2642 | proc_net_remove(net, "pppol2tp"); | 2625 | proc_net_remove(net, "pppol2tp"); |
2643 | pn = net_generic(net, pppol2tp_net_id); | ||
2644 | /* | ||
2645 | * if someone has cached our net then | ||
2646 | * further net_generic call will return NULL | ||
2647 | */ | ||
2648 | net_assign_generic(net, pppol2tp_net_id, NULL); | ||
2649 | kfree(pn); | ||
2650 | } | 2626 | } |
2651 | 2627 | ||
2652 | static struct pernet_operations pppol2tp_net_ops = { | 2628 | static struct pernet_operations pppol2tp_net_ops = { |
2653 | .init = pppol2tp_init_net, | 2629 | .init = pppol2tp_init_net, |
2654 | .exit = pppol2tp_exit_net, | 2630 | .exit = pppol2tp_exit_net, |
2631 | .id = &pppol2tp_net_id, | ||
2632 | .size = sizeof(struct pppol2tp_net), | ||
2655 | }; | 2633 | }; |
2656 | 2634 | ||
2657 | static int __init pppol2tp_init(void) | 2635 | static int __init pppol2tp_init(void) |
@@ -2665,7 +2643,7 @@ static int __init pppol2tp_init(void) | |||
2665 | if (err) | 2643 | if (err) |
2666 | goto out_unregister_pppol2tp_proto; | 2644 | goto out_unregister_pppol2tp_proto; |
2667 | 2645 | ||
2668 | err = register_pernet_gen_device(&pppol2tp_net_id, &pppol2tp_net_ops); | 2646 | err = register_pernet_device(&pppol2tp_net_ops); |
2669 | if (err) | 2647 | if (err) |
2670 | goto out_unregister_pppox_proto; | 2648 | goto out_unregister_pppox_proto; |
2671 | 2649 | ||
@@ -2684,7 +2662,7 @@ out_unregister_pppol2tp_proto: | |||
2684 | static void __exit pppol2tp_exit(void) | 2662 | static void __exit pppol2tp_exit(void) |
2685 | { | 2663 | { |
2686 | unregister_pppox_proto(PX_PROTO_OL2TP); | 2664 | unregister_pppox_proto(PX_PROTO_OL2TP); |
2687 | unregister_pernet_gen_device(pppol2tp_net_id, &pppol2tp_net_ops); | 2665 | unregister_pernet_device(&pppol2tp_net_ops); |
2688 | proto_unregister(&pppol2tp_sk_proto); | 2666 | proto_unregister(&pppol2tp_sk_proto); |
2689 | } | 2667 | } |
2690 | 2668 | ||