Re: [PATCH 0/2] Remove input_call_hotplug

From: Dmitry Torokhov
Date: Wed Jan 19 2005 - 09:32:31 EST


On Wed, 19 Jan 2005 12:56:16 +0100, Hannes Reinecke <hare@xxxxxxx> wrote:
> Greg KH wrote:
> > On Tue, Jan 18, 2005 at 05:20:40PM -0500, Dmitry Torokhov wrote:
> >
> >>I was mostly talking about the need of 2 separate classes and this
> >>patch lays groundwork for it althou lifetime rules in input system
> >>need to be cleaned up before we can go all the way.
> >
> >
> > I agree. But I think only 1 class is needed, that way we don't break
> > userspace, which is a pretty important thing.
> >
> Well, if you could show me how to do this with the class_interface thing
> I'd be happy to comply.
>
> The input layer design is like this:
> - Physical devices present one (or several) abstract input devices
> (which correspond to struct input_dev)
> - Each input device can be linked to one or several input handlers
> (which correspond to struct input_handle)
> - Each handler is represented to userspace with a device node.
>
> The problem with the current input layer is that each 'struct
> input_handle' is associated with a class_simple device.
> This class is named 'input', so we're getting 'input' events from it.
> But each instantiation of struct input_dev is also sending 'input'
> events as it is doing the call_usermodehelper call directly.
>

Yes, this is the problem and needs to be resolved. Thankfully most
people have keyboard support compiled in so it's not fatal but we
probably waht hotplug package be updated first before we commit this
change.

>
> But if we were going to implement this with device_interface, we'd be
> having a /sys/class structure like:
>
> class
> |- isa0060-serio0-input0
> | |- event0
> | | `dev
> | |- key
> | |- ...
> |- ..
>
> So we'd be moving the 'dev' attribute one directory down, again
> incurring a userland breakage.
> Plus it would be far more coding involved as the entire input layer
> structure would have to be redone.
>

If I understand correctly we do not have subclasses so it will look like
class
|- input_device
| |- input0
| |- input1
|
|- input
| |-event0
| |-event1
| |-mouse0

So breakage is really minimal.

--
Dmitry
-
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/