fsa506_ebi.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /**************************************************************************//**
  2. *
  3. * @copyright (C) 2020 Nuvoton Technology Corp. All rights reserved.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0
  6. *
  7. * Change Logs:
  8. * Date Author Notes
  9. * 2022-2-23 Wayne First version
  10. *
  11. ******************************************************************************/
  12. #include <rtconfig.h>
  13. #if defined(NU_PKG_USING_FSA506_EBI)
  14. #include <lcd_fsa506.h>
  15. #include "drv_pdma.h"
  16. #define FSA506_ADDR_CMD 0x0
  17. #define FSA506_ADDR_DATA 0x0
  18. #if defined(FSA506_EBI_16BIT)
  19. #define fsa506_reg_write(RegAddr) (*((volatile uint16_t *)(s_u32AccessBase+(FSA506_ADDR_CMD))) = (RegAddr))
  20. #define fsa506_read_data() (*((volatile uint16_t *)(s_u32AccessBase+(FSA506_ADDR_DATA))))
  21. #define fsa506_write_data(Data) (*((volatile uint16_t *)(s_u32AccessBase+(FSA506_ADDR_DATA))) = (Data))
  22. #else
  23. #define fsa506_reg_write(RegAddr) (*((volatile uint8_t *)(s_u32AccessBase+(FSA506_ADDR_CMD))) = (RegAddr))
  24. #define fsa506_read_data() (*((volatile uint8_t *)(s_u32AccessBase+(FSA506_ADDR_DATA))))
  25. #define fsa506_write_data(Data) (*((volatile uint8_t *)(s_u32AccessBase+(FSA506_ADDR_DATA))) = (Data))
  26. #endif
  27. static rt_uint32_t s_u32AccessBase = 0;
  28. void fsa506_send_cmd(rt_uint8_t cmd)
  29. {
  30. CLR_RS;
  31. fsa506_reg_write(cmd);
  32. SET_RS;
  33. }
  34. void fsa506_send_cmd_parameter(rt_uint8_t data)
  35. {
  36. fsa506_write_data(data);
  37. }
  38. void fsa506_send_cmd_done(void)
  39. {
  40. CLR_RS;
  41. fsa506_reg_write(0x80);
  42. SET_RS;
  43. }
  44. void fsa506_write_reg(rt_uint8_t cmd, rt_uint8_t data)
  45. {
  46. fsa506_send_cmd(cmd);
  47. fsa506_send_cmd_parameter(data);
  48. fsa506_send_cmd_done();
  49. }
  50. void fsa506_send_pixel_data(rt_uint16_t color)
  51. {
  52. #if 1
  53. // for LV_COLOR_16_SWAP
  54. //BGR, B is high byte
  55. fsa506_write_data(color & 0xffu);
  56. fsa506_write_data((color >> 8) & 0xffu);
  57. #else
  58. //RGB, R is high byte
  59. fsa506_write_data((color >> 8) & 0xffu);
  60. fsa506_write_data(color & 0xffu);
  61. #endif
  62. }
  63. void fsa506_send_pixels(rt_uint16_t *pixels, int len)
  64. {
  65. int count = len / sizeof(rt_uint16_t);
  66. if (count < 512)
  67. {
  68. // CPU feed
  69. int i = 0;
  70. while (i < count)
  71. {
  72. fsa506_send_pixel_data(pixels[i]);
  73. i++;
  74. }
  75. }
  76. else
  77. {
  78. // PDMA-M2M feed
  79. // Must enable LV_COLOR_16_SWAP definition in LVGL.
  80. nu_pdma_mempush((void *)(s_u32AccessBase + (FSA506_ADDR_DATA)), (void *)pixels, 8, len);
  81. }
  82. }
  83. void fsa506_set_column(uint16_t StartCol, uint16_t EndCol)
  84. {
  85. fsa506_write_reg(0x0, (StartCol >> 8) & 0xFF);
  86. fsa506_write_reg(0x1, StartCol & 0xFF);
  87. fsa506_write_reg(0x2, (EndCol >> 8) & 0xFF);
  88. fsa506_write_reg(0x3, EndCol & 0xFF);
  89. }
  90. void fsa506_set_page(uint16_t StartPage, uint16_t EndPage)
  91. {
  92. fsa506_write_reg(0x4, (StartPage >> 8) & 0xFF);
  93. fsa506_write_reg(0x5, StartPage & 0xFF);
  94. fsa506_write_reg(0x6, (EndPage >> 8) & 0xFF);
  95. fsa506_write_reg(0x7, EndPage & 0xFF);
  96. }
  97. void fsa506_lcd_get_pixel(char *color, int x, int y)
  98. {
  99. //Not supported.
  100. return;
  101. }
  102. rt_err_t rt_hw_lcd_fsa506_ebi_init(rt_uint32_t fsa506_base)
  103. {
  104. s_u32AccessBase = fsa506_base;
  105. return RT_EOK;
  106. }
  107. #endif /* if defined(NU_PKG_USING_FSA506_EBI) */