|
@@ -573,3 +573,34 @@ void unregister_pernet_device(struct pernet_operations *ops)
|
|
mutex_unlock(&net_mutex);
|
|
mutex_unlock(&net_mutex);
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(unregister_pernet_device);
|
|
EXPORT_SYMBOL_GPL(unregister_pernet_device);
|
|
|
|
+
|
|
|
|
+#ifdef CONFIG_NET_NS
|
|
|
|
+static void *netns_get(struct task_struct *task)
|
|
|
|
+{
|
|
|
|
+ struct net *net;
|
|
|
|
+ rcu_read_lock();
|
|
|
|
+ net = get_net(task->nsproxy->net_ns);
|
|
|
|
+ rcu_read_unlock();
|
|
|
|
+ return net;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static void netns_put(void *ns)
|
|
|
|
+{
|
|
|
|
+ put_net(ns);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static int netns_install(struct nsproxy *nsproxy, void *ns)
|
|
|
|
+{
|
|
|
|
+ put_net(nsproxy->net_ns);
|
|
|
|
+ nsproxy->net_ns = get_net(ns);
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+const struct proc_ns_operations netns_operations = {
|
|
|
|
+ .name = "net",
|
|
|
|
+ .type = CLONE_NEWNET,
|
|
|
|
+ .get = netns_get,
|
|
|
|
+ .put = netns_put,
|
|
|
|
+ .install = netns_install,
|
|
|
|
+};
|
|
|
|
+#endif
|