diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-14 12:32:16 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-14 12:32:16 -0800 | 
| commit | 0a80939b3e6af4b0dc93bf88ec02fd7e90a16f1b (patch) | |
| tree | a112335f2b2b2a51e90531c6c67e8a3b54dcf0ef /include/linux/moduleparam.h | |
| parent | 0b48d42235caf627121f440b57d376f48a9af8b6 (diff) | |
| parent | 72db395ffadb1d33233fd123c2bf87ba0198c6c1 (diff) | |
Merge tag 'for-linus' of git://github.com/rustyrussell/linux
Autogenerated GPG tag for Rusty D1ADB8F1: 15EE 8D6C AB0E 7F0C F999  BFCB D920 0E6C D1AD B8F1
* tag 'for-linus' of git://github.com/rustyrussell/linux:
  module_param: check that bool parameters really are bool.
  intelfbdrv.c: bailearly is an int module_param
  paride/pcd: fix bool verbose module parameter.
  module_param: make bool parameters really bool (drivers & misc)
  module_param: make bool parameters really bool (arch)
  module_param: make bool parameters really bool (core code)
  kernel/async: remove redundant declaration.
  printk: fix unnecessary module_param_name.
  lirc_parallel: fix module parameter description.
  module_param: avoid bool abuse, add bint for special cases.
  module_param: check type correctness for module_param_array
  modpost: use linker section to generate table.
  modpost: use a table rather than a giant if/else statement.
  modules: sysfs - export: taint, coresize, initsize
  kernel/params: replace DEBUGP with pr_debug
  module: replace DEBUGP with pr_debug
  module: struct module_ref should contains long fields
  module: Fix performance regression on modules with large symbol tables
  module: Add comments describing how the "strmap" logic works
Fix up conflicts in scripts/mod/file2alias.c due to the new linker-
generated table approach to adding __mod_*_device_table entries.  The
ARM sa11x0 mcp bus needed to be converted to that too.
Diffstat (limited to 'include/linux/moduleparam.h')
| -rw-r--r-- | include/linux/moduleparam.h | 17 | 
1 files changed, 9 insertions, 8 deletions
| diff --git a/include/linux/moduleparam.h b/include/linux/moduleparam.h index 7939f636c8ba..c47f4d60db0b 100644 --- a/include/linux/moduleparam.h +++ b/include/linux/moduleparam.h @@ -350,23 +350,23 @@ extern int param_set_charp(const char *val, const struct kernel_param *kp);  extern int param_get_charp(char *buffer, const struct kernel_param *kp);  #define param_check_charp(name, p) __param_check(name, p, char *) -/* For historical reasons "bool" parameters can be (unsigned) "int". */ +/* We used to allow int as well as bool.  We're taking that away! */  extern struct kernel_param_ops param_ops_bool;  extern int param_set_bool(const char *val, const struct kernel_param *kp);  extern int param_get_bool(char *buffer, const struct kernel_param *kp); -#define param_check_bool(name, p)					\ -	static inline void __check_##name(void)				\ -	{								\ -		BUILD_BUG_ON(!__same_type((p), bool *) &&		\ -			     !__same_type((p), unsigned int *) &&	\ -			     !__same_type((p), int *));			\ -	} +#define param_check_bool(name, p) __param_check(name, p, bool)  extern struct kernel_param_ops param_ops_invbool;  extern int param_set_invbool(const char *val, const struct kernel_param *kp);  extern int param_get_invbool(char *buffer, const struct kernel_param *kp);  #define param_check_invbool(name, p) __param_check(name, p, bool) +/* An int, which can only be set like a bool (though it shows as an int). */ +extern struct kernel_param_ops param_ops_bint; +extern int param_set_bint(const char *val, const struct kernel_param *kp); +#define param_get_bint param_get_int +#define param_check_bint param_check_int +  /**   * module_param_array - a parameter which is an array of some type   * @name: the name of the array variable @@ -395,6 +395,7 @@ extern int param_get_invbool(char *buffer, const struct kernel_param *kp);   * module_param_named() for why this might be necessary.   */  #define module_param_array_named(name, array, type, nump, perm)		\ +	param_check_##type(name, &(array)[0]);				\  	static const struct kparam_array __param_arr_##name		\  	= { .max = ARRAY_SIZE(array), .num = nump,                      \  	    .ops = ¶m_ops_##type,					\ | 
