Commit 633e45ea authored by Ann Chen's avatar Ann Chen Committed by Greg Kroah-Hartman

greybus: vibrator: integrate runtime pm

Integrate greybus drivers with the Linux Kernel RuntimePM framework
for vibrator driver.

Testing Done: AP side (kernel) can control the vibrator driver with
suspend and resume.
Signed-off-by: default avatarAnn Chen <chen_ann@projectara.com>
Reviewed-by: default avatarDavid Lin <dtwlin@google.com>
Reviewed-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent 553cba82
...@@ -13,6 +13,8 @@ ...@@ -13,6 +13,8 @@
#include <linux/device.h> #include <linux/device.h>
#include <linux/kdev_t.h> #include <linux/kdev_t.h>
#include <linux/idr.h> #include <linux/idr.h>
#include <linux/pm_runtime.h>
#include "greybus.h" #include "greybus.h"
struct gb_vibrator_device { struct gb_vibrator_device {
...@@ -32,16 +34,37 @@ struct gb_vibrator_on_request { ...@@ -32,16 +34,37 @@ struct gb_vibrator_on_request {
static int turn_on(struct gb_vibrator_device *vib, u16 timeout_ms) static int turn_on(struct gb_vibrator_device *vib, u16 timeout_ms)
{ {
struct gb_vibrator_on_request request; struct gb_vibrator_on_request request;
struct gb_bundle *bundle = vib->connection->bundle;
int ret;
ret = gb_pm_runtime_get_sync(bundle);
if (ret)
return ret;
request.timeout_ms = cpu_to_le16(timeout_ms); request.timeout_ms = cpu_to_le16(timeout_ms);
return gb_operation_sync(vib->connection, GB_VIBRATOR_TYPE_ON, ret = gb_operation_sync(vib->connection, GB_VIBRATOR_TYPE_ON,
&request, sizeof(request), NULL, 0); &request, sizeof(request), NULL, 0);
gb_pm_runtime_put_autosuspend(bundle);
return ret;
} }
static int turn_off(struct gb_vibrator_device *vib) static int turn_off(struct gb_vibrator_device *vib)
{ {
return gb_operation_sync(vib->connection, GB_VIBRATOR_TYPE_OFF, struct gb_bundle *bundle = vib->connection->bundle;
NULL, 0, NULL, 0); int ret;
ret = gb_pm_runtime_get_sync(bundle);
if (ret)
return ret;
ret = gb_operation_sync(vib->connection, GB_VIBRATOR_TYPE_OFF,
NULL, 0, NULL, 0);
gb_pm_runtime_put_autosuspend(bundle);
return ret;
} }
static ssize_t timeout_store(struct device *dev, struct device_attribute *attr, static ssize_t timeout_store(struct device *dev, struct device_attribute *attr,
...@@ -151,6 +174,8 @@ static int gb_vibrator_probe(struct gb_bundle *bundle, ...@@ -151,6 +174,8 @@ static int gb_vibrator_probe(struct gb_bundle *bundle,
} }
#endif #endif
gb_pm_runtime_put_autosuspend(bundle);
return 0; return 0;
err_ida_remove: err_ida_remove:
...@@ -168,6 +193,11 @@ static int gb_vibrator_probe(struct gb_bundle *bundle, ...@@ -168,6 +193,11 @@ static int gb_vibrator_probe(struct gb_bundle *bundle,
static void gb_vibrator_disconnect(struct gb_bundle *bundle) static void gb_vibrator_disconnect(struct gb_bundle *bundle)
{ {
struct gb_vibrator_device *vib = greybus_get_drvdata(bundle); struct gb_vibrator_device *vib = greybus_get_drvdata(bundle);
int ret;
ret = gb_pm_runtime_get_sync(bundle);
if (ret)
gb_pm_runtime_get_noresume(bundle);
#if LINUX_VERSION_CODE <= KERNEL_VERSION(3,11,0) #if LINUX_VERSION_CODE <= KERNEL_VERSION(3,11,0)
sysfs_remove_group(&vib->dev->kobj, vibrator_groups[0]); sysfs_remove_group(&vib->dev->kobj, vibrator_groups[0]);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment