diff options
author | Paul Mundt <lethal@linux-sh.org> | 2011-06-14 04:38:19 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2011-06-14 04:38:19 -0400 |
commit | 72b294cf76dcd6d37891387049ddbe3c25043cb8 (patch) | |
tree | e19eaab5e23bba04b1f0f9ef244764ae73656764 /drivers/tty/serial/sh-sci.h | |
parent | 61a6976bf19a6cf5dfcf37c3536665b316f22d49 (diff) |
serial: sh-sci: FIFO sizing helper consolidation.
This consolidates all of the TX/RX fill/room nonsense in to a single set
of fairly heavyweight definitions. The implementation goes in descending
order of complexity, testing the register map for capabilities until we
run out of options and do it the legacy SCI way. Masks are derived
directly from the per-port FIFO size, meaning that platforms with FIFO
sizes not matching the standard port types will still need to manually
fix them up.
This also fixes up a number of issues such as tx_empty being completely
bogus for SCI and IrDA ports, some ports using masks smaller or greater
than their FIFO size, and so forth.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'drivers/tty/serial/sh-sci.h')
-rw-r--r-- | drivers/tty/serial/sh-sci.h | 20 |
1 files changed, 0 insertions, 20 deletions
diff --git a/drivers/tty/serial/sh-sci.h b/drivers/tty/serial/sh-sci.h index 26de640a9d01..e9bed038aa1f 100644 --- a/drivers/tty/serial/sh-sci.h +++ b/drivers/tty/serial/sh-sci.h | |||
@@ -2,26 +2,6 @@ | |||
2 | #include <linux/io.h> | 2 | #include <linux/io.h> |
3 | #include <linux/gpio.h> | 3 | #include <linux/gpio.h> |
4 | 4 | ||
5 | #if defined(CONFIG_CPU_SUBTYPE_SH7705) || \ | ||
6 | defined(CONFIG_CPU_SUBTYPE_SH7720) || \ | ||
7 | defined(CONFIG_CPU_SUBTYPE_SH7721) || \ | ||
8 | defined(CONFIG_ARCH_SH73A0) || \ | ||
9 | defined(CONFIG_ARCH_SH7367) || \ | ||
10 | defined(CONFIG_ARCH_SH7377) || \ | ||
11 | defined(CONFIG_ARCH_SH7372) | ||
12 | # define SCIF_RFDC_MASK 0x007f | ||
13 | # define SCIF_TXROOM_MAX 64 | ||
14 | #elif defined(CONFIG_CPU_SUBTYPE_SH7763) | ||
15 | # define SCIF_RFDC_MASK 0x007f | ||
16 | # define SCIF_TXROOM_MAX 64 | ||
17 | /* SH7763 SCIF2 support */ | ||
18 | # define SCIF2_RFDC_MASK 0x001f | ||
19 | # define SCIF2_TXROOM_MAX 16 | ||
20 | #else | ||
21 | # define SCIF_RFDC_MASK 0x001f | ||
22 | # define SCIF_TXROOM_MAX 16 | ||
23 | #endif | ||
24 | |||
25 | #define SCxSR_TEND(port) (((port)->type == PORT_SCI) ? SCI_TEND : SCIF_TEND) | 5 | #define SCxSR_TEND(port) (((port)->type == PORT_SCI) ? SCI_TEND : SCIF_TEND) |
26 | #define SCxSR_RDxF(port) (((port)->type == PORT_SCI) ? SCI_RDRF : SCIF_RDF) | 6 | #define SCxSR_RDxF(port) (((port)->type == PORT_SCI) ? SCI_RDRF : SCIF_RDF) |
27 | #define SCxSR_TDxE(port) (((port)->type == PORT_SCI) ? SCI_TDRE : SCIF_TDFE) | 7 | #define SCxSR_TDxE(port) (((port)->type == PORT_SCI) ? SCI_TDRE : SCIF_TDFE) |