2005-04-16 15:20:36 -07:00
# include <linux/serial_core.h>
2009-11-25 16:23:35 +09:00
# include <linux/io.h>
2008-12-25 18:17:34 +09:00
# include <linux/gpio.h>
2007-08-20 08:59:33 +09:00
2008-10-02 19:47:12 +09: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 18:19:37 +09:00
# define SCxSR_ERRORS(port) (to_sci_port(port)->cfg->error_mask)
2008-10-02 19:47:12 +09:00
2007-08-20 08:59:33 +09:00
# if defined(CONFIG_CPU_SUBTYPE_SH7705) || \
2007-12-26 11:45:06 +09:00
defined ( CONFIG_CPU_SUBTYPE_SH7720 ) | | \
2010-02-05 11:15:33 +00:00
defined ( CONFIG_CPU_SUBTYPE_SH7721 ) | | \
2010-11-17 10:59:31 +00:00
defined ( CONFIG_ARCH_SH73A0 ) | | \
2010-03-16 11:21:07 +00:00
defined ( CONFIG_ARCH_SH7367 ) | | \
defined ( CONFIG_ARCH_SH7377 ) | | \
defined ( CONFIG_ARCH_SH7372 )
2008-10-02 19:47:12 +09:00
# define SCxSR_RDxF_CLEAR(port) (sci_in(port, SCxSR) & 0xfffc)
# define SCxSR_ERROR_CLEAR(port) (sci_in(port, SCxSR) & 0xfd73)
# define SCxSR_TDxE_CLEAR(port) (sci_in(port, SCxSR) & 0xffdf)
# define SCxSR_BREAK_CLEAR(port) (sci_in(port, SCxSR) & 0xffe3)
2005-04-16 15:20:36 -07: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