i2c: always enable RuntimePM for the adapter device
authorWolfram Sang <wsa+renesas@sang-engineering.com>
Wed, 23 Dec 2015 17:19:28 +0000 (18:19 +0100)
committerWolfram Sang <wsa@the-dreams.de>
Sun, 10 Jan 2016 08:27:06 +0000 (09:27 +0100)
The adapter device is a logical device. Because of that, it already uses
pm_runtime_no_callbacks() in the core. To ensure proper propagation from
the children (i2c devices) to the parent of the adapter (the HW device),
make sure RuntimePM is enabled in any case.

Signed-off-by: Wolfram Sang <wsa+renesas@sang-engineering.com>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
drivers/i2c/i2c-core.c

index 7349b00f410171852b5b4e9d0069840ec91fdf72..ffe715d346d884e13b9a4c52f2beaa2c87872f8a 100644 (file)
@@ -1564,6 +1564,7 @@ static int i2c_register_adapter(struct i2c_adapter *adap)
        dev_dbg(&adap->dev, "adapter [%s] registered\n", adap->name);
 
        pm_runtime_no_callbacks(&adap->dev);
+       pm_runtime_enable(&adap->dev);
 
 #ifdef CONFIG_I2C_COMPAT
        res = class_compat_create_link(i2c_adapter_compat_class, &adap->dev,
@@ -1818,6 +1819,8 @@ void i2c_del_adapter(struct i2c_adapter *adap)
        /* device name is gone after device_unregister */
        dev_dbg(&adap->dev, "adapter [%s] unregistered\n", adap->name);
 
+       pm_runtime_disable(&adap->dev);
+
        /* wait until all references to the device are gone
         *
         * FIXME: This is old code and should ideally be replaced by an