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