rk_spi.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /*
  2. * SPI driver for rockchip
  3. *
  4. * (C) Copyright 2015 Google, Inc
  5. *
  6. * (C) Copyright 2008-2013 Rockchip Electronics
  7. * Peter, Software Engineering, <superpeter.cai@gmail.com>.
  8. *
  9. * SPDX-License-Identifier: GPL-2.0+
  10. */
  11. #ifndef __RK_SPI_H
  12. #define __RK_SPI_H
  13. struct rockchip_spi {
  14. u32 ctrlr0;
  15. u32 ctrlr1;
  16. u32 enr;
  17. u32 ser;
  18. u32 baudr;
  19. u32 txftlr;
  20. u32 rxftlr;
  21. u32 txflr;
  22. u32 rxflr;
  23. u32 sr;
  24. u32 ipr;
  25. u32 imr;
  26. u32 isr;
  27. u32 risr;
  28. u32 icr;
  29. u32 dmacr;
  30. u32 dmatdlr;
  31. u32 dmardlr; /* 0x44 */
  32. u32 reserved[0xef];
  33. u32 txdr[0x100]; /* 0x400 */
  34. u32 rxdr[0x100]; /* 0x800 */
  35. };
  36. /* CTRLR0 */
  37. enum {
  38. DFS_SHIFT = 0, /* Data Frame Size */
  39. DFS_MASK = 3,
  40. DFS_4BIT = 0,
  41. DFS_8BIT,
  42. DFS_16BIT,
  43. DFS_RESV,
  44. CFS_SHIFT = 2, /* Control Frame Size */
  45. CFS_MASK = 0xf,
  46. SCPH_SHIFT = 6, /* Serial Clock Phase */
  47. SCPH_MASK = 1,
  48. SCPH_TOGMID = 0, /* SCLK toggles in middle of first data bit */
  49. SCPH_TOGSTA, /* SCLK toggles at start of first data bit */
  50. SCOL_SHIFT = 7, /* Serial Clock Polarity */
  51. SCOL_MASK = 1,
  52. SCOL_LOW = 0, /* Inactive state of serial clock is low */
  53. SCOL_HIGH, /* Inactive state of serial clock is high */
  54. CSM_SHIFT = 8, /* Chip Select Mode */
  55. CSM_MASK = 0x3,
  56. CSM_KEEP = 0, /* ss_n stays low after each frame */
  57. CSM_HALF, /* ss_n high for half sclk_out cycles */
  58. CSM_ONE, /* ss_n high for one sclk_out cycle */
  59. CSM_RESV,
  60. SSN_DELAY_SHIFT = 10, /* SSN to Sclk_out delay */
  61. SSN_DELAY_MASK = 1,
  62. SSN_DELAY_HALF = 0, /* 1/2 sclk_out cycle */
  63. SSN_DELAY_ONE = 1, /* 1 sclk_out cycle */
  64. SEM_SHIFT = 11, /* Serial Endian Mode */
  65. SEM_MASK = 1,
  66. SEM_LITTLE = 0, /* little endian */
  67. SEM_BIG, /* big endian */
  68. FBM_SHIFT = 12, /* First Bit Mode */
  69. FBM_MASK = 1,
  70. FBM_MSB = 0, /* first bit is MSB */
  71. FBM_LSB, /* first bit in LSB */
  72. HALF_WORD_TX_SHIFT = 13, /* Byte and Halfword Transform */
  73. HALF_WORD_MASK = 1,
  74. HALF_WORD_ON = 0, /* apb 16bit write/read, spi 8bit write/read */
  75. HALF_WORD_OFF, /* apb 8bit write/read, spi 8bit write/read */
  76. RXDSD_SHIFT = 14, /* Rxd Sample Delay, in cycles */
  77. RXDSD_MASK = 3,
  78. FRF_SHIFT = 16, /* Frame Format */
  79. FRF_MASK = 3,
  80. FRF_SPI = 0, /* Motorola SPI */
  81. FRF_SSP, /* Texas Instruments SSP*/
  82. FRF_MICROWIRE, /* National Semiconductors Microwire */
  83. FRF_RESV,
  84. TMOD_SHIFT = 18, /* Transfer Mode */
  85. TMOD_MASK = 3,
  86. TMOD_TR = 0, /* xmit & recv */
  87. TMOD_TO, /* xmit only */
  88. TMOD_RO, /* recv only */
  89. TMOD_RESV,
  90. OMOD_SHIFT = 20, /* Operation Mode */
  91. OMOD_MASK = 1,
  92. OMOD_MASTER = 0, /* Master Mode */
  93. OMOD_SLAVE, /* Slave Mode */
  94. };
  95. /* SR */
  96. enum {
  97. SR_MASK = 0x7f,
  98. SR_BUSY = 1 << 0,
  99. SR_TF_FULL = 1 << 1,
  100. SR_TF_EMPT = 1 << 2,
  101. SR_RF_EMPT = 1 << 3,
  102. SR_RF_FULL = 1 << 4,
  103. };
  104. #define ROCKCHIP_SPI_TIMEOUT_MS 1000
  105. #define ROCKCHIP_SPI_MAX_RATE 48000000
  106. #endif /* __RK_SPI_H */