Re: [PATCH] HID: fix up .raw_event() documentation

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

 



On Mon, Nov 12, 2018 at 12:19 PM Linus Walleij <linus.walleij@xxxxxxxxxx> wrote:
>
> On Sun, Nov 4, 2018 at 11:34 AM Linus Walleij <linus.walleij@xxxxxxxxxx> wrote:
>
> > The documentation for the .raw_event() callback says that if the
> > driver return 1, there will be no further processing of the event,
> > but this is not true, the actual code in hid-core.c looks like this:
> >
> >   if (hdrv && hdrv->raw_event && hid_match_report(hid, report)) {
> >            ret = hdrv->raw_event(hid, report, data, size);
> >            if (ret < 0)
> >                    goto unlock;
> >    }
> >
> >    ret = hid_report_raw_event(hid, type, data, size, interrupt);
> >
> > The only return value that has any effect on the processing is
> > a negative error.
>
> I noticed that there is a whole slew of drivers in the kernel
> that actually return 1 from their .raw_event handlers.
>
> drivers/hid/hid-alps.c
> drivers/hid/hid-asus.c
> drivers/hid/hid-cp2112.c
> drivers/hid/hid-elan.c
> drivers/hid/hid-elo.c
> (...)
>
> I suspect what they want is "no further event processing"
> so it's a pretty weird legacy bug or something.
>
> Should we patch them all one by one to return something like
> -ENODATA or should we patch the library to actually
> respect the return value 1 and skip further event processing
> if that happens?
>

I finally found the time to find the issue of this (I wanted to do it
before your patch get applied, but -ETIME):

So, before b1a1442a23776756b ("HID: core: fix reporting of raw events"
- 2013-06-03), if the returned value of .raw_event() was positive, the
processing of the event was interrupted and .event() was not called
after.
However, there was issues with that as mentioned in b1a1442a. So since
then, the HID processing goes on even if .raw_event() says "please
stop processing".

Given that it's been 5 years, and no one complained about it, I think
we should keep the 'new' behavior of hid-core.c calling .raw_event().

As for fixing the drivers in .raw_event, I would not blindly change
them to -ENODATA as the current code path is equivalent to returning
0. For some of them I can definitively have a good opinion on what to
return (0 or -ENODATA), but for some others, I don't have the hardware
so I can't really take a position.

Cheers,
Benjamin



[Index of Archives]     [Linux Media Devel]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Linux Wireless Networking]     [Linux Omap]

  Powered by Linux