Remove proc_handler() wrapper

As of Linux 2.6.32 the proc handlers where updated to expect only
five arguments.  Therefore there is no longer a need to maintain
this compatibility code and this infrastructure can be simplified.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
This commit is contained in:
Brian Behlendorf 2014-10-02 14:15:19 -04:00
parent e03119e86f
commit 0fac9c9e6d
5 changed files with 39 additions and 139 deletions

View File

@ -37,7 +37,6 @@ AC_DEFUN([SPL_AC_CONFIG_KERNEL], [
SPL_AC_FS_STRUCT_SPINLOCK SPL_AC_FS_STRUCT_SPINLOCK
SPL_AC_KUIDGID_T SPL_AC_KUIDGID_T
SPL_AC_PUT_TASK_STRUCT SPL_AC_PUT_TASK_STRUCT
SPL_AC_5ARGS_PROC_HANDLER
SPL_AC_KVASPRINTF SPL_AC_KVASPRINTF
SPL_AC_EXPORTED_RWSEM_IS_LOCKED SPL_AC_EXPORTED_RWSEM_IS_LOCKED
SPL_AC_KERNEL_FALLOCATE SPL_AC_KERNEL_FALLOCATE
@ -1181,25 +1180,6 @@ AC_DEFUN([SPL_AC_PUT_TASK_STRUCT],
]) ])
]) ])
dnl #
dnl # 2.6.32 API change,
dnl # Unused 'struct file *' removed from prototype.
dnl #
AC_DEFUN([SPL_AC_5ARGS_PROC_HANDLER], [
AC_MSG_CHECKING([whether proc_handler() wants 5 args])
SPL_LINUX_TRY_COMPILE([
#include <linux/sysctl.h>
],[
proc_dostring(NULL, 0, NULL, NULL, NULL);
],[
AC_MSG_RESULT(yes)
AC_DEFINE(HAVE_5ARGS_PROC_HANDLER, 1,
[proc_handler() wants 5 args])
],[
AC_MSG_RESULT(no)
])
])
dnl # dnl #
dnl # 2.6.x API change, dnl # 2.6.x API change,
dnl # kvasprintf() function added. dnl # kvasprintf() function added.

View File

@ -11,7 +11,6 @@ KERNEL_H = \
$(top_srcdir)/include/linux/module_compat.h \ $(top_srcdir)/include/linux/module_compat.h \
$(top_srcdir)/include/linux/proc_compat.h \ $(top_srcdir)/include/linux/proc_compat.h \
$(top_srcdir)/include/linux/rwsem_compat.h \ $(top_srcdir)/include/linux/rwsem_compat.h \
$(top_srcdir)/include/linux/sysctl_compat.h \
$(top_srcdir)/include/linux/wait_compat.h \ $(top_srcdir)/include/linux/wait_compat.h \
$(top_srcdir)/include/linux/zlib_compat.h $(top_srcdir)/include/linux/zlib_compat.h

View File

@ -1,96 +0,0 @@
/*****************************************************************************\
* Copyright (C) 2007-2010 Lawrence Livermore National Security, LLC.
* Copyright (C) 2007 The Regents of the University of California.
* Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER).
* Written by Brian Behlendorf <behlendorf1@llnl.gov>.
* UCRL-CODE-235197
*
* This file is part of the SPL, Solaris Porting Layer.
* For details, see <http://zfsonlinux.org/>.
*
* The SPL is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at your
* option) any later version.
*
* The SPL is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* for more details.
*
* You should have received a copy of the GNU General Public License along
* with the SPL. If not, see <http://www.gnu.org/licenses/>.
\*****************************************************************************/
#ifndef _SPL_SYSCTL_COMPAT_H
#define _SPL_SYSCTL_COMPAT_H
#include <linux/sysctl.h>
/* proc_handler() / proc_do* API changes
* 2.6.x - 2.6.31: 6 args, prototype includes 'struct file *'
* 2.6.32 - 2.6.y: 5 args, removed unused 'struct file *' from prototype
*
* Generic SPL_PROC_HANDLER() macro should be used for correct prototypes.
* It will define the following function arguments which can and should be
* used with the spl_proc_* helper macros.
*
* struct ctl_table *table,
* int write,
* struct file *filp [2.6.31 and earlier kernels],
* void __user *buffer,
* size_t *lenp,
* loff_t *ppos,
*/
#ifdef HAVE_5ARGS_PROC_HANDLER
#define SPL_PROC_HANDLER(proc_handler) \
static int \
proc_handler(struct ctl_table *table, int write, \
void __user *buffer, size_t *lenp, loff_t *ppos)
#define spl_proc_dostring(table, write, filp, buffer, lenp, ppos) \
proc_dostring(table, write, buffer, lenp, ppos)
#define spl_proc_dointvec(table, write, filp, buffer, lenp, ppos) \
proc_dointvec(table, write, buffer, lenp, ppos)
#define spl_proc_dointvec_minmax(table, write, filp, buffer, lenp, ppos) \
proc_dointvec_minmax(table, write, buffer, lenp, ppos)
#define spl_proc_dointvec_jiffies(table, write, filp, buffer, lenp, ppos) \
proc_dointvec_jiffies(table, write, buffer, lenp, ppos)
#define spl_proc_dointvec_userhz_jiffies(table,write,filp,buffer,lenp,ppos) \
proc_dointvec_userhz_jiffies(table, write, buffer, lenp, ppos)
#define spl_proc_dointvec_ms_jiffies(table,write,filp,buffer,lenp,ppos) \
proc_dointvec_ms_jiffies(table, write, buffer, lenp, ppos)
#define spl_proc_doulongvec_minmax(table, write, filp, buffer, lenp, ppos) \
proc_doulongvec_minmax(table, write, buffer, lenp, ppos)
#define spl_proc_doulongvec_ms_jiffies_minmax(table,write,filp,buffer,lenp,ppos)\
proc_doulongvec_ms_jiffies_minmax(table, write, buffer, lenp, ppos)
#else /* HAVE_5ARGS_PROC_HANDLER */
#define SPL_PROC_HANDLER(proc_handler) \
static int \
proc_handler(struct ctl_table *table, int write, struct file *filp, \
void __user *buffer, size_t *lenp, loff_t *ppos)
#define spl_proc_dostring(table, write, filp, buffer, lenp, ppos) \
proc_dostring(table, write, filp, buffer, lenp, ppos)
#define spl_proc_dointvec(table, write, filp, buffer, lenp, ppos) \
proc_dointvec(table, write, filp, buffer, lenp, ppos)
#define spl_proc_dointvec_minmax(table, write, filp, buffer, lenp, ppos) \
proc_dointvec_minmax(table, write, filp, buffer, lenp, ppos)
#define spl_proc_dointvec_jiffies(table, write, filp, buffer, lenp, ppos) \
proc_dointvec_jiffies(table, write, filp, buffer, lenp, ppos)
#define spl_proc_dointvec_userhz_jiffies(table,write,filp,buffer,lenp,ppos) \
proc_dointvec_userhz_jiffies(table, write, filp, buffer, lenp, ppos)
#define spl_proc_dointvec_ms_jiffies(table, write, filp, buffer, lenp, ppos) \
proc_dointvec_ms_jiffies(table, write, filp, buffer, lenp, ppos)
#define spl_proc_doulongvec_minmax(table, write, filp, buffer, lenp, ppos) \
proc_doulongvec_minmax(table, write, filp, buffer, lenp, ppos)
#define spl_proc_doulongvec_ms_jiffies_minmax(table,write,filp,buffer,lenp,ppos) \
proc_doulongvec_ms_jiffies_minmax(table,write,filp,buffer,lenp,ppos)
#endif /* HAVE_5ARGS_PROC_HANDLER */
#endif /* _SPL_SYSCTL_COMPAT_H */

View File

