]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
Fix init ordering of /dev/console vs callers of modprobe
authorDavid Howells <dhowells@redhat.com>
Fri, 6 Aug 2010 15:34:43 +0000 (16:34 +0100)
committerGreg Kroah-Hartman <gregkh@suse.de>
Thu, 26 Aug 2010 23:46:04 +0000 (16:46 -0700)
commitea554ee37bcf4ad4f70b100287ffc84c2cf33066
tree7d07d57bfffe85e22352ffa7f2b7631c8a83ac3e
parent1cd65f87cbf31684d778155b31ea32384f8df5d1
Fix init ordering of /dev/console vs callers of modprobe

commit 31d1d48e199e99077fb30f6fb9a793be7bec756f upstream.

Make /dev/console get initialised before any initialisation routine that
invokes modprobe because if modprobe fails, it's going to want to open
/dev/console, presumably to write an error message to.

The problem with that is that if the /dev/console driver is not yet
initialised, the chardev handler will call request_module() to invoke
modprobe, which will fail, because we never compile /dev/console as a
module.

This will lead to a modprobe loop, showing the following in the kernel
log:

request_module: runaway loop modprobe char-major-5-1
request_module: runaway loop modprobe char-major-5-1
request_module: runaway loop modprobe char-major-5-1
request_module: runaway loop modprobe char-major-5-1
request_module: runaway loop modprobe char-major-5-1

This can happen, for example, when the built in md5 module can't find
the built in cryptomgr module (because the latter fails to initialise).
The md5 module comes before the call to tty_init(), presumably because
'crypto' comes before 'drivers' alphabetically.

Fix this by calling tty_init() from chrdev_init().

Signed-off-by: David Howells <dhowells@redhat.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/char/mem.c
drivers/char/tty_io.c
fs/char_dev.c
include/linux/tty.h