luat_spi_air101.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. #include "luat_base.h"
  2. #include "luat_spi.h"
  3. #include "wm_include.h"
  4. #include "wm_hostspi.h"
  5. #include "wm_gpio_afsel.h"
  6. #include "wm_cpu.h"
  7. #define LUAT_LOG_TAG "luat.spi"
  8. #include "luat_log.h"
  9. int luat_spi_device_config(luat_spi_device_t* spi_dev) {
  10. unsigned int clk;
  11. uint8_t TLS_SPI_MODE = 0x00 ;
  12. clk = spi_dev->spi_config.bandrate;
  13. tls_sys_clk sysclk;
  14. tls_sys_clk_get(&sysclk);
  15. if(clk / (UNIT_MHZ/2) > sysclk.apbclk)
  16. clk = sysclk.apbclk * (UNIT_MHZ/2);
  17. if(spi_dev->spi_config.CPHA)
  18. TLS_SPI_MODE |= SPI_CPHA;
  19. if(spi_dev->spi_config.CPOL)
  20. TLS_SPI_MODE |= SPI_CPOL;
  21. return tls_spi_setup(TLS_SPI_MODE, TLS_SPI_CS_LOW, clk);
  22. }
  23. int luat_spi_bus_setup(luat_spi_device_t* spi_dev){
  24. int bus_id = spi_dev->bus_id;
  25. if (bus_id == 0){
  26. wm_spi_ck_config(WM_IO_PB_02);
  27. wm_spi_di_config(WM_IO_PB_03);
  28. wm_spi_do_config(WM_IO_PB_05);
  29. return 0;
  30. }
  31. #ifdef AIR103
  32. else if (bus_id == 1) { // 本质上是mode=1,不是spi1,该模式下psram可用
  33. wm_spi_ck_config(WM_IO_PB_15);
  34. wm_spi_di_config(WM_IO_PB_16);
  35. wm_spi_do_config(WM_IO_PB_17);
  36. }
  37. else if (bus_id == 2) { // 本质上是mode=2,不是spi2,该模式下psram可用
  38. wm_spi_ck_config(WM_IO_PB_24);
  39. wm_spi_di_config(WM_IO_PB_25);
  40. wm_spi_do_config(WM_IO_PB_26);
  41. }
  42. #endif
  43. else{
  44. LLOGD("spi_bus error");
  45. return -1;
  46. }
  47. tls_spi_trans_type(SPI_BYTE_TRANSFER);
  48. }
  49. //初始化配置SPI各项参数,并打开SPI
  50. //成功返回0
  51. int luat_spi_setup(luat_spi_t* spi) {
  52. int ret;
  53. unsigned int clk;
  54. uint8_t TLS_SPI_MODE = 0x00 ;
  55. if (spi->id == 0) {
  56. // 兼容CS=0,默认配置, 也兼容CS为GPIO20的配置,其他配置不受控,自然不应该配置CS脚
  57. if (spi->cs == 0 || spi->cs == WM_IO_PB_04)
  58. wm_spi_cs_config(WM_IO_PB_04);
  59. wm_spi_ck_config(WM_IO_PB_02);
  60. wm_spi_di_config(WM_IO_PB_03);
  61. wm_spi_do_config(WM_IO_PB_05);
  62. }
  63. #ifdef AIR103
  64. else if (spi->id == 1) { // 本质上是mode=1,不是spi1,该模式下psram可用
  65. if (spi->cs == 0 || spi->cs == WM_IO_PB_14)
  66. wm_spi_cs_config(WM_IO_PB_14);
  67. wm_spi_ck_config(WM_IO_PB_15);
  68. wm_spi_di_config(WM_IO_PB_16);
  69. wm_spi_do_config(WM_IO_PB_17);
  70. }
  71. else if (spi->id == 2) { // 本质上是mode=2,不是spi2,该模式下psram可用
  72. if (spi->cs == 0 || spi->cs == WM_IO_PB_23)
  73. wm_spi_cs_config(WM_IO_PB_23);
  74. wm_spi_ck_config(WM_IO_PB_24);
  75. wm_spi_di_config(WM_IO_PB_25);
  76. wm_spi_do_config(WM_IO_PB_26);
  77. }
  78. #endif
  79. else {
  80. return -1;
  81. }
  82. if(spi->CPHA)
  83. TLS_SPI_MODE |= SPI_CPHA;
  84. if(spi->CPOL)
  85. TLS_SPI_MODE |= SPI_CPOL;
  86. clk = spi->bandrate;
  87. tls_sys_clk sysclk;
  88. tls_sys_clk_get(&sysclk);
  89. if(clk / (UNIT_MHZ/2) > sysclk.apbclk)
  90. clk = sysclk.apbclk * (UNIT_MHZ/2);
  91. tls_spi_trans_type(SPI_BYTE_TRANSFER);
  92. ret = tls_spi_setup(TLS_SPI_MODE, TLS_SPI_CS_LOW, clk);
  93. return ret;
  94. }
  95. //关闭SPI,成功返回0
  96. int luat_spi_close(int spi_id) {
  97. return 0;
  98. }
  99. //收发SPI数据,返回接收字节数
  100. int luat_spi_transfer(int spi_id, const char* send_buf, size_t send_length, char* recv_buf, size_t recv_length){
  101. tls_spi_read_with_cmd(send_buf, send_length, recv_buf, recv_length);
  102. return recv_length;
  103. }
  104. //收SPI数据,返回接收字节数
  105. int luat_spi_recv(int spi_id, char* recv_buf, size_t length) {
  106. int ret;
  107. if(length <= SPI_DMA_BUF_MAX_SIZE)
  108. {
  109. ret = tls_spi_read(recv_buf,length);
  110. }
  111. else
  112. {
  113. size_t i;
  114. for(i=0;i<length;i+=SPI_DMA_BUF_MAX_SIZE)
  115. {
  116. ret = tls_spi_read((u8*)(recv_buf+i), length - i > SPI_DMA_BUF_MAX_SIZE ? SPI_DMA_BUF_MAX_SIZE : length - i);
  117. if(ret != TLS_SPI_STATUS_OK)
  118. break;
  119. }
  120. }
  121. if (ret == TLS_SPI_STATUS_OK)
  122. return length;
  123. else
  124. return -1;
  125. }
  126. //发SPI数据,返回发送字节数
  127. int luat_spi_send(int spi_id, const char* send_buf, size_t length) {
  128. int ret;
  129. if(length <= SPI_DMA_BUF_MAX_SIZE)
  130. {
  131. ret = tls_spi_write(send_buf, length);
  132. }
  133. else
  134. {
  135. size_t i;
  136. for(i=0;i<length;i+=SPI_DMA_BUF_MAX_SIZE)
  137. {
  138. ret = tls_spi_write((const u8*)(send_buf+i), length - i > SPI_DMA_BUF_MAX_SIZE ? SPI_DMA_BUF_MAX_SIZE : length - i);
  139. if(ret != TLS_SPI_STATUS_OK)
  140. break;
  141. }
  142. }
  143. if (ret == TLS_SPI_STATUS_OK)
  144. return length;
  145. else
  146. return -1;
  147. }