Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 104699
b: refs/heads/master
c: faa7612
h: refs/heads/master
i:
  104697: 76e98a5
  104695: de2f8ae
v: v3
  • Loading branch information
Alan Cox authored and Linus Torvalds committed Jul 22, 2008
1 parent 7c939b0 commit adcdc4a
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 29 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 4a56122297ac7a4a3bf09fb66c0a365a13abe707
refs/heads/master: faa7612c09ae4519ad4659c8417aaaba81183833
2 changes: 1 addition & 1 deletion trunk/drivers/char/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -288,7 +288,7 @@ config RISCOM8

config SPECIALIX
tristate "Specialix IO8+ card support"
depends on SERIAL_NONSTANDARD && BROKEN
depends on SERIAL_NONSTANDARD
help
This is a driver for the Specialix IO8+ multiport card (both the
ISA and the PCI version) which gives you many serial ports. You
Expand Down
38 changes: 11 additions & 27 deletions trunk/drivers/char/specialix.c
Original file line number Diff line number Diff line change
Expand Up @@ -1818,13 +1818,15 @@ static int sx_tiocmset(struct tty_struct *tty, struct file *file,
}


static void sx_send_break(struct specialix_port *port,
unsigned long length)
static int sx_send_break(struct tty_struct *tty, int length)
{
struct specialix_port *port = (struct specialix_port *)tty->driver_data;
struct specialix_board *bp = port_Board(port);
unsigned long flags;

func_enter();
if (length == 0 || length == -1)
return -EOPNOTSUPP;

spin_lock_irqsave(&port->lock, flags);
port->break_length = SPECIALIX_TPS / HZ * length;
Expand All @@ -1843,6 +1845,7 @@ static void sx_send_break(struct specialix_port *port,
sx_wait_CCR(bp);

func_exit();
return 0;
}


Expand Down Expand Up @@ -1929,7 +1932,6 @@ static int sx_ioctl(struct tty_struct *tty, struct file *filp,
unsigned int cmd, unsigned long arg)
{
struct specialix_port *port = (struct specialix_port *)tty->driver_data;
int retval;
void __user *argp = (void __user *)arg;

func_enter();
Expand All @@ -1940,34 +1942,14 @@ static int sx_ioctl(struct tty_struct *tty, struct file *filp,
}

switch (cmd) {
case TCSBRK: /* SVID version: non-zero arg --> no break */
retval = tty_check_change(tty);
if (retval) {
func_exit();
return retval;
}
tty_wait_until_sent(tty, 0);
if (!arg)
sx_send_break(port, HZ/4); /* 1/4 second */
return 0;
case TCSBRKP: /* support for POSIX tcsendbreak() */
retval = tty_check_change(tty);
if (retval) {
func_exit();
return retval;
}
tty_wait_until_sent(tty, 0);
sx_send_break(port, arg ? arg*(HZ/10) : HZ/4);
func_exit();
return 0;
case TIOCGSERIAL:
func_exit();
func_exit();
return sx_get_serial_info(port, argp);
case TIOCSSERIAL:
func_exit();
func_exit();
return sx_set_serial_info(port, argp);
default:
func_exit();
func_exit();
return -ENOIOCTLCMD;
}
func_exit();
Expand Down Expand Up @@ -2190,6 +2172,7 @@ static const struct tty_operations sx_ops = {
.hangup = sx_hangup,
.tiocmget = sx_tiocmget,
.tiocmset = sx_tiocmset,
.break_ctl = sx_send_break,
};

static int sx_init_drivers(void)
Expand All @@ -2216,7 +2199,8 @@ static int sx_init_drivers(void)
B9600 | CS8 | CREAD | HUPCL | CLOCAL;
specialix_driver->init_termios.c_ispeed = 9600;
specialix_driver->init_termios.c_ospeed = 9600;
specialix_driver->flags = TTY_DRIVER_REAL_RAW;
specialix_driver->flags = TTY_DRIVER_REAL_RAW |
TTY_DRIVER_HARDWARE_BREAK;
tty_set_operations(specialix_driver, &sx_ops);

error = tty_register_driver(specialix_driver);
Expand Down

0 comments on commit adcdc4a

Please sign in to comment.