greybus: i2c: add runtime pm support
authorDavid Lin <dtwlin@google.com>
Thu, 14 Jul 2016 20:13:00 +0000 (15:13 -0500)
committerAlex Elder <elder@linaro.org>
Thu, 14 Jul 2016 21:53:55 +0000 (16:53 -0500)
Add runtime pm support to camera i2c bridged phy device class driver

Testing Done:
 - Passed #gb_test.sh -v -t i2c

Signed-off-by: David Lin <dtwlin@google.com>
Signed-off-by: Axel Haslam <haslam_axel@projectara.com>
Reviewed-by: Johan Hovold <johan@hovoldconsulting.com>
Signed-off-by: Alex Elder <elder@linaro.org>
drivers/staging/greybus/i2c.c

index 2541bdbb9dd99a601a8de0099014d9f73c5f95aa..c2a50087000c716f2f6a1dcf3d27263e7549f266 100644 (file)
@@ -176,6 +176,10 @@ static int gb_i2c_transfer_operation(struct gb_i2c_device *gb_i2c_dev,
        if (!operation)
                return -ENOMEM;
 
+       ret = gbphy_runtime_get_sync(gb_i2c_dev->gbphy_dev);
+       if (ret)
+               goto exit_operation_put;
+
        ret = gb_operation_request_send_sync(operation);
        if (!ret) {
                struct gb_i2c_transfer_response *response;
@@ -187,6 +191,9 @@ static int gb_i2c_transfer_operation(struct gb_i2c_device *gb_i2c_dev,
                dev_err(dev, "transfer operation failed (%d)\n", ret);
        }
 
+       gbphy_runtime_put_autosuspend(gb_i2c_dev->gbphy_dev);
+
+exit_operation_put:
        gb_operation_put(operation);
 
        return ret;
@@ -290,6 +297,7 @@ static int gb_i2c_probe(struct gbphy_device *gbphy_dev,
        if (ret)
                goto exit_connection_disable;
 
+       gbphy_runtime_put_autosuspend(gbphy_dev);
        return 0;
 
 exit_connection_disable:
@@ -306,6 +314,11 @@ static void gb_i2c_remove(struct gbphy_device *gbphy_dev)
 {
        struct gb_i2c_device *gb_i2c_dev = gb_gbphy_get_data(gbphy_dev);
        struct gb_connection *connection = gb_i2c_dev->connection;
+       int ret;
+
+       ret = gbphy_runtime_get_sync(gbphy_dev);
+       if (ret)
+               gbphy_runtime_get_noresume(gbphy_dev);
 
        i2c_del_adapter(&gb_i2c_dev->adapter);
        gb_connection_disable(connection);