aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/ipv6/sit.c25
1 files changed, 6 insertions, 19 deletions
diff --git a/net/ipv6/sit.c b/net/ipv6/sit.c
index d9deaa7753ef..976e68244b99 100644
--- a/net/ipv6/sit.c
+++ b/net/ipv6/sit.c
@@ -1164,17 +1164,8 @@ static void sit_destroy_tunnels(struct sit_net *sitn, struct list_head *head)
1164 1164
1165static int sit_init_net(struct net *net) 1165static int sit_init_net(struct net *net)
1166{ 1166{
1167 struct sit_net *sitn = net_generic(net, sit_net_id);
1167 int err; 1168 int err;
1168 struct sit_net *sitn;
1169
1170 err = -ENOMEM;
1171 sitn = kzalloc(sizeof(struct sit_net), GFP_KERNEL);
1172 if (sitn == NULL)
1173 goto err_alloc;
1174
1175 err = net_assign_generic(net, sit_net_id, sitn);
1176 if (err < 0)
1177 goto err_assign;
1178 1169
1179 sitn->tunnels[0] = sitn->tunnels_wc; 1170 sitn->tunnels[0] = sitn->tunnels_wc;
1180 sitn->tunnels[1] = sitn->tunnels_l; 1171 sitn->tunnels[1] = sitn->tunnels_l;
@@ -1201,37 +1192,33 @@ err_reg_dev:
1201 dev_put(sitn->fb_tunnel_dev); 1192 dev_put(sitn->fb_tunnel_dev);
1202 free_netdev(sitn->fb_tunnel_dev); 1193 free_netdev(sitn->fb_tunnel_dev);
1203err_alloc_dev: 1194err_alloc_dev:
1204 /* nothing */
1205err_assign:
1206 kfree(sitn);
1207err_alloc:
1208 return err; 1195 return err;
1209} 1196}
1210 1197
1211static void sit_exit_net(struct net *net) 1198static void sit_exit_net(struct net *net)
1212{ 1199{
1213 struct sit_net *sitn; 1200 struct sit_net *sitn = net_generic(net, sit_net_id);
1214 LIST_HEAD(list); 1201 LIST_HEAD(list);
1215 1202
1216 sitn = net_generic(net, sit_net_id);
1217 rtnl_lock(); 1203 rtnl_lock();
1218 sit_destroy_tunnels(sitn, &list); 1204 sit_destroy_tunnels(sitn, &list);
1219 unregister_netdevice_queue(sitn->fb_tunnel_dev, &list); 1205 unregister_netdevice_queue(sitn->fb_tunnel_dev, &list);
1220 unregister_netdevice_many(&list); 1206 unregister_netdevice_many(&list);
1221 rtnl_unlock(); 1207 rtnl_unlock();
1222 kfree(sitn);
1223} 1208}
1224 1209
1225static struct pernet_operations sit_net_ops = { 1210static struct pernet_operations sit_net_ops = {
1226 .init = sit_init_net, 1211 .init = sit_init_net,
1227 .exit = sit_exit_net, 1212 .exit = sit_exit_net,
1213 .id = &sit_net_id,
1214 .size = sizeof(struct sit_net),
1228}; 1215};
1229 1216
1230static void __exit sit_cleanup(void) 1217static void __exit sit_cleanup(void)
1231{ 1218{
1232 xfrm4_tunnel_deregister(&sit_handler, AF_INET6); 1219 xfrm4_tunnel_deregister(&sit_handler, AF_INET6);
1233 1220
1234 unregister_pernet_gen_device(sit_net_id, &sit_net_ops); 1221 unregister_pernet_device(&sit_net_ops);
1235 rcu_barrier(); /* Wait for completion of call_rcu()'s */ 1222 rcu_barrier(); /* Wait for completion of call_rcu()'s */
1236} 1223}
1237 1224
@@ -1246,7 +1233,7 @@ static int __init sit_init(void)
1246 return -EAGAIN; 1233 return -EAGAIN;
1247 } 1234 }
1248 1235
1249 err = register_pernet_gen_device(&sit_net_id, &sit_net_ops); 1236 err = register_pernet_device(&sit_net_ops);
1250 if (err < 0) 1237 if (err < 0)
1251 xfrm4_tunnel_deregister(&sit_handler, AF_INET6); 1238 xfrm4_tunnel_deregister(&sit_handler, AF_INET6);
1252 1239