From: Peter Hutterer <peter.hutterer@who-t.net>
To: "Michal Suchánek" <msuchanek@suse.de>
Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com>,
Benjamin Tissoires <benjamin.tissoires@redhat.com>,
linuxppc-dev <linuxppc-dev@lists.ozlabs.org>,
lkml <linux-kernel@vger.kernel.org>,
"linux-input@vger.kernel.org" <linux-input@vger.kernel.org>
Subject: Re: [PATCH] macintosh: move mac_hid driver to input/mouse.
Date: Sat, 10 Jun 2017 12:00:22 +1000 [thread overview]
Message-ID: <20170610020021.GA10528@m72e.redhat.com> (raw)
In-Reply-To: <20170609133953.1e7221a8@kitsune.suse.cz>
On Fri, Jun 09, 2017 at 01:39:53PM +0200, Michal Suchánek wrote:
> On Thu, 8 Jun 2017 16:18:28 -0700
> Dmitry Torokhov <dmitry.torokhov@gmail.com> wrote:
>
> > On Thu, Jun 8, 2017 at 4:07 PM, Peter Hutterer
> > <peter.hutterer@who-t.net> wrote:
> > > On Thu, Jun 08, 2017 at 03:18:42PM +0200, Michal Suchánek wrote:
> > >> This is what evtest reports about my keyboard:
> > >>
> > >> Select the device event number [0-12]: 2
> > >> Input driver version is 1.0.1
> > >> Input device ID: bus 0x3 vendor 0x413c product 0x2107 version 0x111
> > >> Input device name: "DELL Dell USB Entry Keyboard"
> > >> Supported events:
> > >> Event type 0 (EV_SYN)
> > >> Event type 1 (EV_KEY)
> > >> Event code 1 (KEY_ESC)
> > >> Event code 2 (KEY_1)
> > >> Event code 3 (KEY_2)
> > >> Event code 4 (KEY_3)
> > >> ...
> > >> Event code 193 (KEY_F23)
> > >> Event code 194 (KEY_F24)
> > >> Event code 240 (KEY_UNKNOWN)
> > >> Event code 272 (BTN_LEFT)
> > >> Event code 273 (BTN_RIGHT)
> > >> Event code 274 (BTN_MIDDLE)
> > >> Event type 4 (EV_MSC)
> > >> Event code 4 (MSC_SCAN)
> > >> Event type 17 (EV_LED)
> > >> Event code 0 (LED_NUML) state 1
> > >> Event code 1 (LED_CAPSL) state 0
> > >> Event code 2 (LED_SCROLLL) state 0
> > >> Event code 3 (LED_COMPOSE) state 0
> > >> Event code 4 (LED_KANA) state 0
> > >> Key repeat handling:
> > >> Repeat type 20 (EV_REP)
> > >> Repeat code 0 (REP_DELAY)
> > >> Value 250
> > >> Repeat code 1 (REP_PERIOD)
> > >> Value 33
> > >> Properties:
> > >
> > > looks like it's not tagged as ID_INPUT_MOUSE by the default udev
> > > rules because for that we need x/y axes (either relative for real
> > > mice or absolute ones for the VMWare USB mouse). This keyboard only
> > > has buttons though. So it gets ID_INPUT_KEYBOARD for the keys, but
> > > no ID_INPUT_MOUSE.
> > >
> > > Google isn't overly forthcoming on "DELL Dell USB Entry Keyboard"
> > > but the few pictures I can find all point to a keyboard that
> > > doesn't have any physical mouse buttons at all. Does yours have
> > > buttons? Can you post a picture of it somewhere?
> > >
> >
> > Michal is using udev/hwdb to replace some of the keys on his keyboard
> > to generate BTN_RIGHT/BTN_MIDDLE trying to achive the same end result
> > as with mac_hid. It is not the default keyboard behavior. Having
> > another custom udev rule to mark the device as ID_INPUT_MOUSE is a
> > fair requirement in this case I think.
> >
>
> Which is done in different place, and uses device matching with
> completely different patterns. So for this to work reasonably either
>
> - all devices should have all capabilities by default
> - the capabilities should be detected based on the events actually
> available on the device
>
> And if my keyboard actually claimed to have relative axis because of
> some great firmware engineering on the manufacturer's part and I found
> how to remove them in hwdb it would not take effect either.
https://github.com/systemd/systemd/blob/master/rules/50-udev-default.rules.in
calls input-id which sets the ID_INPUT_* tags. If you modify the
capabilities after that happens, you need to call input-id again to get
updated udev properties.
There is no kernel facility to handle devices that change capabilities at
runtime. We discussed this a short while ago (search for SYN_CONFIG) but
it's ... tricky.
Cheers,
Peter
next prev parent reply other threads:[~2017-06-10 2:00 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-05-09 19:14 [PATCH] macintosh: move mac_hid driver to input/mouse Michal Suchanek
2017-05-10 0:43 ` Dmitry Torokhov
2017-05-10 10:44 ` Michal Suchánek
2017-05-28 9:47 ` Michal Suchanek
2017-05-28 13:26 ` Bastien Nocera
2017-05-28 17:55 ` Dmitry Torokhov
2017-06-07 16:53 ` Michal Suchánek
2017-06-07 17:16 ` Dmitry Torokhov
2017-06-07 19:17 ` Michal Suchánek
2017-06-07 23:13 ` Peter Hutterer
2017-06-08 13:18 ` Michal Suchánek
2017-06-08 23:07 ` Peter Hutterer
2017-06-08 23:18 ` Dmitry Torokhov
2017-06-09 11:39 ` Michal Suchánek
2017-06-10 2:00 ` Peter Hutterer [this message]
2017-06-12 11:40 ` Michal Suchánek
2017-06-12 13:27 ` Michal Suchánek
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=20170610020021.GA10528@m72e.redhat.com \
--to=peter.hutterer@who-t.net \
--cc=benjamin.tissoires@redhat.com \
--cc=dmitry.torokhov@gmail.com \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=msuchanek@suse.de \
/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).