aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/module.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/kernel/module.c b/kernel/module.c
index 5f80478b746d..705e1d5d516c 100644
--- a/kernel/module.c
+++ b/kernel/module.c
@@ -639,8 +639,8 @@ static int __try_stop_module(void *_sref)
639{ 639{
640 struct stopref *sref = _sref; 640 struct stopref *sref = _sref;
641 641
642 /* If it's not unused, quit unless we are told to block. */ 642 /* If it's not unused, quit unless we're forcing. */
643 if ((sref->flags & O_NONBLOCK) && module_refcount(sref->mod) != 0) { 643 if (module_refcount(sref->mod) != 0) {
644 if (!(*sref->forced = try_force_unload(sref->flags))) 644 if (!(*sref->forced = try_force_unload(sref->flags)))
645 return -EWOULDBLOCK; 645 return -EWOULDBLOCK;
646 } 646 }
@@ -652,9 +652,16 @@ static int __try_stop_module(void *_sref)
652 652
653static int try_stop_module(struct module *mod, int flags, int *forced) 653static int try_stop_module(struct module *mod, int flags, int *forced)
654{ 654{
655 struct stopref sref = { mod, flags, forced }; 655 if (flags & O_NONBLOCK) {
656 struct stopref sref = { mod, flags, forced };
656 657
657 return stop_machine_run(__try_stop_module, &sref, NR_CPUS); 658 return stop_machine_run(__try_stop_module, &sref, NR_CPUS);
659 } else {
660 /* We don't need to stop the machine for this. */
661 mod->state = MODULE_STATE_GOING;
662 synchronize_sched();
663 return 0;
664 }
658} 665}
659 666
660unsigned int module_refcount(struct module *mod) 667unsigned int module_refcount(struct module *mod)