2020-02-24 18:22:13

by Eric Biggers

[permalink] [raw]
Subject: [PATCH v2 2/2] tty: fix compat TIOCGSERIAL checking wrong function ptr

From: Eric Biggers <[email protected]>

Commit 77654350306a ("take compat TIOC[SG]SERIAL treatment into
tty_compat_ioctl()") changed the compat version of TIOCGSERIAL to start
checking for the presence of the ->set_serial function pointer rather
than ->get_serial. This appears to be a copy-and-paste error, since
->get_serial is the function pointer that is called as well as the
pointer that is checked by the non-compat version of TIOCGSERIAL.

Fix this by checking the correct function pointer.

Fixes: 77654350306a ("take compat TIOC[SG]SERIAL treatment into tty_compat_ioctl()")
Cc: <[email protected]> # v4.20+
Signed-off-by: Eric Biggers <[email protected]>
---
drivers/tty/tty_io.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/tty/tty_io.c b/drivers/tty/tty_io.c
index db4a13bc855ed6..5a6f36b391d95d 100644
--- a/drivers/tty/tty_io.c
+++ b/drivers/tty/tty_io.c
@@ -2734,7 +2734,7 @@ static int compat_tty_tiocgserial(struct tty_struct *tty,
memset(&v, 0, sizeof(v));
memset(&v32, 0, sizeof(v32));

- if (!tty->ops->set_serial)
+ if (!tty->ops->get_serial)
return -ENOTTY;
err = tty->ops->get_serial(tty, &v);
if (!err) {
--
2.25.0.265.gbab2e86ba0-goog


2020-02-25 07:32:27

by Jiri Slaby

[permalink] [raw]
Subject: Re: [PATCH v2 2/2] tty: fix compat TIOCGSERIAL checking wrong function ptr

On 24. 02. 20, 19:20, Eric Biggers wrote:
> From: Eric Biggers <[email protected]>
>
> Commit 77654350306a ("take compat TIOC[SG]SERIAL treatment into
> tty_compat_ioctl()") changed the compat version of TIOCGSERIAL to start
> checking for the presence of the ->set_serial function pointer rather
> than ->get_serial. This appears to be a copy-and-paste error, since
> ->get_serial is the function pointer that is called as well as the
> pointer that is checked by the non-compat version of TIOCGSERIAL.
>
> Fix this by checking the correct function pointer.
>
> Fixes: 77654350306a ("take compat TIOC[SG]SERIAL treatment into tty_compat_ioctl()")
> Cc: <[email protected]> # v4.20+
> Signed-off-by: Eric Biggers <[email protected]>

Acked-by: Jiri Slaby <[email protected]>

> ---
> drivers/tty/tty_io.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/tty/tty_io.c b/drivers/tty/tty_io.c
> index db4a13bc855ed6..5a6f36b391d95d 100644
> --- a/drivers/tty/tty_io.c
> +++ b/drivers/tty/tty_io.c
> @@ -2734,7 +2734,7 @@ static int compat_tty_tiocgserial(struct tty_struct *tty,
> memset(&v, 0, sizeof(v));
> memset(&v32, 0, sizeof(v32));
>
> - if (!tty->ops->set_serial)
> + if (!tty->ops->get_serial)
> return -ENOTTY;
> err = tty->ops->get_serial(tty, &v);
> if (!err) {
>


--
js
suse labs