i2c: do not try to load modules for of-registered devices
authorDmitry Torokhov <dmitry.torokhov@gmail.com>
Fri, 16 Jan 2015 08:07:22 +0000 (00:07 -0800)
committerWolfram Sang <wsa@the-dreams.de>
Mon, 26 Jan 2015 15:52:51 +0000 (16:52 +0100)
Trying to register an I2C device asynchronously (via async_schedule() call)
results in an ugly warning from request_module() warning about potential
deadlock (because request_module tries to wait for async works to
complete). While we could try to switch to request_module_nowait(), other
buses, as well as I2C itself when not using device tree, do not try to load
modules, but rather rely on the standard infrastructure (udev) to execute
module loading, and we should be doing the same.

Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
drivers/i2c/i2c-core.c

index 7730a68fa2d0f0ddb4bd00b59d2f8a0334855377..72d53e40ebab7cc3af26588a0901f8b38b50fe6e 100644 (file)
@@ -1291,8 +1291,6 @@ static struct i2c_client *of_i2c_register_device(struct i2c_adapter *adap,
        if (of_get_property(node, "wakeup-source", NULL))
                info.flags |= I2C_CLIENT_WAKE;
 
-       request_module("%s%s", I2C_MODULE_PREFIX, info.type);
-
        result = i2c_new_device(adap, &info);
        if (result == NULL) {
                dev_err(&adap->dev, "of_i2c: Failure registering %s\n",