bt_6701_commands.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. /********************************* (C) РОТЕК ***********************************
  2. * @module bt_6701_commands
  3. * @file bt_6701_commands.c
  4. * @version 1.0.0
  5. * @date XX.XX.XXXX
  6. * $brief bt_6701_commands
  7. *******************************************************************************
  8. * @history Version Author Comment
  9. * XX.XX.XXXX 1.0.0 Telenkov D.A. First release.
  10. *******************************************************************************
  11. */
  12. #include "stm32f4xx.h"
  13. #include "bt_6701_commands.h"
  14. #include "commands_api.h"
  15. #include "common_config.h"
  16. #include "gpio.h"
  17. #include "board_bt6702.h"
  18. #include "buttons.h"
  19. #include "led.h"
  20. #include "netconf.h"
  21. #include "stm32f4x7_eth_bsp.h"
  22. #include "http_server.h"
  23. #include "rtc.h"
  24. #include "sntp.h"
  25. #include "d_inouts.h"
  26. #include "config_service.h"
  27. #include "ports.h"
  28. #include "FreeRTOS.h"
  29. #include "task.h"
  30. #include "lwip/opt.h"
  31. #include "lwip/api.h"
  32. #include "lwip/sys.h"
  33. #ifdef PRINTF_STDLIB
  34. #include <stdio.h>
  35. #endif
  36. #ifdef PRINTF_CUSTOM
  37. #include "tinystdio.h"
  38. #endif
  39. #include <string.h>
  40. extern uint8_t DefCounter;
  41. extern BUTTON_NO_FIX_t defButton;
  42. // -------------------------------------------------------------------------- //
  43. // __weak функции
  44. /**
  45. * @brief
  46. */
  47. void TestProcessing(void)
  48. {
  49. vTaskDelay(200);
  50. }
  51. /**
  52. * @brief
  53. */
  54. void Test_U232(void)
  55. {
  56. // Подготавливаем буферы приема и счетчики байт
  57. memset(recvBufRS232, 0, RS232_MAX_REC_LEN);
  58. indexRS232 = 0;
  59. // Отправляем символы в RS232
  60. for (uint16_t i = 0; i < 1023; i++)
  61. RS232_SendByte('A');
  62. vTaskDelay(10);
  63. for (uint16_t i = 0; i < 1023; i++)
  64. {
  65. if (recvBufRS232[i] != 'A') {
  66. printf("U232 FAIL\r\n");
  67. TEST_SetTest(TEST_WAIT);
  68. return;
  69. }
  70. }
  71. printf("U232 OK\r\n");
  72. TEST_SetTest(TEST_WAIT);
  73. }
  74. /**
  75. * @brief
  76. */
  77. void Test_DRY(void)
  78. {
  79. uint8_t inputState;
  80. inputState = get_state_din_outs(DIN1);
  81. set_state_douts(DOUT1, 1);
  82. vTaskDelay(10);
  83. if (get_state_din_outs(DIN1) == inputState) {
  84. printf("DRY FAIL\r\n");
  85. TEST_SetTest(TEST_WAIT);
  86. return;
  87. }
  88. set_state_douts(DOUT1, 0);
  89. vTaskDelay(10);
  90. if (get_state_din_outs(DIN1) != inputState) {
  91. printf("DRY FAIL\r\n");
  92. TEST_SetTest(TEST_WAIT);
  93. return;
  94. }
  95. inputState = get_state_din_outs(DIN1);
  96. set_state_douts(DOUT2, 1);
  97. vTaskDelay(10);
  98. if (get_state_din_outs(DIN1) == inputState) {
  99. printf("DRY FAIL\r\n");
  100. TEST_SetTest(TEST_WAIT);
  101. return;
  102. }
  103. set_state_douts(DOUT2, 0);
  104. vTaskDelay(10);
  105. if (get_state_din_outs(DIN1) != inputState) {
  106. printf("DRY FAIL\r\n");
  107. TEST_SetTest(TEST_WAIT);
  108. return;
  109. }
  110. vTaskDelay(10);
  111. printf("DRY OK\r\n");
  112. TEST_SetTest(TEST_WAIT);
  113. }
  114. /**
  115. * @brief
  116. */
  117. void vTest_DEF(void *params)
  118. {
  119. static uint32_t timeout = 0;
  120. for (;;)
  121. {
  122. if (timeout++ > BUTTON_TIMEOUT) {
  123. timeout = 0;
  124. DefCounter = 0;
  125. LED_Off(LED_INIT_R);
  126. LED_Off(LED_MAJOR_R);
  127. LED_Off(LED_MINOR_R);
  128. printf("DEF FAIL\r\n");
  129. TEST_SetTest(TEST_WAIT);
  130. ifTest_DEF = false;
  131. vTaskDelete(NULL);
  132. }
  133. BUTTON_NoFixHandler(&defButton);
  134. if (DefCounter == 3)
  135. {
  136. timeout = 0;
  137. DefCounter = 0;
  138. printf("DEF OK\r\n");
  139. /* Завершение теста T0 */
  140. /* Устанавливаем статус T0READY, сохраняем статус во флеш */
  141. COM_SetTestState(T0READY);
  142. TEST_SetTest(TEST_WAIT);
  143. ifTest_DEF = false;
  144. vTaskDelete(NULL);
  145. }
  146. vTaskDelay(10);
  147. }
  148. }
  149. /**
  150. * @brief
  151. */
  152. void Test_Ethernet(void)
  153. {
  154. static bool ethernetInit = false;
  155. if (ethernetInit == false)
  156. {
  157. ethernetInit = true;
  158. ETH_BSP_Config();
  159. LwIP_Init();
  160. sys_thread_new("HTTP", vTaskTcpServer, NULL, 4*configMINIMAL_STACK_SIZE, tskIDLE_PRIORITY);
  161. }
  162. TEST_SetTest(TEST_WAIT);
  163. }
  164. /**
  165. * @brief
  166. */
  167. void Test_Serno(void)
  168. {
  169. macWaiting = true;
  170. macIsInstalled = false;
  171. // Устанавливаем статус тестирования "T1OK"
  172. COM_SetTestState(T0OK);
  173. // Отправляем udp пакет с информацией
  174. //COM_TestSerno();
  175. // Пауза. В это время должен прийти GET запрос с MAC адресом.
  176. //vTaskDelay(8000);
  177. //macWaiting = false;
  178. //if (!macIsInstalled)
  179. // printf("SERNO FAIL\r\n");
  180. for (uint8_t i = 0; i < 4; i++)
  181. {
  182. // Отправляем udp пакет с информацией
  183. COM_TestSerno();
  184. // Пауза. В это время должен прийти GET запрос с MAC адресом.
  185. vTaskDelay(8000);
  186. if (macIsInstalled)
  187. break;
  188. }
  189. if (!macIsInstalled)
  190. printf("SERNO FAIL\r\n");
  191. TEST_SetTest(TEST_WAIT);
  192. }
  193. // -------------------------------------------------------------------------- //
  194. /********************************* (C) РОТЕК **********************************/