root/kernel/sysctl_binary.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. bin_dir
  2. bin_string
  3. bin_intvec
  4. bin_ulongvec
  5. bin_uuid
  6. bin_dn_node_address
  7. get_sysctl
  8. sysctl_getname
  9. binary_sysctl
  10. binary_sysctl
  11. deprecated_sysctl_warning
  12. warn_on_bintable
  13. do_sysctl
  14. SYSCALL_DEFINE1
  15. COMPAT_SYSCALL_DEFINE1

   1 // SPDX-License-Identifier: GPL-2.0
   2 #include <linux/stat.h>
   3 #include <linux/sysctl.h>
   4 #include "../fs/xfs/xfs_sysctl.h"
   5 #include <linux/sunrpc/debug.h>
   6 #include <linux/string.h>
   7 #include <linux/syscalls.h>
   8 #include <linux/namei.h>
   9 #include <linux/mount.h>
  10 #include <linux/fs.h>
  11 #include <linux/nsproxy.h>
  12 #include <linux/pid_namespace.h>
  13 #include <linux/file.h>
  14 #include <linux/ctype.h>
  15 #include <linux/netdevice.h>
  16 #include <linux/kernel.h>
  17 #include <linux/uuid.h>
  18 #include <linux/slab.h>
  19 #include <linux/compat.h>
  20 
  21 #ifdef CONFIG_SYSCTL_SYSCALL
  22 
  23 struct bin_table;
  24 typedef ssize_t bin_convert_t(struct file *file,
  25         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen);
  26 
  27 static bin_convert_t bin_dir;
  28 static bin_convert_t bin_string;
  29 static bin_convert_t bin_intvec;
  30 static bin_convert_t bin_ulongvec;
  31 static bin_convert_t bin_uuid;
  32 static bin_convert_t bin_dn_node_address;
  33 
  34 #define CTL_DIR   bin_dir
  35 #define CTL_STR   bin_string
  36 #define CTL_INT   bin_intvec
  37 #define CTL_ULONG bin_ulongvec
  38 #define CTL_UUID  bin_uuid
  39 #define CTL_DNADR bin_dn_node_address
  40 
  41 #define BUFSZ 256
  42 
  43 struct bin_table {
  44         bin_convert_t           *convert;
  45         int                     ctl_name;
  46         const char              *procname;
  47         const struct bin_table  *child;
  48 };
  49 
  50 static const struct bin_table bin_random_table[] = {
  51         { CTL_INT,      RANDOM_POOLSIZE,        "poolsize" },
  52         { CTL_INT,      RANDOM_ENTROPY_COUNT,   "entropy_avail" },
  53         { CTL_INT,      RANDOM_READ_THRESH,     "read_wakeup_threshold" },
  54         { CTL_INT,      RANDOM_WRITE_THRESH,    "write_wakeup_threshold" },
  55         { CTL_UUID,     RANDOM_BOOT_ID,         "boot_id" },
  56         { CTL_UUID,     RANDOM_UUID,            "uuid" },
  57         {}
  58 };
  59 
  60 static const struct bin_table bin_pty_table[] = {
  61         { CTL_INT,      PTY_MAX,        "max" },
  62         { CTL_INT,      PTY_NR,         "nr" },
  63         {}
  64 };
  65 
  66 static const struct bin_table bin_kern_table[] = {
  67         { CTL_STR,      KERN_OSTYPE,                    "ostype" },
  68         { CTL_STR,      KERN_OSRELEASE,                 "osrelease" },
  69         /* KERN_OSREV not used */
  70         { CTL_STR,      KERN_VERSION,                   "version" },
  71         /* KERN_SECUREMASK not used */
  72         /* KERN_PROF not used */
  73         { CTL_STR,      KERN_NODENAME,                  "hostname" },
  74         { CTL_STR,      KERN_DOMAINNAME,                "domainname" },
  75 
  76         { CTL_INT,      KERN_PANIC,                     "panic" },
  77         { CTL_INT,      KERN_REALROOTDEV,               "real-root-dev" },
  78 
  79         { CTL_STR,      KERN_SPARC_REBOOT,              "reboot-cmd" },
  80         { CTL_INT,      KERN_CTLALTDEL,                 "ctrl-alt-del" },
  81         { CTL_INT,      KERN_PRINTK,                    "printk" },
  82 
  83         /* KERN_NAMETRANS not used */
  84         /* KERN_PPC_HTABRECLAIM not used */
  85         /* KERN_PPC_ZEROPAGED not used */
  86         { CTL_INT,      KERN_PPC_POWERSAVE_NAP,         "powersave-nap" },
  87 
  88         { CTL_STR,      KERN_MODPROBE,                  "modprobe" },
  89         { CTL_INT,      KERN_SG_BIG_BUFF,               "sg-big-buff" },
  90         { CTL_INT,      KERN_ACCT,                      "acct" },
  91         /* KERN_PPC_L2CR "l2cr" no longer used */
  92 
  93         /* KERN_RTSIGNR not used */
  94         /* KERN_RTSIGMAX not used */
  95 
  96         { CTL_ULONG,    KERN_SHMMAX,                    "shmmax" },
  97         { CTL_INT,      KERN_MSGMAX,                    "msgmax" },
  98         { CTL_INT,      KERN_MSGMNB,                    "msgmnb" },
  99         /* KERN_MSGPOOL not used*/
 100         { CTL_INT,      KERN_SYSRQ,                     "sysrq" },
 101         { CTL_INT,      KERN_MAX_THREADS,               "threads-max" },
 102         { CTL_DIR,      KERN_RANDOM,                    "random",       bin_random_table },
 103         { CTL_ULONG,    KERN_SHMALL,                    "shmall" },
 104         { CTL_INT,      KERN_MSGMNI,                    "msgmni" },
 105         { CTL_INT,      KERN_SEM,                       "sem" },
 106         { CTL_INT,      KERN_SPARC_STOP_A,              "stop-a" },
 107         { CTL_INT,      KERN_SHMMNI,                    "shmmni" },
 108 
 109         { CTL_INT,      KERN_OVERFLOWUID,               "overflowuid" },
 110         { CTL_INT,      KERN_OVERFLOWGID,               "overflowgid" },
 111 
 112         { CTL_STR,      KERN_HOTPLUG,                   "hotplug", },
 113         { CTL_INT,      KERN_IEEE_EMULATION_WARNINGS,   "ieee_emulation_warnings" },
 114 
 115         { CTL_INT,      KERN_S390_USER_DEBUG_LOGGING,   "userprocess_debug" },
 116         { CTL_INT,      KERN_CORE_USES_PID,             "core_uses_pid" },
 117         /* KERN_TAINTED "tainted" no longer used */
 118         { CTL_INT,      KERN_CADPID,                    "cad_pid" },
 119         { CTL_INT,      KERN_PIDMAX,                    "pid_max" },
 120         { CTL_STR,      KERN_CORE_PATTERN,              "core_pattern" },
 121         { CTL_INT,      KERN_PANIC_ON_OOPS,             "panic_on_oops" },
 122         { CTL_INT,      KERN_HPPA_PWRSW,                "soft-power" },
 123         { CTL_INT,      KERN_HPPA_UNALIGNED,            "unaligned-trap" },
 124 
 125         { CTL_INT,      KERN_PRINTK_RATELIMIT,          "printk_ratelimit" },
 126         { CTL_INT,      KERN_PRINTK_RATELIMIT_BURST,    "printk_ratelimit_burst" },
 127 
 128         { CTL_DIR,      KERN_PTY,                       "pty",          bin_pty_table },
 129         { CTL_INT,      KERN_NGROUPS_MAX,               "ngroups_max" },
 130         { CTL_INT,      KERN_SPARC_SCONS_PWROFF,        "scons-poweroff" },
 131         /* KERN_HZ_TIMER "hz_timer" no longer used */
 132         { CTL_INT,      KERN_UNKNOWN_NMI_PANIC,         "unknown_nmi_panic" },
 133         { CTL_INT,      KERN_BOOTLOADER_TYPE,           "bootloader_type" },
 134         { CTL_INT,      KERN_RANDOMIZE,                 "randomize_va_space" },
 135 
 136         { CTL_INT,      KERN_SPIN_RETRY,                "spin_retry" },
 137         /* KERN_ACPI_VIDEO_FLAGS "acpi_video_flags" no longer used */
 138         { CTL_INT,      KERN_IA64_UNALIGNED,            "ignore-unaligned-usertrap" },
 139         { CTL_INT,      KERN_COMPAT_LOG,                "compat-log" },
 140         { CTL_INT,      KERN_MAX_LOCK_DEPTH,            "max_lock_depth" },
 141         { CTL_INT,      KERN_PANIC_ON_NMI,              "panic_on_unrecovered_nmi" },
 142         { CTL_INT,      KERN_PANIC_ON_WARN,             "panic_on_warn" },
 143         { CTL_ULONG,    KERN_PANIC_PRINT,               "panic_print" },
 144         {}
 145 };
 146 
 147 static const struct bin_table bin_vm_table[] = {
 148         { CTL_INT,      VM_OVERCOMMIT_MEMORY,           "overcommit_memory" },
 149         { CTL_INT,      VM_PAGE_CLUSTER,                "page-cluster" },
 150         { CTL_INT,      VM_DIRTY_BACKGROUND,            "dirty_background_ratio" },
 151         { CTL_INT,      VM_DIRTY_RATIO,                 "dirty_ratio" },
 152         /* VM_DIRTY_WB_CS "dirty_writeback_centisecs" no longer used */
 153         /* VM_DIRTY_EXPIRE_CS "dirty_expire_centisecs" no longer used */
 154         /* VM_NR_PDFLUSH_THREADS "nr_pdflush_threads" no longer used */
 155         { CTL_INT,      VM_OVERCOMMIT_RATIO,            "overcommit_ratio" },
 156         /* VM_PAGEBUF unused */
 157         /* VM_HUGETLB_PAGES "nr_hugepages" no longer used */
 158         { CTL_INT,      VM_SWAPPINESS,                  "swappiness" },
 159         { CTL_INT,      VM_LOWMEM_RESERVE_RATIO,        "lowmem_reserve_ratio" },
 160         { CTL_INT,      VM_MIN_FREE_KBYTES,             "min_free_kbytes" },
 161         { CTL_INT,      VM_MAX_MAP_COUNT,               "max_map_count" },
 162         { CTL_INT,      VM_LAPTOP_MODE,                 "laptop_mode" },
 163         { CTL_INT,      VM_BLOCK_DUMP,                  "block_dump" },
 164         { CTL_INT,      VM_HUGETLB_GROUP,               "hugetlb_shm_group" },
 165         { CTL_INT,      VM_VFS_CACHE_PRESSURE,  "vfs_cache_pressure" },
 166         { CTL_INT,      VM_LEGACY_VA_LAYOUT,            "legacy_va_layout" },
 167         /* VM_SWAP_TOKEN_TIMEOUT unused */
 168         { CTL_INT,      VM_DROP_PAGECACHE,              "drop_caches" },
 169         { CTL_INT,      VM_PERCPU_PAGELIST_FRACTION,    "percpu_pagelist_fraction" },
 170         { CTL_INT,      VM_ZONE_RECLAIM_MODE,           "zone_reclaim_mode" },
 171         { CTL_INT,      VM_MIN_UNMAPPED,                "min_unmapped_ratio" },
 172         { CTL_INT,      VM_PANIC_ON_OOM,                "panic_on_oom" },
 173         { CTL_INT,      VM_VDSO_ENABLED,                "vdso_enabled" },
 174         { CTL_INT,      VM_MIN_SLAB,                    "min_slab_ratio" },
 175 
 176         {}
 177 };
 178 
 179 static const struct bin_table bin_net_core_table[] = {
 180         { CTL_INT,      NET_CORE_WMEM_MAX,      "wmem_max" },
 181         { CTL_INT,      NET_CORE_RMEM_MAX,      "rmem_max" },
 182         { CTL_INT,      NET_CORE_WMEM_DEFAULT,  "wmem_default" },
 183         { CTL_INT,      NET_CORE_RMEM_DEFAULT,  "rmem_default" },
 184         /* NET_CORE_DESTROY_DELAY unused */
 185         { CTL_INT,      NET_CORE_MAX_BACKLOG,   "netdev_max_backlog" },
 186         /* NET_CORE_FASTROUTE unused */
 187         { CTL_INT,      NET_CORE_MSG_COST,      "message_cost" },
 188         { CTL_INT,      NET_CORE_MSG_BURST,     "message_burst" },
 189         { CTL_INT,      NET_CORE_OPTMEM_MAX,    "optmem_max" },
 190         /* NET_CORE_HOT_LIST_LENGTH unused */
 191         /* NET_CORE_DIVERT_VERSION unused */
 192         /* NET_CORE_NO_CONG_THRESH unused */
 193         /* NET_CORE_NO_CONG unused */
 194         /* NET_CORE_LO_CONG unused */
 195         /* NET_CORE_MOD_CONG unused */
 196         { CTL_INT,      NET_CORE_DEV_WEIGHT,    "dev_weight" },
 197         { CTL_INT,      NET_CORE_SOMAXCONN,     "somaxconn" },
 198         { CTL_INT,      NET_CORE_BUDGET,        "netdev_budget" },
 199         { CTL_INT,      NET_CORE_AEVENT_ETIME,  "xfrm_aevent_etime" },
 200         { CTL_INT,      NET_CORE_AEVENT_RSEQTH, "xfrm_aevent_rseqth" },
 201         { CTL_INT,      NET_CORE_WARNINGS,      "warnings" },
 202         {},
 203 };
 204 
 205 static const struct bin_table bin_net_unix_table[] = {
 206         /* NET_UNIX_DESTROY_DELAY unused */
 207         /* NET_UNIX_DELETE_DELAY unused */
 208         { CTL_INT,      NET_UNIX_MAX_DGRAM_QLEN,        "max_dgram_qlen" },
 209         {}
 210 };
 211 
 212 static const struct bin_table bin_net_ipv4_route_table[] = {
 213         { CTL_INT,      NET_IPV4_ROUTE_FLUSH,                   "flush" },
 214         /* NET_IPV4_ROUTE_MIN_DELAY "min_delay" no longer used */
 215         /* NET_IPV4_ROUTE_MAX_DELAY "max_delay" no longer used */
 216         { CTL_INT,      NET_IPV4_ROUTE_GC_THRESH,               "gc_thresh" },
 217         { CTL_INT,      NET_IPV4_ROUTE_MAX_SIZE,                "max_size" },
 218         { CTL_INT,      NET_IPV4_ROUTE_GC_MIN_INTERVAL,         "gc_min_interval" },
 219         { CTL_INT,      NET_IPV4_ROUTE_GC_MIN_INTERVAL_MS,      "gc_min_interval_ms" },
 220         { CTL_INT,      NET_IPV4_ROUTE_GC_TIMEOUT,              "gc_timeout" },
 221         /* NET_IPV4_ROUTE_GC_INTERVAL "gc_interval" no longer used */
 222         { CTL_INT,      NET_IPV4_ROUTE_REDIRECT_LOAD,           "redirect_load" },
 223         { CTL_INT,      NET_IPV4_ROUTE_REDIRECT_NUMBER,         "redirect_number" },
 224         { CTL_INT,      NET_IPV4_ROUTE_REDIRECT_SILENCE,        "redirect_silence" },
 225         { CTL_INT,      NET_IPV4_ROUTE_ERROR_COST,              "error_cost" },
 226         { CTL_INT,      NET_IPV4_ROUTE_ERROR_BURST,             "error_burst" },
 227         { CTL_INT,      NET_IPV4_ROUTE_GC_ELASTICITY,           "gc_elasticity" },
 228         { CTL_INT,      NET_IPV4_ROUTE_MTU_EXPIRES,             "mtu_expires" },
 229         { CTL_INT,      NET_IPV4_ROUTE_MIN_PMTU,                "min_pmtu" },
 230         { CTL_INT,      NET_IPV4_ROUTE_MIN_ADVMSS,              "min_adv_mss" },
 231         {}
 232 };
 233 
 234 static const struct bin_table bin_net_ipv4_conf_vars_table[] = {
 235         { CTL_INT,      NET_IPV4_CONF_FORWARDING,               "forwarding" },
 236         { CTL_INT,      NET_IPV4_CONF_MC_FORWARDING,            "mc_forwarding" },
 237 
 238         { CTL_INT,      NET_IPV4_CONF_ACCEPT_REDIRECTS,         "accept_redirects" },
 239         { CTL_INT,      NET_IPV4_CONF_SECURE_REDIRECTS,         "secure_redirects" },
 240         { CTL_INT,      NET_IPV4_CONF_SEND_REDIRECTS,           "send_redirects" },
 241         { CTL_INT,      NET_IPV4_CONF_SHARED_MEDIA,             "shared_media" },
 242         { CTL_INT,      NET_IPV4_CONF_RP_FILTER,                "rp_filter" },
 243         { CTL_INT,      NET_IPV4_CONF_ACCEPT_SOURCE_ROUTE,      "accept_source_route" },
 244         { CTL_INT,      NET_IPV4_CONF_PROXY_ARP,                "proxy_arp" },
 245         { CTL_INT,      NET_IPV4_CONF_MEDIUM_ID,                "medium_id" },
 246         { CTL_INT,      NET_IPV4_CONF_BOOTP_RELAY,              "bootp_relay" },
 247         { CTL_INT,      NET_IPV4_CONF_LOG_MARTIANS,             "log_martians" },
 248         { CTL_INT,      NET_IPV4_CONF_TAG,                      "tag" },
 249         { CTL_INT,      NET_IPV4_CONF_ARPFILTER,                "arp_filter" },
 250         { CTL_INT,      NET_IPV4_CONF_ARP_ANNOUNCE,             "arp_announce" },
 251         { CTL_INT,      NET_IPV4_CONF_ARP_IGNORE,               "arp_ignore" },
 252         { CTL_INT,      NET_IPV4_CONF_ARP_ACCEPT,               "arp_accept" },
 253         { CTL_INT,      NET_IPV4_CONF_ARP_NOTIFY,               "arp_notify" },
 254 
 255         { CTL_INT,      NET_IPV4_CONF_NOXFRM,                   "disable_xfrm" },
 256         { CTL_INT,      NET_IPV4_CONF_NOPOLICY,                 "disable_policy" },
 257         { CTL_INT,      NET_IPV4_CONF_FORCE_IGMP_VERSION,       "force_igmp_version" },
 258         { CTL_INT,      NET_IPV4_CONF_PROMOTE_SECONDARIES,      "promote_secondaries" },
 259         {}
 260 };
 261 
 262 static const struct bin_table bin_net_ipv4_conf_table[] = {
 263         { CTL_DIR,      NET_PROTO_CONF_ALL,     "all",          bin_net_ipv4_conf_vars_table },
 264         { CTL_DIR,      NET_PROTO_CONF_DEFAULT, "default",      bin_net_ipv4_conf_vars_table },
 265         { CTL_DIR,      0, NULL, bin_net_ipv4_conf_vars_table },
 266         {}
 267 };
 268 
 269 static const struct bin_table bin_net_neigh_vars_table[] = {
 270         { CTL_INT,      NET_NEIGH_MCAST_SOLICIT,        "mcast_solicit" },
 271         { CTL_INT,      NET_NEIGH_UCAST_SOLICIT,        "ucast_solicit" },
 272         { CTL_INT,      NET_NEIGH_APP_SOLICIT,          "app_solicit" },
 273         /* NET_NEIGH_RETRANS_TIME "retrans_time" no longer used */
 274         { CTL_INT,      NET_NEIGH_REACHABLE_TIME,       "base_reachable_time" },
 275         { CTL_INT,      NET_NEIGH_DELAY_PROBE_TIME,     "delay_first_probe_time" },
 276         { CTL_INT,      NET_NEIGH_GC_STALE_TIME,        "gc_stale_time" },
 277         { CTL_INT,      NET_NEIGH_UNRES_QLEN,           "unres_qlen" },
 278         { CTL_INT,      NET_NEIGH_PROXY_QLEN,           "proxy_qlen" },
 279         /* NET_NEIGH_ANYCAST_DELAY "anycast_delay" no longer used */
 280         /* NET_NEIGH_PROXY_DELAY "proxy_delay" no longer used */
 281         /* NET_NEIGH_LOCKTIME "locktime" no longer used */
 282         { CTL_INT,      NET_NEIGH_GC_INTERVAL,          "gc_interval" },
 283         { CTL_INT,      NET_NEIGH_GC_THRESH1,           "gc_thresh1" },
 284         { CTL_INT,      NET_NEIGH_GC_THRESH2,           "gc_thresh2" },
 285         { CTL_INT,      NET_NEIGH_GC_THRESH3,           "gc_thresh3" },
 286         { CTL_INT,      NET_NEIGH_RETRANS_TIME_MS,      "retrans_time_ms" },
 287         { CTL_INT,      NET_NEIGH_REACHABLE_TIME_MS,    "base_reachable_time_ms" },
 288         {}
 289 };
 290 
 291 static const struct bin_table bin_net_neigh_table[] = {
 292         { CTL_DIR,      NET_PROTO_CONF_DEFAULT, "default", bin_net_neigh_vars_table },
 293         { CTL_DIR,      0, NULL, bin_net_neigh_vars_table },
 294         {}
 295 };
 296 
 297 static const struct bin_table bin_net_ipv4_netfilter_table[] = {
 298         { CTL_INT,      NET_IPV4_NF_CONNTRACK_MAX,              "ip_conntrack_max" },
 299 
 300         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_SYN_SENT "ip_conntrack_tcp_timeout_syn_sent" no longer used */
 301         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_SYN_RECV "ip_conntrack_tcp_timeout_syn_recv" no longer used */
 302         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_ESTABLISHED "ip_conntrack_tcp_timeout_established" no longer used */
 303         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_FIN_WAIT "ip_conntrack_tcp_timeout_fin_wait" no longer used */
 304         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_CLOSE_WAIT "ip_conntrack_tcp_timeout_close_wait" no longer used */
 305         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_LAST_ACK "ip_conntrack_tcp_timeout_last_ack" no longer used */
 306         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_TIME_WAIT "ip_conntrack_tcp_timeout_time_wait" no longer used */
 307         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_CLOSE "ip_conntrack_tcp_timeout_close" no longer used */
 308 
 309         /* NET_IPV4_NF_CONNTRACK_UDP_TIMEOUT "ip_conntrack_udp_timeout" no longer used */
 310         /* NET_IPV4_NF_CONNTRACK_UDP_TIMEOUT_STREAM "ip_conntrack_udp_timeout_stream" no longer used */
 311         /* NET_IPV4_NF_CONNTRACK_ICMP_TIMEOUT "ip_conntrack_icmp_timeout" no longer used */
 312         /* NET_IPV4_NF_CONNTRACK_GENERIC_TIMEOUT "ip_conntrack_generic_timeout" no longer used */
 313 
 314         { CTL_INT,      NET_IPV4_NF_CONNTRACK_BUCKETS,          "ip_conntrack_buckets" },
 315         { CTL_INT,      NET_IPV4_NF_CONNTRACK_LOG_INVALID,      "ip_conntrack_log_invalid" },
 316         /* NET_IPV4_NF_CONNTRACK_TCP_TIMEOUT_MAX_RETRANS "ip_conntrack_tcp_timeout_max_retrans" no longer used */
 317         { CTL_INT,      NET_IPV4_NF_CONNTRACK_TCP_LOOSE,        "ip_conntrack_tcp_loose" },
 318         { CTL_INT,      NET_IPV4_NF_CONNTRACK_TCP_BE_LIBERAL,   "ip_conntrack_tcp_be_liberal" },
 319         { CTL_INT,      NET_IPV4_NF_CONNTRACK_TCP_MAX_RETRANS,  "ip_conntrack_tcp_max_retrans" },
 320 
 321         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_CLOSED "ip_conntrack_sctp_timeout_closed" no longer used */
 322         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_COOKIE_WAIT "ip_conntrack_sctp_timeout_cookie_wait" no longer used */
 323         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_COOKIE_ECHOED "ip_conntrack_sctp_timeout_cookie_echoed" no longer used */
 324         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_ESTABLISHED "ip_conntrack_sctp_timeout_established" no longer used */
 325         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_SHUTDOWN_SENT "ip_conntrack_sctp_timeout_shutdown_sent" no longer used */
 326         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_SHUTDOWN_RECD "ip_conntrack_sctp_timeout_shutdown_recd" no longer used */
 327         /* NET_IPV4_NF_CONNTRACK_SCTP_TIMEOUT_SHUTDOWN_ACK_SENT "ip_conntrack_sctp_timeout_shutdown_ack_sent" no longer used */
 328 
 329         { CTL_INT,      NET_IPV4_NF_CONNTRACK_COUNT,            "ip_conntrack_count" },
 330         { CTL_INT,      NET_IPV4_NF_CONNTRACK_CHECKSUM,         "ip_conntrack_checksum" },
 331         {}
 332 };
 333 
 334 static const struct bin_table bin_net_ipv4_table[] = {
 335         {CTL_INT,       NET_IPV4_FORWARD,                       "ip_forward" },
 336 
 337         { CTL_DIR,      NET_IPV4_CONF,          "conf",         bin_net_ipv4_conf_table },
 338         { CTL_DIR,      NET_IPV4_NEIGH,         "neigh",        bin_net_neigh_table },
 339         { CTL_DIR,      NET_IPV4_ROUTE,         "route",        bin_net_ipv4_route_table },
 340         /* NET_IPV4_FIB_HASH unused */
 341         { CTL_DIR,      NET_IPV4_NETFILTER,     "netfilter",    bin_net_ipv4_netfilter_table },
 342 
 343         { CTL_INT,      NET_IPV4_TCP_TIMESTAMPS,                "tcp_timestamps" },
 344         { CTL_INT,      NET_IPV4_TCP_WINDOW_SCALING,            "tcp_window_scaling" },
 345         { CTL_INT,      NET_IPV4_TCP_SACK,                      "tcp_sack" },
 346         { CTL_INT,      NET_IPV4_TCP_RETRANS_COLLAPSE,          "tcp_retrans_collapse" },
 347         { CTL_INT,      NET_IPV4_DEFAULT_TTL,                   "ip_default_ttl" },
 348         /* NET_IPV4_AUTOCONFIG unused */
 349         { CTL_INT,      NET_IPV4_NO_PMTU_DISC,                  "ip_no_pmtu_disc" },
 350         { CTL_INT,      NET_IPV4_NONLOCAL_BIND,                 "ip_nonlocal_bind" },
 351         { CTL_INT,      NET_IPV4_TCP_SYN_RETRIES,               "tcp_syn_retries" },
 352         { CTL_INT,      NET_TCP_SYNACK_RETRIES,                 "tcp_synack_retries" },
 353         { CTL_INT,      NET_TCP_MAX_ORPHANS,                    "tcp_max_orphans" },
 354         { CTL_INT,      NET_TCP_MAX_TW_BUCKETS,                 "tcp_max_tw_buckets" },
 355         { CTL_INT,      NET_IPV4_DYNADDR,                       "ip_dynaddr" },
 356         { CTL_INT,      NET_IPV4_TCP_KEEPALIVE_TIME,            "tcp_keepalive_time" },
 357         { CTL_INT,      NET_IPV4_TCP_KEEPALIVE_PROBES,          "tcp_keepalive_probes" },
 358         { CTL_INT,      NET_IPV4_TCP_KEEPALIVE_INTVL,           "tcp_keepalive_intvl" },
 359         { CTL_INT,      NET_IPV4_TCP_RETRIES1,                  "tcp_retries1" },
 360         { CTL_INT,      NET_IPV4_TCP_RETRIES2,                  "tcp_retries2" },
 361         { CTL_INT,      NET_IPV4_TCP_FIN_TIMEOUT,               "tcp_fin_timeout" },
 362         { CTL_INT,      NET_TCP_SYNCOOKIES,                     "tcp_syncookies" },
 363         { CTL_INT,      NET_TCP_TW_RECYCLE,                     "tcp_tw_recycle" },
 364         { CTL_INT,      NET_TCP_ABORT_ON_OVERFLOW,              "tcp_abort_on_overflow" },
 365         { CTL_INT,      NET_TCP_STDURG,                         "tcp_stdurg" },
 366         { CTL_INT,      NET_TCP_RFC1337,                        "tcp_rfc1337" },
 367         { CTL_INT,      NET_TCP_MAX_SYN_BACKLOG,                "tcp_max_syn_backlog" },
 368         { CTL_INT,      NET_IPV4_LOCAL_PORT_RANGE,              "ip_local_port_range" },
 369         { CTL_INT,      NET_IPV4_IGMP_MAX_MEMBERSHIPS,          "igmp_max_memberships" },
 370         { CTL_INT,      NET_IPV4_IGMP_MAX_MSF,                  "igmp_max_msf" },
 371         { CTL_INT,      NET_IPV4_INET_PEER_THRESHOLD,           "inet_peer_threshold" },
 372         { CTL_INT,      NET_IPV4_INET_PEER_MINTTL,              "inet_peer_minttl" },
 373         { CTL_INT,      NET_IPV4_INET_PEER_MAXTTL,              "inet_peer_maxttl" },
 374         { CTL_INT,      NET_IPV4_INET_PEER_GC_MINTIME,          "inet_peer_gc_mintime" },
 375         { CTL_INT,      NET_IPV4_INET_PEER_GC_MAXTIME,          "inet_peer_gc_maxtime" },
 376         { CTL_INT,      NET_TCP_ORPHAN_RETRIES,                 "tcp_orphan_retries" },
 377         { CTL_INT,      NET_TCP_FACK,                           "tcp_fack" },
 378         { CTL_INT,      NET_TCP_REORDERING,                     "tcp_reordering" },
 379         { CTL_INT,      NET_TCP_ECN,                            "tcp_ecn" },
 380         { CTL_INT,      NET_TCP_DSACK,                          "tcp_dsack" },
 381         { CTL_INT,      NET_TCP_MEM,                            "tcp_mem" },
 382         { CTL_INT,      NET_TCP_WMEM,                           "tcp_wmem" },
 383         { CTL_INT,      NET_TCP_RMEM,                           "tcp_rmem" },
 384         { CTL_INT,      NET_TCP_APP_WIN,                        "tcp_app_win" },
 385         { CTL_INT,      NET_TCP_ADV_WIN_SCALE,                  "tcp_adv_win_scale" },
 386         { CTL_INT,      NET_TCP_TW_REUSE,                       "tcp_tw_reuse" },
 387         { CTL_INT,      NET_TCP_FRTO,                           "tcp_frto" },
 388         { CTL_INT,      NET_TCP_FRTO_RESPONSE,                  "tcp_frto_response" },
 389         { CTL_INT,      NET_TCP_LOW_LATENCY,                    "tcp_low_latency" },
 390         { CTL_INT,      NET_TCP_NO_METRICS_SAVE,                "tcp_no_metrics_save" },
 391         { CTL_INT,      NET_TCP_MODERATE_RCVBUF,                "tcp_moderate_rcvbuf" },
 392         { CTL_INT,      NET_TCP_TSO_WIN_DIVISOR,                "tcp_tso_win_divisor" },
 393         { CTL_STR,      NET_TCP_CONG_CONTROL,                   "tcp_congestion_control" },
 394         { CTL_INT,      NET_TCP_MTU_PROBING,                    "tcp_mtu_probing" },
 395         { CTL_INT,      NET_TCP_BASE_MSS,                       "tcp_base_mss" },
 396         { CTL_INT,      NET_IPV4_TCP_WORKAROUND_SIGNED_WINDOWS, "tcp_workaround_signed_windows" },
 397         { CTL_INT,      NET_TCP_SLOW_START_AFTER_IDLE,          "tcp_slow_start_after_idle" },
 398         { CTL_INT,      NET_CIPSOV4_CACHE_ENABLE,               "cipso_cache_enable" },
 399         { CTL_INT,      NET_CIPSOV4_CACHE_BUCKET_SIZE,          "cipso_cache_bucket_size" },
 400         { CTL_INT,      NET_CIPSOV4_RBM_OPTFMT,                 "cipso_rbm_optfmt" },
 401         { CTL_INT,      NET_CIPSOV4_RBM_STRICTVALID,            "cipso_rbm_strictvalid" },
 402         /* NET_TCP_AVAIL_CONG_CONTROL "tcp_available_congestion_control" no longer used */
 403         { CTL_STR,      NET_TCP_ALLOWED_CONG_CONTROL,           "tcp_allowed_congestion_control" },
 404         { CTL_INT,      NET_TCP_MAX_SSTHRESH,                   "tcp_max_ssthresh" },
 405 
 406         { CTL_INT,      NET_IPV4_ICMP_ECHO_IGNORE_ALL,          "icmp_echo_ignore_all" },
 407         { CTL_INT,      NET_IPV4_ICMP_ECHO_IGNORE_BROADCASTS,   "icmp_echo_ignore_broadcasts" },
 408         { CTL_INT,      NET_IPV4_ICMP_IGNORE_BOGUS_ERROR_RESPONSES,     "icmp_ignore_bogus_error_responses" },
 409         { CTL_INT,      NET_IPV4_ICMP_ERRORS_USE_INBOUND_IFADDR,        "icmp_errors_use_inbound_ifaddr" },
 410         { CTL_INT,      NET_IPV4_ICMP_RATELIMIT,                "icmp_ratelimit" },
 411         { CTL_INT,      NET_IPV4_ICMP_RATEMASK,                 "icmp_ratemask" },
 412 
 413         { CTL_INT,      NET_IPV4_IPFRAG_HIGH_THRESH,            "ipfrag_high_thresh" },
 414         { CTL_INT,      NET_IPV4_IPFRAG_LOW_THRESH,             "ipfrag_low_thresh" },
 415         { CTL_INT,      NET_IPV4_IPFRAG_TIME,                   "ipfrag_time" },
 416 
 417         { CTL_INT,      NET_IPV4_IPFRAG_SECRET_INTERVAL,        "ipfrag_secret_interval" },
 418         /* NET_IPV4_IPFRAG_MAX_DIST "ipfrag_max_dist" no longer used */
 419 
 420         { CTL_INT,      2088 /* NET_IPQ_QMAX */,                "ip_queue_maxlen" },
 421 
 422         /* NET_TCP_DEFAULT_WIN_SCALE unused */
 423         /* NET_TCP_BIC_BETA unused */
 424         /* NET_IPV4_TCP_MAX_KA_PROBES unused */
 425         /* NET_IPV4_IP_MASQ_DEBUG unused */
 426         /* NET_TCP_SYN_TAILDROP unused */
 427         /* NET_IPV4_ICMP_SOURCEQUENCH_RATE unused */
 428         /* NET_IPV4_ICMP_DESTUNREACH_RATE unused */
 429         /* NET_IPV4_ICMP_TIMEEXCEED_RATE unused */
 430         /* NET_IPV4_ICMP_PARAMPROB_RATE unused */
 431         /* NET_IPV4_ICMP_ECHOREPLY_RATE unused */
 432         /* NET_IPV4_ALWAYS_DEFRAG unused */
 433         {}
 434 };
 435 
 436 static const struct bin_table bin_net_ipx_table[] = {
 437         { CTL_INT,      NET_IPX_PPROP_BROADCASTING,     "ipx_pprop_broadcasting" },
 438         /* NET_IPX_FORWARDING unused */
 439         {}
 440 };
 441 
 442 static const struct bin_table bin_net_atalk_table[] = {
 443         { CTL_INT,      NET_ATALK_AARP_EXPIRY_TIME,             "aarp-expiry-time" },
 444         { CTL_INT,      NET_ATALK_AARP_TICK_TIME,               "aarp-tick-time" },
 445         { CTL_INT,      NET_ATALK_AARP_RETRANSMIT_LIMIT,        "aarp-retransmit-limit" },
 446         { CTL_INT,      NET_ATALK_AARP_RESOLVE_TIME,            "aarp-resolve-time" },
 447         {},
 448 };
 449 
 450 static const struct bin_table bin_net_netrom_table[] = {
 451         { CTL_INT,      NET_NETROM_DEFAULT_PATH_QUALITY,                "default_path_quality" },
 452         { CTL_INT,      NET_NETROM_OBSOLESCENCE_COUNT_INITIALISER,      "obsolescence_count_initialiser" },
 453         { CTL_INT,      NET_NETROM_NETWORK_TTL_INITIALISER,             "network_ttl_initialiser" },
 454         { CTL_INT,      NET_NETROM_TRANSPORT_TIMEOUT,                   "transport_timeout" },
 455         { CTL_INT,      NET_NETROM_TRANSPORT_MAXIMUM_TRIES,             "transport_maximum_tries" },
 456         { CTL_INT,      NET_NETROM_TRANSPORT_ACKNOWLEDGE_DELAY,         "transport_acknowledge_delay" },
 457         { CTL_INT,      NET_NETROM_TRANSPORT_BUSY_DELAY,                "transport_busy_delay" },
 458         { CTL_INT,      NET_NETROM_TRANSPORT_REQUESTED_WINDOW_SIZE,     "transport_requested_window_size" },
 459         { CTL_INT,      NET_NETROM_TRANSPORT_NO_ACTIVITY_TIMEOUT,       "transport_no_activity_timeout" },
 460         { CTL_INT,      NET_NETROM_ROUTING_CONTROL,                     "routing_control" },
 461         { CTL_INT,      NET_NETROM_LINK_FAILS_COUNT,                    "link_fails_count" },
 462         { CTL_INT,      NET_NETROM_RESET,                               "reset" },
 463         {}
 464 };
 465 
 466 static const struct bin_table bin_net_ax25_param_table[] = {
 467         { CTL_INT,      NET_AX25_IP_DEFAULT_MODE,       "ip_default_mode" },
 468         { CTL_INT,      NET_AX25_DEFAULT_MODE,          "ax25_default_mode" },
 469         { CTL_INT,      NET_AX25_BACKOFF_TYPE,          "backoff_type" },
 470         { CTL_INT,      NET_AX25_CONNECT_MODE,          "connect_mode" },
 471         { CTL_INT,      NET_AX25_STANDARD_WINDOW,       "standard_window_size" },
 472         { CTL_INT,      NET_AX25_EXTENDED_WINDOW,       "extended_window_size" },
 473         { CTL_INT,      NET_AX25_T1_TIMEOUT,            "t1_timeout" },
 474         { CTL_INT,      NET_AX25_T2_TIMEOUT,            "t2_timeout" },
 475         { CTL_INT,      NET_AX25_T3_TIMEOUT,            "t3_timeout" },
 476         { CTL_INT,      NET_AX25_IDLE_TIMEOUT,          "idle_timeout" },
 477         { CTL_INT,      NET_AX25_N2,                    "maximum_retry_count" },
 478         { CTL_INT,      NET_AX25_PACLEN,                "maximum_packet_length" },
 479         { CTL_INT,      NET_AX25_PROTOCOL,              "protocol" },
 480         { CTL_INT,      NET_AX25_DAMA_SLAVE_TIMEOUT,    "dama_slave_timeout" },
 481         {}
 482 };
 483 
 484 static const struct bin_table bin_net_ax25_table[] = {
 485         { CTL_DIR,      0, NULL, bin_net_ax25_param_table },
 486         {}
 487 };
 488 
 489 static const struct bin_table bin_net_rose_table[] = {
 490         { CTL_INT,      NET_ROSE_RESTART_REQUEST_TIMEOUT,       "restart_request_timeout" },
 491         { CTL_INT,      NET_ROSE_CALL_REQUEST_TIMEOUT,          "call_request_timeout" },
 492         { CTL_INT,      NET_ROSE_RESET_REQUEST_TIMEOUT,         "reset_request_timeout" },
 493         { CTL_INT,      NET_ROSE_CLEAR_REQUEST_TIMEOUT,         "clear_request_timeout" },
 494         { CTL_INT,      NET_ROSE_ACK_HOLD_BACK_TIMEOUT,         "acknowledge_hold_back_timeout" },
 495         { CTL_INT,      NET_ROSE_ROUTING_CONTROL,               "routing_control" },
 496         { CTL_INT,      NET_ROSE_LINK_FAIL_TIMEOUT,             "link_fail_timeout" },
 497         { CTL_INT,      NET_ROSE_MAX_VCS,                       "maximum_virtual_circuits" },
 498         { CTL_INT,      NET_ROSE_WINDOW_SIZE,                   "window_size" },
 499         { CTL_INT,      NET_ROSE_NO_ACTIVITY_TIMEOUT,           "no_activity_timeout" },
 500         {}
 501 };
 502 
 503 static const struct bin_table bin_net_ipv6_conf_var_table[] = {
 504         { CTL_INT,      NET_IPV6_FORWARDING,                    "forwarding" },
 505         { CTL_INT,      NET_IPV6_HOP_LIMIT,                     "hop_limit" },
 506         { CTL_INT,      NET_IPV6_MTU,                           "mtu" },
 507         { CTL_INT,      NET_IPV6_ACCEPT_RA,                     "accept_ra" },
 508         { CTL_INT,      NET_IPV6_ACCEPT_REDIRECTS,              "accept_redirects" },
 509         { CTL_INT,      NET_IPV6_AUTOCONF,                      "autoconf" },
 510         { CTL_INT,      NET_IPV6_DAD_TRANSMITS,                 "dad_transmits" },
 511         { CTL_INT,      NET_IPV6_RTR_SOLICITS,                  "router_solicitations" },
 512         { CTL_INT,      NET_IPV6_RTR_SOLICIT_INTERVAL,          "router_solicitation_interval" },
 513         { CTL_INT,      NET_IPV6_RTR_SOLICIT_DELAY,             "router_solicitation_delay" },
 514         { CTL_INT,      NET_IPV6_USE_TEMPADDR,                  "use_tempaddr" },
 515         { CTL_INT,      NET_IPV6_TEMP_VALID_LFT,                "temp_valid_lft" },
 516         { CTL_INT,      NET_IPV6_TEMP_PREFERED_LFT,             "temp_prefered_lft" },
 517         { CTL_INT,      NET_IPV6_REGEN_MAX_RETRY,               "regen_max_retry" },
 518         { CTL_INT,      NET_IPV6_MAX_DESYNC_FACTOR,             "max_desync_factor" },
 519         { CTL_INT,      NET_IPV6_MAX_ADDRESSES,                 "max_addresses" },
 520         { CTL_INT,      NET_IPV6_FORCE_MLD_VERSION,             "force_mld_version" },
 521         { CTL_INT,      NET_IPV6_ACCEPT_RA_DEFRTR,              "accept_ra_defrtr" },
 522         { CTL_INT,      NET_IPV6_ACCEPT_RA_PINFO,               "accept_ra_pinfo" },
 523         { CTL_INT,      NET_IPV6_ACCEPT_RA_RTR_PREF,            "accept_ra_rtr_pref" },
 524         { CTL_INT,      NET_IPV6_RTR_PROBE_INTERVAL,            "router_probe_interval" },
 525         { CTL_INT,      NET_IPV6_ACCEPT_RA_RT_INFO_MAX_PLEN,    "accept_ra_rt_info_max_plen" },
 526         { CTL_INT,      NET_IPV6_PROXY_NDP,                     "proxy_ndp" },
 527         { CTL_INT,      NET_IPV6_ACCEPT_SOURCE_ROUTE,           "accept_source_route" },
 528         { CTL_INT,      NET_IPV6_ACCEPT_RA_FROM_LOCAL,          "accept_ra_from_local" },
 529         {}
 530 };
 531 
 532 static const struct bin_table bin_net_ipv6_conf_table[] = {
 533         { CTL_DIR,      NET_PROTO_CONF_ALL,             "all",  bin_net_ipv6_conf_var_table },
 534         { CTL_DIR,      NET_PROTO_CONF_DEFAULT,         "default", bin_net_ipv6_conf_var_table },
 535         { CTL_DIR,      0, NULL, bin_net_ipv6_conf_var_table },
 536         {}
 537 };
 538 
 539 static const struct bin_table bin_net_ipv6_route_table[] = {
 540         /* NET_IPV6_ROUTE_FLUSH "flush"  no longer used */
 541         { CTL_INT,      NET_IPV6_ROUTE_GC_THRESH,               "gc_thresh" },
 542         { CTL_INT,      NET_IPV6_ROUTE_MAX_SIZE,                "max_size" },
 543         { CTL_INT,      NET_IPV6_ROUTE_GC_MIN_INTERVAL,         "gc_min_interval" },
 544         { CTL_INT,      NET_IPV6_ROUTE_GC_TIMEOUT,              "gc_timeout" },
 545         { CTL_INT,      NET_IPV6_ROUTE_GC_INTERVAL,             "gc_interval" },
 546         { CTL_INT,      NET_IPV6_ROUTE_GC_ELASTICITY,           "gc_elasticity" },
 547         { CTL_INT,      NET_IPV6_ROUTE_MTU_EXPIRES,             "mtu_expires" },
 548         { CTL_INT,      NET_IPV6_ROUTE_MIN_ADVMSS,              "min_adv_mss" },
 549         { CTL_INT,      NET_IPV6_ROUTE_GC_MIN_INTERVAL_MS,      "gc_min_interval_ms" },
 550         {}
 551 };
 552 
 553 static const struct bin_table bin_net_ipv6_icmp_table[] = {
 554         { CTL_INT,      NET_IPV6_ICMP_RATELIMIT,        "ratelimit" },
 555         {}
 556 };
 557 
 558 static const struct bin_table bin_net_ipv6_table[] = {
 559         { CTL_DIR,      NET_IPV6_CONF,          "conf",         bin_net_ipv6_conf_table },
 560         { CTL_DIR,      NET_IPV6_NEIGH,         "neigh",        bin_net_neigh_table },
 561         { CTL_DIR,      NET_IPV6_ROUTE,         "route",        bin_net_ipv6_route_table },
 562         { CTL_DIR,      NET_IPV6_ICMP,          "icmp",         bin_net_ipv6_icmp_table },
 563         { CTL_INT,      NET_IPV6_BINDV6ONLY,            "bindv6only" },
 564         { CTL_INT,      NET_IPV6_IP6FRAG_HIGH_THRESH,   "ip6frag_high_thresh" },
 565         { CTL_INT,      NET_IPV6_IP6FRAG_LOW_THRESH,    "ip6frag_low_thresh" },
 566         { CTL_INT,      NET_IPV6_IP6FRAG_TIME,          "ip6frag_time" },
 567         { CTL_INT,      NET_IPV6_IP6FRAG_SECRET_INTERVAL,       "ip6frag_secret_interval" },
 568         { CTL_INT,      NET_IPV6_MLD_MAX_MSF,           "mld_max_msf" },
 569         { CTL_INT,      2088 /* IPQ_QMAX */,            "ip6_queue_maxlen" },
 570         {}
 571 };
 572 
 573 static const struct bin_table bin_net_x25_table[] = {
 574         { CTL_INT,      NET_X25_RESTART_REQUEST_TIMEOUT,        "restart_request_timeout" },
 575         { CTL_INT,      NET_X25_CALL_REQUEST_TIMEOUT,           "call_request_timeout" },
 576         { CTL_INT,      NET_X25_RESET_REQUEST_TIMEOUT,  "reset_request_timeout" },
 577         { CTL_INT,      NET_X25_CLEAR_REQUEST_TIMEOUT,  "clear_request_timeout" },
 578         { CTL_INT,      NET_X25_ACK_HOLD_BACK_TIMEOUT,  "acknowledgement_hold_back_timeout" },
 579         { CTL_INT,      NET_X25_FORWARD,                        "x25_forward" },
 580         {}
 581 };
 582 
 583 static const struct bin_table bin_net_tr_table[] = {
 584         { CTL_INT,      NET_TR_RIF_TIMEOUT,     "rif_timeout" },
 585         {}
 586 };
 587 
 588 
 589 static const struct bin_table bin_net_decnet_conf_vars[] = {
 590         { CTL_INT,      NET_DECNET_CONF_DEV_FORWARDING, "forwarding" },
 591         { CTL_INT,      NET_DECNET_CONF_DEV_PRIORITY,   "priority" },
 592         { CTL_INT,      NET_DECNET_CONF_DEV_T2,         "t2" },
 593         { CTL_INT,      NET_DECNET_CONF_DEV_T3,         "t3" },
 594         {}
 595 };
 596 
 597 static const struct bin_table bin_net_decnet_conf[] = {
 598         { CTL_DIR, NET_DECNET_CONF_ETHER,    "ethernet", bin_net_decnet_conf_vars },
 599         { CTL_DIR, NET_DECNET_CONF_GRE,      "ipgre",    bin_net_decnet_conf_vars },
 600         { CTL_DIR, NET_DECNET_CONF_X25,      "x25",      bin_net_decnet_conf_vars },
 601         { CTL_DIR, NET_DECNET_CONF_PPP,      "ppp",      bin_net_decnet_conf_vars },
 602         { CTL_DIR, NET_DECNET_CONF_DDCMP,    "ddcmp",    bin_net_decnet_conf_vars },
 603         { CTL_DIR, NET_DECNET_CONF_LOOPBACK, "loopback", bin_net_decnet_conf_vars },
 604         { CTL_DIR, 0,                        NULL,       bin_net_decnet_conf_vars },
 605         {}
 606 };
 607 
 608 static const struct bin_table bin_net_decnet_table[] = {
 609         { CTL_DIR,      NET_DECNET_CONF,                "conf", bin_net_decnet_conf },
 610         { CTL_DNADR,    NET_DECNET_NODE_ADDRESS,        "node_address" },
 611         { CTL_STR,      NET_DECNET_NODE_NAME,           "node_name" },
 612         { CTL_STR,      NET_DECNET_DEFAULT_DEVICE,      "default_device" },
 613         { CTL_INT,      NET_DECNET_TIME_WAIT,           "time_wait" },
 614         { CTL_INT,      NET_DECNET_DN_COUNT,            "dn_count" },
 615         { CTL_INT,      NET_DECNET_DI_COUNT,            "di_count" },
 616         { CTL_INT,      NET_DECNET_DR_COUNT,            "dr_count" },
 617         { CTL_INT,      NET_DECNET_DST_GC_INTERVAL,     "dst_gc_interval" },
 618         { CTL_INT,      NET_DECNET_NO_FC_MAX_CWND,      "no_fc_max_cwnd" },
 619         { CTL_INT,      NET_DECNET_MEM,         "decnet_mem" },
 620         { CTL_INT,      NET_DECNET_RMEM,                "decnet_rmem" },
 621         { CTL_INT,      NET_DECNET_WMEM,                "decnet_wmem" },
 622         { CTL_INT,      NET_DECNET_DEBUG_LEVEL, "debug" },
 623         {}
 624 };
 625 
 626 static const struct bin_table bin_net_sctp_table[] = {
 627         { CTL_INT,      NET_SCTP_RTO_INITIAL,           "rto_initial" },
 628         { CTL_INT,      NET_SCTP_RTO_MIN,               "rto_min" },
 629         { CTL_INT,      NET_SCTP_RTO_MAX,               "rto_max" },
 630         { CTL_INT,      NET_SCTP_RTO_ALPHA,             "rto_alpha_exp_divisor" },
 631         { CTL_INT,      NET_SCTP_RTO_BETA,              "rto_beta_exp_divisor" },
 632         { CTL_INT,      NET_SCTP_VALID_COOKIE_LIFE,     "valid_cookie_life" },
 633         { CTL_INT,      NET_SCTP_ASSOCIATION_MAX_RETRANS,       "association_max_retrans" },
 634         { CTL_INT,      NET_SCTP_PATH_MAX_RETRANS,      "path_max_retrans" },
 635         { CTL_INT,      NET_SCTP_MAX_INIT_RETRANSMITS,  "max_init_retransmits" },
 636         { CTL_INT,      NET_SCTP_HB_INTERVAL,           "hb_interval" },
 637         { CTL_INT,      NET_SCTP_PRESERVE_ENABLE,       "cookie_preserve_enable" },
 638         { CTL_INT,      NET_SCTP_MAX_BURST,             "max_burst" },
 639         { CTL_INT,      NET_SCTP_ADDIP_ENABLE,          "addip_enable" },
 640         { CTL_INT,      NET_SCTP_PRSCTP_ENABLE,         "prsctp_enable" },
 641         { CTL_INT,      NET_SCTP_SNDBUF_POLICY,         "sndbuf_policy" },
 642         { CTL_INT,      NET_SCTP_SACK_TIMEOUT,          "sack_timeout" },
 643         { CTL_INT,      NET_SCTP_RCVBUF_POLICY,         "rcvbuf_policy" },
 644         {}
 645 };
 646 
 647 static const struct bin_table bin_net_llc_llc2_timeout_table[] = {
 648         { CTL_INT,      NET_LLC2_ACK_TIMEOUT,   "ack" },
 649         { CTL_INT,      NET_LLC2_P_TIMEOUT,     "p" },
 650         { CTL_INT,      NET_LLC2_REJ_TIMEOUT,   "rej" },
 651         { CTL_INT,      NET_LLC2_BUSY_TIMEOUT,  "busy" },
 652         {}
 653 };
 654 
 655 static const struct bin_table bin_net_llc_station_table[] = {
 656         { CTL_INT,      NET_LLC_STATION_ACK_TIMEOUT,    "ack_timeout" },
 657         {}
 658 };
 659 
 660 static const struct bin_table bin_net_llc_llc2_table[] = {
 661         { CTL_DIR,      NET_LLC2,               "timeout",      bin_net_llc_llc2_timeout_table },
 662         {}
 663 };
 664 
 665 static const struct bin_table bin_net_llc_table[] = {
 666         { CTL_DIR,      NET_LLC2,               "llc2",         bin_net_llc_llc2_table },
 667         { CTL_DIR,      NET_LLC_STATION,        "station",      bin_net_llc_station_table },
 668         {}
 669 };
 670 
 671 static const struct bin_table bin_net_netfilter_table[] = {
 672         { CTL_INT,      NET_NF_CONNTRACK_MAX,                   "nf_conntrack_max" },
 673         /* NET_NF_CONNTRACK_TCP_TIMEOUT_SYN_SENT "nf_conntrack_tcp_timeout_syn_sent" no longer used */
 674         /* NET_NF_CONNTRACK_TCP_TIMEOUT_SYN_RECV "nf_conntrack_tcp_timeout_syn_recv" no longer used */
 675         /* NET_NF_CONNTRACK_TCP_TIMEOUT_ESTABLISHED "nf_conntrack_tcp_timeout_established" no longer used */
 676         /* NET_NF_CONNTRACK_TCP_TIMEOUT_FIN_WAIT "nf_conntrack_tcp_timeout_fin_wait" no longer used */
 677         /* NET_NF_CONNTRACK_TCP_TIMEOUT_CLOSE_WAIT "nf_conntrack_tcp_timeout_close_wait" no longer used */
 678         /* NET_NF_CONNTRACK_TCP_TIMEOUT_LAST_ACK "nf_conntrack_tcp_timeout_last_ack" no longer used */
 679         /* NET_NF_CONNTRACK_TCP_TIMEOUT_TIME_WAIT "nf_conntrack_tcp_timeout_time_wait" no longer used */
 680         /* NET_NF_CONNTRACK_TCP_TIMEOUT_CLOSE "nf_conntrack_tcp_timeout_close" no longer used */
 681         /* NET_NF_CONNTRACK_UDP_TIMEOUT "nf_conntrack_udp_timeout" no longer used */
 682         /* NET_NF_CONNTRACK_UDP_TIMEOUT_STREAM "nf_conntrack_udp_timeout_stream" no longer used */
 683         /* NET_NF_CONNTRACK_ICMP_TIMEOUT "nf_conntrack_icmp_timeout" no longer used */
 684         /* NET_NF_CONNTRACK_GENERIC_TIMEOUT "nf_conntrack_generic_timeout" no longer used */
 685         { CTL_INT,      NET_NF_CONNTRACK_BUCKETS,               "nf_conntrack_buckets" },
 686         { CTL_INT,      NET_NF_CONNTRACK_LOG_INVALID,           "nf_conntrack_log_invalid" },
 687         /* NET_NF_CONNTRACK_TCP_TIMEOUT_MAX_RETRANS "nf_conntrack_tcp_timeout_max_retrans" no longer used */
 688         { CTL_INT,      NET_NF_CONNTRACK_TCP_LOOSE,             "nf_conntrack_tcp_loose" },
 689         { CTL_INT,      NET_NF_CONNTRACK_TCP_BE_LIBERAL,        "nf_conntrack_tcp_be_liberal" },
 690         { CTL_INT,      NET_NF_CONNTRACK_TCP_MAX_RETRANS,       "nf_conntrack_tcp_max_retrans" },
 691         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_CLOSED "nf_conntrack_sctp_timeout_closed" no longer used */
 692         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_COOKIE_WAIT "nf_conntrack_sctp_timeout_cookie_wait" no longer used */
 693         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_COOKIE_ECHOED "nf_conntrack_sctp_timeout_cookie_echoed" no longer used */
 694         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_ESTABLISHED "nf_conntrack_sctp_timeout_established" no longer used */
 695         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_SHUTDOWN_SENT "nf_conntrack_sctp_timeout_shutdown_sent" no longer used */
 696         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_SHUTDOWN_RECD "nf_conntrack_sctp_timeout_shutdown_recd" no longer used */
 697         /* NET_NF_CONNTRACK_SCTP_TIMEOUT_SHUTDOWN_ACK_SENT "nf_conntrack_sctp_timeout_shutdown_ack_sent" no longer used */
 698         { CTL_INT,      NET_NF_CONNTRACK_COUNT,                 "nf_conntrack_count" },
 699         /* NET_NF_CONNTRACK_ICMPV6_TIMEOUT "nf_conntrack_icmpv6_timeout" no longer used */
 700         /* NET_NF_CONNTRACK_FRAG6_TIMEOUT "nf_conntrack_frag6_timeout" no longer used */
 701         { CTL_INT,      NET_NF_CONNTRACK_FRAG6_LOW_THRESH,      "nf_conntrack_frag6_low_thresh" },
 702         { CTL_INT,      NET_NF_CONNTRACK_FRAG6_HIGH_THRESH,     "nf_conntrack_frag6_high_thresh" },
 703         { CTL_INT,      NET_NF_CONNTRACK_CHECKSUM,              "nf_conntrack_checksum" },
 704 
 705         {}
 706 };
 707 
 708 static const struct bin_table bin_net_table[] = {
 709         { CTL_DIR,      NET_CORE,               "core",         bin_net_core_table },
 710         /* NET_ETHER not used */
 711         /* NET_802 not used */
 712         { CTL_DIR,      NET_UNIX,               "unix",         bin_net_unix_table },
 713         { CTL_DIR,      NET_IPV4,               "ipv4",         bin_net_ipv4_table },
 714         { CTL_DIR,      NET_IPX,                "ipx",          bin_net_ipx_table },
 715         { CTL_DIR,      NET_ATALK,              "appletalk",    bin_net_atalk_table },
 716         { CTL_DIR,      NET_NETROM,             "netrom",       bin_net_netrom_table },
 717         { CTL_DIR,      NET_AX25,               "ax25",         bin_net_ax25_table },
 718         /*  NET_BRIDGE "bridge" no longer used */
 719         { CTL_DIR,      NET_ROSE,               "rose",         bin_net_rose_table },
 720         { CTL_DIR,      NET_IPV6,               "ipv6",         bin_net_ipv6_table },
 721         { CTL_DIR,      NET_X25,                "x25",          bin_net_x25_table },
 722         { CTL_DIR,      NET_TR,                 "token-ring",   bin_net_tr_table },
 723         { CTL_DIR,      NET_DECNET,             "decnet",       bin_net_decnet_table },
 724         /*  NET_ECONET not used */
 725         { CTL_DIR,      NET_SCTP,               "sctp",         bin_net_sctp_table },
 726         { CTL_DIR,      NET_LLC,                "llc",          bin_net_llc_table },
 727         { CTL_DIR,      NET_NETFILTER,          "netfilter",    bin_net_netfilter_table },
 728         /* NET_DCCP "dccp" no longer used */
 729         /* NET_IRDA "irda" no longer used */
 730         { CTL_INT,      2089,                   "nf_conntrack_max" },
 731         {}
 732 };
 733 
 734 static const struct bin_table bin_fs_quota_table[] = {
 735         { CTL_INT,      FS_DQ_LOOKUPS,          "lookups" },
 736         { CTL_INT,      FS_DQ_DROPS,            "drops" },
 737         { CTL_INT,      FS_DQ_READS,            "reads" },
 738         { CTL_INT,      FS_DQ_WRITES,           "writes" },
 739         { CTL_INT,      FS_DQ_CACHE_HITS,       "cache_hits" },
 740         { CTL_INT,      FS_DQ_ALLOCATED,        "allocated_dquots" },
 741         { CTL_INT,      FS_DQ_FREE,             "free_dquots" },
 742         { CTL_INT,      FS_DQ_SYNCS,            "syncs" },
 743         { CTL_INT,      FS_DQ_WARNINGS,         "warnings" },
 744         {}
 745 };
 746 
 747 static const struct bin_table bin_fs_xfs_table[] = {
 748         { CTL_INT,      XFS_SGID_INHERIT,       "irix_sgid_inherit" },
 749         { CTL_INT,      XFS_SYMLINK_MODE,       "irix_symlink_mode" },
 750         { CTL_INT,      XFS_PANIC_MASK,         "panic_mask" },
 751 
 752         { CTL_INT,      XFS_ERRLEVEL,           "error_level" },
 753         { CTL_INT,      XFS_SYNCD_TIMER,        "xfssyncd_centisecs" },
 754         { CTL_INT,      XFS_INHERIT_SYNC,       "inherit_sync" },
 755         { CTL_INT,      XFS_INHERIT_NODUMP,     "inherit_nodump" },
 756         { CTL_INT,      XFS_INHERIT_NOATIME,    "inherit_noatime" },
 757         { CTL_INT,      XFS_BUF_TIMER,          "xfsbufd_centisecs" },
 758         { CTL_INT,      XFS_BUF_AGE,            "age_buffer_centisecs" },
 759         { CTL_INT,      XFS_INHERIT_NOSYM,      "inherit_nosymlinks" },
 760         { CTL_INT,      XFS_ROTORSTEP,  "rotorstep" },
 761         { CTL_INT,      XFS_INHERIT_NODFRG,     "inherit_nodefrag" },
 762         { CTL_INT,      XFS_FILESTREAM_TIMER,   "filestream_centisecs" },
 763         { CTL_INT,      XFS_STATS_CLEAR,        "stats_clear" },
 764         {}
 765 };
 766 
 767 static const struct bin_table bin_fs_ocfs2_nm_table[] = {
 768         { CTL_STR,      1, "hb_ctl_path" },
 769         {}
 770 };
 771 
 772 static const struct bin_table bin_fs_ocfs2_table[] = {
 773         { CTL_DIR,      1,      "nm",   bin_fs_ocfs2_nm_table },
 774         {}
 775 };
 776 
 777 static const struct bin_table bin_inotify_table[] = {
 778         { CTL_INT,      INOTIFY_MAX_USER_INSTANCES,     "max_user_instances" },
 779         { CTL_INT,      INOTIFY_MAX_USER_WATCHES,       "max_user_watches" },
 780         { CTL_INT,      INOTIFY_MAX_QUEUED_EVENTS,      "max_queued_events" },
 781         {}
 782 };
 783 
 784 static const struct bin_table bin_fs_table[] = {
 785         { CTL_INT,      FS_NRINODE,             "inode-nr" },
 786         { CTL_INT,      FS_STATINODE,           "inode-state" },
 787         /* FS_MAXINODE unused */
 788         /* FS_NRDQUOT unused */
 789         /* FS_MAXDQUOT unused */
 790         /* FS_NRFILE "file-nr" no longer used */
 791         { CTL_INT,      FS_MAXFILE,             "file-max" },
 792         { CTL_INT,      FS_DENTRY,              "dentry-state" },
 793         /* FS_NRSUPER unused */
 794         /* FS_MAXUPSER unused */
 795         { CTL_INT,      FS_OVERFLOWUID,         "overflowuid" },
 796         { CTL_INT,      FS_OVERFLOWGID,         "overflowgid" },
 797         { CTL_INT,      FS_LEASES,              "leases-enable" },
 798         { CTL_INT,      FS_DIR_NOTIFY,          "dir-notify-enable" },
 799         { CTL_INT,      FS_LEASE_TIME,          "lease-break-time" },
 800         { CTL_DIR,      FS_DQSTATS,             "quota",        bin_fs_quota_table },
 801         { CTL_DIR,      FS_XFS,                 "xfs",          bin_fs_xfs_table },
 802         { CTL_ULONG,    FS_AIO_NR,              "aio-nr" },
 803         { CTL_ULONG,    FS_AIO_MAX_NR,          "aio-max-nr" },
 804         { CTL_DIR,      FS_INOTIFY,             "inotify",      bin_inotify_table },
 805         { CTL_DIR,      FS_OCFS2,               "ocfs2",        bin_fs_ocfs2_table },
 806         { CTL_INT,      KERN_SETUID_DUMPABLE,   "suid_dumpable" },
 807         {}
 808 };
 809 
 810 static const struct bin_table bin_ipmi_table[] = {
 811         { CTL_INT,      DEV_IPMI_POWEROFF_POWERCYCLE,   "poweroff_powercycle" },
 812         {}
 813 };
 814 
 815 static const struct bin_table bin_mac_hid_files[] = {
 816         /* DEV_MAC_HID_KEYBOARD_SENDS_LINUX_KEYCODES unused */
 817         /* DEV_MAC_HID_KEYBOARD_LOCK_KEYCODES unused */
 818         { CTL_INT,      DEV_MAC_HID_MOUSE_BUTTON_EMULATION,     "mouse_button_emulation" },
 819         { CTL_INT,      DEV_MAC_HID_MOUSE_BUTTON2_KEYCODE,      "mouse_button2_keycode" },
 820         { CTL_INT,      DEV_MAC_HID_MOUSE_BUTTON3_KEYCODE,      "mouse_button3_keycode" },
 821         /* DEV_MAC_HID_ADB_MOUSE_SENDS_KEYCODES unused */
 822         {}
 823 };
 824 
 825 static const struct bin_table bin_raid_table[] = {
 826         { CTL_INT,      DEV_RAID_SPEED_LIMIT_MIN,       "speed_limit_min" },
 827         { CTL_INT,      DEV_RAID_SPEED_LIMIT_MAX,       "speed_limit_max" },
 828         {}
 829 };
 830 
 831 static const struct bin_table bin_scsi_table[] = {
 832         { CTL_INT, DEV_SCSI_LOGGING_LEVEL, "logging_level" },
 833         {}
 834 };
 835 
 836 static const struct bin_table bin_dev_table[] = {
 837         /* DEV_CDROM    "cdrom" no longer used */
 838         /* DEV_HWMON unused */
 839         /* DEV_PARPORT  "parport" no longer used */
 840         { CTL_DIR,      DEV_RAID,       "raid",         bin_raid_table },
 841         { CTL_DIR,      DEV_MAC_HID,    "mac_hid",      bin_mac_hid_files },
 842         { CTL_DIR,      DEV_SCSI,       "scsi",         bin_scsi_table },
 843         { CTL_DIR,      DEV_IPMI,       "ipmi",         bin_ipmi_table },
 844         {}
 845 };
 846 
 847 static const struct bin_table bin_bus_isa_table[] = {
 848         { CTL_INT,      BUS_ISA_MEM_BASE,       "membase" },
 849         { CTL_INT,      BUS_ISA_PORT_BASE,      "portbase" },
 850         { CTL_INT,      BUS_ISA_PORT_SHIFT,     "portshift" },
 851         {}
 852 };
 853 
 854 static const struct bin_table bin_bus_table[] = {
 855         { CTL_DIR,      CTL_BUS_ISA,    "isa",  bin_bus_isa_table },
 856         {}
 857 };
 858 
 859 
 860 static const struct bin_table bin_s390dbf_table[] = {
 861         { CTL_INT,      5678 /* CTL_S390DBF_STOPPABLE */, "debug_stoppable" },
 862         { CTL_INT,      5679 /* CTL_S390DBF_ACTIVE */,    "debug_active" },
 863         {}
 864 };
 865 
 866 static const struct bin_table bin_sunrpc_table[] = {
 867         /* CTL_RPCDEBUG "rpc_debug"  no longer used */
 868         /* CTL_NFSDEBUG "nfs_debug"  no longer used */
 869         /* CTL_NFSDDEBUG "nfsd_debug" no longer used  */
 870         /* CTL_NLMDEBUG "nlm_debug" no longer used */
 871 
 872         { CTL_INT,      CTL_SLOTTABLE_UDP,      "udp_slot_table_entries" },
 873         { CTL_INT,      CTL_SLOTTABLE_TCP,      "tcp_slot_table_entries" },
 874         { CTL_INT,      CTL_MIN_RESVPORT,       "min_resvport" },
 875         { CTL_INT,      CTL_MAX_RESVPORT,       "max_resvport" },
 876         {}
 877 };
 878 
 879 static const struct bin_table bin_pm_table[] = {
 880         /* frv specific */
 881         /* 1 == CTL_PM_SUSPEND  "suspend"  no longer used" */
 882         { CTL_INT,      2 /* CTL_PM_CMODE */,           "cmode" },
 883         { CTL_INT,      3 /* CTL_PM_P0 */,              "p0" },
 884         { CTL_INT,      4 /* CTL_PM_CM */,              "cm" },
 885         {}
 886 };
 887 
 888 static const struct bin_table bin_root_table[] = {
 889         { CTL_DIR,      CTL_KERN,       "kernel",       bin_kern_table },
 890         { CTL_DIR,      CTL_VM,         "vm",           bin_vm_table },
 891         { CTL_DIR,      CTL_NET,        "net",          bin_net_table },
 892         /* CTL_PROC not used */
 893         { CTL_DIR,      CTL_FS,         "fs",           bin_fs_table },
 894         /* CTL_DEBUG "debug" no longer used */
 895         { CTL_DIR,      CTL_DEV,        "dev",          bin_dev_table },
 896         { CTL_DIR,      CTL_BUS,        "bus",          bin_bus_table },
 897         { CTL_DIR,      CTL_ABI,        "abi" },
 898         /* CTL_CPU not used */
 899         /* CTL_ARLAN "arlan" no longer used */
 900         { CTL_DIR,      CTL_S390DBF,    "s390dbf",      bin_s390dbf_table },
 901         { CTL_DIR,      CTL_SUNRPC,     "sunrpc",       bin_sunrpc_table },
 902         { CTL_DIR,      CTL_PM,         "pm",           bin_pm_table },
 903         {}
 904 };
 905 
 906 static ssize_t bin_dir(struct file *file,
 907         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
 908 {
 909         return -ENOTDIR;
 910 }
 911 
 912 
 913 static ssize_t bin_string(struct file *file,
 914         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
 915 {
 916         ssize_t result, copied = 0;
 917 
 918         if (oldval && oldlen) {
 919                 char __user *lastp;
 920                 loff_t pos = 0;
 921                 int ch;
 922 
 923                 result = vfs_read(file, oldval, oldlen, &pos);
 924                 if (result < 0)
 925                         goto out;
 926 
 927                 copied = result;
 928                 lastp = oldval + copied - 1;
 929 
 930                 result = -EFAULT;
 931                 if (get_user(ch, lastp))
 932                         goto out;
 933 
 934                 /* Trim off the trailing newline */
 935                 if (ch == '\n') {
 936                         result = -EFAULT;
 937                         if (put_user('\0', lastp))
 938                                 goto out;
 939                         copied -= 1;
 940                 }
 941         }
 942 
 943         if (newval && newlen) {
 944                 loff_t pos = 0;
 945 
 946                 result = vfs_write(file, newval, newlen, &pos);
 947                 if (result < 0)
 948                         goto out;
 949         }
 950 
 951         result = copied;
 952 out:
 953         return result;
 954 }
 955 
 956 static ssize_t bin_intvec(struct file *file,
 957         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
 958 {
 959         ssize_t copied = 0;
 960         char *buffer;
 961         ssize_t result;
 962 
 963         result = -ENOMEM;
 964         buffer = kmalloc(BUFSZ, GFP_KERNEL);
 965         if (!buffer)
 966                 goto out;
 967 
 968         if (oldval && oldlen) {
 969                 unsigned __user *vec = oldval;
 970                 size_t length = oldlen / sizeof(*vec);
 971                 char *str, *end;
 972                 int i;
 973                 loff_t pos = 0;
 974 
 975                 result = kernel_read(file, buffer, BUFSZ - 1, &pos);
 976                 if (result < 0)
 977                         goto out_kfree;
 978 
 979                 str = buffer;
 980                 end = str + result;
 981                 *end++ = '\0';
 982                 for (i = 0; i < length; i++) {
 983                         unsigned long value;
 984 
 985                         value = simple_strtoul(str, &str, 10);
 986                         while (isspace(*str))
 987                                 str++;
 988                         
 989                         result = -EFAULT;
 990                         if (put_user(value, vec + i))
 991                                 goto out_kfree;
 992 
 993                         copied += sizeof(*vec);
 994                         if (!isdigit(*str))
 995                                 break;
 996                 }
 997         }
 998 
 999         if (newval && newlen) {
1000                 unsigned __user *vec = newval;
1001                 size_t length = newlen / sizeof(*vec);
1002                 char *str, *end;
1003                 int i;
1004                 loff_t pos = 0;
1005 
1006                 str = buffer;
1007                 end = str + BUFSZ;
1008                 for (i = 0; i < length; i++) {
1009                         unsigned long value;
1010 
1011                         result = -EFAULT;
1012                         if (get_user(value, vec + i))
1013                                 goto out_kfree;
1014 
1015                         str += scnprintf(str, end - str, "%lu\t", value);
1016                 }
1017 
1018                 result = kernel_write(file, buffer, str - buffer, &pos);
1019                 if (result < 0)
1020                         goto out_kfree;
1021         }
1022         result = copied;
1023 out_kfree:
1024         kfree(buffer);
1025 out:
1026         return result;
1027 }
1028 
1029 static ssize_t bin_ulongvec(struct file *file,
1030         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
1031 {
1032         ssize_t copied = 0;
1033         char *buffer;
1034         ssize_t result;
1035 
1036         result = -ENOMEM;
1037         buffer = kmalloc(BUFSZ, GFP_KERNEL);
1038         if (!buffer)
1039                 goto out;
1040 
1041         if (oldval && oldlen) {
1042                 unsigned long __user *vec = oldval;
1043                 size_t length = oldlen / sizeof(*vec);
1044                 char *str, *end;
1045                 int i;
1046                 loff_t pos = 0;
1047 
1048                 result = kernel_read(file, buffer, BUFSZ - 1, &pos);
1049                 if (result < 0)
1050                         goto out_kfree;
1051 
1052                 str = buffer;
1053                 end = str + result;
1054                 *end++ = '\0';
1055                 for (i = 0; i < length; i++) {
1056                         unsigned long value;
1057 
1058                         value = simple_strtoul(str, &str, 10);
1059                         while (isspace(*str))
1060                                 str++;
1061                         
1062                         result = -EFAULT;
1063                         if (put_user(value, vec + i))
1064                                 goto out_kfree;
1065 
1066                         copied += sizeof(*vec);
1067                         if (!isdigit(*str))
1068                                 break;
1069                 }
1070         }
1071 
1072         if (newval && newlen) {
1073                 unsigned long __user *vec = newval;
1074                 size_t length = newlen / sizeof(*vec);
1075                 char *str, *end;
1076                 int i;
1077                 loff_t pos = 0;
1078 
1079                 str = buffer;
1080                 end = str + BUFSZ;
1081                 for (i = 0; i < length; i++) {
1082                         unsigned long value;
1083 
1084                         result = -EFAULT;
1085                         if (get_user(value, vec + i))
1086                                 goto out_kfree;
1087 
1088                         str += scnprintf(str, end - str, "%lu\t", value);
1089                 }
1090 
1091                 result = kernel_write(file, buffer, str - buffer, &pos);
1092                 if (result < 0)
1093                         goto out_kfree;
1094         }
1095         result = copied;
1096 out_kfree:
1097         kfree(buffer);
1098 out:
1099         return result;
1100 }
1101 
1102 static ssize_t bin_uuid(struct file *file,
1103         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
1104 {
1105         ssize_t result, copied = 0;
1106 
1107         /* Only supports reads */
1108         if (oldval && oldlen) {
1109                 char buf[UUID_STRING_LEN + 1];
1110                 uuid_t uuid;
1111                 loff_t pos = 0;
1112 
1113                 result = kernel_read(file, buf, sizeof(buf) - 1, &pos);
1114                 if (result < 0)
1115                         goto out;
1116 
1117                 buf[result] = '\0';
1118 
1119                 result = -EIO;
1120                 if (uuid_parse(buf, &uuid))
1121                         goto out;
1122 
1123                 if (oldlen > 16)
1124                         oldlen = 16;
1125 
1126                 result = -EFAULT;
1127                 if (copy_to_user(oldval, &uuid, oldlen))
1128                         goto out;
1129 
1130                 copied = oldlen;
1131         }
1132         result = copied;
1133 out:
1134         return result;
1135 }
1136 
1137 static ssize_t bin_dn_node_address(struct file *file,
1138         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
1139 {
1140         ssize_t result, copied = 0;
1141 
1142         if (oldval && oldlen) {
1143                 char buf[15], *nodep;
1144                 unsigned long area, node;
1145                 __le16 dnaddr;
1146                 loff_t pos = 0;
1147 
1148                 result = kernel_read(file, buf, sizeof(buf) - 1, &pos);
1149                 if (result < 0)
1150                         goto out;
1151 
1152                 buf[result] = '\0';
1153 
1154                 /* Convert the decnet address to binary */
1155                 result = -EIO;
1156                 nodep = strchr(buf, '.');
1157                 if (!nodep)
1158                         goto out;
1159                 ++nodep;
1160 
1161                 area = simple_strtoul(buf, NULL, 10);
1162                 node = simple_strtoul(nodep, NULL, 10);
1163 
1164                 result = -EIO;
1165                 if ((area > 63)||(node > 1023))
1166                         goto out;
1167 
1168                 dnaddr = cpu_to_le16((area << 10) | node);
1169 
1170                 result = -EFAULT;
1171                 if (put_user(dnaddr, (__le16 __user *)oldval))
1172                         goto out;
1173 
1174                 copied = sizeof(dnaddr);
1175         }
1176 
1177         if (newval && newlen) {
1178                 __le16 dnaddr;
1179                 char buf[15];
1180                 int len;
1181                 loff_t pos = 0;
1182 
1183                 result = -EINVAL;
1184                 if (newlen != sizeof(dnaddr))
1185                         goto out;
1186 
1187                 result = -EFAULT;
1188                 if (get_user(dnaddr, (__le16 __user *)newval))
1189                         goto out;
1190 
1191                 len = scnprintf(buf, sizeof(buf), "%hu.%hu",
1192                                 le16_to_cpu(dnaddr) >> 10,
1193                                 le16_to_cpu(dnaddr) & 0x3ff);
1194 
1195                 result = kernel_write(file, buf, len, &pos);
1196                 if (result < 0)
1197                         goto out;
1198         }
1199 
1200         result = copied;
1201 out:
1202         return result;
1203 }
1204 
1205 static const struct bin_table *get_sysctl(const int *name, int nlen, char *path)
1206 {
1207         const struct bin_table *table = &bin_root_table[0];
1208         int ctl_name;
1209 
1210         /* The binary sysctl tables have a small maximum depth so
1211          * there is no danger of overflowing our path as it PATH_MAX
1212          * bytes long.
1213          */
1214         memcpy(path, "sys/", 4);
1215         path += 4;
1216 
1217 repeat:
1218         if (!nlen)
1219                 return ERR_PTR(-ENOTDIR);
1220         ctl_name = *name;
1221         name++;
1222         nlen--;
1223         for ( ; table->convert; table++) {
1224                 int len = 0;
1225 
1226                 /*
1227                  * For a wild card entry map from ifindex to network
1228                  * device name.
1229                  */
1230                 if (!table->ctl_name) {
1231 #ifdef CONFIG_NET
1232                         struct net *net = current->nsproxy->net_ns;
1233                         struct net_device *dev;
1234                         dev = dev_get_by_index(net, ctl_name);
1235                         if (dev) {
1236                                 len = strlen(dev->name);
1237                                 memcpy(path, dev->name, len);
1238                                 dev_put(dev);
1239                         }
1240 #endif
1241                 /* Use the well known sysctl number to proc name mapping */
1242                 } else if (ctl_name == table->ctl_name) {
1243                         len = strlen(table->procname);
1244                         memcpy(path, table->procname, len);
1245                 }
1246                 if (len) {
1247                         path += len;
1248                         if (table->child) {
1249                                 *path++ = '/';
1250                                 table = table->child;
1251                                 goto repeat;
1252                         }
1253                         *path = '\0';
1254                         return table;
1255                 }
1256         }
1257         return ERR_PTR(-ENOTDIR);
1258 }
1259 
1260 static char *sysctl_getname(const int *name, int nlen, const struct bin_table **tablep)
1261 {
1262         char *tmp, *result;
1263 
1264         result = ERR_PTR(-ENOMEM);
1265         tmp = __getname();
1266         if (tmp) {
1267                 const struct bin_table *table = get_sysctl(name, nlen, tmp);
1268                 result = tmp;
1269                 *tablep = table;
1270                 if (IS_ERR(table)) {
1271                         __putname(tmp);
1272                         result = ERR_CAST(table);
1273                 }
1274         }
1275         return result;
1276 }
1277 
1278 static ssize_t binary_sysctl(const int *name, int nlen,
1279         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
1280 {
1281         const struct bin_table *table = NULL;
1282         struct vfsmount *mnt;
1283         struct file *file;
1284         ssize_t result;
1285         char *pathname;
1286         int flags;
1287 
1288         pathname = sysctl_getname(name, nlen, &table);
1289         result = PTR_ERR(pathname);
1290         if (IS_ERR(pathname))
1291                 goto out;
1292 
1293         /* How should the sysctl be accessed? */
1294         if (oldval && oldlen && newval && newlen) {
1295                 flags = O_RDWR;
1296         } else if (newval && newlen) {
1297                 flags = O_WRONLY;
1298         } else if (oldval && oldlen) {
1299                 flags = O_RDONLY;
1300         } else {
1301                 result = 0;
1302                 goto out_putname;
1303         }
1304 
1305         mnt = task_active_pid_ns(current)->proc_mnt;
1306         file = file_open_root(mnt->mnt_root, mnt, pathname, flags, 0);
1307         result = PTR_ERR(file);
1308         if (IS_ERR(file))
1309                 goto out_putname;
1310 
1311         result = table->convert(file, oldval, oldlen, newval, newlen);
1312 
1313         fput(file);
1314 out_putname:
1315         __putname(pathname);
1316 out:
1317         return result;
1318 }
1319 
1320 
1321 #else /* CONFIG_SYSCTL_SYSCALL */
1322 
1323 static ssize_t binary_sysctl(const int *name, int nlen,
1324         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
1325 {
1326         return -ENOSYS;
1327 }
1328 
1329 #endif /* CONFIG_SYSCTL_SYSCALL */
1330 
1331 
1332 static void deprecated_sysctl_warning(const int *name, int nlen)
1333 {
1334         int i;
1335 
1336         /*
1337          * CTL_KERN/KERN_VERSION is used by older glibc and cannot
1338          * ever go away.
1339          */
1340         if (nlen >= 2 && name[0] == CTL_KERN && name[1] == KERN_VERSION)
1341                 return;
1342 
1343         if (printk_ratelimit()) {
1344                 printk(KERN_INFO
1345                         "warning: process `%s' used the deprecated sysctl "
1346                         "system call with ", current->comm);
1347                 for (i = 0; i < nlen; i++)
1348                         printk(KERN_CONT "%d.", name[i]);
1349                 printk(KERN_CONT "\n");
1350         }
1351         return;
1352 }
1353 
1354 #define WARN_ONCE_HASH_BITS 8
1355 #define WARN_ONCE_HASH_SIZE (1<<WARN_ONCE_HASH_BITS)
1356 
1357 static DECLARE_BITMAP(warn_once_bitmap, WARN_ONCE_HASH_SIZE);
1358 
1359 #define FNV32_OFFSET 2166136261U
1360 #define FNV32_PRIME 0x01000193
1361 
1362 /*
1363  * Print each legacy sysctl (approximately) only once.
1364  * To avoid making the tables non-const use a external
1365  * hash-table instead.
1366  * Worst case hash collision: 6, but very rarely.
1367  * NOTE! We don't use the SMP-safe bit tests. We simply
1368  * don't care enough.
1369  */
1370 static void warn_on_bintable(const int *name, int nlen)
1371 {
1372         int i;
1373         u32 hash = FNV32_OFFSET;
1374 
1375         for (i = 0; i < nlen; i++)
1376                 hash = (hash ^ name[i]) * FNV32_PRIME;
1377         hash %= WARN_ONCE_HASH_SIZE;
1378         if (__test_and_set_bit(hash, warn_once_bitmap))
1379                 return;
1380         deprecated_sysctl_warning(name, nlen);
1381 }
1382 
1383 static ssize_t do_sysctl(int __user *args_name, int nlen,
1384         void __user *oldval, size_t oldlen, void __user *newval, size_t newlen)
1385 {
1386         int name[CTL_MAXNAME];
1387         int i;
1388 
1389         /* Check args->nlen. */
1390         if (nlen < 0 || nlen > CTL_MAXNAME)
1391                 return -ENOTDIR;
1392         /* Read in the sysctl name for simplicity */
1393         for (i = 0; i < nlen; i++)
1394                 if (get_user(name[i], args_name + i))
1395                         return -EFAULT;
1396 
1397         warn_on_bintable(name, nlen);
1398 
1399         return binary_sysctl(name, nlen, oldval, oldlen, newval, newlen);
1400 }
1401 
1402 SYSCALL_DEFINE1(sysctl, struct __sysctl_args __user *, args)
1403 {
1404         struct __sysctl_args tmp;
1405         size_t oldlen = 0;
1406         ssize_t result;
1407 
1408         if (copy_from_user(&tmp, args, sizeof(tmp)))
1409                 return -EFAULT;
1410 
1411         if (tmp.oldval && !tmp.oldlenp)
1412                 return -EFAULT;
1413 
1414         if (tmp.oldlenp && get_user(oldlen, tmp.oldlenp))
1415                 return -EFAULT;
1416 
1417         result = do_sysctl(tmp.name, tmp.nlen, tmp.oldval, oldlen,
1418                            tmp.newval, tmp.newlen);
1419 
1420         if (result >= 0) {
1421                 oldlen = result;
1422                 result = 0;
1423         }
1424 
1425         if (tmp.oldlenp && put_user(oldlen, tmp.oldlenp))
1426                 return -EFAULT;
1427 
1428         return result;
1429 }
1430 
1431 
1432 #ifdef CONFIG_COMPAT
1433 
1434 struct compat_sysctl_args {
1435         compat_uptr_t   name;
1436         int             nlen;
1437         compat_uptr_t   oldval;
1438         compat_uptr_t   oldlenp;
1439         compat_uptr_t   newval;
1440         compat_size_t   newlen;
1441         compat_ulong_t  __unused[4];
1442 };
1443 
1444 COMPAT_SYSCALL_DEFINE1(sysctl, struct compat_sysctl_args __user *, args)
1445 {
1446         struct compat_sysctl_args tmp;
1447         compat_size_t __user *compat_oldlenp;
1448         size_t oldlen = 0;
1449         ssize_t result;
1450 
1451         if (copy_from_user(&tmp, args, sizeof(tmp)))
1452                 return -EFAULT;
1453 
1454         if (tmp.oldval && !tmp.oldlenp)
1455                 return -EFAULT;
1456 
1457         compat_oldlenp = compat_ptr(tmp.oldlenp);
1458         if (compat_oldlenp && get_user(oldlen, compat_oldlenp))
1459                 return -EFAULT;
1460 
1461         result = do_sysctl(compat_ptr(tmp.name), tmp.nlen,
1462                            compat_ptr(tmp.oldval), oldlen,
1463                            compat_ptr(tmp.newval), tmp.newlen);
1464 
1465         if (result >= 0) {
1466                 oldlen = result;
1467                 result = 0;
1468         }
1469 
1470         if (compat_oldlenp && put_user(oldlen, compat_oldlenp))
1471                 return -EFAULT;
1472 
1473         return result;
1474 }
1475 
1476 #endif /* CONFIG_COMPAT */

/* [<][>][^][v][top][bottom][index][help] */