Message ID | 56A0028C.9080308@gmail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
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.
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.
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,
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 --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 */
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(-)