From: Dmitry Torokhov <dmitry.torokhov@gmail.com>
To: "jingle.wu" <jingle.wu@emc.com.tw>
Cc: linux-kernel@vger.kernel.org, linux-input@vger.kernel.org,
phoenix@emc.com.tw,
"jingle.wu" <jingle.wu@elan.corp-partner.google.com>
Subject: Re: [PATCH] Input: trackpoint - Add Suspend mode for Elan TrackPoint
Date: Wed, 23 Mar 2022 10:27:30 -0700 [thread overview]
Message-ID: <YjtYgoBvytgQu/pn@google.com> (raw)
In-Reply-To: <20200904024231.26812-1-jingle.wu@emc.com.tw>
Hi Jingle,
On Fri, Sep 04, 2020 at 10:42:31AM +0800, jingle.wu wrote:
> From: "jingle.wu" <jingle.wu@elan.corp-partner.google.com>
>
> Add suspend command for elan trackpoint
Could you please elaborate what this mode does to the trackpint?
Also, your signed-off-by is missing.
> ---
> drivers/input/mouse/trackpoint.c | 16 ++++++++++++++++
> drivers/input/mouse/trackpoint.h | 1 +
> 2 files changed, 17 insertions(+)
>
> diff --git a/drivers/input/mouse/trackpoint.c b/drivers/input/mouse/trackpoint.c
> index 3eefee2ee2a1..b3cba973a4eb 100644
> --- a/drivers/input/mouse/trackpoint.c
> +++ b/drivers/input/mouse/trackpoint.c
> @@ -389,6 +389,20 @@ static int trackpoint_reconnect(struct psmouse *psmouse)
> return 0;
> }
>
> +static void trackpoint_cleanup(struct psmouse *psmouse)
> +{
> + struct trackpoint_data *tp = psmouse->private;
> + u8 param[3] = { TP_TOGGLE, TP_TOGGLE_BURST, TP_TOGGLE_ELAN_SLEEP };
> +
> + if (tp->variant_id == TP_VARIANT_ELAN) {
> + if (ps2_command(&psmouse->ps2dev, param,
I'd combine the 2 "ifs".
> + MAKE_PS2_CMD(3, 0, TP_COMMAND))) {
> + psmouse_err(psmouse,
psmouse_warn() since it is not a hard error.
> + "failed to suspend trackpont.\n");
I'd say "failed to suspend Elan trackpont\n".
> + }
> + }
> +}
> +
> int trackpoint_detect(struct psmouse *psmouse, bool set_properties)
> {
> struct ps2dev *ps2dev = &psmouse->ps2dev;
> @@ -421,6 +435,8 @@ int trackpoint_detect(struct psmouse *psmouse, bool set_properties)
> psmouse->reconnect = trackpoint_reconnect;
> psmouse->disconnect = trackpoint_disconnect;
>
> + psmouse->cleanup = trackpoint_cleanup;
> +
> if (variant_id != TP_VARIANT_IBM) {
> /* Newer variants do not support extended button query. */
> button_info = 0x33;
> diff --git a/drivers/input/mouse/trackpoint.h b/drivers/input/mouse/trackpoint.h
> index 5cb93ed26085..c7fa75452976 100644
> --- a/drivers/input/mouse/trackpoint.h
> +++ b/drivers/input/mouse/trackpoint.h
> @@ -107,6 +107,7 @@
> #define TP_TOGGLE_EXT_TAG 0x22 /* Bit 3 of the first packet coming from the
> external device will be forced to 1 */
> #define TP_MASK_EXT_TAG 0x04
> +#define TP_TOGGLE_ELAN_SLEEP 0x8
It seems to me that TP_TOGGLE_ELAN_SLEEP is a bit in TP_TOGGLE_BURST
subcommand, so it is better to move it next to TP_MASK_BURST and call it
TP_MASK_ELAN_SLEEP to match the rest.
Thanks.
--
Dmitry
next prev parent reply other threads:[~2022-03-23 17:27 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-09-04 2:42 [PATCH] Input: trackpoint - Add Suspend mode for Elan TrackPoint jingle.wu
2022-03-23 17:27 ` Dmitry Torokhov [this message]
2022-03-24 1:13 ` Jingle.Wu
2022-03-24 1:50 ` Josh.Chen
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=YjtYgoBvytgQu/pn@google.com \
--to=dmitry.torokhov@gmail.com \
--cc=jingle.wu@elan.corp-partner.google.com \
--cc=jingle.wu@emc.com.tw \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=phoenix@emc.com.tw \
/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.