From: Dmitry Torokhov <dmitry.torokhov@gmail.com>
To: Chris Diamand <chris@diamand.org>
Cc: Richard Pospesel <pospeselr@gmail.com>,
linux-input@vger.kernel.org, phonesyfreakies@gmail.com,
Michael Shell <list1@michaelshell.org>,
Ondrej Zary <linux@rainbow-software.org>
Subject: Re: [PATCH] Input: byd - use DMI detection
Date: Sat, 12 Nov 2016 11:13:13 -0800 [thread overview]
Message-ID: <20161112191313.GB5809@dtor-ws> (raw)
In-Reply-To: <20161111235759.11988-1-chris@diamand.org>
On Fri, Nov 11, 2016 at 11:57:59PM +0000, Chris Diamand wrote:
> Because the BYD touchpad uses standard PS/2 commands for its
> detection sequence, some other models are incorrectly detected as BYD
> touchpads. This causes chaos when byd_init() later fails.
>
> To fix this, init() and detect() should be merged. However, this
> would slow down detection for other mouse models. Instead, add a DMI
> check before attempting touchpad detection.
>
> Signed-off-by: Chris Diamand <chris@diamand.org>
> ---
> Hi all,
>
> This patch should fix the mis-detection of some mouse models as BYD touchpads,
> as mentioned in a few bug reports and other threads.
>
> However, I no longer have a machine with a BYD touchpad (although I did record
> its DMI data), so this is mostly untested - could anyone *with* a BYD touchpad
> please try this patch to check their touchpad still works, and could anyone
> with a misdetected non-BYD touchpad please check that this fixes the
> misdetection?
>
> Also, the DMI fields really are pretty much all like that ("To Be Filled By
> O.E.M.", etc). I've tried to choose the most specific ones, but it's still
> fairly arbitrary...
No, unfortunately this will trigger on many more whitebox devices.
>
> Cheers!
> Chris
>
> drivers/input/mouse/byd.c | 15 +++++++++++++++
> 1 file changed, 15 insertions(+)
>
> diff --git a/drivers/input/mouse/byd.c b/drivers/input/mouse/byd.c
> index b27aa63..b4c5fd0 100644
> --- a/drivers/input/mouse/byd.c
> +++ b/drivers/input/mouse/byd.c
> @@ -13,6 +13,7 @@
> */
>
> #include <linux/delay.h>
> +#include <linux/dmi.h>
> #include <linux/input.h>
> #include <linux/libps2.h>
> #include <linux/serio.h>
> @@ -235,6 +236,17 @@ struct byd_data {
> bool touch;
> };
>
> +static const struct dmi_system_id byd_dmi_table[] = {
> + {
> + .matches = {
> + DMI_MATCH(DMI_PRODUCT_NAME, "SharkBay Platform"),
> + DMI_MATCH(DMI_PRODUCT_SERIAL, "System Serial Number"),
> + DMI_MATCH(DMI_BOARD_NAME, "WhiteTip Mountain1 Fab2"),
> + DMI_MATCH(DMI_CHASSIS_VENDOR, "To Be Filled By O.E.M."),
> + },
> + },
> +};
> +
> static void byd_report_input(struct psmouse *psmouse)
> {
> struct byd_data *priv = psmouse->private;
> @@ -439,6 +451,9 @@ int byd_detect(struct psmouse *psmouse, bool set_properties)
> struct ps2dev *ps2dev = &psmouse->ps2dev;
> u8 param[4] = {0x03, 0x00, 0x00, 0x00};
>
> + if (!dmi_check_system(byd_dmi_table))
> + return -1;
> +
> if (ps2_command(ps2dev, param, PSMOUSE_CMD_SETRES))
> return -1;
> if (ps2_command(ps2dev, param, PSMOUSE_CMD_SETRES))
> --
> 2.10.1
>
--
Dmitry
prev parent reply other threads:[~2016-11-12 19:13 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-11-11 23:57 [PATCH] Input: byd - use DMI detection Chris Diamand
2016-11-12 12:12 ` Pali Rohár
2016-11-12 14:48 ` Chris Diamand
2016-11-12 15:04 ` Pali Rohár
2016-11-12 17:33 ` Richard Pospesel
2016-11-12 17:48 ` Pali Rohár
2016-11-12 18:01 ` Richard Pospesel
2016-11-12 19:13 ` Dmitry Torokhov [this message]
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=20161112191313.GB5809@dtor-ws \
--to=dmitry.torokhov@gmail.com \
--cc=chris@diamand.org \
--cc=linux-input@vger.kernel.org \
--cc=linux@rainbow-software.org \
--cc=list1@michaelshell.org \
--cc=phonesyfreakies@gmail.com \
--cc=pospeselr@gmail.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).