Commit 06489b4e authored by Eric W. Biederman's avatar Eric W. Biederman Committed by Linus Torvalds

sysctl: remove broken cdrom binary sysctls

The binary interface for the cdrom sysctls can't possilby work.  So remove the
binary sysctls and update the test for finding out which sysctl table entry we
are dealy with to use the procname and not the ctl_name (which I am removing).
Signed-off-by: default avatarEric W. Biederman <ebiederm@xmission.com>
Cc: Alexey Dobriyan <adobriyan@sw.ru>
Cc: Jens Axboe <jens.axboe@oracle.com>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 282a821f
...@@ -3458,47 +3458,19 @@ static void cdrom_update_settings(void) ...@@ -3458,47 +3458,19 @@ static void cdrom_update_settings(void)
static int cdrom_sysctl_handler(ctl_table *ctl, int write, struct file * filp, static int cdrom_sysctl_handler(ctl_table *ctl, int write, struct file * filp,
void __user *buffer, size_t *lenp, loff_t *ppos) void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int *valp = ctl->data;
int val = *valp;
int ret; int ret;
ret = proc_dointvec(ctl, write, filp, buffer, lenp, ppos); ret = proc_dointvec(ctl, write, filp, buffer, lenp, ppos);
if (write && *valp != val) { if (write) {
/* we only care for 1 or 0. */ /* we only care for 1 or 0. */
if (*valp) autoclose = !!cdrom_sysctl_settings.autoclose;
*valp = 1; autoeject = !!cdrom_sysctl_settings.autoeject;
else debug = !!cdrom_sysctl_settings.debug;
*valp = 0; lockdoor = !!cdrom_sysctl_settings.lock;
check_media_type = !!cdrom_sysctl_settings.check;
switch (ctl->ctl_name) {
case DEV_CDROM_AUTOCLOSE: {
if (valp == &cdrom_sysctl_settings.autoclose)
autoclose = cdrom_sysctl_settings.autoclose;
break;
}
case DEV_CDROM_AUTOEJECT: {
if (valp == &cdrom_sysctl_settings.autoeject)
autoeject = cdrom_sysctl_settings.autoeject;
break;
}
case DEV_CDROM_DEBUG: {
if (valp == &cdrom_sysctl_settings.debug)
debug = cdrom_sysctl_settings.debug;
break;
}
case DEV_CDROM_LOCK: {
if (valp == &cdrom_sysctl_settings.lock)
lockdoor = cdrom_sysctl_settings.lock;
break;
}
case DEV_CDROM_CHECK_MEDIA: {
if (valp == &cdrom_sysctl_settings.check)
check_media_type = cdrom_sysctl_settings.check;
break;
}
}
/* update the option flags according to the changes. we /* update the option flags according to the changes. we
don't have per device options through sysctl yet, don't have per device options through sysctl yet,
but we will have and then this will disappear. */ but we will have and then this will disappear. */
...@@ -3511,7 +3483,6 @@ static int cdrom_sysctl_handler(ctl_table *ctl, int write, struct file * filp, ...@@ -3511,7 +3483,6 @@ static int cdrom_sysctl_handler(ctl_table *ctl, int write, struct file * filp,
/* Place files in /proc/sys/dev/cdrom */ /* Place files in /proc/sys/dev/cdrom */
static ctl_table cdrom_table[] = { static ctl_table cdrom_table[] = {
{ {
.ctl_name = DEV_CDROM_INFO,
.procname = "info", .procname = "info",
.data = &cdrom_sysctl_settings.info, .data = &cdrom_sysctl_settings.info,
.maxlen = CDROM_STR_SIZE, .maxlen = CDROM_STR_SIZE,
...@@ -3519,7 +3490,6 @@ static ctl_table cdrom_table[] = { ...@@ -3519,7 +3490,6 @@ static ctl_table cdrom_table[] = {
.proc_handler = &cdrom_sysctl_info, .proc_handler = &cdrom_sysctl_info,
}, },
{ {
.ctl_name = DEV_CDROM_AUTOCLOSE,
.procname = "autoclose", .procname = "autoclose",
.data = &cdrom_sysctl_settings.autoclose, .data = &cdrom_sysctl_settings.autoclose,
.maxlen = sizeof(int), .maxlen = sizeof(int),
...@@ -3527,7 +3497,6 @@ static ctl_table cdrom_table[] = { ...@@ -3527,7 +3497,6 @@ static ctl_table cdrom_table[] = {
.proc_handler = &cdrom_sysctl_handler, .proc_handler = &cdrom_sysctl_handler,
}, },
{ {
.ctl_name = DEV_CDROM_AUTOEJECT,
.procname = "autoeject", .procname = "autoeject",
.data = &cdrom_sysctl_settings.autoeject, .data = &cdrom_sysctl_settings.autoeject,
.maxlen = sizeof(int), .maxlen = sizeof(int),
...@@ -3535,7 +3504,6 @@ static ctl_table cdrom_table[] = { ...@@ -3535,7 +3504,6 @@ static ctl_table cdrom_table[] = {
.proc_handler = &cdrom_sysctl_handler, .proc_handler = &cdrom_sysctl_handler,
}, },
{ {
.ctl_name = DEV_CDROM_DEBUG,
.procname = "debug", .procname = "debug",
.data = &cdrom_sysctl_settings.debug, .data = &cdrom_sysctl_settings.debug,
.maxlen = sizeof(int), .maxlen = sizeof(int),
...@@ -3543,7 +3511,6 @@ static ctl_table cdrom_table[] = { ...@@ -3543,7 +3511,6 @@ static ctl_table cdrom_table[] = {
.proc_handler = &cdrom_sysctl_handler, .proc_handler = &cdrom_sysctl_handler,
}, },
{ {
.ctl_name = DEV_CDROM_LOCK,
.procname = "lock", .procname = "lock",
.data = &cdrom_sysctl_settings.lock, .data = &cdrom_sysctl_settings.lock,
.maxlen = sizeof(int), .maxlen = sizeof(int),
...@@ -3551,7 +3518,6 @@ static ctl_table cdrom_table[] = { ...@@ -3551,7 +3518,6 @@ static ctl_table cdrom_table[] = {
.proc_handler = &cdrom_sysctl_handler, .proc_handler = &cdrom_sysctl_handler,
}, },
{ {
.ctl_name = DEV_CDROM_CHECK_MEDIA,
.procname = "check_media", .procname = "check_media",
.data = &cdrom_sysctl_settings.check, .data = &cdrom_sysctl_settings.check,
.maxlen = sizeof(int), .maxlen = sizeof(int),
......
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