net: sysctl: introduce sysctl SYSCTL_THREE
This patch introdues the SYSCTL_THREE. KUnit: [00:10:14] ================ sysctl_test (10 subtests) ================= [00:10:14] [PASSED] sysctl_test_api_dointvec_null_tbl_data [00:10:14] [PASSED] sysctl_test_api_dointvec_table_maxlen_unset [00:10:14] [PASSED] sysctl_test_api_dointvec_table_len_is_zero [00:10:14] [PASSED] sysctl_test_api_dointvec_table_read_but_position_set [00:10:14] [PASSED] sysctl_test_dointvec_read_happy_single_positive [00:10:14] [PASSED] sysctl_test_dointvec_read_happy_single_negative [00:10:14] [PASSED] sysctl_test_dointvec_write_happy_single_positive [00:10:14] [PASSED] sysctl_test_dointvec_write_happy_single_negative [00:10:14] [PASSED] sysctl_test_api_dointvec_write_single_less_int_min [00:10:14] [PASSED] sysctl_test_api_dointvec_write_single_greater_int_max [00:10:14] =================== [PASSED] sysctl_test =================== ./run_kselftest.sh -c sysctl ... ok 1 selftests: sysctl: sysctl.sh Cc: Luis Chamberlain <mcgrof@kernel.org> Cc: Kees Cook <keescook@chromium.org> Cc: Iurii Zaikin <yzaikin@google.com> Cc: "David S. Miller" <davem@davemloft.net> Cc: Jakub Kicinski <kuba@kernel.org> Cc: Paolo Abeni <pabeni@redhat.com> Cc: Hideaki YOSHIFUJI <yoshfuji@linux-ipv6.org> Cc: David Ahern <dsahern@kernel.org> Cc: Simon Horman <horms@verge.net.au> Cc: Julian Anastasov <ja@ssi.bg> Cc: Pablo Neira Ayuso <pablo@netfilter.org> Cc: Jozsef Kadlecsik <kadlec@netfilter.org> Cc: Florian Westphal <fw@strlen.de> Cc: Shuah Khan <shuah@kernel.org> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Alexei Starovoitov <ast@kernel.org> Cc: Eric Dumazet <edumazet@google.com> Cc: Lorenz Bauer <lmb@cloudflare.com> Cc: Akhmat Karakotov <hmukos@yandex-team.ru> Signed-off-by: Tonghao Zhang <xiangxia.m.yue@gmail.com> Reviewed-by: Simon Horman <horms@verge.net.au> Signed-off-by: Paolo Abeni <pabeni@redhat.com>
This commit is contained in:
parent
bd8a53675c
commit
4c7f24f857
|
@ -26,7 +26,7 @@ static const struct file_operations proc_sys_dir_file_operations;
|
||||||
static const struct inode_operations proc_sys_dir_operations;
|
static const struct inode_operations proc_sys_dir_operations;
|
||||||
|
|
||||||
/* shared constants to be used in various sysctls */
|
/* shared constants to be used in various sysctls */
|
||||||
const int sysctl_vals[] = { -1, 0, 1, 2, 4, 100, 200, 1000, 3000, INT_MAX, 65535 };
|
const int sysctl_vals[] = { 0, 1, 2, 3, 4, 100, 200, 1000, 3000, INT_MAX, 65535, -1 };
|
||||||
EXPORT_SYMBOL(sysctl_vals);
|
EXPORT_SYMBOL(sysctl_vals);
|
||||||
|
|
||||||
const unsigned long sysctl_long_vals[] = { 0, 1, LONG_MAX };
|
const unsigned long sysctl_long_vals[] = { 0, 1, LONG_MAX };
|
||||||
|
|
|
@ -38,10 +38,10 @@ struct ctl_table_header;
|
||||||
struct ctl_dir;
|
struct ctl_dir;
|
||||||
|
|
||||||
/* Keep the same order as in fs/proc/proc_sysctl.c */
|
/* Keep the same order as in fs/proc/proc_sysctl.c */
|
||||||
#define SYSCTL_NEG_ONE ((void *)&sysctl_vals[0])
|
#define SYSCTL_ZERO ((void *)&sysctl_vals[0])
|
||||||
#define SYSCTL_ZERO ((void *)&sysctl_vals[1])
|
#define SYSCTL_ONE ((void *)&sysctl_vals[1])
|
||||||
#define SYSCTL_ONE ((void *)&sysctl_vals[2])
|
#define SYSCTL_TWO ((void *)&sysctl_vals[2])
|
||||||
#define SYSCTL_TWO ((void *)&sysctl_vals[3])
|
#define SYSCTL_THREE ((void *)&sysctl_vals[3])
|
||||||
#define SYSCTL_FOUR ((void *)&sysctl_vals[4])
|
#define SYSCTL_FOUR ((void *)&sysctl_vals[4])
|
||||||
#define SYSCTL_ONE_HUNDRED ((void *)&sysctl_vals[5])
|
#define SYSCTL_ONE_HUNDRED ((void *)&sysctl_vals[5])
|
||||||
#define SYSCTL_TWO_HUNDRED ((void *)&sysctl_vals[6])
|
#define SYSCTL_TWO_HUNDRED ((void *)&sysctl_vals[6])
|
||||||
|
@ -51,6 +51,7 @@ struct ctl_dir;
|
||||||
|
|
||||||
/* this is needed for the proc_dointvec_minmax for [fs_]overflow UID and GID */
|
/* this is needed for the proc_dointvec_minmax for [fs_]overflow UID and GID */
|
||||||
#define SYSCTL_MAXOLDUID ((void *)&sysctl_vals[10])
|
#define SYSCTL_MAXOLDUID ((void *)&sysctl_vals[10])
|
||||||
|
#define SYSCTL_NEG_ONE ((void *)&sysctl_vals[11])
|
||||||
|
|
||||||
extern const int sysctl_vals[];
|
extern const int sysctl_vals[];
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
|
|
||||||
#include "dev.h"
|
#include "dev.h"
|
||||||
|
|
||||||
static int three = 3;
|
|
||||||
static int int_3600 = 3600;
|
static int int_3600 = 3600;
|
||||||
static int min_sndbuf = SOCK_MIN_SNDBUF;
|
static int min_sndbuf = SOCK_MIN_SNDBUF;
|
||||||
static int min_rcvbuf = SOCK_MIN_RCVBUF;
|
static int min_rcvbuf = SOCK_MIN_RCVBUF;
|
||||||
|
@ -553,7 +552,7 @@ static struct ctl_table net_core_table[] = {
|
||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = proc_dointvec_minmax,
|
.proc_handler = proc_dointvec_minmax,
|
||||||
.extra1 = SYSCTL_ZERO,
|
.extra1 = SYSCTL_ZERO,
|
||||||
.extra2 = &three,
|
.extra2 = SYSCTL_THREE,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.procname = "high_order_alloc_disable",
|
.procname = "high_order_alloc_disable",
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
#include <net/protocol.h>
|
#include <net/protocol.h>
|
||||||
#include <net/netevent.h>
|
#include <net/netevent.h>
|
||||||
|
|
||||||
static int three __maybe_unused = 3;
|
|
||||||
static int tcp_retr1_max = 255;
|
static int tcp_retr1_max = 255;
|
||||||
static int ip_local_port_range_min[] = { 1, 1 };
|
static int ip_local_port_range_min[] = { 1, 1 };
|
||||||
static int ip_local_port_range_max[] = { 65535, 65535 };
|
static int ip_local_port_range_max[] = { 65535, 65535 };
|
||||||
|
@ -1056,7 +1055,7 @@ static struct ctl_table ipv4_net_table[] = {
|
||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = proc_fib_multipath_hash_policy,
|
.proc_handler = proc_fib_multipath_hash_policy,
|
||||||
.extra1 = SYSCTL_ZERO,
|
.extra1 = SYSCTL_ZERO,
|
||||||
.extra2 = &three,
|
.extra2 = SYSCTL_THREE,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.procname = "fib_multipath_hash_fields",
|
.procname = "fib_multipath_hash_fields",
|
||||||
|
|
|
@ -23,7 +23,6 @@
|
||||||
#endif
|
#endif
|
||||||
#include <linux/ioam6.h>
|
#include <linux/ioam6.h>
|
||||||
|
|
||||||
static int three = 3;
|
|
||||||
static int flowlabel_reflect_max = 0x7;
|
static int flowlabel_reflect_max = 0x7;
|
||||||
static int auto_flowlabels_max = IP6_AUTO_FLOW_LABEL_MAX;
|
static int auto_flowlabels_max = IP6_AUTO_FLOW_LABEL_MAX;
|
||||||
static u32 rt6_multipath_hash_fields_all_mask =
|
static u32 rt6_multipath_hash_fields_all_mask =
|
||||||
|
@ -171,7 +170,7 @@ static struct ctl_table ipv6_table_template[] = {
|
||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = proc_rt6_multipath_hash_policy,
|
.proc_handler = proc_rt6_multipath_hash_policy,
|
||||||
.extra1 = SYSCTL_ZERO,
|
.extra1 = SYSCTL_ZERO,
|
||||||
.extra2 = &three,
|
.extra2 = SYSCTL_THREE,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.procname = "fib_multipath_hash_fields",
|
.procname = "fib_multipath_hash_fields",
|
||||||
|
|
|
@ -1767,8 +1767,6 @@ static int ip_vs_zero_all(struct netns_ipvs *ipvs)
|
||||||
|
|
||||||
#ifdef CONFIG_SYSCTL
|
#ifdef CONFIG_SYSCTL
|
||||||
|
|
||||||
static int three = 3;
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
proc_do_defense_mode(struct ctl_table *table, int write,
|
proc_do_defense_mode(struct ctl_table *table, int write,
|
||||||
void *buffer, size_t *lenp, loff_t *ppos)
|
void *buffer, size_t *lenp, loff_t *ppos)
|
||||||
|
@ -1977,7 +1975,7 @@ static struct ctl_table vs_vars[] = {
|
||||||
.mode = 0644,
|
.mode = 0644,
|
||||||
.proc_handler = proc_dointvec_minmax,
|
.proc_handler = proc_dointvec_minmax,
|
||||||
.extra1 = SYSCTL_ZERO,
|
.extra1 = SYSCTL_ZERO,
|
||||||
.extra2 = &three,
|
.extra2 = SYSCTL_THREE,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.procname = "nat_icmp_send",
|
.procname = "nat_icmp_send",
|
||||||
|
|
Loading…
Reference in New Issue