aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/module.c
diff options
context:
space:
mode:
authorPavel Roskin <proski@gnu.org>2008-02-28 17:11:02 -0500
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-03-04 20:29:40 -0800
commit9b37ccfc637be27d9a652fcedc35e6e782c3aa78 (patch)
tree525fd97d130c630ff5e65de2d83823174986a6a5 /kernel/module.c
parent27d0483aa1ef66a8877d71b63bb97f46ab0246b2 (diff)
downloadkernel_samsung_smdk4412-9b37ccfc637be27d9a652fcedc35e6e782c3aa78.tar.gz
kernel_samsung_smdk4412-9b37ccfc637be27d9a652fcedc35e6e782c3aa78.tar.bz2
kernel_samsung_smdk4412-9b37ccfc637be27d9a652fcedc35e6e782c3aa78.zip
module: allow ndiswrapper to use GPL-only symbols
A change after 2.6.24 broke ndiswrapper by accidentally removing its access to GPL-only symbols. Revert that change and add comments about the reasons why ndiswrapper and driverloader are treated in a special way. Signed-off-by: Pavel Roskin <proski@gnu.org> Acked-by: Greg KH <gregkh@suse.de> Acked-by: Ingo Molnar <mingo@elte.hu> Cc: Rusty Russell <rusty@rustcorp.com.au> Cc: Jon Masters <jonathan@jonmasters.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel/module.c')
-rw-r--r--kernel/module.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/kernel/module.c b/kernel/module.c
index 901cd6ac2f1..be4807fb90e 100644
--- a/kernel/module.c
+++ b/kernel/module.c
@@ -1933,8 +1933,15 @@ static struct module *load_module(void __user *umod,
/* Set up license info based on the info section */
set_license(mod, get_modinfo(sechdrs, infoindex, "license"));
+ /*
+ * ndiswrapper is under GPL by itself, but loads proprietary modules.
+ * Don't use add_taint_module(), as it would prevent ndiswrapper from
+ * using GPL-only symbols it needs.
+ */
if (strcmp(mod->name, "ndiswrapper") == 0)
- add_taint_module(mod, TAINT_PROPRIETARY_MODULE);
+ add_taint(TAINT_PROPRIETARY_MODULE);
+
+ /* driverloader was caught wrongly pretending to be under GPL */
if (strcmp(mod->name, "driverloader") == 0)
add_taint_module(mod, TAINT_PROPRIETARY_MODULE);