iio: cros_ec: Remove pm function
authorGwendal Grignou <gwendal@chromium.org>
Fri, 27 Mar 2020 22:34:39 +0000 (15:34 -0700)
committerEnric Balletbo i Serra <enric.balletbo@collabora.com>
Sat, 28 Mar 2020 21:04:32 +0000 (22:04 +0100)
Since cros_ec_sensorhub is shutting down the FIFO when the device
suspends, no need to slow down the EC sampling period rate.

It was necesseary to do that before command CMD_FIFO_INT_ENABLE was
introduced, but now all supported chromebooks have it.

Signed-off-by: Gwendal Grignou <gwendal@chromium.org>
Acked-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Acked-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Enric Balletbo i Serra <enric.balletbo@collabora.com>
drivers/iio/common/cros_ec_sensors/cros_ec_lid_angle.c
drivers/iio/common/cros_ec_sensors/cros_ec_sensors.c
drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c
drivers/iio/light/cros_ec_light_prox.c
include/linux/iio/common/cros_ec_sensors_core.h

index e30a59fcf0f952e581d2cd66c84ac22c9e4c5bd2..af801e203623e37b00188b4c96985c1165d2c35d 100644 (file)
@@ -127,7 +127,6 @@ MODULE_DEVICE_TABLE(platform, cros_ec_lid_angle_ids);
 static struct platform_driver cros_ec_lid_angle_platform_driver = {
        .driver = {
                .name   = DRV_NAME,
-               .pm     = &cros_ec_sensors_pm_ops,
        },
        .probe          = cros_ec_lid_angle_probe,
        .id_table       = cros_ec_lid_angle_ids,
index 711134d67ddeea3364cad88077a4dea8962537d3..fad21a90bc7e8428fd512aaa177470e2c814d210 100644 (file)
@@ -314,7 +314,6 @@ MODULE_DEVICE_TABLE(platform, cros_ec_sensors_ids);
 static struct platform_driver cros_ec_sensors_platform_driver = {
        .driver = {
                .name   = "cros-ec-sensors",
-               .pm     = &cros_ec_sensors_pm_ops,
        },
        .probe          = cros_ec_sensors_probe,
        .id_table       = cros_ec_sensors_ids,
index 01513cb933653d3c1da1e0a98494249450457104..a1ecbd55ea767300dcbb9c1470f86b21dc7f9dd2 100644 (file)
@@ -738,52 +738,5 @@ int cros_ec_sensors_core_write(struct cros_ec_sensors_core_state *st,
 }
 EXPORT_SYMBOL_GPL(cros_ec_sensors_core_write);
 
-static int __maybe_unused cros_ec_sensors_prepare(struct device *dev)
-{
-       struct iio_dev *indio_dev = dev_get_drvdata(dev);
-       struct cros_ec_sensors_core_state *st = iio_priv(indio_dev);
-
-       if (st->curr_sampl_freq == 0)
-               return 0;
-
-       /*
-        * If the sensors are sampled at high frequency, we will not be able to
-        * sleep. Set sampling to a long period if necessary.
-        */
-       if (st->curr_sampl_freq < CROS_EC_MIN_SUSPEND_SAMPLING_FREQUENCY) {
-               mutex_lock(&st->cmd_lock);
-               st->param.cmd = MOTIONSENSE_CMD_EC_RATE;
-               st->param.ec_rate.data = CROS_EC_MIN_SUSPEND_SAMPLING_FREQUENCY;
-               cros_ec_motion_send_host_cmd(st, 0);
-               mutex_unlock(&st->cmd_lock);
-       }
-       return 0;
-}
-
-static void __maybe_unused cros_ec_sensors_complete(struct device *dev)
-{
-       struct iio_dev *indio_dev = dev_get_drvdata(dev);
-       struct cros_ec_sensors_core_state *st = iio_priv(indio_dev);
-
-       if (st->curr_sampl_freq == 0)
-               return;
-
-       if (st->curr_sampl_freq < CROS_EC_MIN_SUSPEND_SAMPLING_FREQUENCY) {
-               mutex_lock(&st->cmd_lock);
-               st->param.cmd = MOTIONSENSE_CMD_EC_RATE;
-               st->param.ec_rate.data = st->curr_sampl_freq;
-               cros_ec_motion_send_host_cmd(st, 0);
-               mutex_unlock(&st->cmd_lock);
-       }
-}
-
-const struct dev_pm_ops cros_ec_sensors_pm_ops = {
-#ifdef CONFIG_PM_SLEEP
-       .prepare = cros_ec_sensors_prepare,
-       .complete = cros_ec_sensors_complete
-#endif
-};
-EXPORT_SYMBOL_GPL(cros_ec_sensors_pm_ops);
-
 MODULE_DESCRIPTION("ChromeOS EC sensor hub core functions");
 MODULE_LICENSE("GPL v2");
index 03c951ff4a3c3ca10e7d03183ec3711edc150ae1..e10b35de4c2fafffd6f20a9b2d137598915a0f81 100644 (file)
@@ -255,7 +255,6 @@ MODULE_DEVICE_TABLE(platform, cros_ec_light_prox_ids);
 static struct platform_driver cros_ec_light_prox_platform_driver = {
        .driver = {
                .name   = "cros-ec-light-prox",
-               .pm     = &cros_ec_sensors_pm_ops,
        },
        .probe          = cros_ec_light_prox_probe,
        .id_table       = cros_ec_light_prox_ids,
index b8f573ca9dcc996886f5ea82956a2e0e63d6e8a5..96ea4551945e2770dd7ab4bf403c7d6cfb6a20fa 100644 (file)
@@ -30,9 +30,6 @@ enum {
  */
 #define CROS_EC_SAMPLE_SIZE  (sizeof(s64) * 2)
 
-/* Minimum sampling period to use when device is suspending */
-#define CROS_EC_MIN_SUSPEND_SAMPLING_FREQUENCY 1000  /* 1 second */
-
 typedef irqreturn_t (*cros_ec_sensors_capture_t)(int irq, void *p);
 
 /**
@@ -117,8 +114,6 @@ int cros_ec_sensors_core_write(struct cros_ec_sensors_core_state *st,
                               struct iio_chan_spec const *chan,
                               int val, int val2, long mask);
 
-extern const struct dev_pm_ops cros_ec_sensors_pm_ops;
-
 /* List of extended channel specification for all sensors */
 extern const struct iio_chan_spec_ext_info cros_ec_sensors_ext_info[];