2
0

sysfs_software_spi.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. /*****************************************************************************
  2. * | File : sysfs_software_spi.h
  3. * | Author : Waveshare team
  4. * | Function : Read and write /sys/class/gpio, software spi
  5. * | Info :
  6. *----------------
  7. * | This version: V1.0
  8. * | Date : 2019-06-05
  9. * | Info : Basic version
  10. *
  11. #
  12. # Permission is hereby granted, free of charge, to any person obtaining a copy
  13. # of this software and associated documnetation files (the "Software"), to deal
  14. # in the Software without restriction, including without limitation the rights
  15. # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  16. # copies of the Software, and to permit persons to whom the Software is
  17. # furished to do so, subject to the following conditions:
  18. #
  19. # The above copyright notice and this permission notice shall be included in
  20. # all copies or substantial portions of the Software.
  21. #
  22. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  23. # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  24. # FITNESS OR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  25. # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  26. # LIABILITY WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  27. # Read_data OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  28. # THE SOFTWARE.
  29. #
  30. ******************************************************************************/
  31. #include "sysfs_software_spi.h"
  32. SOFTWARE_SPI software_spi;
  33. /******************************************************************************
  34. function:
  35. parameter:
  36. Info:
  37. ******************************************************************************/
  38. void SYSFS_software_spi_begin(void)
  39. {
  40. // gpio
  41. software_spi.SCLK_PIN = SPI0_SCK;
  42. software_spi.MOSI_PIN = SPI0_MOSI;
  43. software_spi.MISO_PIN = SPI0_MISO;
  44. //software spi configure
  45. software_spi.Mode = SOFTWARE_SPI_Mode0;
  46. software_spi.Type = SOFTWARE_SPI_Master;
  47. software_spi.Delay = SOFTWARE_SPI_CLOCK_DIV2;
  48. software_spi.Order = SOFTWARE_SPI_MSBFIRST; // MSBFIRST
  49. SYSFS_GPIO_Export(software_spi.SCLK_PIN);
  50. SYSFS_GPIO_Export(software_spi.MOSI_PIN);
  51. SYSFS_GPIO_Export(software_spi.MISO_PIN);
  52. SYSFS_GPIO_Direction(software_spi.SCLK_PIN, OUT);
  53. SYSFS_GPIO_Direction(software_spi.MOSI_PIN, OUT);
  54. SYSFS_GPIO_Direction(software_spi.MISO_PIN, IN);
  55. }
  56. void SYSFS_software_spi_end(void)
  57. {
  58. SYSFS_GPIO_Write(software_spi.SCLK_PIN, LOW);
  59. SYSFS_GPIO_Write(software_spi.MOSI_PIN, LOW);
  60. SYSFS_GPIO_Unexport(software_spi.SCLK_PIN);
  61. SYSFS_GPIO_Unexport(software_spi.MOSI_PIN);
  62. }
  63. void SYSFS_software_spi_setBitOrder(uint8_t order)
  64. {
  65. software_spi.Order = order & 1;
  66. }
  67. void SYSFS_software_spi_setDataMode(uint8_t mode)
  68. {
  69. if(mode > 4) {
  70. SYSFS_SOFTWARE_SPI_Debug("MODE must be 0-3\r\n");
  71. return;
  72. }
  73. software_spi.Mode = mode;
  74. switch (software_spi.Mode) {
  75. case SOFTWARE_SPI_Mode0:
  76. software_spi.CPOL = 0;
  77. software_spi.CPHA = 0;
  78. break;
  79. case SOFTWARE_SPI_Mode1:
  80. software_spi.CPOL = 0;
  81. software_spi.CPHA = 1;
  82. break;
  83. case SOFTWARE_SPI_Mode2:
  84. software_spi.CPOL = 1;
  85. software_spi.CPHA = 0;
  86. break;
  87. case SOFTWARE_SPI_Mode3:
  88. software_spi.CPOL = 1;
  89. software_spi.CPHA = 1;
  90. break;
  91. }
  92. }
  93. void SYSFS_software_spi_setClockDivider(uint8_t div)
  94. {
  95. if(div > 8) {
  96. SYSFS_SOFTWARE_SPI_Debug("div must be 0-7\r\n");
  97. return;
  98. }
  99. switch (div) {
  100. case SOFTWARE_SPI_CLOCK_DIV2:
  101. software_spi.Delay = 2;
  102. break;
  103. case SOFTWARE_SPI_CLOCK_DIV4:
  104. software_spi.Delay = 4;
  105. break;
  106. case SOFTWARE_SPI_CLOCK_DIV8:
  107. software_spi.Delay = 8;
  108. break;
  109. case SOFTWARE_SPI_CLOCK_DIV16:
  110. software_spi.Delay = 16;
  111. break;
  112. case SOFTWARE_SPI_CLOCK_DIV32:
  113. software_spi.Delay = 32;
  114. break;
  115. case SOFTWARE_SPI_CLOCK_DIV64:
  116. software_spi.Delay = 64;
  117. break;
  118. case SOFTWARE_SPI_CLOCK_DIV128:
  119. software_spi.Delay = 128;
  120. break;
  121. default:
  122. software_spi.Delay = 128;
  123. break;
  124. }
  125. }
  126. /******************************************************************************
  127. function: SPI Mode 0
  128. parameter:
  129. Info:
  130. ******************************************************************************/
  131. uint8_t SYSFS_software_spi_transfer(uint8_t value)
  132. {
  133. // printf("value = %d\r\n", value);
  134. uint8_t Read_data;
  135. if (software_spi.Order == SOFTWARE_SPI_LSBFIRST) {
  136. uint8_t temp =
  137. ((value & 0x01) << 7) |
  138. ((value & 0x02) << 5) |
  139. ((value & 0x04) << 3) |
  140. ((value & 0x08) << 1) |
  141. ((value & 0x10) >> 1) |
  142. ((value & 0x20) >> 3) |
  143. ((value & 0x40) >> 5) |
  144. ((value & 0x80) >> 7);
  145. value = temp;
  146. }
  147. uint8_t delay = software_spi.Delay >> 1;
  148. for(int j=delay; j > 0; j--);
  149. // printf("value = %d\r\n", value);
  150. uint8_t Read_miso = 0;
  151. SYSFS_GPIO_Write(software_spi.SCLK_PIN, 0);
  152. for (uint8_t bit = 0; bit < 8; bit++) {
  153. SYSFS_GPIO_Write(software_spi.SCLK_PIN, 0);
  154. // for(int j=delay; j > 0; j--);// DELAY
  155. if (software_spi.CPHA) {
  156. Read_miso = SYSFS_GPIO_Read(software_spi.MISO_PIN);
  157. if (software_spi.Order == SOFTWARE_SPI_LSBFIRST) {
  158. Read_data <<= 1;
  159. Read_data |= Read_miso;
  160. } else {
  161. Read_data >>= 1;
  162. Read_data |= Read_miso << 7;
  163. }
  164. } else {
  165. SYSFS_GPIO_Write(software_spi.MOSI_PIN, ((value<<bit) & 0x80) ? HIGH : LOW);
  166. }
  167. // for(int j=delay; j > 0; j--);// DELAY
  168. SYSFS_GPIO_Write(software_spi.SCLK_PIN, 1);
  169. // for(int j=delay; j > 0; j--);// DELAY
  170. if (software_spi.CPHA) {
  171. SYSFS_GPIO_Write(software_spi.MOSI_PIN, ((value<<bit) & 0x80) ? HIGH : LOW);
  172. } else {
  173. Read_miso = SYSFS_GPIO_Read(software_spi.MISO_PIN);
  174. if (software_spi.Order == SOFTWARE_SPI_LSBFIRST) {
  175. Read_data <<= 1;
  176. Read_data |= Read_miso;
  177. } else {
  178. Read_data >>= 1;
  179. Read_data |= Read_miso << 7;
  180. }
  181. }
  182. // for(int j=delay; j > 0; j--);// DELAY
  183. }
  184. return Read_data;
  185. }