diff mbox

usbhid: replace inappropriate ENOSYS with ENODEV

Message ID 56A0028C.9080308@gmail.com (mailing list archive)
State New, archived
Headers show

Commit Message

Heiner Kallweit Jan. 20, 2016, 9:56 p.m. UTC
Primary meaning of ENOSYS is "system call not available" but it's also used
with meaning "function not implemented". Both are not applicable here.

Typically this error occurs when the device was unplugged.
usbhid_raw_request returns -ENODEV in such a case what seems to be more
reasonable. Therefore use -ENODEV also here.

Primary motivation for this change is a change in the LED subsystem to
ignore -ENODEV if the device was most likely unplugged.

Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
---
 drivers/hid/usbhid/hid-core.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Jiri Kosina Jan. 21, 2016, 2:18 p.m. UTC | #1
On Wed, 20 Jan 2016, Heiner Kallweit wrote:

> Primary meaning of ENOSYS is "system call not available" but it's also used
> with meaning "function not implemented". Both are not applicable here.
> 
> Typically this error occurs when the device was unplugged.
> usbhid_raw_request returns -ENODEV in such a case what seems to be more
> reasonable. Therefore use -ENODEV also here.
> 
> Primary motivation for this change is a change in the LED subsystem to
> ignore -ENODEV if the device was most likely unplugged.

I believe POSIX defines ENOSYS as "Function not implemented". In this 
case, we are signalling there is no "URB OUT" function.

I don't have strong preference either way, but ENODEV doesn't seem to be 
particularly good fit for this purpose either.
Dmitry Torokhov Jan. 21, 2016, 5:42 p.m. UTC | #2
On Thu, Jan 21, 2016 at 6:18 AM, Jiri Kosina <jikos@kernel.org> wrote:
> On Wed, 20 Jan 2016, Heiner Kallweit wrote:
>
>> Primary meaning of ENOSYS is "system call not available" but it's also used
>> with meaning "function not implemented". Both are not applicable here.
>>
>> Typically this error occurs when the device was unplugged.
>> usbhid_raw_request returns -ENODEV in such a case what seems to be more
>> reasonable. Therefore use -ENODEV also here.
>>
>> Primary motivation for this change is a change in the LED subsystem to
>> ignore -ENODEV if the device was most likely unplugged.
>
> I believe POSIX defines ENOSYS as "Function not implemented". In this
> case, we are signalling there is no "URB OUT" function.
>

Well, it looks like ENOSYS is really reserved for unimplemented system calls:

commit 91c9afaf97ee554d2cd3042a5ad01ad21c99e8c4
Author: Andy Lutomirski <luto@amacapital.net>
Date:   Thu Apr 16 12:44:44 2015 -0700

    checkpatch.pl: new instances of ENOSYS are errors

    ENOSYS means that a nonexistent system call was called.  We have a
    bad habit of using it for things like invalid operations on
    otherwise valid syscalls.  We should avoid this in new code.

    Pervasive incorrect usage of ENOSYS came up at the kernel summit ABI
    review discussion.  Let's see if checkpatch can help.

    I'll submit a separate patch for include/uapi/asm-generic/errno.h.

    Signed-off-by: Andy Lutomirski <luto@amacapital.net>
    Cc: Pavel Machek <pavel@ucw.cz>
    Cc: Michael Kerrisk <mtk.manpages@gmail.com>
    Cc: Joe Perches <joe@perches.com>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>

> I don't have strong preference either way, but ENODEV doesn't seem to be
> particularly good fit for this purpose either.

If there is no urbout during normal operation then -EINVAL I think is
applicable - upper layers are trying to send request to the device
that can not be executed, i.e. invalid request. If it happens during
removal then it is either a) there is a race or b) we are not actually
racing with whomever is resetting urbout to NULL but we need to check
if device is actually gone and return -ENXIO in this case.

Thanks.
Jiri Kosina Jan. 22, 2016, 11:30 p.m. UTC | #3
On Thu, 21 Jan 2016, Dmitry Torokhov wrote:

