linux-input.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Dmitry Torokhov <dmitry.torokhov@gmail.com>
To: Mauro Carvalho Chehab <mchehab@redhat.com>
Cc: Devin Heitmueller <dheitmueller@kernellabs.com>,
	Jon Smirl <jonsmirl@gmail.com>,
	Maxim Levitsky <maximlevitsky@gmail.com>,
	awalls@radix.net, j@jannau.net, jarod@redhat.com,
	jarod@wilsonet.com, khc@pm.waw.pl, linux-input@vger.kernel.org,
	linux-kernel@vger.kernel.org, linux-media@vger.kernel.org,
	lirc-list@lists.sourceforge.net, superm1@ubuntu.com,
	Christoph Bartelmus <lirc@bartelmus.de>
Subject: Re: [RFC v2] Another approach to IR
Date: Wed, 2 Dec 2009 09:10:59 -0800	[thread overview]
Message-ID: <20091202171059.GC17839@core.coreip.homeip.net> (raw)
In-Reply-To: <4B16614A.3000208@redhat.com>

On Wed, Dec 02, 2009 at 10:44:58AM -0200, Mauro Carvalho Chehab wrote:
> Dmitry Torokhov wrote:
> > On Tue, Dec 01, 2009 at 07:05:49PM -0200, Mauro Carvalho Chehab wrote:
> >> Dmitry Torokhov wrote:
> >>> On Tue, Dec 01, 2009 at 05:00:40PM -0200, Mauro Carvalho Chehab wrote:
> >>>> Dmitry Torokhov wrote:
> >>>>> On Tue, Dec 01, 2009 at 03:29:44PM -0200, Mauro Carvalho Chehab wrote:
> >>>>>> For sure we need to add an EVIOSETPROTO ioctl to allow the driver 
> >>>>>> to change the protocol in runtime.
> >>>>>>
> >>>>> Mauro,
> >>>>>
> >>>>> I think this kind of confuguration belongs to lirc device space,
> >>>>> not input/evdev. This is the same as protocol selection for psmouse
> >>>>> module: while it is normally auto-detected we have sysfs attribute to
> >>>>> force one or another and it is tied to serio device, not input
> >>>>> device.
> >>>> Dmitry,
> >>>>
> >>>> This has nothing to do with the raw interface nor with lirc. This problem 
> >>>> happens with the evdev interface and already affects the in-kernel drivers.
> >>>>
> >>>> In this case, psmouse is not a good example. With a mouse, when a movement
> >>>> occurs, you'll receive some data from its port. So, a software can autodetect
> >>>> the protocol. The same principle can be used also with a raw pulse/space
> >>>> interface, where software can autodetect the protocol.
> >>> Or, in certain cases, it can not.
> >>>
> >>> [... skipped rationale for adding a way to control protocol (with which
> >>> I agree) ...]
> >>>
> >>>> To solve this, we really need to extend evdev API to do 3 things: enumberate the
> >>>> supported protocols, get the current protocol(s), and select the protocol(s) that
> >>>> will be used by a newer table.
> >>>>
> >>> And here we start disagreeing. My preference would be for adding this
> >>> API on lirc device level (i.e. /syc/class/lirc/lircX/blah namespace),
> >>> since it only applicable to IR, not to input devices in general.
> >>>
> >>> Once you selected proper protocol(s) and maybe instantiated several
> >>> input devices then udev (by examining input device capabilities and
> >>> optionally looking up at the parent device properties) would use
> >>> input evdev API to load proper keymap. Because translation of
> >>> driver-specific codes into standard key definitions is in the input
> >>> realm. Reading these driver-specific codes from hardware is outside of
> >>> input layer domain.
> >>>
> >>> Just as psmouse ability to specify protocol is not shoved into evdev;
> >>> just as atkbd quirks (force release key list and other driver-specific
> >>> options) are not in evdev either; we should not overload evdev interface
> >>> with IR-specific items.
> >> I'm not against mapping those features as sysfs atributes, but they don't belong
> >> to lirc, as far as I understand. From all we've discussed, we'll create a lirc
> >> interface to allow the direct usage of raw IO. However, IR protocol is a property
> >> that is not related to raw IO mode but, instead, to evdev mode.
> >>
> > 
> > Why would protocol relate to evdev node? Evdev does not really care what
> > how the fact that a certain button was pressed was communicated to it.
> > It may be deliveretd through PS/2 port, or maybe it was Bluetooth HID,
> > or USB HID or USB boot protocol or some custom protocol, or RC-5, NEC or
> > some custom IR protocol. It makes no difference _whatsoever_ to evdev
> > nor any users of evdev care about protocol used by underlying hardware
> > device to transmit the data.
> >  
> >> We might add a /sys/class/IR and add IR specific stuff there, but it seems
> >> overkill to me and will hide the fact that those parameters are part of the evdev
> >> interface.
> >>
> >> So, I would just add the IR sysfs parameters at the /sys/class/input, if
> >> the device is an IR (or create it is /sys/class/input/IR).
> >>
> >> I agree that the code to implement the IR specific sysfs parameter should be kept
> >> oustide input core, as they're specific to IR implementations.
> >>
> >> Would this work for you?
> > 
> > I am seeing a little bit differently structured subsystem for IR at the
> > moment. I think we should do something like this:
> > 
> > - receivers create /sys/class/lirc devices. These devices provide API
> >   with a ring buffer (fifo) for the raw data stream coming from (and to)
> >   them.
> 
> The raw interface applies only to the devices that doesn't have a hardware decoder
> (something between 40%-60% of the currently supported devices).

