From: Jonathan Cameron <jic23@kernel.org>
To: Martin Kepplinger <martink@posteo.de>,
knaack.h@gmx.de, lars@metafoo.de, pmeerw@pmeerw.net,
christoph.muellner@theobroma-systems.com, mfuzzey@parkeon.com
Cc: linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH 2/4] iio: mma8452: avoid switching to active because of config change
Date: Sat, 5 Mar 2016 17:23:07 +0000 [thread overview]
Message-ID: <56DB15FB.20308@kernel.org> (raw)
In-Reply-To: <1456993444-21320-3-git-send-email-martink@posteo.de>
On 03/03/16 08:24, Martin Kepplinger wrote:
> The devices' config registers can only be changed in standby mode.
> Up until now the driver just held the device *always* active, so for
> changing a config it was *always* necessary to switch to standby.
>
> For upcoming support for runtime pm, the device can as well be in standby
> mode. Instead of putting runtime pm functions in there, just keep the
> device in standby if it already is. This section is protected by a lock
> after all.
>
> Signed-off-by: Martin Kepplinger <martink@posteo.de>
> Signed-off-by: Christoph Muellner <christoph.muellner@theobroma-systems.com>
Applied to the togreg branch of iio.git - initially pushed out as testing
Thanks,
Jonathan
> ---
> drivers/iio/accel/mma8452.c | 35 +++++++++++++++++++++++++++++------
> 1 file changed, 29 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/iio/accel/mma8452.c b/drivers/iio/accel/mma8452.c
> index 17d72bc..9c4a84a 100644
> --- a/drivers/iio/accel/mma8452.c
> +++ b/drivers/iio/accel/mma8452.c
> @@ -393,24 +393,47 @@ static int mma8452_active(struct mma8452_data *data)
> data->ctrl_reg1);
> }
>
> +/* returns >0 if active, 0 if in standby and <0 on error */
> +static int mma8452_is_active(struct mma8452_data *data)
> +{
> + int reg;
> +
> + reg = i2c_smbus_read_byte_data(data->client, MMA8452_CTRL_REG1);
> + if (reg < 0)
> + return reg;
> +
> + return reg & MMA8452_CTRL_ACTIVE;
> +}
> +
> static int mma8452_change_config(struct mma8452_data *data, u8 reg, u8 val)
> {
> int ret;
> + int is_active;
>
> mutex_lock(&data->lock);
>
> - /* config can only be changed when in standby */
> - ret = mma8452_standby(data);
> - if (ret < 0)
> + is_active = mma8452_is_active(data);
> + if (is_active < 0) {
> + ret = is_active;
> goto fail;
> + }
> +
> + /* config can only be changed when in standby */
> + if (is_active > 0) {
> + ret = mma8452_standby(data);
> + if (ret < 0)
> + goto fail;
> + }
>
> ret = i2c_smbus_write_byte_data(data->client, reg, val);
> if (ret < 0)
> goto fail;
>
> - ret = mma8452_active(data);
> - if (ret < 0)
> - goto fail;
> + if (is_active > 0) {
> + ret = mma8452_active(data);
> + if (ret < 0)
> + goto fail;
> + }
>
> ret = 0;
> fail:
>
next prev parent reply other threads:[~2016-03-05 17:23 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-03-03 8:24 iio: mma8452: power saving features for v4.7 Martin Kepplinger
2016-03-03 8:24 ` [PATCH 1/4] iio: mma8452: coding style fixes Martin Kepplinger
2016-03-05 17:19 ` Jonathan Cameron
2016-03-03 8:24 ` [PATCH 2/4] iio: mma8452: avoid switching to active because of config change Martin Kepplinger
2016-03-05 17:23 ` Jonathan Cameron [this message]
2016-03-03 8:24 ` [PATCH 3/4] iio: mma8452: add support for runtime power management Martin Kepplinger
2016-03-06 12:59 ` Jonathan Cameron
2016-03-03 8:24 ` [PATCH 4/4] iio: mma8452: add low_power mode Martin Kepplinger
2016-03-05 17:40 ` Jonathan Cameron
2016-03-06 15:49 ` Martin Kepplinger
2016-03-09 21:17 ` Jonathan Cameron
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=56DB15FB.20308@kernel.org \
--to=jic23@kernel.org \
--cc=christoph.muellner@theobroma-systems.com \
--cc=knaack.h@gmx.de \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=martink@posteo.de \
--cc=mfuzzey@parkeon.com \
--cc=pmeerw@pmeerw.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.