Commit 9b1c0c0e authored by Anton Ivanov's avatar Anton Ivanov Committed by Richard Weinberger

um: tty: Fix handling of close in tty lines

Fix a logical error in tty reading. We get 0 and errno == EAGAIN
on the first attempt to read from a closed file descriptor.

Compared to that a true EAGAIN is EAGAIN and -1.

If we check errno for EAGAIN first, before checking the return
value we miss the fact that the descriptor is closed.

This bug is as old as the driver. It was not showing up with
the original POLL based IRQ controller, because it was
producing multiple events. Switching to EPOLL unmasked it.

Fixes: ff6a1798 ("Epoll based IRQ controller")
Signed-off-by: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
parent e3a01cbe
...@@ -26,10 +26,10 @@ int generic_read(int fd, char *c_out, void *unused) ...@@ -26,10 +26,10 @@ int generic_read(int fd, char *c_out, void *unused)
n = read(fd, c_out, sizeof(*c_out)); n = read(fd, c_out, sizeof(*c_out));
if (n > 0) if (n > 0)
return n; return n;
else if (errno == EAGAIN)
return 0;
else if (n == 0) else if (n == 0)
return -EIO; return -EIO;
else if (errno == EAGAIN)
return 0;
return -errno; return -errno;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment