[Devel] [PATCH RHEL COMMIT] ve/proc/net: virtualize all the network proc entries
Konstantin Khorenko
khorenko at virtuozzo.com
Fri Sep 24 15:48:54 MSK 2021
The commit is pushed to "branch-rh9-5.14.vz9.1.x-ovz" and will appear at https://src.openvz.org/scm/ovz/vzkernel.git
after ark-5.14
------>
commit 80540c1eb0e67c70132940d9603f41a5030e15b6
Author: Stanislav Kinsburskiy <skinsbursky at virtuozzo.com>
Date: Fri Sep 24 15:48:53 2021 +0300
ve/proc/net: virtualize all the network proc entries
Directories should be created via proc_net_mkdir(),
files via proc_net_create() or proc_net_create_data() to become visible in a
container.
Signed-off-by: Konstantin Khlebnikov <khlebnikov at openvz.org>
Signed-off-by: Stanislav Kinsburskiy <skinsbursky at virtuozzo.com>
khorenko@: TODO: helpers are to be renamed.
Rebased to vz9:
- since commit d56c0d45f0e2 ("proc: decouple proc from VFS with "struct proc_ops"")
proc_create() now uses struct proc_ops instead of struct file_operations.
Change accordingly.
(cherry picked from vz8 commit 8537747aac81b4c3a8ce80389fe5fb53013d21e5)
Signed-off-by: Andrey Zhadchenko <andrey.zhadchenko at virtuozzo.com>
---
drivers/net/bonding/bond_procfs.c | 5 +++--
drivers/net/ppp/pppoe.c | 2 +-
include/linux/proc_fs.h | 8 ++++----
net/8021q/vlanproc.c | 4 ++--
net/bluetooth/af_bluetooth.c | 2 +-
net/core/net-procfs.c | 8 ++++----
net/core/pktgen.c | 2 +-
net/core/sock.c | 2 +-
net/ipv4/arp.c | 2 +-
net/ipv4/fib_trie.c | 6 +++---
net/ipv4/igmp.c | 4 ++--
net/ipv4/ipmr.c | 4 ++--
net/ipv4/netfilter/ipt_CLUSTERIP.c | 2 +-
net/ipv4/ping.c | 2 +-
net/ipv4/proc.c | 6 +++---
net/ipv4/raw.c | 2 +-
net/ipv4/route.c | 6 +++---
net/ipv4/tcp_ipv4.c | 2 +-
net/ipv4/udp.c | 2 +-
net/ipv6/addrconf.c | 2 +-
net/ipv6/anycast.c | 2 +-
net/ipv6/ip6_flowlabel.c | 2 +-
net/ipv6/ip6mr.c | 4 ++--
net/ipv6/mcast.c | 4 ++--
net/ipv6/proc.c | 8 ++++----
net/ipv6/raw.c | 2 +-
net/ipv6/route.c | 4 ++--
net/key/af_key.c | 2 +-
net/l2tp/l2tp_ppp.c | 2 +-
net/netfilter/ipvs/ip_vs_app.c | 2 +-
net/netfilter/ipvs/ip_vs_conn.c | 4 ++--
net/netfilter/ipvs/ip_vs_ctl.c | 6 +++---
net/netfilter/nf_conntrack_expect.c | 2 +-
net/netfilter/nf_conntrack_standalone.c | 4 ++--
net/netfilter/nf_synproxy_core.c | 2 +-
net/netfilter/x_tables.c | 6 +++---
net/netfilter/xt_hashlimit.c | 6 +++---
net/netfilter/xt_recent.c | 4 ++--
net/netlink/af_netlink.c | 2 +-
net/packet/af_packet.c | 2 +-
net/phonet/pn_dev.c | 2 +-
net/sched/sch_api.c | 2 +-
net/sctp/objcnt.c | 2 +-
net/sctp/proc.c | 8 ++++----
net/sunrpc/cache.c | 8 ++++----
net/sunrpc/stats.c | 4 ++--
net/unix/af_unix.c | 2 +-
net/wireless/wext-proc.c | 2 +-
net/xfrm/xfrm_proc.c | 2 +-
49 files changed, 88 insertions(+), 87 deletions(-)
diff --git a/drivers/net/bonding/bond_procfs.c b/drivers/net/bonding/bond_procfs.c
index 0fb1da361bb1..d7d5ae5a5a3e 100644
--- a/drivers/net/bonding/bond_procfs.c
+++ b/drivers/net/bonding/bond_procfs.c
@@ -267,7 +267,7 @@ void bond_create_proc_entry(struct bonding *bond)
struct bond_net *bn = net_generic(dev_net(bond_dev), bond_net_id);
if (bn->proc_dir) {
- bond->proc_entry = proc_create_seq_data(bond_dev->name, 0444,
+ bond->proc_entry = proc_net_create_seq_data(bond_dev->name, 0444,
bn->proc_dir, &bond_info_seq_ops, bond);
if (bond->proc_entry == NULL)
netdev_warn(bond_dev, "Cannot create /proc/net/%s/%s\n",
@@ -295,7 +295,8 @@ void bond_remove_proc_entry(struct bonding *bond)
void __net_init bond_create_proc_dir(struct bond_net *bn)
{
if (!bn->proc_dir) {
- bn->proc_dir = proc_mkdir(DRV_NAME, bn->net->proc_net);
+ bn->proc_dir = proc_net_mkdir(bn->net, DRV_NAME,
+ bn->net->proc_net);
if (!bn->proc_dir)
pr_warn("Warning: Cannot create /proc/net/%s\n",
DRV_NAME);
diff --git a/drivers/net/ppp/pppoe.c b/drivers/net/ppp/pppoe.c
index 7d20af8bf4fd..4b18dc9b28a4 100644
--- a/drivers/net/ppp/pppoe.c
+++ b/drivers/net/ppp/pppoe.c
@@ -1177,7 +1177,7 @@ static __net_init int pppoe_init_net(struct net *net)
rwlock_init(&pn->hash_lock);
- pde = proc_create_net("pppoe", 0444, net->proc_net,
+ pde = proc_net_create_net("pppoe", 0444, net->proc_net,
&pppoe_seq_ops, sizeof(struct seq_net_private));
#ifdef CONFIG_PROC_FS
if (!pde)
diff --git a/include/linux/proc_fs.h b/include/linux/proc_fs.h
index e89d4bfc48a0..51504694bf41 100644
--- a/include/linux/proc_fs.h
+++ b/include/linux/proc_fs.h
@@ -211,16 +211,16 @@ static inline struct proc_dir_entry *proc_net_mkdir(
static inline struct proc_dir_entry *proc_net_create_data(const char *name,
umode_t mode, struct proc_dir_entry *parent,
- const struct file_operations *fops, void *data)
+ const struct proc_ops *proc_ops, void *data)
{
- return proc_create_data(name, S_ISVTX | mode, parent, fops, data);
+ return proc_create_data(name, S_ISVTX | mode, parent, proc_ops, data);
}
static inline struct proc_dir_entry *proc_net_create(const char *name,
umode_t mode, struct proc_dir_entry *parent,
- const struct file_operations *fops)
+ const struct proc_ops *proc_ops)
{
- return proc_net_create_data(name, mode, parent, fops, NULL);
+ return proc_net_create_data(name, mode, parent, proc_ops, NULL);
}
static inline struct proc_dir_entry *proc_net_create_seq_private(
diff --git a/net/8021q/vlanproc.c b/net/8021q/vlanproc.c
index ec87dea23719..cafdde58c503 100644
--- a/net/8021q/vlanproc.c
+++ b/net/8021q/vlanproc.c
@@ -116,7 +116,7 @@ int __net_init vlan_proc_init(struct net *net)
if (!vn->proc_vlan_dir)
goto err;
- vn->proc_vlan_conf = proc_create_net(name_conf, S_IFREG | 0600,
+ vn->proc_vlan_conf = proc_net_create_net(name_conf, S_IFREG | 0600,
vn->proc_vlan_dir, &vlan_seq_ops,
sizeof(struct seq_net_private));
if (!vn->proc_vlan_conf)
@@ -140,7 +140,7 @@ int vlan_proc_add_dev(struct net_device *vlandev)
if (!strcmp(vlandev->name, name_conf))
return -EINVAL;
- vlan->dent = proc_create_single_data(vlandev->name, S_IFREG | 0600,
+ vlan->dent = proc_net_create_single_data(vlandev->name, S_IFREG | 0600,
vn->proc_vlan_dir, vlandev_seq_show, vlandev);
if (!vlan->dent)
return -ENOBUFS;
diff --git a/net/bluetooth/af_bluetooth.c b/net/bluetooth/af_bluetooth.c
index 1661979b6a6e..0932cec6e667 100644
--- a/net/bluetooth/af_bluetooth.c
+++ b/net/bluetooth/af_bluetooth.c
@@ -682,7 +682,7 @@ int bt_procfs_init(struct net *net, const char *name,
{
sk_list->custom_seq_show = seq_show;
- if (!proc_create_seq_data(name, 0, net->proc_net, &bt_seq_ops, sk_list))
+ if (!proc_net_create_seq_data(name, 0, net->proc_net, &bt_seq_ops, sk_list))
return -ENOMEM;
return 0;
}
diff --git a/net/core/net-procfs.c b/net/core/net-procfs.c
index d8b9dbabd4a4..38b4fc30159b 100644
--- a/net/core/net-procfs.c
+++ b/net/core/net-procfs.c
@@ -284,13 +284,13 @@ static int __net_init dev_proc_net_init(struct net *net)
{
int rc = -ENOMEM;
- if (!proc_create_net("dev", 0444, net->proc_net, &dev_seq_ops,
+ if (!proc_net_create_net("dev", 0444, net->proc_net, &dev_seq_ops,
sizeof(struct seq_net_private)))
goto out;
- if (!proc_create_seq("softnet_stat", 0444, net->proc_net,
+ if (!proc_net_create_seq("softnet_stat", 0444, net->proc_net,
&softnet_seq_ops))
goto out_dev;
- if (!proc_create_net("ptype", 0444, net->proc_net, &ptype_seq_ops,
+ if (!proc_net_create_net("ptype", 0444, net->proc_net, &ptype_seq_ops,
sizeof(struct seq_net_private)))
goto out_softnet;
@@ -350,7 +350,7 @@ static const struct seq_operations dev_mc_seq_ops = {
static int __net_init dev_mc_net_init(struct net *net)
{
- if (!proc_create_net("dev_mcast", 0, net->proc_net, &dev_mc_seq_ops,
+ if (!proc_net_create_net("dev_mcast", 0, net->proc_net, &dev_mc_seq_ops,
sizeof(struct seq_net_private)))
return -ENOMEM;
return 0;
diff --git a/net/core/pktgen.c b/net/core/pktgen.c
index 7e258d255e90..eabab0f1d21f 100644
--- a/net/core/pktgen.c
+++ b/net/core/pktgen.c
@@ -3776,7 +3776,7 @@ static int __net_init pg_net_init(struct net *net)
pn->net = net;
INIT_LIST_HEAD(&pn->pktgen_threads);
pn->pktgen_exiting = false;
- pn->proc_dir = proc_mkdir(PG_PROC_DIR, pn->net->proc_net);
+ pn->proc_dir = proc_net_mkdir(pn->net, PG_PROC_DIR, pn->net->proc_net);
if (!pn->proc_dir) {
pr_warn("cannot create /proc/net/%s\n", PG_PROC_DIR);
return -ENODEV;
diff --git a/net/core/sock.c b/net/core/sock.c
index a3eea6e0b30a..29c907648342 100644
--- a/net/core/sock.c
+++ b/net/core/sock.c
@@ -3783,7 +3783,7 @@ static const struct seq_operations proto_seq_ops = {
static __net_init int proto_init_net(struct net *net)
{
- if (!proc_create_net("protocols", 0444, net->proc_net, &proto_seq_ops,
+ if (!proc_net_create_net("protocols", 0444, net->proc_net, &proto_seq_ops,
sizeof(struct seq_net_private)))
return -ENOMEM;
diff --git a/net/ipv4/arp.c b/net/ipv4/arp.c
index 922dd73e5740..45f7f7d83399 100644
--- a/net/ipv4/arp.c
+++ b/net/ipv4/arp.c
@@ -1426,7 +1426,7 @@ static const struct seq_operations arp_seq_ops = {
static int __net_init arp_net_init(struct net *net)
{
- if (!proc_create_net("arp", 0444, net->proc_net, &arp_seq_ops,
+ if (!proc_net_create_net("arp", 0444, net->proc_net, &arp_seq_ops,
sizeof(struct neigh_seq_state)))
return -ENOMEM;
return 0;
diff --git a/net/ipv4/fib_trie.c b/net/ipv4/fib_trie.c
index 25cf387cca5b..6611ed3cba97 100644
--- a/net/ipv4/fib_trie.c
+++ b/net/ipv4/fib_trie.c
@@ -3014,15 +3014,15 @@ static const struct seq_operations fib_route_seq_ops = {
int __net_init fib_proc_init(struct net *net)
{
- if (!proc_create_net("fib_trie", 0444, net->proc_net, &fib_trie_seq_ops,
+ if (!proc_net_create_net("fib_trie", 0444, net->proc_net, &fib_trie_seq_ops,
sizeof(struct fib_trie_iter)))
goto out1;
- if (!proc_create_net_single("fib_triestat", 0444, net->proc_net,
+ if (!proc_net_create_net_single("fib_triestat", 0444, net->proc_net,
fib_triestat_seq_show, NULL))
goto out2;
- if (!proc_create_net("route", 0444, net->proc_net, &fib_route_seq_ops,
+ if (!proc_net_create_net("route", 0444, net->proc_net, &fib_route_seq_ops,
sizeof(struct fib_route_iter)))
goto out3;
diff --git a/net/ipv4/igmp.c b/net/ipv4/igmp.c
index 00576bae183d..2138da37ee37 100644
--- a/net/ipv4/igmp.c
+++ b/net/ipv4/igmp.c
@@ -3003,11 +3003,11 @@ static int __net_init igmp_net_init(struct net *net)
struct proc_dir_entry *pde;
int err;
- pde = proc_create_net("igmp", 0444, net->proc_net, &igmp_mc_seq_ops,
+ pde = proc_net_create_net("igmp", 0444, net->proc_net, &igmp_mc_seq_ops,
sizeof(struct igmp_mc_iter_state));
if (!pde)
goto out_igmp;
- pde = proc_create_net("mcfilter", 0444, net->proc_net,
+ pde = proc_net_create_net("mcfilter", 0444, net->proc_net,
&igmp_mcf_seq_ops, sizeof(struct igmp_mcf_iter_state));
if (!pde)
goto out_mcfilter;
diff --git a/net/ipv4/ipmr.c b/net/ipv4/ipmr.c
index 2dda856ca260..2b3db4ed782c 100644
--- a/net/ipv4/ipmr.c
+++ b/net/ipv4/ipmr.c
@@ -3066,10 +3066,10 @@ static int __net_init ipmr_net_init(struct net *net)
#ifdef CONFIG_PROC_FS
err = -ENOMEM;
- if (!proc_create_net("ip_mr_vif", 0, net->proc_net, &ipmr_vif_seq_ops,
+ if (!proc_net_create_net("ip_mr_vif", 0, net->proc_net, &ipmr_vif_seq_ops,
sizeof(struct mr_vif_iter)))
goto proc_vif_fail;
- if (!proc_create_net("ip_mr_cache", 0, net->proc_net, &ipmr_mfc_seq_ops,
+ if (!proc_net_create_net("ip_mr_cache", 0, net->proc_net, &ipmr_mfc_seq_ops,
sizeof(struct mr_mfc_iter)))
goto proc_cache_fail;
#endif
diff --git a/net/ipv4/netfilter/ipt_CLUSTERIP.c b/net/ipv4/netfilter/ipt_CLUSTERIP.c
index 8f7ca67475b7..46d8c23fd7ae 100644
--- a/net/ipv4/netfilter/ipt_CLUSTERIP.c
+++ b/net/ipv4/netfilter/ipt_CLUSTERIP.c
@@ -828,7 +828,7 @@ static int clusterip_net_init(struct net *net)
return ret;
#ifdef CONFIG_PROC_FS
- cn->procdir = proc_mkdir("ipt_CLUSTERIP", net->proc_net);
+ cn->procdir = proc_net_mkdir(net, "ipt_CLUSTERIP", net->proc_net);
if (!cn->procdir) {
nf_unregister_net_hook(net, &cip_arp_ops);
pr_err("Unable to proc dir entry\n");
diff --git a/net/ipv4/ping.c b/net/ipv4/ping.c
index 1e44a43acfe2..846ddcf31541 100644
--- a/net/ipv4/ping.c
+++ b/net/ipv4/ping.c
@@ -1140,7 +1140,7 @@ static const struct seq_operations ping_v4_seq_ops = {
static int __net_init ping_v4_proc_init_net(struct net *net)
{
- if (!proc_create_net("icmp", 0444, net->proc_net, &ping_v4_seq_ops,
+ if (!proc_net_create_net("icmp", 0444, net->proc_net, &ping_v4_seq_ops,
sizeof(struct ping_iter_state)))
return -ENOMEM;
return 0;
diff --git a/net/ipv4/proc.c b/net/ipv4/proc.c
index b0d3a09dc84e..077438362b0d 100644
--- a/net/ipv4/proc.c
+++ b/net/ipv4/proc.c
@@ -519,13 +519,13 @@ static int netstat_seq_show(struct seq_file *seq, void *v)
static __net_init int ip_proc_init_net(struct net *net)
{
- if (!proc_create_net_single("sockstat", 0444, net->proc_net,
+ if (!proc_net_create_net_single("sockstat", 0444, net->proc_net,
sockstat_seq_show, NULL))
goto out_sockstat;
- if (!proc_create_net_single("netstat", 0444, net->proc_net,
+ if (!proc_net_create_net_single("netstat", 0444, net->proc_net,
netstat_seq_show, NULL))
goto out_netstat;
- if (!proc_create_net_single("snmp", 0444, net->proc_net, snmp_seq_show,
+ if (!proc_net_create_net_single("snmp", 0444, net->proc_net, snmp_seq_show,
NULL))
goto out_snmp;
diff --git a/net/ipv4/raw.c b/net/ipv4/raw.c
index bb446e60cf58..60ed42e52852 100644
--- a/net/ipv4/raw.c
+++ b/net/ipv4/raw.c
@@ -1083,7 +1083,7 @@ static const struct seq_operations raw_seq_ops = {
static __net_init int raw_init_net(struct net *net)
{
- if (!proc_create_net_data("raw", 0444, net->proc_net, &raw_seq_ops,
+ if (!proc_net_create_net_data("raw", 0444, net->proc_net, &raw_seq_ops,
sizeof(struct raw_iter_state), &raw_v4_hashinfo))
return -ENOMEM;
diff --git a/net/ipv4/route.c b/net/ipv4/route.c
index a6f20ee35335..56f8bf46b401 100644
--- a/net/ipv4/route.c
+++ b/net/ipv4/route.c
@@ -342,18 +342,18 @@ static int __net_init ip_rt_do_proc_init(struct net *net)
{
struct proc_dir_entry *pde;
- pde = proc_create_seq("rt_cache", 0444, net->proc_net,
+ pde = proc_net_create_seq("rt_cache", 0444, net->proc_net,
&rt_cache_seq_ops);
if (!pde)
goto err1;
- pde = proc_create_seq("rt_cache", 0444, net->proc_net_stat,
+ pde = proc_net_create_seq("rt_cache", 0444, net->proc_net_stat,
&rt_cpu_seq_ops);
if (!pde)
goto err2;
#ifdef CONFIG_IP_ROUTE_CLASSID
- pde = proc_create_single("rt_acct", 0, net->proc_net,
+ pde = proc_net_create_single("rt_acct", 0, net->proc_net,
rt_acct_proc_show);
if (!pde)
goto err3;
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c
index a692626c19e4..0bbd56decc74 100644
--- a/net/ipv4/tcp_ipv4.c
+++ b/net/ipv4/tcp_ipv4.c
@@ -2767,7 +2767,7 @@ static struct tcp_seq_afinfo tcp4_seq_afinfo = {
static int __net_init tcp4_proc_init_net(struct net *net)
{
- if (!proc_create_net_data("tcp", 0444, net->proc_net, &tcp4_seq_ops,
+ if (!proc_net_create_net_data("tcp", 0444, net->proc_net, &tcp4_seq_ops,
sizeof(struct tcp_iter_state), &tcp4_seq_afinfo))
return -ENOMEM;
return 0;
diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c
index 1a742b710e54..4983a4cce48b 100644
--- a/net/ipv4/udp.c
+++ b/net/ipv4/udp.c
@@ -3149,7 +3149,7 @@ static struct udp_seq_afinfo udp4_seq_afinfo = {
static int __net_init udp4_proc_init_net(struct net *net)
{
- if (!proc_create_net_data("udp", 0444, net->proc_net, &udp_seq_ops,
+ if (!proc_net_create_net_data("udp", 0444, net->proc_net, &udp_seq_ops,
sizeof(struct udp_iter_state), &udp4_seq_afinfo))
return -ENOMEM;
return 0;
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c
index 3bf685fe64b9..db00087c29e9 100644
--- a/net/ipv6/addrconf.c
+++ b/net/ipv6/addrconf.c
@@ -4343,7 +4343,7 @@ static const struct seq_operations if6_seq_ops = {
static int __net_init if6_proc_net_init(struct net *net)
{
- if (!proc_create_net("if_inet6", 0444, net->proc_net, &if6_seq_ops,
+ if (!proc_net_create_net("if_inet6", 0444, net->proc_net, &if6_seq_ops,
sizeof(struct if6_iter_state)))
return -ENOMEM;
return 0;
diff --git a/net/ipv6/anycast.c b/net/ipv6/anycast.c
index dacdea7fcb62..40a384667528 100644
--- a/net/ipv6/anycast.c
+++ b/net/ipv6/anycast.c
@@ -584,7 +584,7 @@ static const struct seq_operations ac6_seq_ops = {
int __net_init ac6_proc_init(struct net *net)
{
- if (!proc_create_net("anycast6", 0444, net->proc_net, &ac6_seq_ops,
+ if (!proc_net_create_net("anycast6", 0444, net->proc_net, &ac6_seq_ops,
sizeof(struct ac6_iter_state)))
return -ENOMEM;
diff --git a/net/ipv6/ip6_flowlabel.c b/net/ipv6/ip6_flowlabel.c
index aa673a6a7e43..8bb246fd33d0 100644
--- a/net/ipv6/ip6_flowlabel.c
+++ b/net/ipv6/ip6_flowlabel.c
@@ -863,7 +863,7 @@ static const struct seq_operations ip6fl_seq_ops = {
static int __net_init ip6_flowlabel_proc_init(struct net *net)
{
- if (!proc_create_net("ip6_flowlabel", 0444, net->proc_net,
+ if (!proc_net_create_net("ip6_flowlabel", 0444, net->proc_net,
&ip6fl_seq_ops, sizeof(struct ip6fl_iter_state)))
return -ENOMEM;
return 0;
diff --git a/net/ipv6/ip6mr.c b/net/ipv6/ip6mr.c
index 06b0d2c329b9..520dbb4b5dc5 100644
--- a/net/ipv6/ip6mr.c
+++ b/net/ipv6/ip6mr.c
@@ -1314,10 +1314,10 @@ static int __net_init ip6mr_net_init(struct net *net)
#ifdef CONFIG_PROC_FS
err = -ENOMEM;
- if (!proc_create_net("ip6_mr_vif", 0, net->proc_net, &ip6mr_vif_seq_ops,
+ if (!proc_net_create_net("ip6_mr_vif", 0, net->proc_net, &ip6mr_vif_seq_ops,
sizeof(struct mr_vif_iter)))
goto proc_vif_fail;
- if (!proc_create_net("ip6_mr_cache", 0, net->proc_net, &ipmr_mfc_seq_ops,
+ if (!proc_net_create_net("ip6_mr_cache", 0, net->proc_net, &ipmr_mfc_seq_ops,
sizeof(struct mr_mfc_iter)))
goto proc_cache_fail;
#endif
diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c
index 54ec163fbafa..1892eb8d8dd0 100644
--- a/net/ipv6/mcast.c
+++ b/net/ipv6/mcast.c
@@ -3095,10 +3095,10 @@ static int __net_init igmp6_proc_init(struct net *net)
int err;
err = -ENOMEM;
- if (!proc_create_net("igmp6", 0444, net->proc_net, &igmp6_mc_seq_ops,
+ if (!proc_net_create_net("igmp6", 0444, net->proc_net, &igmp6_mc_seq_ops,
sizeof(struct igmp6_mc_iter_state)))
goto out;
- if (!proc_create_net("mcfilter6", 0444, net->proc_net,
+ if (!proc_net_create_net("mcfilter6", 0444, net->proc_net,
&igmp6_mcf_seq_ops,
sizeof(struct igmp6_mcf_iter_state)))
goto out_proc_net_igmp6;
diff --git a/net/ipv6/proc.c b/net/ipv6/proc.c
index d6306aa46bb1..51f71b37bba0 100644
--- a/net/ipv6/proc.c
+++ b/net/ipv6/proc.c
@@ -253,7 +253,7 @@ int snmp6_register_dev(struct inet6_dev *idev)
if (!net->mib.proc_net_devsnmp6)
return -ENOENT;
- p = proc_create_single_data(idev->dev->name, 0444,
+ p = proc_net_create_single_data(idev->dev->name, 0444,
net->mib.proc_net_devsnmp6, snmp6_dev_seq_show, idev);
if (!p)
return -ENOMEM;
@@ -276,15 +276,15 @@ int snmp6_unregister_dev(struct inet6_dev *idev)
static int __net_init ipv6_proc_init_net(struct net *net)
{
- if (!proc_create_net_single("sockstat6", 0444, net->proc_net,
+ if (!proc_net_create_net_single("sockstat6", 0444, net->proc_net,
sockstat6_seq_show, NULL))
return -ENOMEM;
- if (!proc_create_net_single("snmp6", 0444, net->proc_net,
+ if (!proc_net_create_net_single("snmp6", 0444, net->proc_net,
snmp6_seq_show, NULL))
goto proc_snmp6_fail;
- net->mib.proc_net_devsnmp6 = proc_mkdir("dev_snmp6", net->proc_net);
+ net->mib.proc_net_devsnmp6 = proc_net_mkdir(net, "dev_snmp6", net->proc_net);
if (!net->mib.proc_net_devsnmp6)
goto proc_dev_snmp6_fail;
return 0;
diff --git a/net/ipv6/raw.c b/net/ipv6/raw.c
index 60f1e4f5be5a..bc020d6b3fba 100644
--- a/net/ipv6/raw.c
+++ b/net/ipv6/raw.c
@@ -1277,7 +1277,7 @@ static const struct seq_operations raw6_seq_ops = {
static int __net_init raw6_init_net(struct net *net)
{
- if (!proc_create_net_data("raw6", 0444, net->proc_net, &raw6_seq_ops,
+ if (!proc_net_create_net_data("raw6", 0444, net->proc_net, &raw6_seq_ops,
sizeof(struct raw_iter_state), &raw_v6_hashinfo))
return -ENOMEM;
diff --git a/net/ipv6/route.c b/net/ipv6/route.c
index c5e8ecb96426..772de1c240cd 100644
--- a/net/ipv6/route.c
+++ b/net/ipv6/route.c
@@ -6529,9 +6529,9 @@ static void __net_exit ip6_route_net_exit(struct net *net)
static int __net_init ip6_route_net_init_late(struct net *net)
{
#ifdef CONFIG_PROC_FS
- proc_create_net("ipv6_route", 0, net->proc_net, &ipv6_route_seq_ops,
+ proc_net_create_net("ipv6_route", 0, net->proc_net, &ipv6_route_seq_ops,
sizeof(struct ipv6_route_iter));
- proc_create_net_single("rt6_stats", 0444, net->proc_net,
+ proc_net_create_net_single("rt6_stats", 0444, net->proc_net,
rt6_stats_seq_show, NULL);
#endif
return 0;
diff --git a/net/key/af_key.c b/net/key/af_key.c
index de24a7d474df..bb9d8cddd9eb 100644
--- a/net/key/af_key.c
+++ b/net/key/af_key.c
@@ -3807,7 +3807,7 @@ static int __net_init pfkey_init_proc(struct net *net)
{
struct proc_dir_entry *e;
- e = proc_create_net("pfkey", 0, net->proc_net, &pfkey_seq_ops,
+ e = proc_net_create_net("pfkey", 0, net->proc_net, &pfkey_seq_ops,
sizeof(struct seq_net_private));
if (e == NULL)
return -ENOMEM;
diff --git a/net/l2tp/l2tp_ppp.c b/net/l2tp/l2tp_ppp.c
index 9494212b078e..9121c9162299 100644
--- a/net/l2tp/l2tp_ppp.c
+++ b/net/l2tp/l2tp_ppp.c
@@ -1618,7 +1618,7 @@ static __net_init int pppol2tp_init_net(struct net *net)
struct proc_dir_entry *pde;
int err = 0;
- pde = proc_create_net("pppol2tp", 0444, net->proc_net,
+ pde = proc_net_create_net("pppol2tp", 0444, net->proc_net,
&pppol2tp_seq_ops, sizeof(struct pppol2tp_seq_data));
if (!pde) {
err = -ENOMEM;
diff --git a/net/netfilter/ipvs/ip_vs_app.c b/net/netfilter/ipvs/ip_vs_app.c
index f9b16f2b2219..8644d2ff0d7e 100644
--- a/net/netfilter/ipvs/ip_vs_app.c
+++ b/net/netfilter/ipvs/ip_vs_app.c
@@ -599,7 +599,7 @@ static const struct seq_operations ip_vs_app_seq_ops = {
int __net_init ip_vs_app_net_init(struct netns_ipvs *ipvs)
{
INIT_LIST_HEAD(&ipvs->app_list);
- proc_create_net("ip_vs_app", 0, ipvs->net->proc_net, &ip_vs_app_seq_ops,
+ proc_net_create_net("ip_vs_app", 0, ipvs->net->proc_net, &ip_vs_app_seq_ops,
sizeof(struct seq_net_private));
return 0;
}
diff --git a/net/netfilter/ipvs/ip_vs_conn.c b/net/netfilter/ipvs/ip_vs_conn.c
index c100c6b112c8..a159c75bb39c 100644
--- a/net/netfilter/ipvs/ip_vs_conn.c
+++ b/net/netfilter/ipvs/ip_vs_conn.c
@@ -1447,9 +1447,9 @@ int __net_init ip_vs_conn_net_init(struct netns_ipvs *ipvs)
{
atomic_set(&ipvs->conn_count, 0);
- proc_create_net("ip_vs_conn", 0, ipvs->net->proc_net,
+ proc_net_create_net("ip_vs_conn", 0, ipvs->net->proc_net,
&ip_vs_conn_seq_ops, sizeof(struct ip_vs_iter_state));
- proc_create_net("ip_vs_conn_sync", 0, ipvs->net->proc_net,
+ proc_net_create_net("ip_vs_conn_sync", 0, ipvs->net->proc_net,
&ip_vs_conn_sync_seq_ops,
sizeof(struct ip_vs_iter_state));
return 0;
diff --git a/net/netfilter/ipvs/ip_vs_ctl.c b/net/netfilter/ipvs/ip_vs_ctl.c
index 14e26a7e55c5..21e6d704ebbc 100644
--- a/net/netfilter/ipvs/ip_vs_ctl.c
+++ b/net/netfilter/ipvs/ip_vs_ctl.c
@@ -4168,13 +4168,13 @@ int __net_init ip_vs_control_net_init(struct netns_ipvs *ipvs)
spin_lock_init(&ipvs->tot_stats.lock);
#ifdef CONFIG_PROC_FS
- if (!proc_create_net("ip_vs", 0, ipvs->net->proc_net,
+ if (!proc_net_create_net("ip_vs", 0, ipvs->net->proc_net,
&ip_vs_info_seq_ops, sizeof(struct ip_vs_iter)))
goto err_vs;
- if (!proc_create_net_single("ip_vs_stats", 0, ipvs->net->proc_net,
+ if (!proc_net_create_net_single("ip_vs_stats", 0, ipvs->net->proc_net,
ip_vs_stats_show, NULL))
goto err_stats;
- if (!proc_create_net_single("ip_vs_stats_percpu", 0,
+ if (!proc_net_create_net_single("ip_vs_stats_percpu", 0,
ipvs->net->proc_net,
ip_vs_stats_percpu_show, NULL))
goto err_percpu;
diff --git a/net/netfilter/nf_conntrack_expect.c b/net/netfilter/nf_conntrack_expect.c
index 1e851bc2e61a..13c071fbe2ef 100644
--- a/net/netfilter/nf_conntrack_expect.c
+++ b/net/netfilter/nf_conntrack_expect.c
@@ -671,7 +671,7 @@ static int exp_proc_init(struct net *net)
kuid_t root_uid;
kgid_t root_gid;
- proc = proc_create_net("nf_conntrack_expect", 0440, net->proc_net,
+ proc = proc_net_create_net("nf_conntrack_expect", 0440, net->proc_net,
&exp_seq_ops, sizeof(struct ct_expect_iter_state));
if (!proc)
return -ENOMEM;
diff --git a/net/netfilter/nf_conntrack_standalone.c b/net/netfilter/nf_conntrack_standalone.c
index e84b499b7bfa..615ecfa32a4a 100644
--- a/net/netfilter/nf_conntrack_standalone.c
+++ b/net/netfilter/nf_conntrack_standalone.c
@@ -472,7 +472,7 @@ static int nf_conntrack_standalone_init_proc(struct net *net)
kuid_t root_uid;
kgid_t root_gid;
- pde = proc_create_net("nf_conntrack", 0440, net->proc_net, &ct_seq_ops,
+ pde = proc_net_create_net("nf_conntrack", 0440, net->proc_net, &ct_seq_ops,
sizeof(struct ct_iter_state));
if (!pde)
goto out_nf_conntrack;
@@ -482,7 +482,7 @@ static int nf_conntrack_standalone_init_proc(struct net *net)
if (uid_valid(root_uid) && gid_valid(root_gid))
proc_set_user(pde, root_uid, root_gid);
- pde = proc_create_net("nf_conntrack", 0444, net->proc_net_stat,
+ pde = proc_net_create_net("nf_conntrack", 0444, net->proc_net_stat,
&ct_cpu_seq_ops, sizeof(struct seq_net_private));
if (!pde)
goto out_stat_nf_conntrack;
diff --git a/net/netfilter/nf_synproxy_core.c b/net/netfilter/nf_synproxy_core.c
index 3d6d49420db8..5759f146a24f 100644
--- a/net/netfilter/nf_synproxy_core.c
+++ b/net/netfilter/nf_synproxy_core.c
@@ -311,7 +311,7 @@ static const struct seq_operations synproxy_cpu_seq_ops = {
static int __net_init synproxy_proc_init(struct net *net)
{
- if (!proc_create_net("synproxy", 0444, net->proc_net_stat,
+ if (!proc_net_create_net("synproxy", 0444, net->proc_net_stat,
&synproxy_cpu_seq_ops, sizeof(struct seq_net_private)))
return -ENOMEM;
return 0;
diff --git a/net/netfilter/x_tables.c b/net/netfilter/x_tables.c
index 84e58ee501a4..c507a7f8d2c0 100644
--- a/net/netfilter/x_tables.c
+++ b/net/netfilter/x_tables.c
@@ -1768,7 +1768,7 @@ int xt_proto_init(struct net *net, u_int8_t af)
strlcpy(buf, xt_prefix[af], sizeof(buf));
strlcat(buf, FORMAT_TABLES, sizeof(buf));
- proc = proc_create_net_data(buf, 0440, net->proc_net, &xt_table_seq_ops,
+ proc = proc_net_create_net_data(buf, 0440, net->proc_net, &xt_table_seq_ops,
sizeof(struct seq_net_private),
(void *)(unsigned long)af);
if (!proc)
@@ -1778,7 +1778,7 @@ int xt_proto_init(struct net *net, u_int8_t af)
strlcpy(buf, xt_prefix[af], sizeof(buf));
strlcat(buf, FORMAT_MATCHES, sizeof(buf));
- proc = proc_create_seq_private(buf, 0440, net->proc_net,
+ proc = proc_net_create_seq_private(buf, 0440, net->proc_net,
&xt_match_seq_ops, sizeof(struct nf_mttg_trav),
(void *)(unsigned long)af);
if (!proc)
@@ -1788,7 +1788,7 @@ int xt_proto_init(struct net *net, u_int8_t af)
strlcpy(buf, xt_prefix[af], sizeof(buf));
strlcat(buf, FORMAT_TARGETS, sizeof(buf));
- proc = proc_create_seq_private(buf, 0440, net->proc_net,
+ proc = proc_net_create_seq_private(buf, 0440, net->proc_net,
&xt_target_seq_ops, sizeof(struct nf_mttg_trav),
(void *)(unsigned long)af);
if (!proc)
diff --git a/net/netfilter/xt_hashlimit.c b/net/netfilter/xt_hashlimit.c
index 9c5cfd74a0ee..013812100c44 100644
--- a/net/netfilter/xt_hashlimit.c
+++ b/net/netfilter/xt_hashlimit.c
@@ -338,7 +338,7 @@ static int htable_create(struct net *net, struct hashlimit_cfg3 *cfg,
ops = &dl_seq_ops;
}
- hinfo->pde = proc_create_seq_data(name, 0,
+ hinfo->pde = proc_net_create_seq_data(name, 0,
(family == NFPROTO_IPV4) ?
hashlimit_net->ipt_hashlimit : hashlimit_net->ip6t_hashlimit,
ops, hinfo);
@@ -1234,11 +1234,11 @@ static int __net_init hashlimit_proc_net_init(struct net *net)
{
struct hashlimit_net *hashlimit_net = hashlimit_pernet(net);
- hashlimit_net->ipt_hashlimit = proc_mkdir("ipt_hashlimit", net->proc_net);
+ hashlimit_net->ipt_hashlimit = proc_net_mkdir(net, "ipt_hashlimit", net->proc_net);
if (!hashlimit_net->ipt_hashlimit)
return -ENOMEM;
#if IS_ENABLED(CONFIG_IP6_NF_IPTABLES)
- hashlimit_net->ip6t_hashlimit = proc_mkdir("ip6t_hashlimit", net->proc_net);
+ hashlimit_net->ip6t_hashlimit = proc_net_mkdir(net, "ip6t_hashlimit", net->proc_net);
if (!hashlimit_net->ip6t_hashlimit) {
remove_proc_entry("ipt_hashlimit", net->proc_net);
return -ENOMEM;
diff --git a/net/netfilter/xt_recent.c b/net/netfilter/xt_recent.c
index 0446307516cd..c84efe7e7d7a 100644
--- a/net/netfilter/xt_recent.c
+++ b/net/netfilter/xt_recent.c
@@ -412,7 +412,7 @@ static int recent_mt_check(const struct xt_mtchk_param *par,
ret = -EINVAL;
goto out;
}
- pde = proc_create_data(t->name, ip_list_perms, recent_net->xt_recent,
+ pde = proc_net_create_data(t->name, ip_list_perms, recent_net->xt_recent,
&recent_mt_proc_ops, t);
if (pde == NULL) {
recent_table_free(t);
@@ -636,7 +636,7 @@ static int __net_init recent_proc_net_init(struct net *net)
{
struct recent_net *recent_net = recent_pernet(net);
- recent_net->xt_recent = proc_mkdir("xt_recent", net->proc_net);
+ recent_net->xt_recent = proc_net_mkdir(net, "xt_recent", net->proc_net);
if (!recent_net->xt_recent)
return -ENOMEM;
return 0;
diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c
index e8cece873e06..528f43593e9e 100644
--- a/net/netlink/af_netlink.c
+++ b/net/netlink/af_netlink.c
@@ -2801,7 +2801,7 @@ static const struct net_proto_family netlink_family_ops = {
static int __net_init netlink_net_init(struct net *net)
{
#ifdef CONFIG_PROC_FS
- if (!proc_create_net("netlink", 0, net->proc_net, &netlink_seq_ops,
+ if (!proc_net_create_net("netlink", 0, net->proc_net, &netlink_seq_ops,
sizeof(struct nl_seq_iter)))
return -ENOMEM;
#endif
diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c
index 57a1971f29e5..99bb7b309cc9 100644
--- a/net/packet/af_packet.c
+++ b/net/packet/af_packet.c
@@ -4644,7 +4644,7 @@ static int __net_init packet_net_init(struct net *net)
INIT_HLIST_HEAD(&net->packet.sklist);
#ifdef CONFIG_PROC_FS
- if (!proc_create_net("packet", 0, net->proc_net, &packet_seq_ops,
+ if (!proc_net_create_net("packet", 0, net->proc_net, &packet_seq_ops,
sizeof(struct seq_net_private)))
return -ENOMEM;
#endif /* CONFIG_PROC_FS */
diff --git a/net/phonet/pn_dev.c b/net/phonet/pn_dev.c
index ac0fae06cc15..15ad278c8434 100644
--- a/net/phonet/pn_dev.c
+++ b/net/phonet/pn_dev.c
@@ -305,7 +305,7 @@ static int __net_init phonet_init_net(struct net *net)
{
struct phonet_net *pnn = phonet_pernet(net);
- if (!proc_create_net("phonet", 0, net->proc_net, &pn_sock_seq_ops,
+ if (!proc_net_create_net("phonet", 0, net->proc_net, &pn_sock_seq_ops,
sizeof(struct seq_net_private)))
return -ENOMEM;
diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c
index f87d07736a14..b39bcee8f433 100644
--- a/net/sched/sch_api.c
+++ b/net/sched/sch_api.c
@@ -2245,7 +2245,7 @@ static int __net_init psched_net_init(struct net *net)
{
struct proc_dir_entry *e;
- e = proc_create_single("psched", 0, net->proc_net, psched_show);
+ e = proc_net_create_single("psched", 0, net->proc_net, psched_show);
if (e == NULL)
return -ENOMEM;
diff --git a/net/sctp/objcnt.c b/net/sctp/objcnt.c
index 0400c964e125..3c60e0bbcbad 100644
--- a/net/sctp/objcnt.c
+++ b/net/sctp/objcnt.c
@@ -98,7 +98,7 @@ void sctp_dbg_objcnt_init(struct net *net)
{
struct proc_dir_entry *ent;
- ent = proc_create_seq("sctp_dbg_objcnt", 0,
+ ent = proc_net_create_seq("sctp_dbg_objcnt", 0,
net->sctp.proc_net_sctp, &sctp_objcnt_seq_ops);
if (!ent)
pr_warn("sctp_dbg_objcnt: Unable to create /proc entry.\n");
diff --git a/net/sctp/proc.c b/net/sctp/proc.c
index 982a87b3e11f..2e5ff30af563 100644
--- a/net/sctp/proc.c
+++ b/net/sctp/proc.c
@@ -380,16 +380,16 @@ int __net_init sctp_proc_init(struct net *net)
net->sctp.proc_net_sctp = proc_net_mkdir(net, "sctp", net->proc_net);
if (!net->sctp.proc_net_sctp)
return -ENOMEM;
- if (!proc_create_net_single("snmp", 0444, net->sctp.proc_net_sctp,
+ if (!proc_net_create_net_single("snmp", 0444, net->sctp.proc_net_sctp,
sctp_snmp_seq_show, NULL))
goto cleanup;
- if (!proc_create_net("eps", 0444, net->sctp.proc_net_sctp,
+ if (!proc_net_create_net("eps", 0444, net->sctp.proc_net_sctp,
&sctp_eps_ops, sizeof(struct seq_net_private)))
goto cleanup;
- if (!proc_create_net("assocs", 0444, net->sctp.proc_net_sctp,
+ if (!proc_net_create_net("assocs", 0444, net->sctp.proc_net_sctp,
&sctp_assoc_ops, sizeof(struct sctp_ht_iter)))
goto cleanup;
- if (!proc_create_net("remaddr", 0444, net->sctp.proc_net_sctp,
+ if (!proc_net_create_net("remaddr", 0444, net->sctp.proc_net_sctp,
&sctp_remaddr_ops, sizeof(struct sctp_ht_iter)))
goto cleanup;
return 0;
diff --git a/net/sunrpc/cache.c b/net/sunrpc/cache.c
index 1a2c1c44bb00..b4d0ec64bdf4 100644
--- a/net/sunrpc/cache.c
+++ b/net/sunrpc/cache.c
@@ -1664,23 +1664,23 @@ static int create_cache_proc_entries(struct cache_detail *cd, struct net *net)
struct sunrpc_net *sn;
sn = net_generic(net, sunrpc_net_id);
- cd->procfs = proc_mkdir(cd->name, sn->proc_net_rpc);
+ cd->procfs = proc_net_mkdir(net, cd->name, sn->proc_net_rpc);
if (cd->procfs == NULL)
goto out_nomem;
- p = proc_create_data("flush", S_IFREG | 0600,
+ p = proc_net_create_data("flush", S_IFREG | 0600,
cd->procfs, &cache_flush_proc_ops, cd);
if (p == NULL)
goto out_nomem;
if (cd->cache_request || cd->cache_parse) {
- p = proc_create_data("channel", S_IFREG | 0600, cd->procfs,
+ p = proc_net_create_data("channel", S_IFREG | 0600, cd->procfs,
&cache_channel_proc_ops, cd);
if (p == NULL)
goto out_nomem;
}
if (cd->cache_show) {
- p = proc_create_data("content", S_IFREG | 0400, cd->procfs,
+ p = proc_net_create_data("content", S_IFREG | 0400, cd->procfs,
&content_proc_ops, cd);
if (p == NULL)
goto out_nomem;
diff --git a/net/sunrpc/stats.c b/net/sunrpc/stats.c
index c964b48eaaba..77434b2017ad 100644
--- a/net/sunrpc/stats.c
+++ b/net/sunrpc/stats.c
@@ -286,7 +286,7 @@ do_register(struct net *net, const char *name, void *data,
dprintk("RPC: registering /proc/net/rpc/%s\n", name);
sn = net_generic(net, sunrpc_net_id);
- return proc_create_data(name, 0, sn->proc_net_rpc, proc_ops, data);
+ return proc_net_create_data(name, 0, sn->proc_net_rpc, proc_ops, data);
}
struct proc_dir_entry *
@@ -329,7 +329,7 @@ int rpc_proc_init(struct net *net)
dprintk("RPC: registering /proc/net/rpc\n");
sn = net_generic(net, sunrpc_net_id);
- sn->proc_net_rpc = proc_mkdir("rpc", net->proc_net);
+ sn->proc_net_rpc = proc_net_mkdir(net, "rpc", net->proc_net);
if (sn->proc_net_rpc == NULL)
return -ENOMEM;
diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c
index ba7ced947e51..db075316c9ff 100644
--- a/net/unix/af_unix.c
+++ b/net/unix/af_unix.c
@@ -2936,7 +2936,7 @@ static int __net_init unix_net_init(struct net *net)
goto out;
#ifdef CONFIG_PROC_FS
- if (!proc_create_net("unix", 0, net->proc_net, &unix_seq_ops,
+ if (!proc_net_create_net("unix", 0, net->proc_net, &unix_seq_ops,
sizeof(struct seq_net_private))) {
unix_sysctl_unregister(net);
goto out;
diff --git a/net/wireless/wext-proc.c b/net/wireless/wext-proc.c
index cadcf8613af2..81e35aac09cc 100644
--- a/net/wireless/wext-proc.c
+++ b/net/wireless/wext-proc.c
@@ -129,7 +129,7 @@ static const struct seq_operations wireless_seq_ops = {
int __net_init wext_proc_init(struct net *net)
{
/* Create /proc/net/wireless entry */
- if (!proc_create_net("wireless", 0444, net->proc_net,
+ if (!proc_net_create_net("wireless", 0444, net->proc_net,
&wireless_seq_ops, sizeof(struct seq_net_private)))
return -ENOMEM;
diff --git a/net/xfrm/xfrm_proc.c b/net/xfrm/xfrm_proc.c
index fee9b5cf37a7..b8fa652313fd 100644
--- a/net/xfrm/xfrm_proc.c
+++ b/net/xfrm/xfrm_proc.c
@@ -63,7 +63,7 @@ static int xfrm_statistics_seq_show(struct seq_file *seq, void *v)
int __net_init xfrm_proc_init(struct net *net)
{
- if (!proc_create_net_single("xfrm_stat", 0444, net->proc_net,
+ if (!proc_net_create_net_single("xfrm_stat", 0444, net->proc_net,
xfrm_statistics_seq_show, NULL))
return -ENOMEM;
return 0;
More information about the Devel
mailing list