aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/isdn
diff options
context:
space:
mode:
authorEric W. Biederman <ebiederm@xmission.com>2007-09-12 06:01:34 -0400
committerDavid S. Miller <davem@sunset.davemloft.net>2007-10-10 19:49:06 -0400
commit457c4cbc5a3dde259d2a1f15d5f9785290397267 (patch)
treea2ceee88780cbce27433b9a4434b3e9251efd81a /drivers/isdn
parent07feaebfcc10cd35e745c7073667935246494bee (diff)
[NET]: Make /proc/net per network namespace
This patch makes /proc/net per network namespace. It modifies the global variables proc_net and proc_net_stat to be per network namespace. The proc_net file helpers are modified to take a network namespace argument, and all of their callers are fixed to pass &init_net for that argument. This ensures that all of the /proc/net files are only visible and usable in the initial network namespace until the code behind them has been updated to be handle multiple network namespaces. Making /proc/net per namespace is necessary as at least some files in /proc/net depend upon the set of network devices which is per network namespace, and even more files in /proc/net have contents that are relevant to a single network namespace. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/isdn')
-rw-r--r--drivers/isdn/divert/divert_procfs.c7
-rw-r--r--drivers/isdn/hardware/eicon/diva_didd.c5
-rw-r--r--drivers/isdn/hysdn/hysdn_procconf.c5
3 files changed, 10 insertions, 7 deletions
diff --git a/drivers/isdn/divert/divert_procfs.c b/drivers/isdn/divert/divert_procfs.c
index 559a0d0244cf..4fd4c46892e3 100644
--- a/drivers/isdn/divert/divert_procfs.c
+++ b/drivers/isdn/divert/divert_procfs.c
@@ -17,6 +17,7 @@
17#include <linux/fs.h> 17#include <linux/fs.h>
18#endif 18#endif
19#include <linux/isdnif.h> 19#include <linux/isdnif.h>
20#include <net/net_namespace.h>
20#include "isdn_divert.h" 21#include "isdn_divert.h"
21 22
22 23
@@ -284,12 +285,12 @@ divert_dev_init(void)
284 init_waitqueue_head(&rd_queue); 285 init_waitqueue_head(&rd_queue);
285 286
286#ifdef CONFIG_PROC_FS 287#ifdef CONFIG_PROC_FS
287 isdn_proc_entry = proc_mkdir("net/isdn", NULL); 288 isdn_proc_entry = proc_mkdir("isdn", init_net.proc_net);
288 if (!isdn_proc_entry) 289 if (!isdn_proc_entry)
289 return (-1); 290 return (-1);
290 isdn_divert_entry = create_proc_entry("divert", S_IFREG | S_IRUGO, isdn_proc_entry); 291 isdn_divert_entry = create_proc_entry("divert", S_IFREG | S_IRUGO, isdn_proc_entry);
291 if (!isdn_divert_entry) { 292 if (!isdn_divert_entry) {
292 remove_proc_entry("net/isdn", NULL); 293 remove_proc_entry("isdn", init_net.proc_net);
293 return (-1); 294 return (-1);
294 } 295 }
295 isdn_divert_entry->proc_fops = &isdn_fops; 296 isdn_divert_entry->proc_fops = &isdn_fops;
@@ -309,7 +310,7 @@ divert_dev_deinit(void)
309 310
310#ifdef CONFIG_PROC_FS 311#ifdef CONFIG_PROC_FS
311 remove_proc_entry("divert", isdn_proc_entry); 312 remove_proc_entry("divert", isdn_proc_entry);
312 remove_proc_entry("net/isdn", NULL); 313 remove_proc_entry("isdn", init_net.proc_net);
313#endif /* CONFIG_PROC_FS */ 314#endif /* CONFIG_PROC_FS */
314 315
315 return (0); 316 return (0);
diff --git a/drivers/isdn/hardware/eicon/diva_didd.c b/drivers/isdn/hardware/eicon/diva_didd.c
index d755d904e62c..993b14cf1778 100644
--- a/drivers/isdn/hardware/eicon/diva_didd.c
+++ b/drivers/isdn/hardware/eicon/diva_didd.c
@@ -15,6 +15,7 @@
15#include <linux/init.h> 15#include <linux/init.h>
16#include <linux/kernel.h> 16#include <linux/kernel.h>
17#include <linux/proc_fs.h> 17#include <linux/proc_fs.h>
18#include <net/net_namespace.h>
18 19
19#include "platform.h" 20#include "platform.h"
20#include "di_defs.h" 21#include "di_defs.h"
@@ -86,7 +87,7 @@ proc_read(char *page, char **start, off_t off, int count, int *eof,
86 87
87static int DIVA_INIT_FUNCTION create_proc(void) 88static int DIVA_INIT_FUNCTION create_proc(void)
88{ 89{
89 proc_net_eicon = proc_mkdir("net/eicon", NULL); 90 proc_net_eicon = proc_mkdir("eicon", init_net.proc_net);
90 91
91 if (proc_net_eicon) { 92 if (proc_net_eicon) {
92 if ((proc_didd = 93 if ((proc_didd =
@@ -102,7 +103,7 @@ static int DIVA_INIT_FUNCTION create_proc(void)
102static void remove_proc(void) 103static void remove_proc(void)
103{ 104{
104 remove_proc_entry(DRIVERLNAME, proc_net_eicon); 105 remove_proc_entry(DRIVERLNAME, proc_net_eicon);
105 remove_proc_entry("net/eicon", NULL); 106 remove_proc_entry("eicon", init_net.proc_net);
106} 107}
107 108
108static int DIVA_INIT_FUNCTION divadidd_init(void) 109static int DIVA_INIT_FUNCTION divadidd_init(void)
diff --git a/drivers/isdn/hysdn/hysdn_procconf.c b/drivers/isdn/hysdn/hysdn_procconf.c
index dc477e0aab0e..27d890b48f88 100644
--- a/drivers/isdn/hysdn/hysdn_procconf.c
+++ b/drivers/isdn/hysdn/hysdn_procconf.c
@@ -16,6 +16,7 @@
16#include <linux/proc_fs.h> 16#include <linux/proc_fs.h>
17#include <linux/pci.h> 17#include <linux/pci.h>
18#include <linux/smp_lock.h> 18#include <linux/smp_lock.h>
19#include <net/net_namespace.h>
19 20
20#include "hysdn_defs.h" 21#include "hysdn_defs.h"
21 22
@@ -392,7 +393,7 @@ hysdn_procconf_init(void)
392 hysdn_card *card; 393 hysdn_card *card;
393 unsigned char conf_name[20]; 394 unsigned char conf_name[20];
394 395
395 hysdn_proc_entry = proc_mkdir(PROC_SUBDIR_NAME, proc_net); 396 hysdn_proc_entry = proc_mkdir(PROC_SUBDIR_NAME, init_net.proc_net);
396 if (!hysdn_proc_entry) { 397 if (!hysdn_proc_entry) {
397 printk(KERN_ERR "HYSDN: unable to create hysdn subdir\n"); 398 printk(KERN_ERR "HYSDN: unable to create hysdn subdir\n");
398 return (-1); 399 return (-1);
@@ -437,5 +438,5 @@ hysdn_procconf_release(void)
437 card = card->next; /* point to next card */ 438 card = card->next; /* point to next card */
438 } 439 }
439 440
440 remove_proc_entry(PROC_SUBDIR_NAME, proc_net); 441 remove_proc_entry(PROC_SUBDIR_NAME, init_net.proc_net);
441} 442}