netns: assign PDE->data before gluing entry into /proc tree
authorDenis V. Lunev <den@openvz.org>
Fri, 2 May 2008 11:12:41 +0000 (04:12 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 2 May 2008 11:12:41 +0000 (04:12 -0700)
In this unfortunate case, proc_mkdir_mode wrapper can't be used anymore and
this is no way to reuse proc_create_data due to nlinks assignment. So,
copy the code from proc_mkdir and assign PDE->data at the appropriate
moment.

Signed-off-by: Denis V. Lunev <den@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
fs/proc/generic.c
fs/proc/proc_net.c

index 9d53b39a9cf8983b8c2e30b9bc1c661dfe89f1b6..43e54e86cefd995aee7fc01d3e32515283472123 100644 (file)
@@ -641,6 +641,23 @@ struct proc_dir_entry *proc_mkdir_mode(const char *name, mode_t mode,
        return ent;
 }
 
+struct proc_dir_entry *proc_net_mkdir(struct net *net, const char *name,
+               struct proc_dir_entry *parent)
+{
+       struct proc_dir_entry *ent;
+
+       ent = __proc_create(&parent, name, S_IFDIR | S_IRUGO | S_IXUGO, 2);
+       if (ent) {
+               ent->data = net;
+               if (proc_register(parent, ent) < 0) {
+                       kfree(ent);
+                       ent = NULL;
+               }
+       }
+       return ent;
+}
+EXPORT_SYMBOL_GPL(proc_net_mkdir);
+
 struct proc_dir_entry *proc_mkdir(const char *name,
                struct proc_dir_entry *parent)
 {
index 13cd7835d0dfdc5027c61df7270bbb61d51d2273..83f357b30d71c583e4662784e53639b5391cf84e 100644 (file)
@@ -159,17 +159,6 @@ struct net *get_proc_net(const struct inode *inode)
 }
 EXPORT_SYMBOL_GPL(get_proc_net);
 
-struct proc_dir_entry *proc_net_mkdir(struct net *net, const char *name,
-               struct proc_dir_entry *parent)
-{
-       struct proc_dir_entry *pde;
-       pde = proc_mkdir_mode(name, S_IRUGO | S_IXUGO, parent);
-       if (pde != NULL)
-               pde->data = net;
-       return pde;
-}
-EXPORT_SYMBOL_GPL(proc_net_mkdir);
-
 static __net_init int proc_net_ns_init(struct net *net)
 {
        struct proc_dir_entry *netd, *net_statd;