> On Thu, Jan 21, 2016 at 6:18 AM, Jiri Kosina <jikos@kernel.org> wrote:
> > On Wed, 20 Jan 2016, Heiner Kallweit wrote:
> >
> >> Primary meaning of ENOSYS is "system call not available" but it's also used
> >> with meaning "function not implemented". Both are not applicable here.
> >>
> >> Typically this error occurs when the device was unplugged.
> >> usbhid_raw_request returns -ENODEV in such a case what seems to be more
> >> reasonable. Therefore use -ENODEV also here.
> >>
> >> Primary motivation for this change is a change in the LED subsystem to
> >> ignore -ENODEV if the device was most likely unplugged.
> >
> > I believe POSIX defines ENOSYS as "Function not implemented". In this
> > case, we are signalling there is no "URB OUT" function.
> >
> 
> Well, it looks like ENOSYS is really reserved for unimplemented system calls:
> 
> commit 91c9afaf97ee554d2cd3042a5ad01ad21c99e8c4
> Author: Andy Lutomirski <luto@amacapital.net>
> Date:   Thu Apr 16 12:44:44 2015 -0700
> 
>     checkpatch.pl: new instances of ENOSYS are errors
> 
>     ENOSYS means that a nonexistent system call was called.  We have a
>     bad habit of using it for things like invalid operations on
>     otherwise valid syscalls.  We should avoid this in new code.
> 
>     Pervasive incorrect usage of ENOSYS came up at the kernel summit ABI
>     review discussion.  Let's see if checkpatch can help.
> 
>     I'll submit a separate patch for include/uapi/asm-generic/errno.h.

Let's add Andy to CC.

Andy, my understanding of POSIX is that ENOSYS is "function not 
implemented", meaning whatever internal function of kernel, not strictly 
just syscall entrypoint.

Where does your explanation of ENOSYS as "syscall not implemented" come 
from, please?

Thanks,
Andy Lutomirski Jan. 22, 2016, 11:35 p.m. UTC | #4
On Fri, Jan 22, 2016 at 3:30 PM, Jiri Kosina <jikos@kernel.org> wrote:
> On Thu, 21 Jan 2016, Dmitry Torokhov wrote:
>
>> On Thu, Jan 21, 2016 at 6:18 AM, Jiri Kosina <jikos@kernel.org> wrote:
>> > On Wed, 20 Jan 2016, Heiner Kallweit wrote:
>> >
>> >> Primary meaning of ENOSYS is "system call not available" but it's also used
>> >> with meaning "function not implemented". Both are not applicable here.
>> >>
>> >> Typically this error occurs when the device was unplugged.
>> >> usbhid_raw_request returns -ENODEV in such a case what seems to be more
>> >> reasonable. Therefore use -ENODEV also here.
>> >>
>> >> Primary motivation for this change is a change in the LED subsystem to
>> >> ignore -ENODEV if the device was most likely unplugged.
>> >
>> > I believe POSIX defines ENOSYS as "Function not implemented". In this
>> > case, we are signalling there is no "URB OUT" function.
>> >
>>
>> Well, it looks like ENOSYS is really reserved for unimplemented system calls:
>>
>> commit 91c9afaf97ee554d2cd3042a5ad01ad21c99e8c4
>> Author: Andy Lutomirski <luto@amacapital.net>
>> Date:   Thu Apr 16 12:44:44 2015 -0700
>>
>>     checkpatch.pl: new instances of ENOSYS are errors
>>
>>     ENOSYS means that a nonexistent system call was called.  We have a
>>     bad habit of using it for things like invalid operations on
>>     otherwise valid syscalls.  We should avoid this in new code.
>>
>>     Pervasive incorrect usage of ENOSYS came up at the kernel summit ABI
>>     review discussion.  Let's see if checkpatch can help.
>>
>>     I'll submit a separate patch for include/uapi/asm-generic/errno.h.
>
> Let's add Andy to CC.
>
> Andy, my understanding of POSIX is that ENOSYS is "function not
> implemented", meaning whatever internal function of kernel, not strictly
> just syscall entrypoint.
>
> Where does your explanation of ENOSYS as "syscall not implemented" come
> from, please?
>

Userspace likes to be able to tell whether a given syscall is
implemented by the running kernel.  Unimplemented syscalls return
-ENOSYS, and having syscalls that *are* implemented return -ENOSYS can
confuse things.

--Andy
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/hid/usbhid/hid-core.c b/drivers/hid/usbhid/hid-core.c
index ad71160..64a8d9c 100644
--- a/drivers/hid/usbhid/hid-core.c
+++ b/drivers/hid/usbhid/hid-core.c
@@ -928,7 +928,7 @@  static int usbhid_output_report(struct hid_device *hid, __u8 *buf, size_t count)
 	int actual_length, skipped_report_id = 0, ret;
 
 	if (!usbhid->urbout)
-		return -ENOSYS;
+		return -ENODEV;
 
 	if (buf[0] == 0x0) {
 		/* Don't send the Report ID */