From: Dmitry Torokhov <dmitry.torokhov@gmail.com>
To: Dudley Du <dudley.dulixin@gmail.com>
Cc: rydberg@euromail.se, Dudley Du <dudl@cypress.com>,
bleung@google.com, linux-input@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH v9 05/18] input: cyapa: add power management interfaces supported for the device
Date: Mon, 10 Nov 2014 00:38:06 -0800 [thread overview]
Message-ID: <20141110083806.GC39688@dtor-ws> (raw)
In-Reply-To: <1415003590-30485-6-git-send-email-dudl@cypress.com>
On Mon, Nov 03, 2014 at 04:32:57PM +0800, Dudley Du wrote:
> Add suspend_scanrate_ms power management interfaces in device's
> power group, so users or applications can control the power management
> strategy of trackpad device as their requirements.
> TEST=test on Chromebooks.
>
> Signed-off-by: Dudley Du <dudl@cypress.com>
> ---
> drivers/input/mouse/cyapa.c | 112 ++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 112 insertions(+)
>
> diff --git a/drivers/input/mouse/cyapa.c b/drivers/input/mouse/cyapa.c
> index fac361a..420696d 100644
> --- a/drivers/input/mouse/cyapa.c
> +++ b/drivers/input/mouse/cyapa.c
> @@ -505,6 +505,96 @@ u16 cyapa_pwr_cmd_to_sleep_time(u8 pwr_mode)
> : (encoded_time - 5) * 20;
> }
>
> +#ifdef CONFIG_PM_SLEEP
> +static ssize_t cyapa_show_suspend_scanrate(struct device *dev,
> + struct device_attribute *attr,
> + char *buf)
> +{
> + struct cyapa *cyapa = dev_get_drvdata(dev);
> + u8 pwr_cmd = cyapa->suspend_power_mode;
> + u16 sleep_time;
> + int len;
> + int ret;
> +
> + ret = mutex_lock_interruptible(&cyapa->state_sync_lock);
> + if (ret)
> + return ret;
> + pwr_cmd = cyapa->suspend_power_mode;
> + sleep_time = cyapa->suspend_sleep_time;
> + mutex_unlock(&cyapa->state_sync_lock);
> +
> + if (pwr_cmd == PWR_MODE_BTN_ONLY)
> + len = scnprintf(buf, PAGE_SIZE, "%s\n", BTN_ONLY_MODE_NAME);
> + else if (pwr_cmd == PWR_MODE_OFF)
> + len = scnprintf(buf, PAGE_SIZE, "%s\n", OFF_MODE_NAME);
> + else {
> + if (cyapa->gen == CYAPA_GEN3)
> + sleep_time = cyapa_pwr_cmd_to_sleep_time(pwr_cmd);
> + len = scnprintf(buf, PAGE_SIZE, "%u\n", sleep_time);
> + }
> +
> + return len;
> +}
> +
> +static u16 cyapa_clamp_sleep_time(u16 sleep_time)
> +{
> + if (sleep_time > 1000)
> + sleep_time = 1000;
> + return sleep_time;
> +}
> +
> +static ssize_t cyapa_update_suspend_scanrate(struct device *dev,
> + struct device_attribute *attr,
> + const char *buf, size_t count)
> +{
> + struct cyapa *cyapa = dev_get_drvdata(dev);
> + u16 sleep_time;
> + int ret;
> +
> + ret = mutex_lock_interruptible(&cyapa->state_sync_lock);
> + if (ret)
> + return ret;
> +
> + if (sysfs_streq(buf, BTN_ONLY_MODE_NAME))
> + cyapa->suspend_power_mode = PWR_MODE_BTN_ONLY;
> + else if (sysfs_streq(buf, OFF_MODE_NAME))
> + cyapa->suspend_power_mode = PWR_MODE_OFF;
> + else if (!kstrtou16(buf, 10, &sleep_time)) {
> + cyapa->suspend_sleep_time = cyapa_clamp_sleep_time(sleep_time);
I'd simply do
cyapa->suspend_sleep_time = max_t(u16, sleep_time, 1000);
here.
> + cyapa->suspend_power_mode =
> + cyapa_sleep_time_to_pwr_cmd(cyapa->suspend_sleep_time);
> + } else
> + count = 0;
> +
If one branch uses curly braces then all branches shoudl use them, even
if they contain only one statement.
> + mutex_unlock(&cyapa->state_sync_lock);
> + if (!count)
> + dev_err(dev, "invalid suspend scanrate ms parameters\n");
> + return count ? count : -EINVAL;
> +}
> +
> +static DEVICE_ATTR(suspend_scanrate_ms, S_IRUGO|S_IWUSR,
> + cyapa_show_suspend_scanrate,
> + cyapa_update_suspend_scanrate);
> +
> +static struct attribute *cyapa_power_wakeup_entries[] = {
> + &dev_attr_suspend_scanrate_ms.attr,
> + NULL,
> +};
> +
> +static const struct attribute_group cyapa_power_wakeup_group = {
> + .name = power_group_name,
> + .attrs = cyapa_power_wakeup_entries,
> +};
> +
> +static void cyapa_remove_power_wakeup_group(void *data)
> +{
> + struct cyapa *cyapa = data;
> +
> + sysfs_unmerge_group(&cyapa->client->dev.kobj,
> + &cyapa_power_wakeup_group);
> +}
> +#endif /* CONFIG_PM_SLEEP */
> +
> /*
> * Returns:
> * 0 Driver and device initialization successfully done.
> @@ -588,6 +678,28 @@ static int cyapa_probe(struct i2c_client *client,
> return ret;
> }
>
> +#ifdef CONFIG_PM_SLEEP
> + if (device_can_wakeup(dev)) {
> + ret = sysfs_merge_group(&client->dev.kobj,
> + &cyapa_power_wakeup_group);
> + if (ret) {
> + dev_err(dev, "failed to add power wakeup group, (%d)\n",
> + ret);
> + return ret;
> + }
> +
> + ret = devm_add_action(dev,
> + cyapa_remove_power_wakeup_group, cyapa);
> + if (ret) {
> + cyapa_remove_power_wakeup_group(cyapa);
> + dev_err(dev,
> + "failed to add power cleanup action, (%d)\n",
> + ret);
> + return ret;
> + }
> + }
> +#endif /* CONFIG_PM_SLEEP */
> +
> return 0;
> }
>
> --
> 1.9.1
>
--
Dmitry
next prev parent reply other threads:[~2014-11-10 8:38 UTC|newest]
Thread overview: 34+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-11-03 8:32 [PATCH v9 01/18] input: cyapa: instruction of cyapa patches Dudley Du
2014-11-03 8:32 ` [PATCH v9 01/18] input: cyapa: add device resource management infrastructure support Dudley Du
2014-11-09 21:25 ` Dmitry Torokhov
2014-11-10 2:48 ` Dudley Du
2014-11-10 3:30 ` Dmitry Torokhov
2014-11-03 8:32 ` [PATCH v9 02/18] input: cyapa: re-design driver to support multi-trackpad in one driver Dudley Du
2014-11-10 8:18 ` Dmitry Torokhov
2014-11-10 11:04 ` Dudley Du
2014-11-03 8:32 ` [PATCH v9 03/18] input: cyapa: add gen3 trackpad device basic functions support Dudley Du
2014-11-10 8:30 ` Dmitry Torokhov
2014-11-10 11:05 ` Dudley Du
2014-11-03 8:32 ` [PATCH v9 04/18] input: cyapa: add gen5 " Dudley Du
2014-11-03 8:32 ` [PATCH v9 05/18] input: cyapa: add power management interfaces supported for the device Dudley Du
2014-11-10 8:38 ` Dmitry Torokhov [this message]
2014-11-10 11:05 ` Dudley Du
2014-11-03 8:32 ` [PATCH v9 06/18] input: cyapa: add runtime " Dudley Du
2014-11-03 8:32 ` [PATCH v9 07/18] input: cyapa: add sysfs interfaces supported in the cyapa driver Dudley Du
2014-11-03 8:33 ` [PATCH v9 08/18] input: cyapa: add gen3 trackpad device firmware update function support Dudley Du
2014-11-03 8:33 ` [PATCH v9 09/18] input: cyapa: add gen3 trackpad device read baseline " Dudley Du
2014-11-03 8:33 ` [PATCH v9 10/18] input: cyapa: add gen3 trackpad device force re-calibrate " Dudley Du
2014-11-03 8:33 ` [PATCH v9 11/18] input: cyapa: add gen5 trackpad device firmware update " Dudley Du
2014-11-03 8:33 ` [PATCH v9 12/18] input: cyapa: add gen5 trackpad device read baseline " Dudley Du
2014-11-03 8:33 ` [PATCH v9 13/18] input: cyapa: add gen5 trackpad device force re-calibrate " Dudley Du
2014-11-03 8:33 ` [PATCH v9 14/18] input: cyapa: add read firmware image debugfs interface support Dudley Du
2014-11-03 8:33 ` [PATCH v9 15/18] input: cyapa: add gen3 trackpad device read firmware image function support Dudley Du
2014-11-10 8:39 ` Dmitry Torokhov
2014-11-10 11:05 ` Dudley Du
2014-12-04 17:46 ` Dmitry Torokhov
2014-12-04 17:46 ` Dmitry Torokhov
2014-12-05 1:43 ` Dudley Du
2014-12-05 1:43 ` Dudley Du
2014-11-03 8:33 ` [PATCH v9 16/18] input: cyapa: add gen5 " Dudley Du
2014-11-03 8:33 ` [PATCH v9 17/18] input: cyapa: add read sensors raw data debugfs interface support Dudley Du
2014-11-03 8:33 ` [PATCH v9 18/18] input: cyapa: add gen5 trackpad device read raw data function support Dudley Du
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=20141110083806.GC39688@dtor-ws \
--to=dmitry.torokhov@gmail.com \
--cc=bleung@google.com \
--cc=dudl@cypress.com \
--cc=dudley.dulixin@gmail.com \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=rydberg@euromail.se \
/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.