aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty/serial/sh-sci.h
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2011-06-14 04:38:19 -0400
committerPaul Mundt <lethal@linux-sh.org>2011-06-14 04:38:19 -0400
commit72b294cf76dcd6d37891387049ddbe3c25043cb8 (patch)
treee19eaab5e23bba04b1f0f9ef244764ae73656764 /drivers/tty/serial/sh-sci.h
parent61a6976bf19a6cf5dfcf37c3536665b316f22d49 (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.h20
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)