diff options
author | Tilman Schmidt <tilman@imap.cc> | 2009-08-06 23:33:33 -0400 |
---|---|---|
committer | Live-CD User <linux@linux.site> | 2009-09-19 16:13:09 -0400 |
commit | a4304f2d5a3823deea894026ec95e43b33912357 (patch) | |
tree | 4b673ae8e7686fe973e1c3a6264389f6712ee222 /drivers/isdn/gigaset | |
parent | 78f28b7c555359c67c2a0d23f7436e915329421e (diff) |
tty: gigaset: really fix chars_in_buffer
The tty_operation chars_in_buffer() is not allowed to return a negative
value to signal an error. Corrects the problem flagged by commit
23198fda7182969b619613a555f8645fdc3dc334, "tty: fix chars_in_buffers".
Signed-off-by: Tilman Schmidt <tilman@imap.cc>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: stable <stable@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/isdn/gigaset')
-rw-r--r-- | drivers/isdn/gigaset/interface.c | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/drivers/isdn/gigaset/interface.c b/drivers/isdn/gigaset/interface.c index 8ff7e35c7069..f33ac27de643 100644 --- a/drivers/isdn/gigaset/interface.c +++ b/drivers/isdn/gigaset/interface.c | |||
@@ -408,33 +408,28 @@ static int if_write_room(struct tty_struct *tty) | |||
408 | return retval; | 408 | return retval; |
409 | } | 409 | } |
410 | 410 | ||
411 | /* FIXME: This function does not have error returns */ | ||
412 | |||
413 | static int if_chars_in_buffer(struct tty_struct *tty) | 411 | static int if_chars_in_buffer(struct tty_struct *tty) |
414 | { | 412 | { |
415 | struct cardstate *cs; | 413 | struct cardstate *cs; |
416 | int retval = -ENODEV; | 414 | int retval = 0; |
417 | 415 | ||
418 | cs = (struct cardstate *) tty->driver_data; | 416 | cs = (struct cardstate *) tty->driver_data; |
419 | if (!cs) { | 417 | if (!cs) { |
420 | pr_err("%s: no cardstate\n", __func__); | 418 | pr_err("%s: no cardstate\n", __func__); |
421 | return -ENODEV; | 419 | return 0; |
422 | } | 420 | } |
423 | 421 | ||
424 | gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); | 422 | gig_dbg(DEBUG_IF, "%u: %s()", cs->minor_index, __func__); |
425 | 423 | ||
426 | if (mutex_lock_interruptible(&cs->mutex)) | 424 | mutex_lock(&cs->mutex); |
427 | return -ERESTARTSYS; // FIXME -EINTR? | ||
428 | 425 | ||
429 | if (!cs->connected) { | 426 | if (!cs->connected) |
430 | gig_dbg(DEBUG_IF, "not connected"); | 427 | gig_dbg(DEBUG_IF, "not connected"); |
431 | retval = -ENODEV; | 428 | else if (!cs->open_count) |
432 | } else if (!cs->open_count) | ||
433 | dev_warn(cs->dev, "%s: device not opened\n", __func__); | 429 | dev_warn(cs->dev, "%s: device not opened\n", __func__); |
434 | else if (cs->mstate != MS_LOCKED) { | 430 | else if (cs->mstate != MS_LOCKED) |
435 | dev_warn(cs->dev, "can't write to unlocked device\n"); | 431 | dev_warn(cs->dev, "can't write to unlocked device\n"); |
436 | retval = -EBUSY; | 432 | else |
437 | } else | ||
438 | retval = cs->ops->chars_in_buffer(cs); | 433 | retval = cs->ops->chars_in_buffer(cs); |
439 | 434 | ||
440 | mutex_unlock(&cs->mutex); | 435 | mutex_unlock(&cs->mutex); |