Re: [PATCH] iio: humidity: hts221: add power management support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, May 10, 2017 at 10:40:05PM +0200, Lorenzo Bianconi wrote:
> Add system sleep power management support to hts221 driver
> 
> Signed-off-by: Lorenzo Bianconi <lorenzo.bianconi@xxxxxx>
> ---
>  drivers/iio/humidity/hts221.h      |  3 ++
>  drivers/iio/humidity/hts221_core.c | 56 +++++++++++++++++++++++++++++++++++---
>  drivers/iio/humidity/hts221_i2c.c  |  1 +
>  drivers/iio/humidity/hts221_spi.c  |  1 +
>  4 files changed, 57 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/iio/humidity/hts221.h b/drivers/iio/humidity/hts221.h
> index c7154665512e..94510266e0a5 100644
> --- a/drivers/iio/humidity/hts221.h
> +++ b/drivers/iio/humidity/hts221.h
> @@ -57,12 +57,15 @@ struct hts221_hw {
>  
>  	struct hts221_sensor sensors[HTS221_SENSOR_MAX];
>  
> +	bool enabled;
>  	u8 odr;
>  
>  	const struct hts221_transfer_function *tf;
>  	struct hts221_transfer_buffer tb;
>  };
>  
> +extern const struct dev_pm_ops hts221_pm_ops;
> +
>  int hts221_config_drdy(struct hts221_hw *hw, bool enable);
>  int hts221_probe(struct iio_dev *iio_dev);
>  int hts221_power_on(struct hts221_hw *hw);
> diff --git a/drivers/iio/humidity/hts221_core.c b/drivers/iio/humidity/hts221_core.c
> index 3f3ef4a1a474..ccb07e7f993f 100644
> --- a/drivers/iio/humidity/hts221_core.c
> +++ b/drivers/iio/humidity/hts221_core.c
> @@ -13,6 +13,7 @@
>  #include <linux/device.h>
>  #include <linux/iio/sysfs.h>
>  #include <linux/delay.h>
> +#include <linux/pm.h>
>  #include <asm/unaligned.h>
>  
>  #include "hts221.h"
> @@ -307,15 +308,30 @@ hts221_sysfs_temp_oversampling_avail(struct device *dev,
>  
>  int hts221_power_on(struct hts221_hw *hw)
>  {
> -	return hts221_update_odr(hw, hw->odr);
> +	int err;
> +
> +	err = hts221_update_odr(hw, hw->odr);
> +	if (err < 0)
> +		return err;
> +
> +	hw->enabled = true;
> +
> +	return 0;
>  }
>  
>  int hts221_power_off(struct hts221_hw *hw)
>  {
> -	u8 data[] = {0x00, 0x00};
> +	__le16 data = 0;
> +	int err;
>  
> -	return hw->tf->write(hw->dev, HTS221_REG_CNTRL1_ADDR, sizeof(data),
> -			     data);
> +	err = hw->tf->write(hw->dev, HTS221_REG_CNTRL1_ADDR, sizeof(data),
> +			    (u8 *)&data);
> +	if (err < 0)
> +		return err;
> +
> +	hw->enabled = false;
> +
> +	return 0;
>  }
>  
>  static int hts221_parse_temp_caldata(struct hts221_hw *hw)
> @@ -682,6 +698,38 @@ int hts221_probe(struct iio_dev *iio_dev)
>  }
>  EXPORT_SYMBOL(hts221_probe);
>  
> +#ifdef CONFIG_PM
> +static int hts221_suspend(struct device *dev)

You can get rid of this #ifdef by adding __maybe_unused to the
_suspend and _resume function declarations. This will allow for
additional compile-time code checking if power management is
disabled.

If desired, one way to get rid of the enabled flag would be to
add support for runtime power management to automatically shutdown
the chip after a period of inactivity. See
https://lkml.org/lkml/2017/4/25/101 for an example.

Brian
--
To unsubscribe from this list: send the line "unsubscribe linux-iio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux