Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 112031
b: refs/heads/master
c: 835bcc0
h: refs/heads/master
i:
  112029: 4c48540
  112027: 3606f61
  112023: 6ac9428
  112015: 9bc281c
  111999: c29606f
v: v3
  • Loading branch information
Denis V. Lunev authored and David S. Miller committed Oct 7, 2008
1 parent 2158427 commit 68fc038
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 10 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 4a7e56098f06d505f23f8d7c8d6762221065922a
refs/heads/master: 835bcc0497e18f54153ac9e32b598dd8ffb7aa66
4 changes: 4 additions & 0 deletions trunk/include/net/netns/mib.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,10 @@ struct netns_mib {
DEFINE_SNMP_STAT(struct udp_mib, udplite_statistics);
DEFINE_SNMP_STAT(struct icmp_mib, icmp_statistics);
DEFINE_SNMP_STAT(struct icmpmsg_mib, icmpmsg_statistics);

#if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE)
struct proc_dir_entry *proc_net_devsnmp6;
#endif
};

#endif
20 changes: 11 additions & 9 deletions trunk/net/ipv6/proc.c
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,6 @@
#include <net/transp_v6.h>
#include <net/ipv6.h>

static struct proc_dir_entry *proc_net_devsnmp6;

static int sockstat6_seq_show(struct seq_file *seq, void *v)
{
struct net *net = seq->private;
Expand Down Expand Up @@ -210,18 +208,20 @@ static const struct file_operations snmp6_seq_fops = {
int snmp6_register_dev(struct inet6_dev *idev)
{
struct proc_dir_entry *p;
struct net *net;

if (!idev || !idev->dev)
return -EINVAL;

if (!net_eq(dev_net(idev->dev), &init_net))
net = dev_net(idev->dev);
if (!net_eq(net, &init_net))
return 0;

if (!proc_net_devsnmp6)
if (!net->mib.proc_net_devsnmp6)
return -ENOENT;

p = proc_create_data(idev->dev->name, S_IRUGO,
proc_net_devsnmp6, &snmp6_seq_fops, idev);
net->mib.proc_net_devsnmp6, &snmp6_seq_fops, idev);
if (!p)
return -ENOMEM;

Expand All @@ -231,12 +231,13 @@ int snmp6_register_dev(struct inet6_dev *idev)

int snmp6_unregister_dev(struct inet6_dev *idev)
{
if (!proc_net_devsnmp6)
struct net *net = dev_net(idev->dev);
if (!net->mib.proc_net_devsnmp6)
return -ENOENT;
if (!idev || !idev->stats.proc_dir_entry)
return -EINVAL;
remove_proc_entry(idev->stats.proc_dir_entry->name,
proc_net_devsnmp6);
net->mib.proc_net_devsnmp6);
idev->stats.proc_dir_entry = NULL;
return 0;
}
Expand Down Expand Up @@ -269,8 +270,9 @@ int __init ipv6_misc_proc_init(void)
if (!proc_net_fops_create(&init_net, "snmp6", S_IRUGO, &snmp6_seq_fops))
goto proc_snmp6_fail;

proc_net_devsnmp6 = proc_mkdir("dev_snmp6", init_net.proc_net);
if (!proc_net_devsnmp6)
init_net.mib.proc_net_devsnmp6 =
proc_mkdir("dev_snmp6", init_net.proc_net);
if (!init_net.mib.proc_net_devsnmp6)
goto proc_dev_snmp6_fail;
out:
return rc;
Expand Down

0 comments on commit 68fc038

Please sign in to comment.