ra8875.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /**************************************************************************************
  2. * drivers/lcd/ra8875.h
  3. * Definitions for the RAiO Technologies RA8875 LCD controller
  4. *
  5. * Copyright (C) 2015 Intuitive Aerial AB. All rights reserved.
  6. * Author: Marten Svanfeldt <marten@intuitiveaerial.com>
  7. *
  8. * References: RA8875, Rev 1.6, Apr 2013, RAiO Technologies Inc
  9. *
  10. * Redistribution and use in source and binary forms, with or without
  11. * modification, are permitted provided that the following conditions
  12. * are met:
  13. *
  14. * 1. Redistributions of source code must retain the above copyright
  15. * notice, this list of conditions and the following disclaimer.
  16. * 2. Redistributions in binary form must reproduce the above copyright
  17. * notice, this list of conditions and the following disclaimer in
  18. * the documentation and/or other materials provided with the
  19. * distribution.
  20. * 3. Neither the name NuttX nor the names of its contributors may be
  21. * used to endorse or promote products derived from this software
  22. * without specific prior written permission.
  23. *
  24. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  25. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  26. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  27. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  28. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  29. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  30. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  31. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  32. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  33. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  34. * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  35. * POSSIBILITY OF SUCH DAMAGE.
  36. *
  37. **************************************************************************************/
  38. #ifndef __DRIVERS_LCD_RA8875_H
  39. #define __DRIVERS_LCD_RA8875_H
  40. /**************************************************************************************
  41. * Included Files
  42. **************************************************************************************/
  43. #include <nuttx/config.h>
  44. #ifdef CONFIG_LCD_RA8875
  45. /**************************************************************************************
  46. * Pre-processor Definitions
  47. **************************************************************************************/
  48. /* RA8875 Register Addresses (All with RS=1) */
  49. /* System and Configuration Addresses */
  50. #define RA8875_PWRR 0x01 /* Power and display control */
  51. #define RA8875_MRWC 0x02 /* Memory Read/Write Control/command */
  52. #define RA8875_PCSR 0x04 /* Pixel Clock Setting Register */
  53. #define RA8875_SROC 0x05 /* Serial Flash/ROM Configuration */
  54. #define RA8875_SFCLR 0x06 /* Serial Flash/ROM CLK Setting */
  55. #define RA8875_SYSR 0x10 /* System configuration Register */
  56. #define RA8875_GPI 0x12 /* General Purpose Input */
  57. #define RA8875_GPO 0x13 /* General Purpose Output */
  58. #define RA8875_HDWR 0x14 /* LCD Horizontal Display Width Register */
  59. #define RA8875_HNDFTR 0x15 /* LCD Horizontal Non-Display Period Fine Tuning Register */
  60. #define RA8875_HNDR 0x16 /* LCD Horizontal Non-Display Period Register */
  61. #define RA8875_HSTR 0x17 /* HSYNC Start Position Register */
  62. #define RA8875_HPWR 0x18 /* HSYNC Pulse Width Register */
  63. #define RA8875_VDHR0 0x19 /* LCD Vertical Display Height Register 0 */
  64. #define RA8875_VDHR1 0x1A /* LCD Vertical Display Height Register 1 */
  65. #define RA8875_VNDR0 0x1B /* LCD Vertical Non-Display Period Register 0 */
  66. #define RA8875_VNDR1 0x1C /* LCD Vertical Non-Display Period Register 1 */
  67. #define RA8875_VSTR0 0x1D /* VSYNC Start Position Register 0 */
  68. #define RA8875_VSTR1 0x1E /* VSYNC Start Position Register 1 */
  69. #define RA8875_VPWR 0x1F /* VSYNC Pulse Width Register */
  70. /* LCD Display Control Registers */
  71. #define RA8875_DPCR 0x20 /* Display Configuration Registers */
  72. /* Active Window and Scroll Window Settings */
  73. #define RA8875_HSAW0 0x30 /* Horizontal Start Point of Active Window 0 */
  74. #define RA8875_HSAW1 0x31 /* Horizontal Start Point of Active Window 1 */
  75. #define RA8875_VSAW0 0x32 /* Vertical Start Point of Active Window 0 */
  76. #define RA8875_VSAW1 0x33 /* Vertical Start Point of Active Window 1 */
  77. #define RA8875_HEAW0 0x34 /* Horizontal End Point of Active Window 0 */
  78. #define RA8875_HEAW1 0x35 /* Horizontal End Point of Active Window 1 */
  79. #define RA8875_VEAW0 0x36 /* Vertical End Point of Active Window 0 */
  80. #define RA8875_VEAW1 0x37 /* Vertical End Point of Active Window 1 */
  81. /* Cursor Setting Registers */
  82. #define RA8875_MWCR0 0x40 /* Memory Write Control Register 0 */
  83. #define RA8875_MWCR1 0x41 /* Memory Write Control Register 1 */
  84. #define RA8875_BTCR 0x44 /* Blink Time Control Register */
  85. #define RA8875_MRDC 0x45 /* Memory Read Cursor Direction */
  86. #define RA8875_CURH0 0x46 /* Memory Write Cursor Horizontal Position Register 0 */
  87. #define RA8875_CURH1 0x47 /* Memory Write Cursor Horizontal Position Register 1 */
  88. #define RA8875_CURV0 0x48 /* Memory Write Cursor Vertical Position Register 0 */
  89. #define RA8875_CURV1 0x49 /* Memory Write Cursor Vertical Position Register 1 */
  90. #define RA8875_RCURH0 0x4A /* Memory Read Cursor Horizontal Position Register 0 */
  91. #define RA8875_RCURH1 0x4B /* Memory Read Cursor Horizontal Position Register 1 */
  92. #define RA8875_RCURV0 0x4C /* Memory Read Cursor Vertical Position Register 0 */
  93. #define RA8875_RCURV1 0x4D /* Memory Read Cursor Vertical Position Register 1 */
  94. /* BTE Control Registers */
  95. #define RA8875_LTPR0 0x50 /* Layer Transparency Register 0 */
  96. #define RA8875_BGCR0 0x60 /* Background Color Register 0 */
  97. #define RA8875_BGCR1 0x61 /* Background Color Register 1 */
  98. #define RA8875_BGCR2 0x62 /* Background Color Register 2 */
  99. #define RA8875_FGCR0 0x63 /* Foreground Color Register 0 */
  100. #define RA8875_FGCR1 0x64 /* Foreground Color Register 1 */
  101. #define RA8875_FGCR2 0x65 /* Foreground Color Register 2 */
  102. /* PWM Control Registers */
  103. #define RA8875_P1CR 0x8A /* PWM1 Control Register */
  104. #define RA8875_P1DCR 0x8B /* PWM1 Duty Cycle Register */
  105. #define RA8875_MCLR 0x8E /* Memory Clear Control Register */
  106. /* PLL Setting Registers */
  107. #define RA8875_PLLC1 0x88 /* PLL Control Register 1 */
  108. #define RA8875_PLLC2 0x89 /* PLL Control Register 2 */
  109. /* Drawing Control Registers */
  110. #define RA8875_DCR 0x90 /* Draw Line/Circle/Square Control Register */
  111. #define RA8875_DLHSR0 0x91 /* Draw Horizontal Start Address Register 0 */
  112. #define RA8875_DLHSR1 0x92 /* Draw Horizontal Start Address Register 1 */
  113. #define RA8875_DLVSR0 0x93 /* Draw Vertical Start Address Register 0 */
  114. #define RA8875_DLVSR1 0x94 /* Draw Vertical Start Address Register 1 */
  115. #define RA8875_DLHER0 0x95 /* Draw Horizontal End Address Register 0 */
  116. #define RA8875_DLHER1 0x96 /* Draw Horizontal End Address Register 1 */
  117. #define RA8875_DLVER0 0x97 /* Draw Vertical End Address Register 0 */
  118. #define RA8875_DLVER1 0x98 /* Draw Vertical End Address Register 1 */
  119. #define RA8875_DCHR0 0x99 /* Draw Circle Center Horizontal Address Register 0 */
  120. #define RA8875_DCHR1 0x9A /* Draw Circle Center Horizontal Address Register 1 */
  121. #define RA8875_DCVR0 0x9B /* Draw Circle Center Vertical Address Register 0 */
  122. #define RA8875_DCVR1 0x9C /* Draw Circle Center Vertical Address Register 1 */
  123. #define RA8875_DCRR 0x9D /* Draw Circle Radius Register */
  124. #define RA8875_DTPH0 0xA9 /* Draw Triangle Point 2 Horizontal Address Register 0 */
  125. #define RA8875_DTPH1 0xAA /* Draw Triangle Point 2 Horizontal Address Register 1 */
  126. #define RA8875_DTPV0 0xAB /* Draw Triangle Point 2 Vertical Address Register 0 */
  127. #define RA8875_DTPV1 0xAC /* Draw Triangle Point 2 Vertical Address Register 1 */
  128. /* Bit definitions */
  129. /* Power and display control */
  130. #define RA8875_PWRR_DISPLAY_OFF (0)
  131. #define RA8875_PWRR_DISPLAY_ON (1<<7)
  132. #define RA8875_PWRR_SLEEP (1<<1)
  133. #define RA8875_PWRR_SWRESET (1<<0)
  134. /* Pixel Clock Setting Register */
  135. #define RA8875_PCSR_PCLK_INV (1<<7)
  136. #define RA8875_PCSR_PERIOD_MASK (3)
  137. # define RA8875_PCSR_PERIOD_SYS (0)
  138. # define RA8875_PCSR_PERIOD_2SYS (1)
  139. # define RA8875_PCSR_PERIOD_4SYS (2)
  140. # define RA8875_PCSR_PERIOD_8SYS (3)
  141. /* System configuration Register */
  142. #define RA8875_SYSR_COLOR_SHIFT (2)
  143. #define RA8875_SYSR_COLOR_MASK (3<<RA8875_SYSR_COLOR_SHIFT)
  144. # define RA8875_SYSR_COLOR_256 (0<<RA8875_SYSR_COLOR_SHIFT)
  145. # define RA8875_SYSR_COLOR_65K (3<<RA8875_SYSR_COLOR_SHIFT)
  146. #define RA8875_SYSR_MCUIF_MASK (3)
  147. # define RA8875_SYSR_MCUIF_8BIT (0)
  148. # define RA8875_SYSR_MCUIF_16BIT (3)
  149. /* LCD Horizontal Display Width Register */
  150. #define RA8875_HDWR_WIDTH(p) ((p)/8 - 1)
  151. /* LCD Vertical Display Height Register 0 */
  152. #define RA8875_VDHR0_HEIGHT(p) (((p) - 1)&0xff)
  153. /* LCD Vertical Display Height Register 1 */
  154. #define RA8875_VDHR1_HEIGHT(p) (((p) - 1)>>8)
  155. /* Display Configuration Registers */
  156. #define RA8875_DPCR_LAYERS_ONE (0)
  157. #define RA8875_DPCR_LAYERS_TWO (1<<7)
  158. #define RA8875_DPCR_HSCAN_INC (0)
  159. #define RA8875_DPCR_HSCAN_DEC (1<<3)
  160. #define RA8875_DPCR_VSCAN_INC (0)
  161. #define RA8875_DPCR_VSCAN_DEC (1<<2)
  162. /* Memory Write Control Register 0 */
  163. #define RA8875_MWCR0_MODE_GRAPHICS (0)
  164. #define RA8875_MWCR0_MODE_TEXT (1<<7)
  165. #define RA8875_MWCR0_CURSOR_INVISIBLE (0)
  166. #define RA8875_MWCR0_CURSOR_VISIBLE (1<<6)
  167. #define RA8875_MWCR0_CURSOR_NORMAL (0)
  168. #define RA8875_MWCR0_CURSOR_BLINK (1<<5)
  169. #define RA8875_MWCR0_MEMDIR_SHIFT (2)
  170. #define RA8875_MWCR0_MEMDIR_MASK (3<<RA8875_MWCR0_MEMDIR_SHIFT)
  171. # define RA8875_MWCR0_MEMDIR_LEFTRIGHT (0<<RA8875_MWCR0_MEMDIR_SHIFT)
  172. # define RA8875_MWCR0_MEMDIR_RIGHTLEFT (1<<RA8875_MWCR0_MEMDIR_SHIFT)
  173. # define RA8875_MWCR0_MEMDIR_TOPDOWN (2<<RA8875_MWCR0_MEMDIR_SHIFT)
  174. # define RA8875_MWCR0_MEMDIR_DOWNTOP (3<<RA8875_MWCR0_MEMDIR_SHIFT)
  175. #define RA8875_MWCR0_WINC_ENABLE (0)
  176. #define RA8875_MWCR0_WINC_DISABLE (1<<1)
  177. #define RA8875_MWCR0_RINC_ENABLE (0)
  178. #define RA8875_MWCR0_RINC_DISABLE (1<<0)
  179. /* Memory Write Control Register 1 */
  180. #define RA8875_MWCR1_LAYER_1 (0)
  181. #define RA8875_MWCR1_LAYER_2 (1)
  182. /* Memory Read Cursor Direction */
  183. #define RA8875_MRCD_MEMDIR_SHIFT (0)
  184. #define RA8875_MRCD_MEMDIR_MASK (3<<RA8875_MWCR0_MEMDIR_SHIFT)
  185. # define RA8875_MRCD_MEMDIR_LEFTRIGHT (0<<RA8875_MWCR0_MEMDIR_SHIFT)
  186. # define RA8875_MRCD_MEMDIR_RIGHTLEFT (1<<RA8875_MWCR0_MEMDIR_SHIFT)
  187. # define RA8875_MRCD_MEMDIR_TOPDOWN (2<<RA8875_MWCR0_MEMDIR_SHIFT)
  188. # define RA8875_MRCD_MEMDIR_DOWNTOP (3<<RA8875_MWCR0_MEMDIR_SHIFT)
  189. /* Layer Transparency Register 0 */
  190. #define RA8875_LTPR0_MODE_MASK (7)
  191. # define RA8875_LTPR0_MODE_L1 (0)
  192. # define RA8875_LTPR0_MODE_L2 (1)
  193. /* PWM1 Control Register */
  194. #define RA8875_P1CR_PWM_DISABLE (0)
  195. #define RA8875_P1CR_PWM_ENABLE (1<<7)
  196. #define RA8875_P1CR_DISABLE_LOW (0)
  197. #define RA8875_P1CR_DISABLE_HIGH (1<<6)
  198. #define RA8875_P1CR_FUNC_PWM (0)
  199. #define RA8875_P1CR_FUNC_FIXED (1<<4)
  200. #define RA8875_P1CR_CSDIV_MASK (0xf)
  201. # define RA8875_P1CR_CSDIV(p) ((p) & 0xf)
  202. /* Memory Clear Control Register */
  203. #define RA8875_MCLR_CLEAR (1<<7)
  204. #define RA8875_MCLR_FULL (0)
  205. #define RA8875_MCLR_ACTIVE (1<<6)
  206. /* PLL Control Register 1 */
  207. #define RA8875_PLLC1_PLLDIVM (1<<7)
  208. #define RA8875_PLLC1_PLLDIVN(p) ((p)&0x1f)
  209. /* PLL Control Register 2 */
  210. #define RA8875_PLLC2_PLLDIVK(p) ((p)&0x7)
  211. /* Draw Line/Circle/Square Control Register */
  212. #define RA8875_DCR_LINE_START (1<<7)
  213. #define RA8875_DCR_CIRCLE_START (1<<6)
  214. #define RA8875_DCR_NOFILL (0)
  215. #define RA8875_DCR_FILL (1<<5)
  216. #define RA8875_DCR_LINE (0)
  217. #define RA8875_DCR_SQUARE (1<<4)
  218. #define RA8875_DCR_TRIANGLE (1<<0)
  219. #endif /* CONFIG_LCD_RA8875 */
  220. #endif /* __DRIVERS_LCD_RA8875_H */