>From 7a210bec3d9dc3382ef0d6809a7742856373bbee Mon Sep 17 00:00:00 2001 From: Manfred Spraul Date: Thu, 4 Dec 2014 07:03:39 +0100 Subject: [PATCH] Allow type safe & documented sysctl Idea from Andrew: - add a union into struct ctl_table instead of the void * - further idea: replace "extra1" and "extra2" with min/max - use it for ipc Notes: - not tested - not coding style reviewed - open FIXME in ipc_sysctl.c Signed-off-by: Manfred Spraul --- include/linux/sysctl.h | 16 ++++++++++++++-- ipc/ipc_sysctl.c | 34 ++++++++++++++++++---------------- 2 files changed, 32 insertions(+), 18 deletions(-) diff --git a/include/linux/sysctl.h b/include/linux/sysctl.h index b7361f8..acc7581 100644 --- a/include/linux/sysctl.h +++ b/include/linux/sysctl.h @@ -111,8 +111,20 @@ struct ctl_table struct ctl_table *child; /* Deprecated */ proc_handler *proc_handler; /* Callback for text formatting */ struct ctl_table_poll *poll; - void *extra1; - void *extra2; + union { + void *extra1; + int *int_min; + long *long_min; + unsigned int *uint_min; + unsigned long *ulong_min; + }; + union { + void *extra2; + int *int_max; + long *long_max; + unsigned int *uint_max; + unsigned long *ulong_max; + }; }; struct ctl_node { diff --git a/ipc/ipc_sysctl.c b/ipc/ipc_sysctl.c index c3f0326..50a6e1c 100644 --- a/ipc/ipc_sysctl.c +++ b/ipc/ipc_sysctl.c @@ -167,6 +167,7 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.shm_ctlmax), .mode = 0644, .proc_handler = proc_ipc_doulongvec_minmax, + /* FIXME: Why no ulong_min & ulong_max ?? */ }, { .procname = "shmall", @@ -174,6 +175,7 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.shm_ctlall), .mode = 0644, .proc_handler = proc_ipc_doulongvec_minmax, + /* FIXME: Why no ulong_min & ulong_max ?? */ }, { .procname = "shmmni", @@ -188,8 +190,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.shm_rmid_forced), .mode = 0644, .proc_handler = proc_ipc_dointvec_minmax_orphans, - .extra1 = &zero, - .extra2 = &one, + .int_min = &zero, + .int_max = &one, }, { .procname = "msgmax", @@ -197,8 +199,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.msg_ctlmax), .mode = 0644, .proc_handler = proc_ipc_dointvec_minmax, - .extra1 = &zero, - .extra2 = &int_max, + .int_min = &zero, + .int_max = &int_max, }, { .procname = "msgmni", @@ -206,8 +208,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.msg_ctlmni), .mode = 0644, .proc_handler = proc_ipc_callback_dointvec_minmax, - .extra1 = &zero, - .extra2 = &int_max, + .int_min = &zero, + .int_max = &int_max, }, { .procname = "msgmnb", @@ -215,8 +217,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.msg_ctlmnb), .mode = 0644, .proc_handler = proc_ipc_dointvec_minmax, - .extra1 = &zero, - .extra2 = &int_max, + .int_min = &zero, + .int_max = &int_max, }, { .procname = "sem", @@ -231,8 +233,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(int), .mode = 0644, .proc_handler = proc_ipcauto_dointvec_minmax, - .extra1 = &zero, - .extra2 = &one, + .int_min = &zero, + .int_max = &one, }, #ifdef CONFIG_CHECKPOINT_RESTORE { @@ -241,8 +243,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.ids[IPC_SEM_IDS].next_id), .mode = 0644, .proc_handler = proc_ipc_dointvec_minmax, - .extra1 = &zero, - .extra2 = &int_max, + .int_min = &zero, + .int_max = &int_max, }, { .procname = "msg_next_id", @@ -250,8 +252,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.ids[IPC_MSG_IDS].next_id), .mode = 0644, .proc_handler = proc_ipc_dointvec_minmax, - .extra1 = &zero, - .extra2 = &int_max, + .int_min = &zero, + .int_max = &int_max, }, { .procname = "shm_next_id", @@ -259,8 +261,8 @@ static struct ctl_table ipc_kern_table[] = { .maxlen = sizeof(init_ipc_ns.ids[IPC_SHM_IDS].next_id), .mode = 0644, .proc_handler = proc_ipc_dointvec_minmax, - .extra1 = &zero, - .extra2 = &int_max, + .int_min = &zero, + .int_max = &int_max, }, #endif {} -- 1.9.3