module: fix missing module_mutex unlock
authorLinus Torvalds <torvalds@linux-foundation.org>
Mon, 21 Jan 2013 04:22:58 +0000 (20:22 -0800)
committerLinus Torvalds <torvalds@linux-foundation.org>
Mon, 21 Jan 2013 04:22:58 +0000 (20:22 -0800)
Commit 1fb9341ac348 ("module: put modules in list much earlier") moved
some of the module initialization code around, and in the process
changed the exit paths too.  But for the duplicate export symbol error
case the change made the ddebug_cleanup path jump to after the module
mutex unlock, even though it happens with the mutex held.

Rusty has some patches to split this function up into some helper
functions, hopefully the mess of complex goto targets will go away
eventually.

Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
kernel/module.c

index d25e359279ae8a42056bad59e3d44056c4b6fe89..eab08274ec9bf9a1e5b8c83de0f925da0aeaf761 100644 (file)
@@ -3274,8 +3274,8 @@ again:
        /* module_bug_cleanup needs module_mutex protection */
        mutex_lock(&module_mutex);
        module_bug_cleanup(mod);
-       mutex_unlock(&module_mutex);
  ddebug_cleanup:
+       mutex_unlock(&module_mutex);
        dynamic_debug_remove(info->debug);
        synchronize_sched();
        kfree(mod->args);