2005-04-17 02:20:36 +04:00
|
|
|
#include <linux/serial_core.h>
|
2009-11-25 10:23:35 +03:00
|
|
|
#include <linux/io.h>
|
2008-12-25 12:17:34 +03:00
|
|
|
#include <linux/gpio.h>
|
2007-08-20 03:59:33 +04:00
|
|
|
|
2008-10-02 14:47:12 +04:00
|
|
|
#define SCxSR_TEND(port) (((port)->type == PORT_SCI) ? SCI_TEND : SCIF_TEND)
|
|
|
|
#define SCxSR_RDxF(port) (((port)->type == PORT_SCI) ? SCI_RDRF : SCIF_RDF)
|
|
|
|
#define SCxSR_TDxE(port) (((port)->type == PORT_SCI) ? SCI_TDRE : SCIF_TDFE)
|
|
|
|
#define SCxSR_FER(port) (((port)->type == PORT_SCI) ? SCI_FER : SCIF_FER)
|
|
|
|
#define SCxSR_PER(port) (((port)->type == PORT_SCI) ? SCI_PER : SCIF_PER)
|
|
|
|
#define SCxSR_BRK(port) (((port)->type == PORT_SCI) ? 0x00 : SCIF_BRK)
|
2011-06-08 13:19:37 +04:00
|
|
|
|
|
|
|
#define SCxSR_ERRORS(port) (to_sci_port(port)->cfg->error_mask)
|
2008-10-02 14:47:12 +04:00
|
|
|
|
2007-08-20 03:59:33 +04:00
|
|
|
#if defined(CONFIG_CPU_SUBTYPE_SH7705) || \
|
2007-12-26 05:45:06 +03:00
|
|
|
defined(CONFIG_CPU_SUBTYPE_SH7720) || \
|
2010-02-05 14:15:33 +03:00
|
|
|
defined(CONFIG_CPU_SUBTYPE_SH7721) || \
|
2010-11-17 13:59:31 +03:00
|
|
|
defined(CONFIG_ARCH_SH73A0) || \
|
2010-03-16 14:21:07 +03:00
|
|
|
defined(CONFIG_ARCH_SH7367) || \
|
|
|
|
defined(CONFIG_ARCH_SH7377) || \
|
2011-11-11 06:45:52 +04:00
|
|
|
defined(CONFIG_ARCH_SH7372) || \
|
|
|
|
defined(CONFIG_ARCH_R8A7740)
|
|
|
|
|
2012-03-30 14:50:15 +04:00
|
|
|
# define SCxSR_RDxF_CLEAR(port) (serial_port_in(port, SCxSR) & 0xfffc)
|
|
|
|
# define SCxSR_ERROR_CLEAR(port) (serial_port_in(port, SCxSR) & 0xfd73)
|
|
|
|
# define SCxSR_TDxE_CLEAR(port) (serial_port_in(port, SCxSR) & 0xffdf)
|
|
|
|
# define SCxSR_BREAK_CLEAR(port) (serial_port_in(port, SCxSR) & 0xffe3)
|
2005-04-17 02:20:36 +04:00
|
|
|
#else
|
|
|
|
# define SCxSR_RDxF_CLEAR(port) (((port)->type == PORT_SCI) ? 0xbc : 0x00fc)
|
|
|
|
# define SCxSR_ERROR_CLEAR(port) (((port)->type == PORT_SCI) ? 0xc4 : 0x0073)
|
|
|
|
# define SCxSR_TDxE_CLEAR(port) (((port)->type == PORT_SCI) ? 0x78 : 0x00df)
|
|
|
|
# define SCxSR_BREAK_CLEAR(port) (((port)->type == PORT_SCI) ? 0xc4 : 0x00e3)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* SCFCR */
|
|
|
|
#define SCFCR_RFRST 0x0002
|
|
|
|
#define SCFCR_TFRST 0x0004
|
|
|
|
#define SCFCR_MCE 0x0008
|
|
|
|
|
|
|
|
#define SCI_MAJOR 204
|
|
|
|
#define SCI_MINOR_START 8
|