Re: [PATCH] Input: Support for a less exclusive grab.
From: Ryan Lortie
Date: Tue Oct 23 2007 - 11:58:18 EST
On Tue, 2007-23-10 at 09:21 -0400, Dmitry Torokhov wrote:
> Priority/filter idea is different matter. I don't think it is a giood
> solution. There will always be an "arms race", new applications would
> like to get in front of the queue all the time and it will be hard to
> manage. X should just keep console open in raw mode and simply ignore
> all events coming from it while using evdev driver. I understand that
> X's hotplug support is getting there so you should be able to switch
> to pure evdev setup pretty easy.
The only reason that I don't like the numeric priority system is that I
believe it is arbitrary and a bit kludgy. I don't think an arms race
will be a problem. We don't have a lot of closed source applications
running as root on Linux and open source projects either choose sane
values or get patched (by users, distributions, etc) or don't get used.
I do believe there needs to be some concept of filtering events in such
a way that they reach some clients but not others -- that's half of the
purpose of this thread. rfkill wants to be able to see keypresses while
they are kept away from X. I'd be open to another way of handling this
but I think any other way will necessarily be more complex to use.
As for X using evdev, it still puts you in a position of two pieces of
software being required to know what events have been (conceptually)
"filtered" by various filters running on the system. ie: the filter
itself needs to know, and also X needs to know so that it can remove
those key events from normal delivery.
So while I agree that the priority numbering is a bit kludgy (and have
no particular affinity to it) I do think that some prioritising system
is required and that pointing out the 'arms race' isn't a good reason to
write the whole idea off. I'd gladly accept another method.
Note, of course, that the priorities mean nothing unless you actively
switch on filtering.
> >
> > - how should we decide what gets what priority level?
> >
>
> Exactly. You can't predict all future uses. There will always be
> someone wanting to get in front of the line.
Two proposals here:
1) Modules like rfkill could have parameters to set priority level.
Presumably, programs hooking in via evdev could also have their priority
configurable. Leave it up to distributions (or users installing their
own software) to make sure everything is sane.
2) For matters like this, an unsigned int is a large place. We could
easily use numbers like 10, 100, 1000 while still leaving plenty of room
between them and possibility for expansion on either side.
> Input core now has prper locking. You may take device's event_lock to
> stop event propagation.
noted.
Thanks for the review
Cheers
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/