Re: [ibm-acpi-devel] ACPI: thinkpad-acpi: add input device support to hotkey subdriver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, 15 Jul 2007, Matthew Garrett wrote:
> On Sun, Jul 15, 2007 at 06:54:53PM -0300, Henrique de Moraes Holschuh wrote:
> > On Sun, 15 Jul 2007, Matthew Garrett wrote:
> > > Hal is the only piece of userspace that knows how to speak to more than 
> > > one type of backlight in any useful way, which makes it the de-facto 
> > > reference for how userspace interprets these keys.
> > 
> > Since when does system-specific programs not count?
> 
> If they're Thinkpad-specific, they're already doing the right thing. If 
> they're specific to another model, they're not running on a Thinkpad.

True. I missed that angle.

> > > The fact that keys share event codes doesn't mean that these keycodes 
> > > are going to have identical semantics on all hardware. One solution to 
> > > that would be to avoid ever sending these keycodes, but that would make 
> > > having them defined in the first place a bit silly. Since they /are/ 
> > > there, it makes sense to use them.
> > 
> > I see a keycode defined in the USB HID spec for use in stuff that only knows
> > active handling -- passive doesn't even make any sense for them -- and its
> > reflect on the kernel input layer.
> > 
> > There _are_ a few platforms where *one* of the built-in devices need a
> > different handling, and that's just because the firmware won't cooperate.
> > But if I plug a USB keyboard on a thinkpad, for example, I need the proper
> > (active) handling of the event.
> 
> That's fine. You know that the event came from an external keyboard, so 
> you know that it has to be handled actively.
> 
> > I definately think "avoid ever sending these keycodes" in this instance is
> > the right way to go, until we can actually issue a "this is a passive key
> > press" event.
> 
> As I said, the existing userspace implementation disagrees. I'd prefer 
> to avoid breaking that.

I have not nearly as much patience as you do with broken designs.  The input
layer interface was *not* made to convey the idea of passive keys.  *This*
was not broken (it just wasn't generic enough, and the fact that you don't
have an extensible "flags" field that you could use to extend it *is* the
real design shortcoming).

However, abusing that interface to send passive events *is* broken.
Especially because the other side has to know by itself what is active and
what is passive, and this changes from system model to model, and maybe even
from bios version to bios version.

IMHO, it should NEVER have been done like that in the first place.  You
start walking such a road, you will have to work thrice to fix it.  The
correct thing to do is to fix the interface.  It can be done in a backwards
compatible way.  It won't be anywhere as pretty as it could have been if
input layer events were friendly to being extended, but it can be done.

Please correct me if I am mistaken, but AFAIK, nothing I do in thinkpad-acpi
that doesn't start generating *new* passive-masquerated-as-active events
around will break any old system, as these are ALREADY working using tpb or
somesuch. 

Since thinkpad-acpi not generating such broken events by default that
doesn't stop (or even make it more difficult) for new HAL to get the driver
to produce them if it wants to, and it also doesn't stop old HAL from
working just fine (using tpb, etc), it looks to me like the best path.

-- 
  "One disk to rule them all, One disk to find them. One disk to bring
  them all and in the darkness grind them. In the Land of Redmond
  where the shadows lie." -- The Silicon Valley Tarot
  Henrique Holschuh
-
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux