sh-sci.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. #include <linux/serial_core.h>
  2. #include <linux/io.h>
  3. #include <linux/gpio.h>
  4. #define SCxSR_TEND(port) (((port)->type == PORT_SCI) ? SCI_TEND : SCIF_TEND)
  5. #define SCxSR_RDxF(port) (((port)->type == PORT_SCI) ? SCI_RDRF : SCIF_RDF)
  6. #define SCxSR_TDxE(port) (((port)->type == PORT_SCI) ? SCI_TDRE : SCIF_TDFE)
  7. #define SCxSR_FER(port) (((port)->type == PORT_SCI) ? SCI_FER : SCIF_FER)
  8. #define SCxSR_PER(port) (((port)->type == PORT_SCI) ? SCI_PER : SCIF_PER)
  9. #define SCxSR_BRK(port) (((port)->type == PORT_SCI) ? 0x00 : SCIF_BRK)
  10. #define SCxSR_ERRORS(port) (to_sci_port(port)->cfg->error_mask)
  11. #if defined(CONFIG_CPU_SUBTYPE_SH7705) || \
  12. defined(CONFIG_CPU_SUBTYPE_SH7720) || \
  13. defined(CONFIG_CPU_SUBTYPE_SH7721) || \
  14. defined(CONFIG_ARCH_SH73A0) || \
  15. defined(CONFIG_ARCH_SH7367) || \
  16. defined(CONFIG_ARCH_SH7377) || \
  17. defined(CONFIG_ARCH_SH7372) || \
  18. defined(CONFIG_ARCH_R8A7740)
  19. # define SCxSR_RDxF_CLEAR(port) (serial_port_in(port, SCxSR) & 0xfffc)
  20. # define SCxSR_ERROR_CLEAR(port) (serial_port_in(port, SCxSR) & 0xfd73)
  21. # define SCxSR_TDxE_CLEAR(port) (serial_port_in(port, SCxSR) & 0xffdf)
  22. # define SCxSR_BREAK_CLEAR(port) (serial_port_in(port, SCxSR) & 0xffe3)
  23. #else
  24. # define SCxSR_RDxF_CLEAR(port) (((port)->type == PORT_SCI) ? 0xbc : 0x00fc)
  25. # define SCxSR_ERROR_CLEAR(port) (((port)->type == PORT_SCI) ? 0xc4 : 0x0073)
  26. # define SCxSR_TDxE_CLEAR(port) (((port)->type == PORT_SCI) ? 0x78 : 0x00df)
  27. # define SCxSR_BREAK_CLEAR(port) (((port)->type == PORT_SCI) ? 0xc4 : 0x00e3)
  28. #endif
  29. /* SCFCR */
  30. #define SCFCR_RFRST 0x0002
  31. #define SCFCR_TFRST 0x0004
  32. #define SCFCR_MCE 0x0008
  33. #define SCI_MAJOR 204
  34. #define SCI_MINOR_START 8