Commit 4aaa9774 authored by Johan Hovold's avatar Johan Hovold Committed by Luis Henriques

USB: cdc-acm: fix TIOCMIWAIT

BugLink: http://bugs.launchpad.net/bugs/1642968

commit 18266403 upstream.

The TIOCMIWAIT implementation would return -EINVAL if any of the three
supported signals were included in the mask.

Instead of returning an error in case TIOCM_CTS is included, simply
drop the mask check completely, which is in accordance with how other
drivers implement this ioctl.

Fixes: 5a6a62bd ("cdc-acm: add TIOCMIWAIT")
Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
Acked-by: default avatarOliver Neukum <oneukum@suse.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent e7fdffb6
...@@ -877,8 +877,6 @@ static int wait_serial_change(struct acm *acm, unsigned long arg) ...@@ -877,8 +877,6 @@ static int wait_serial_change(struct acm *acm, unsigned long arg)
DECLARE_WAITQUEUE(wait, current); DECLARE_WAITQUEUE(wait, current);
struct async_icount old, new; struct async_icount old, new;
if (arg & (TIOCM_DSR | TIOCM_RI | TIOCM_CD ))
return -EINVAL;
do { do {
spin_lock_irq(&acm->read_lock); spin_lock_irq(&acm->read_lock);
old = acm->oldcount; old = acm->oldcount;
......
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