shift_reg.c 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. #include "at32f403a_407.h"
  2. #include "shift_reg.h"
  3. #include "FreeRTOS.h"
  4. #include "task.h"
  5. #include "misc.h"
  6. #include <stdio.h>
  7. #include <stdbool.h>
  8. #define SH_SPI SPI2
  9. // PD1 - ART_nCS_LS_CH16/DAC2
  10. // PC10 - ART_CLK_LS (SPI3_CK remap)
  11. // PC11 - ART_MISO_CH16/CS_LS (SPI3_MISO remap)
  12. // PC12 - ART_MOSI_LS (SPI3_MOSI remap)
  13. // PD0 - ART_nCS_LS_CH712/DAC3
  14. // PD2 - ART_MISO_CH712
  15. void sh_init(void)
  16. {
  17. spi_init_type spi_init_struct;
  18. gpio_init_type gpio_initstructure;
  19. crm_periph_clock_enable(CRM_IOMUX_PERIPH_CLOCK, TRUE);
  20. crm_periph_clock_enable(CRM_GPIOB_PERIPH_CLOCK, TRUE);
  21. crm_periph_clock_enable(CRM_GPIOC_PERIPH_CLOCK, TRUE);
  22. crm_periph_clock_enable(CRM_GPIOD_PERIPH_CLOCK, TRUE);
  23. // SCK
  24. gpio_initstructure.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  25. gpio_initstructure.gpio_pull = GPIO_PULL_DOWN;
  26. gpio_initstructure.gpio_mode = GPIO_MODE_MUX;
  27. gpio_initstructure.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  28. gpio_initstructure.gpio_pins = GPIO_PINS_13;
  29. gpio_init(GPIOB, &gpio_initstructure);
  30. // MISO
  31. gpio_initstructure.gpio_pull = GPIO_PULL_UP;
  32. gpio_initstructure.gpio_mode = GPIO_MODE_INPUT;
  33. gpio_initstructure.gpio_pins = GPIO_PINS_14;
  34. gpio_init(GPIOB, &gpio_initstructure);
  35. // MOSI
  36. gpio_initstructure.gpio_pull = GPIO_PULL_UP;
  37. gpio_initstructure.gpio_mode = GPIO_MODE_MUX;
  38. gpio_initstructure.gpio_pins = GPIO_PINS_15;
  39. gpio_init(GPIOB, &gpio_initstructure);
  40. // CS
  41. // Эти два CS управляют двумя парами регистров
  42. gpio_initstructure.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  43. gpio_initstructure.gpio_pull = GPIO_PULL_NONE;
  44. gpio_initstructure.gpio_mode = GPIO_MODE_OUTPUT;
  45. gpio_initstructure.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  46. #if defined (MAI_12)
  47. gpio_initstructure.gpio_pins = GPIO_PINS_0 | GPIO_PINS_1;
  48. gpio_init(GPIOD, &gpio_initstructure);
  49. // CS для сдвигового регистра U1010 -> MUX301, MUX401
  50. gpio_initstructure.gpio_pins = GPIO_PINS_3;
  51. gpio_init(GPIOD, &gpio_initstructure);
  52. gpio_bits_reset(GPIOD, GPIO_PINS_0 | GPIO_PINS_1 | GPIO_PINS_3);
  53. #endif
  54. #if defined (MAO_4)
  55. // CS для сдвиговых регистров U860, U861
  56. gpio_initstructure.gpio_pins = GPIO_PINS_11;
  57. gpio_init(GPIOC, &gpio_initstructure);
  58. gpio_bits_reset(GPIOC, GPIO_PINS_11);
  59. #endif
  60. crm_periph_clock_enable(CRM_SPI2_PERIPH_CLOCK, TRUE);
  61. spi_default_para_init(&spi_init_struct);
  62. spi_init_struct.transmission_mode = SPI_TRANSMIT_FULL_DUPLEX;
  63. spi_init_struct.master_slave_mode = SPI_MODE_MASTER;
  64. spi_init_struct.mclk_freq_division = SPI_MCLK_DIV_32;
  65. spi_init_struct.first_bit_transmission = SPI_FIRST_BIT_MSB;
  66. spi_init_struct.frame_bit_num = SPI_FRAME_8BIT;
  67. spi_init_struct.clock_polarity = SPI_CLOCK_POLARITY_HIGH;//SPI_CLOCK_POLARITY_LOW;
  68. spi_init_struct.clock_phase = SPI_CLOCK_PHASE_2EDGE;
  69. spi_init_struct.cs_mode_selection = SPI_CS_SOFTWARE_MODE;
  70. spi_init(SH_SPI, &spi_init_struct);
  71. spi_hardware_cs_output_enable(SH_SPI, FALSE);
  72. spi_enable(SH_SPI, TRUE);
  73. }
  74. // Установка сигналов EN_CRNT_SNS_1..EN_CRNT_SNS_12 (режим измерения тока или напряжения)
  75. // Получение сигналов ALRM_IN_1..ALRM_IN_12
  76. uint16_t sh_ai_mode(uint16_t val)
  77. {
  78. uint16_t ret = 0;
  79. // Данные отправлеяются во второй регистр U402
  80. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  81. SH_SPI->dt = (0x003F) & (val >> 8);
  82. // Данные из второго регистра U400
  83. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  84. ret = (SH_SPI->dt & 0x3F) << 6;
  85. // Данные отправлеяются во второй регистр U302
  86. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  87. SH_SPI->dt = (0x003F) & val;
  88. // Данные из первого регистра U300
  89. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  90. ret |= SH_SPI->dt & 0x3F;
  91. gpio_bits_set(GPIOD, GPIO_PINS_0);
  92. nop(5);
  93. gpio_bits_reset(GPIOD, GPIO_PINS_0);
  94. nop(5);
  95. vTaskDelay(1);
  96. // Данные отправлеяются во второй регистр U402
  97. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  98. SH_SPI->dt = (0x003F) & (val >> 8);
  99. // Данные из второго регистра U400
  100. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  101. ret = (SH_SPI->dt & 0x3F) << 6;
  102. // Данные отправлеяются во второй регистр U302
  103. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  104. SH_SPI->dt = (0x003F) & val;
  105. // Данные из первого регистра U300
  106. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  107. ret |= SH_SPI->dt & 0x3F;
  108. gpio_bits_set(GPIOD, GPIO_PINS_0);
  109. nop(5);
  110. gpio_bits_reset(GPIOD, GPIO_PINS_0);
  111. nop(5);
  112. //printf("SH return: %X\r\n", ret);
  113. return ret;
  114. }
  115. //
  116. // Установка сигналов EN_CRNT_SNS_1..EN_CRNT_SNS_12 (режим измерения тока или напряжения)
  117. // Получение сигналов ALRM_IN_1..ALRM_IN_12
  118. uint16_t sh_ai_mode_two(uint16_t val, uint8_t ch_1, uint8_t ch_2)
  119. {
  120. uint16_t ret = 0;
  121. // Данные отправлеяются во второй регистр U402
  122. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  123. SH_SPI->dt = ((0x003F) & (val >> 8)) | (ch_2 << 6);
  124. // Данные из второго регистра U400
  125. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  126. ret = (SH_SPI->dt & 0x3F) << 6;
  127. // Данные отправлеяются во второй регистр U302
  128. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  129. SH_SPI->dt = ((0x003F) & val) | (ch_1 << 6);
  130. // Данные из первого регистра U300
  131. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  132. ret |= SH_SPI->dt & 0x3F;
  133. gpio_bits_set(GPIOD, GPIO_PINS_0);
  134. nop(5);
  135. gpio_bits_reset(GPIOD, GPIO_PINS_0);
  136. nop(5);
  137. vTaskDelay(1);
  138. // Данные отправлеяются во второй регистр U402
  139. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  140. SH_SPI->dt = ((0x003F) & (val >> 8)) | (ch_2 << 6);
  141. // Данные из второго регистра U400
  142. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  143. ret = (SH_SPI->dt & 0x3F) << 6;
  144. // Данные отправлеяются во второй регистр U302
  145. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  146. SH_SPI->dt = ((0x003F) & val) | (ch_1 << 6);
  147. // Данные из первого регистра U300
  148. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  149. ret |= SH_SPI->dt & 0x3F;
  150. gpio_bits_set(GPIOD, GPIO_PINS_0);
  151. nop(5);
  152. gpio_bits_reset(GPIOD, GPIO_PINS_0);
  153. nop(5);
  154. //printf("SH return: %X\r\n", ret);
  155. return ret;
  156. }
  157. //
  158. uint16_t sh_ao_mode(uint16_t val)
  159. {
  160. uint16_t ret = 0;
  161. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  162. SH_SPI->dt = val;
  163. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  164. ret = (uint16_t)SH_SPI->dt & 0x0F;
  165. gpio_bits_set(GPIOC, GPIO_PINS_11);
  166. nop(5);
  167. gpio_bits_reset(GPIOC, GPIO_PINS_11);
  168. nop(5);
  169. return ret;
  170. }
  171. // Подключает выбранный канал к АЦП
  172. void sh_ai_connect(uint16_t val)
  173. {
  174. uint16_t ret;
  175. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_TDBE_FLAG) == RESET);
  176. SH_SPI->dt = val;
  177. while (spi_i2s_flag_get(SH_SPI, SPI_I2S_RDBF_FLAG) == RESET);
  178. ret = SH_SPI->dt;
  179. gpio_bits_set(GPIOD, GPIO_PINS_3);
  180. nop(5);
  181. gpio_bits_reset(GPIOD, GPIO_PINS_3);
  182. }
  183. //
  184. void sh_delay(void)
  185. {
  186. for (unsigned int i = 0; i < 1; i++) {}
  187. }