Commit 73dbd8cf authored by Joel Granados's avatar Joel Granados Committed by David S. Miller

net: Remove ctl_table sentinel elements from several networking subsystems

This commit comes at the tail end of a greater effort to remove the
empty elements at the end of the ctl_table arrays (sentinels) which
will reduce the overall build time size of the kernel and run time
memory bloat by ~64 bytes per sentinel (further information Link :
https://lore.kernel.org/all/ZO5Yx5JFogGi%2FcBo@bombadil.infradead.org/)

To avoid lots of small commits, this commit brings together network
changes from (as they appear in MAINTAINERS) LLC, MPTCP, NETROM NETWORK
LAYER, PHONET PROTOCOL, ROSE NETWORK LAYER, RXRPC SOCKETS, SCTP
PROTOCOL, SHARED MEMORY COMMUNICATIONS (SMC), TIPC NETWORK LAYER and
NETWORKING [IPSEC]

* Remove sentinel element from ctl_table structs.
* Replace empty array registration with the register_net_sysctl_sz call
  in llc_sysctl_init
* Replace the for loop stop condition that tests for procname == NULL
  with one that depends on array size in sctp_sysctl_net_register
* Remove instances where an array element is zeroed out to make it look
  like a sentinel in xfrm_sysctl_init. This is not longer needed and is
  safe after commit c899710f ("networking: Update to
  register_net_sysctl_sz") added the array size to the ctl_table
  registration
* Use a table_size variable to keep the value of ARRAY_SIZE
Signed-off-by: default avatarJoel Granados <j.granados@samsung.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ca5d1fce
...@@ -44,11 +44,6 @@ static struct ctl_table llc2_timeout_table[] = { ...@@ -44,11 +44,6 @@ static struct ctl_table llc2_timeout_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_dointvec_jiffies, .proc_handler = proc_dointvec_jiffies,
}, },
{ },
};
static struct ctl_table llc_station_table[] = {
{ },
}; };
static struct ctl_table_header *llc2_timeout_header; static struct ctl_table_header *llc2_timeout_header;
...@@ -56,8 +51,9 @@ static struct ctl_table_header *llc_station_header; ...@@ -56,8 +51,9 @@ static struct ctl_table_header *llc_station_header;
int __init llc_sysctl_init(void) int __init llc_sysctl_init(void)
{ {
struct ctl_table empty[1] = {};
llc2_timeout_header = register_net_sysctl(&init_net, "net/llc/llc2/timeout", llc2_timeout_table); llc2_timeout_header = register_net_sysctl(&init_net, "net/llc/llc2/timeout", llc2_timeout_table);
llc_station_header = register_net_sysctl(&init_net, "net/llc/station", llc_station_table); llc_station_header = register_net_sysctl_sz(&init_net, "net/llc/station", empty, 0);
if (!llc2_timeout_header || !llc_station_header) { if (!llc2_timeout_header || !llc_station_header) {
llc_sysctl_exit(); llc_sysctl_exit();
......
...@@ -156,7 +156,6 @@ static struct ctl_table mptcp_sysctl_table[] = { ...@@ -156,7 +156,6 @@ static struct ctl_table mptcp_sysctl_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_dointvec_jiffies, .proc_handler = proc_dointvec_jiffies,
}, },
{}
}; };
static int mptcp_pernet_new_table(struct net *net, struct mptcp_pernet *pernet) static int mptcp_pernet_new_table(struct net *net, struct mptcp_pernet *pernet)
......
...@@ -140,7 +140,6 @@ static struct ctl_table nr_table[] = { ...@@ -140,7 +140,6 @@ static struct ctl_table nr_table[] = {
.extra1 = &min_reset, .extra1 = &min_reset,
.extra2 = &max_reset .extra2 = &max_reset
}, },
{ }
}; };
int __init nr_register_sysctl(void) int __init nr_register_sysctl(void)
......
...@@ -81,7 +81,6 @@ static struct ctl_table phonet_table[] = { ...@@ -81,7 +81,6 @@ static struct ctl_table phonet_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_local_port_range, .proc_handler = proc_local_port_range,
}, },
{ }
}; };
int __init phonet_sysctl_init(void) int __init phonet_sysctl_init(void)
......
...@@ -112,7 +112,6 @@ static struct ctl_table rose_table[] = { ...@@ -112,7 +112,6 @@ static struct ctl_table rose_table[] = {
.extra1 = &min_window, .extra1 = &min_window,
.extra2 = &max_window .extra2 = &max_window
}, },
{ }
}; };
void __init rose_register_sysctl(void) void __init rose_register_sysctl(void)
......
...@@ -127,7 +127,6 @@ static struct ctl_table rxrpc_sysctl_table[] = { ...@@ -127,7 +127,6 @@ static struct ctl_table rxrpc_sysctl_table[] = {
.extra1 = (void *)SYSCTL_ONE, .extra1 = (void *)SYSCTL_ONE,
.extra2 = (void *)&four, .extra2 = (void *)&four,
}, },
{ }
}; };
int __init rxrpc_sysctl_init(void) int __init rxrpc_sysctl_init(void)
......
...@@ -80,8 +80,6 @@ static struct ctl_table sctp_table[] = { ...@@ -80,8 +80,6 @@ static struct ctl_table sctp_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_dointvec, .proc_handler = proc_dointvec,
}, },
{ /* sentinel */ }
}; };
/* The following index defines are used in sctp_sysctl_net_register(). /* The following index defines are used in sctp_sysctl_net_register().
...@@ -384,8 +382,6 @@ static struct ctl_table sctp_net_table[] = { ...@@ -384,8 +382,6 @@ static struct ctl_table sctp_net_table[] = {
.extra1 = SYSCTL_ZERO, .extra1 = SYSCTL_ZERO,
.extra2 = &pf_expose_max, .extra2 = &pf_expose_max,
}, },
{ /* sentinel */ }
}; };
static int proc_sctp_do_hmac_alg(struct ctl_table *ctl, int write, static int proc_sctp_do_hmac_alg(struct ctl_table *ctl, int write,
...@@ -597,6 +593,7 @@ static int proc_sctp_do_probe_interval(struct ctl_table *ctl, int write, ...@@ -597,6 +593,7 @@ static int proc_sctp_do_probe_interval(struct ctl_table *ctl, int write,
int sctp_sysctl_net_register(struct net *net) int sctp_sysctl_net_register(struct net *net)
{ {
size_t table_size = ARRAY_SIZE(sctp_net_table);
struct ctl_table *table; struct ctl_table *table;
int i; int i;
...@@ -604,7 +601,7 @@ int sctp_sysctl_net_register(struct net *net) ...@@ -604,7 +601,7 @@ int sctp_sysctl_net_register(struct net *net)
if (!table) if (!table)
return -ENOMEM; return -ENOMEM;
for (i = 0; table[i].data; i++) for (i = 0; i < table_size; i++)
table[i].data += (char *)(&net->sctp) - (char *)&init_net.sctp; table[i].data += (char *)(&net->sctp) - (char *)&init_net.sctp;
table[SCTP_RTO_MIN_IDX].extra2 = &net->sctp.rto_max; table[SCTP_RTO_MIN_IDX].extra2 = &net->sctp.rto_max;
...@@ -613,8 +610,7 @@ int sctp_sysctl_net_register(struct net *net) ...@@ -613,8 +610,7 @@ int sctp_sysctl_net_register(struct net *net)
table[SCTP_PS_RETRANS_IDX].extra1 = &net->sctp.pf_retrans; table[SCTP_PS_RETRANS_IDX].extra1 = &net->sctp.pf_retrans;
net->sctp.sysctl_header = register_net_sysctl_sz(net, "net/sctp", net->sctp.sysctl_header = register_net_sysctl_sz(net, "net/sctp",
table, table, table_size);
ARRAY_SIZE(sctp_net_table));
if (net->sctp.sysctl_header == NULL) { if (net->sctp.sysctl_header == NULL) {
kfree(table); kfree(table);
return -ENOMEM; return -ENOMEM;
......
...@@ -90,11 +90,11 @@ static struct ctl_table smc_table[] = { ...@@ -90,11 +90,11 @@ static struct ctl_table smc_table[] = {
.extra1 = &conns_per_lgr_min, .extra1 = &conns_per_lgr_min,
.extra2 = &conns_per_lgr_max, .extra2 = &conns_per_lgr_max,
}, },
{ }
}; };
int __net_init smc_sysctl_net_init(struct net *net) int __net_init smc_sysctl_net_init(struct net *net)
{ {
size_t table_size = ARRAY_SIZE(smc_table);
struct ctl_table *table; struct ctl_table *table;
table = smc_table; table = smc_table;
...@@ -105,12 +105,12 @@ int __net_init smc_sysctl_net_init(struct net *net) ...@@ -105,12 +105,12 @@ int __net_init smc_sysctl_net_init(struct net *net)
if (!table) if (!table)
goto err_alloc; goto err_alloc;
for (i = 0; i < ARRAY_SIZE(smc_table) - 1; i++) for (i = 0; i < table_size; i++)
table[i].data += (void *)net - (void *)&init_net; table[i].data += (void *)net - (void *)&init_net;
} }
net->smc.smc_hdr = register_net_sysctl_sz(net, "net/smc", table, net->smc.smc_hdr = register_net_sysctl_sz(net, "net/smc", table,
ARRAY_SIZE(smc_table)); table_size);
if (!net->smc.smc_hdr) if (!net->smc.smc_hdr)
goto err_reg; goto err_reg;
......
...@@ -91,7 +91,6 @@ static struct ctl_table tipc_table[] = { ...@@ -91,7 +91,6 @@ static struct ctl_table tipc_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_doulongvec_minmax, .proc_handler = proc_doulongvec_minmax,
}, },
{}
}; };
int tipc_register_sysctl(void) int tipc_register_sysctl(void)
......
...@@ -38,7 +38,6 @@ static struct ctl_table xfrm_table[] = { ...@@ -38,7 +38,6 @@ static struct ctl_table xfrm_table[] = {
.mode = 0644, .mode = 0644,
.proc_handler = proc_dointvec .proc_handler = proc_dointvec
}, },
{}
}; };
int __net_init xfrm_sysctl_init(struct net *net) int __net_init xfrm_sysctl_init(struct net *net)
...@@ -57,10 +56,8 @@ int __net_init xfrm_sysctl_init(struct net *net) ...@@ -57,10 +56,8 @@ int __net_init xfrm_sysctl_init(struct net *net)
table[3].data = &net->xfrm.sysctl_acq_expires; table[3].data = &net->xfrm.sysctl_acq_expires;
/* Don't export sysctls to unprivileged users */ /* Don't export sysctls to unprivileged users */
if (net->user_ns != &init_user_ns) { if (net->user_ns != &init_user_ns)
table[0].procname = NULL;
table_size = 0; table_size = 0;
}
net->xfrm.sysctl_hdr = register_net_sysctl_sz(net, "net/core", table, net->xfrm.sysctl_hdr = register_net_sysctl_sz(net, "net/core", table,
table_size); table_size);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment