Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 338369
b: refs/heads/master
c: 3c7e9eb
h: refs/heads/master
i:
  338367: c3036f4
v: v3
  • Loading branch information
Alexander Shiyan authored and Greg Kroah-Hartman committed Oct 24, 2012
1 parent 32a5768 commit 8faca3e
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 16 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: 117d5d424a1ee7aedaf6ad8b0ba6eff163c57815
refs/heads/master: 3c7e9eb1603d21659a38b92f5b764d41d88fa652
32 changes: 17 additions & 15 deletions trunk/drivers/tty/serial/clps711x.c
Original file line number Diff line number Diff line change
Expand Up @@ -56,29 +56,32 @@

#define UART_ANY_ERR (UARTDR_FRMERR | UARTDR_PARERR | UARTDR_OVERR)

#define tx_enabled(port) ((port)->unused[0])

struct clps711x_port {
struct uart_driver uart;
struct uart_port port[UART_CLPS711X_NR];
int tx_enabled[UART_CLPS711X_NR];
#ifdef CONFIG_SERIAL_CLPS711X_CONSOLE
struct console console;
#endif
};

static void clps711xuart_stop_tx(struct uart_port *port)
{
if (tx_enabled(port)) {
struct clps711x_port *s = dev_get_drvdata(port->dev);

if (s->tx_enabled[port->line]) {
disable_irq(TX_IRQ(port));
tx_enabled(port) = 0;
s->tx_enabled[port->line] = 0;
}
}

static void clps711xuart_start_tx(struct uart_port *port)
{
if (!tx_enabled(port)) {
struct clps711x_port *s = dev_get_drvdata(port->dev);

if (!s->tx_enabled[port->line]) {
enable_irq(TX_IRQ(port));
tx_enabled(port) = 1;
s->tx_enabled[port->line] = 1;
}
}

Expand Down Expand Up @@ -148,6 +151,7 @@ static irqreturn_t clps711xuart_int_rx(int irq, void *dev_id)
static irqreturn_t clps711xuart_int_tx(int irq, void *dev_id)
{
struct uart_port *port = dev_id;
struct clps711x_port *s = dev_get_drvdata(port->dev);
struct circ_buf *xmit = &port->state->xmit;
int count;

Expand All @@ -158,8 +162,11 @@ static irqreturn_t clps711xuart_int_tx(int irq, void *dev_id)
return IRQ_HANDLED;
}

if (uart_circ_empty(xmit) || uart_tx_stopped(port))
goto disable_tx_irq;
if (uart_circ_empty(xmit) || uart_tx_stopped(port)) {
disable_irq_nosync(TX_IRQ(port));
s->tx_enabled[port->line] = 0;
return IRQ_HANDLED;
}

count = port->fifosize >> 1;
do {
Expand All @@ -173,12 +180,6 @@ static irqreturn_t clps711xuart_int_tx(int irq, void *dev_id)
if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
uart_write_wakeup(port);

if (uart_circ_empty(xmit)) {
disable_tx_irq:
disable_irq_nosync(TX_IRQ(port));
tx_enabled(port) = 0;
}

return IRQ_HANDLED;
}

Expand Down Expand Up @@ -230,10 +231,11 @@ static void clps711xuart_break_ctl(struct uart_port *port, int break_state)

static int clps711xuart_startup(struct uart_port *port)
{
struct clps711x_port *s = dev_get_drvdata(port->dev);
unsigned int syscon;
int retval;

tx_enabled(port) = 1;
s->tx_enabled[port->line] = 1;

/*
* Allocate the IRQs
Expand Down

0 comments on commit 8faca3e

Please sign in to comment.