50% is quite a number I think. But if driver does not allow access to
the raw stream - it will refuse binding to lirc_dev interface.

> 
> > - we allow registering several data interfaces/decoders that can be bound
> >   (manually or maybe automatically) to lirc devices. lirc devices may
> >   provide hints as to which interface(s) better suited for handling the
> >   data coming form particular receiver. Several interfaces may be bound
> >   to one device at a time.
> > - one of the interfaces is interface implementing current lirc_dev
> > - other interfaces may be in-kernel RC-5 decoder or other decoders.
> >   decoders will create instances of input devices
> 
> I don't see why having more than one interface, especially for devices with
> hardware decoders.
> 
> On IR remote receivers, internally, there's just one interface per hardware.
> 
> Considering the hardware decoding case, why to artificially create other
> interfaces that can't be used simultaneously? No current hardware
> decoders can do that (or, at least, no current implementation allows).
> We're foreseen some cases where we'll have that (like Patrick's dib0700 driver),
> but for now, it is not possible to offer more than one interface to userspace.
> Creating an arbitrary number of artificial interfaces just to pass a parameter
> to the driver (the protocol), really seems overkill to me.

We need to cater to the future cases as well. I don't want to redesign
it in 2 years. But for devices that have only hardware decoders I
suppose we can short-curcuit "interfaces" and have a library-like module
creating input devices directly.

> 
> In the case of the cheap devices with just raw interfaces, running in-kernel
> decoders, while it will work if you create one interface per protocol
> per IR receiver, this also seems overkill. Why to do that? It sounds that it will
> just create additional complexity at the kernelspace and at the userspace, since
> now userspace programs will need to open more than one device to receive the
> keycodes.

_Yes_!!! You open as many event devices as there are devices you are
interested in receiving data from. Multiplexing devices are bad, bad,
bad. Witness /dev/input/mouse and all the attempts at working around the
fact that if you have a special driver for one of your devices you
receive events from the same device through 2 interfaces and all kind of
"grab", "super-grab", "smart-grab" schemes are born.

> 
> > (for each remote/substream that they can recognize).
> 
> I'm assuming that, by remote, you're referring to a remote receiver (and not to 
> the remote itself), right?

If we could separate by remote transmitter that would be the best I
think, but I understand that it is rarely possible?

-- 
Dmitry

  reply	other threads:[~2009-12-02 17:10 UTC|newest]

Thread overview: 72+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-12-01 15:08 [RFC v2] Another approach to IR Jon Smirl
2009-12-01 15:47 ` Maxim Levitsky
2009-12-01 16:16   ` Jon Smirl
2009-12-01 17:03     ` Mauro Carvalho Chehab
2009-12-01 17:09       ` Devin Heitmueller
2009-12-01 17:29         ` Mauro Carvalho Chehab
2009-12-01 17:54           ` Dmitry Torokhov
2009-12-01 19:00             ` Mauro Carvalho Chehab
2009-12-01 19:27               ` Jon Smirl
2009-12-01 20:11               ` Dmitry Torokhov
2009-12-01 21:05                 ` Mauro Carvalho Chehab
2009-12-02  9:38                   ` Dmitry Torokhov
2009-12-02 12:44                     ` Mauro Carvalho Chehab
2009-12-02 17:10                       ` Dmitry Torokhov [this message]
2009-12-02 17:30                         ` Jon Smirl
2009-12-02 18:23                           ` Dmitry Torokhov
2009-12-02 18:57                             ` Jon Smirl
2009-12-02 20:54                               ` Mauro Carvalho Chehab
2009-12-02 19:22                           ` Jarod Wilson
2009-12-02 19:56                             ` Dmitry Torokhov
2009-12-02 20:04                               ` Jarod Wilson
2009-12-02 20:14                                 ` Dmitry Torokhov
2009-12-02 20:23                                   ` Mauro Carvalho Chehab
2009-12-02 20:53                                     ` Dmitry Torokhov
2009-12-02 21:13                                       ` Mauro Carvalho Chehab
2009-12-03 16:03                                         ` Ferenc Wagner
2009-12-03 16:33                                           ` Mauro Carvalho Chehab
2009-12-03 16:50                                             ` Jon Smirl
2009-12-03 17:19                                               ` Mauro Carvalho Chehab
2009-12-03 17:31                                             ` Dmitry Torokhov
2009-12-04 16:11                                               ` Ferenc Wagner
2009-12-02 20:42                                   ` Jarod Wilson
2009-12-02 20:48                                     ` Dmitry Torokhov
2009-12-02 20:57                                       ` Jarod Wilson
2009-12-02 21:12                                         ` Trent Piepho
2009-12-02 21:28                                           ` Jarod Wilson
2009-12-02 21:40                                             ` Mauro Carvalho Chehab
2009-12-03 18:06                                             ` Krzysztof Halasa
2009-12-03  1:19                                   ` Andy Walls
2009-12-03  2:27                                     ` hermann pitton
2009-12-03  0:20                                 ` Jon Smirl
2009-12-03  2:22                                   ` Mauro Carvalho Chehab
2009-12-03  5:08                                     ` Jon Smirl
2009-12-03 11:09                                       ` Mauro Carvalho Chehab
2009-12-03 18:18                                         ` Krzysztof Halasa
2009-12-03 20:54                                           ` Mauro Carvalho Chehab
2009-12-03  2:48                                   ` Trent Piepho
2009-12-03  4:13                                     ` Jarod Wilson
2009-12-03  5:18                                       ` Jon Smirl
2009-12-03 11:20                                         ` Mauro Carvalho Chehab
2009-12-03 19:48                                   ` alhaz
2009-12-02 19:33                         ` Mauro Carvalho Chehab
2009-12-02 19:50                           ` Jon Smirl
2009-12-02 19:58                             ` Jon Smirl
2009-12-02 20:47                             ` Mauro Carvalho Chehab
2009-12-02 19:55                           ` Jarod Wilson
2009-12-03  1:02                             ` Andy Walls
2009-12-03 10:00                               ` Mauro Carvalho Chehab
2009-12-03 12:02                                 ` Andy Walls
2009-12-03 11:09                               ` Mauro Carvalho Chehab
2009-12-02 20:01                           ` Dmitry Torokhov
2009-12-02 15:37                     ` Jon Smirl
2009-12-02 17:00                       ` Dmitry Torokhov
2009-12-02 11:26                   ` Gerd Hoffmann
2009-12-02 12:45                     ` Mauro Carvalho Chehab
2009-12-01 17:35         ` Patrick Boettcher
2009-12-01 17:41           ` Mauro Carvalho Chehab
2009-12-01 18:19       ` Jon Smirl
2009-12-01 17:37   ` Mauro Carvalho Chehab
  -- strict thread matches above, loose matches on Subject: below --
2009-12-03 19:47 Guus Sliepen
2009-12-03 21:53 ` Jarod Wilson
2009-12-05 11:23   ` Guus Sliepen

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=20091202171059.GC17839@core.coreip.homeip.net \
    --to=dmitry.torokhov@gmail.com \
    --cc=awalls@radix.net \
    --cc=dheitmueller@kernellabs.com \
    --cc=j@jannau.net \
    --cc=jarod@redhat.com \
    --cc=jarod@wilsonet.com \
    --cc=jonsmirl@gmail.com \
    --cc=khc@pm.waw.pl \
    --cc=linux-input@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    --cc=lirc-list@lists.sourceforge.net \
    --cc=lirc@bartelmus.de \
    --cc=maximlevitsky@gmail.com \
    --cc=mchehab@redhat.com \
    --cc=superm1@ubuntu.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).