@ -32,7 +32,6 @@
#include <linux/list_compat.h> #include <linux/list_compat.h>
#include <linux/bitops_compat.h> #include <linux/bitops_compat.h>
#include <linux/module_compat.h> #include <linux/module_compat.h>
#include <linux/sysctl_compat.h>
#include <linux/proc_compat.h> #include <linux/proc_compat.h>
#include <linux/math64_compat.h> #include <linux/math64_compat.h>
#include <linux/zlib_compat.h> #include <linux/zlib_compat.h>

View File

@ -111,7 +111,9 @@ proc_copyout_string(char *ubuffer, int ubuffer_size,
} }
#ifdef DEBUG_LOG #ifdef DEBUG_LOG
SPL_PROC_HANDLER(proc_dobitmasks) static int
proc_dobitmasks(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
unsigned long *mask = table->data; unsigned long *mask = table->data;
int is_subsys = (mask == &spl_debug_subsys) ? 1 : 0; int is_subsys = (mask == &spl_debug_subsys) ? 1 : 0;
@ -152,7 +154,9 @@ SPL_PROC_HANDLER(proc_dobitmasks)
SRETURN(rc); SRETURN(rc);
} }
SPL_PROC_HANDLER(proc_debug_mb) static int
proc_debug_mb(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
char str[32]; char str[32];
int rc, len; int rc, len;
@ -181,7 +185,9 @@ SPL_PROC_HANDLER(proc_debug_mb)
SRETURN(rc); SRETURN(rc);
} }
SPL_PROC_HANDLER(proc_dump_kernel) static int
proc_dump_kernel(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
SENTRY; SENTRY;
@ -195,7 +201,9 @@ SPL_PROC_HANDLER(proc_dump_kernel)
SRETURN(0); SRETURN(0);
} }
SPL_PROC_HANDLER(proc_force_bug) static int
proc_force_bug(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
SENTRY; SENTRY;
@ -207,7 +215,9 @@ SPL_PROC_HANDLER(proc_force_bug)
SRETURN(0); SRETURN(0);
} }
SPL_PROC_HANDLER(proc_console_max_delay_cs) static int
proc_console_max_delay_cs(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int rc, max_delay_cs; int rc, max_delay_cs;
spl_ctl_table dummy = *table; spl_ctl_table dummy = *table;
@ -219,7 +229,7 @@ SPL_PROC_HANDLER(proc_console_max_delay_cs)
if (write) { if (write) {
max_delay_cs = 0; max_delay_cs = 0;
rc = spl_proc_dointvec(&dummy,write,filp,buffer,lenp,ppos); rc = proc_dointvec(&dummy, write, buffer, lenp, ppos);
if (rc < 0) if (rc < 0)
SRETURN(rc); SRETURN(rc);
@ -233,13 +243,15 @@ SPL_PROC_HANDLER(proc_console_max_delay_cs)
spl_console_max_delay = d; spl_console_max_delay = d;
} else { } else {
max_delay_cs = (spl_console_max_delay * 100) / HZ; max_delay_cs = (spl_console_max_delay * 100) / HZ;
rc = spl_proc_dointvec(&dummy,write,filp,buffer,lenp,ppos); rc = proc_dointvec(&dummy, write, buffer, lenp, ppos);
} }
SRETURN(rc); SRETURN(rc);
} }
SPL_PROC_HANDLER(proc_console_min_delay_cs) static int
proc_console_min_delay_cs(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int rc, min_delay_cs; int rc, min_delay_cs;
spl_ctl_table dummy = *table; spl_ctl_table dummy = *table;
@ -251,7 +263,7 @@ SPL_PROC_HANDLER(proc_console_min_delay_cs)
if (write) { if (write) {
min_delay_cs = 0; min_delay_cs = 0;
rc = spl_proc_dointvec(&dummy,write,filp,buffer,lenp,ppos); rc = proc_dointvec(&dummy, write, buffer, lenp, ppos);
if (rc < 0) if (rc < 0)
SRETURN(rc); SRETURN(rc);
@ -265,13 +277,15 @@ SPL_PROC_HANDLER(proc_console_min_delay_cs)
spl_console_min_delay = d; spl_console_min_delay = d;
} else { } else {
min_delay_cs = (spl_console_min_delay * 100) / HZ; min_delay_cs = (spl_console_min_delay * 100) / HZ;
rc = spl_proc_dointvec(&dummy,write,filp,buffer,lenp,ppos); rc = proc_dointvec(&dummy, write, buffer, lenp, ppos);
} }
SRETURN(rc); SRETURN(rc);
} }
SPL_PROC_HANDLER(proc_console_backoff) static int
proc_console_backoff(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int rc, backoff; int rc, backoff;
spl_ctl_table dummy = *table; spl_ctl_table dummy = *table;
@ -282,7 +296,7 @@ SPL_PROC_HANDLER(proc_console_backoff)
if (write) { if (write) {
backoff = 0; backoff = 0;
rc = spl_proc_dointvec(&dummy,write,filp,buffer,lenp,ppos); rc = proc_dointvec(&dummy, write, buffer, lenp, ppos);
if (rc < 0) if (rc < 0)
SRETURN(rc); SRETURN(rc);
@ -292,7 +306,7 @@ SPL_PROC_HANDLER(proc_console_backoff)
spl_console_backoff = backoff; spl_console_backoff = backoff;
} else { } else {
backoff = spl_console_backoff; backoff = spl_console_backoff;
rc = spl_proc_dointvec(&dummy,write,filp,buffer,lenp,ppos); rc = proc_dointvec(&dummy, write, buffer, lenp, ppos);
} }
SRETURN(rc); SRETURN(rc);
@ -300,7 +314,9 @@ SPL_PROC_HANDLER(proc_console_backoff)
#endif /* DEBUG_LOG */ #endif /* DEBUG_LOG */
#ifdef DEBUG_KMEM #ifdef DEBUG_KMEM
SPL_PROC_HANDLER(proc_domemused) static int
proc_domemused(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int rc = 0; int rc = 0;
unsigned long min = 0, max = ~0, val; unsigned long min = 0, max = ~0, val;
@ -320,14 +336,15 @@ SPL_PROC_HANDLER(proc_domemused)
# else # else
val = atomic_read((atomic_t *)table->data); val = atomic_read((atomic_t *)table->data);
# endif /* HAVE_ATOMIC64_T */ # endif /* HAVE_ATOMIC64_T */
rc = spl_proc_doulongvec_minmax(&dummy, write, filp, rc = proc_doulongvec_minmax(&dummy, write, buffer, lenp, ppos);
buffer, lenp, ppos);
} }
SRETURN(rc); SRETURN(rc);
} }
SPL_PROC_HANDLER(proc_doslab) static int
proc_doslab(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int rc = 0; int rc = 0;
unsigned long min = 0, max = ~0, val = 0, mask; unsigned long min = 0, max = ~0, val = 0, mask;
@ -367,22 +384,23 @@ SPL_PROC_HANDLER(proc_doslab)
} }
up_read(&spl_kmem_cache_sem); up_read(&spl_kmem_cache_sem);
rc = spl_proc_doulongvec_minmax(&dummy, write, filp, rc = proc_doulongvec_minmax(&dummy, write, buffer, lenp, ppos);
buffer, lenp, ppos);
} }
SRETURN(rc); SRETURN(rc);
} }
#endif /* DEBUG_KMEM */ #endif /* DEBUG_KMEM */
SPL_PROC_HANDLER(proc_dohostid) static int
proc_dohostid(struct ctl_table *table, int write,
void __user *buffer, size_t *lenp, loff_t *ppos)
{ {
int len, rc = 0; int len, rc = 0;
char *end, str[32]; char *end, str[32];
SENTRY; SENTRY;
if (write) { if (write) {
/* We can't use spl_proc_doulongvec_minmax() in the write /* We can't use proc_doulongvec_minmax() in the write
* case here because hostid while a hex value has no * case here because hostid while a hex value has no
* leading 0x which confuses the helper function. */ * leading 0x which confuses the helper function. */
rc = proc_copyin_string(str, sizeof(str), buffer, *lenp); rc = proc_copyin_string(str, sizeof(str), buffer, *lenp);