netconf.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. #include "lwip/mem.h"
  2. #include "lwip/memp.h"
  3. #include "lwip/dhcp.h"
  4. #include "ethernetif.h"
  5. #include "common_config.h"
  6. #include "netconf.h"
  7. #include "tcpip.h"
  8. #include "main.h"
  9. #include "settings_api.h"
  10. #include "parameters.h"
  11. #include "web_params_api.h"
  12. #include "snmp_api.h"
  13. #include "trap_api.h"
  14. #include "hal.h"
  15. #ifdef PRINTF_STDLIB
  16. #include <stdio.h>
  17. #endif
  18. #ifdef PRINTF_CUSTOM
  19. #include "tinystdio.h"
  20. #endif
  21. #include <string.h>
  22. #define MAX_DHCP_TRIES 3
  23. #define TIME_COUNTER_10_MIN 600
  24. #define TIME_COUNTER_1_MIN 60
  25. /**
  26. * @brief Общая структура настроек
  27. */
  28. extern SETTINGS_t sSettings;
  29. /**
  30. * @brief Флаг подтверждения новых сетевых параметров пользователем
  31. */
  32. extern bool fConfirmWebParams;
  33. /**
  34. * @brief Network interface structure
  35. */
  36. struct netif xnetif;
  37. /**
  38. * @brief Задача получения сетевый параметров по DHCP протоколу
  39. */
  40. TaskHandle_t xHandleDHCP = NULL;
  41. /**
  42. * @brief Задача переинициализации сети
  43. */
  44. TaskHandle_t xHandleWebReinit = NULL;
  45. bool dhcp = false;
  46. bool isIpReceived = false;
  47. void LwIP_Init(void)
  48. {
  49. struct ip4_addr ipaddr;
  50. struct ip4_addr netmask;
  51. struct ip4_addr gw;
  52. char str[20];
  53. tcpip_init( NULL, NULL );
  54. /* Если настройки изменили, то используем временные параметры */
  55. if (sSettings.sFlags.netsettingsChanged == true)
  56. {
  57. if (sSettings.sWebTempParams.dhcpEnable)
  58. {
  59. ipaddr.addr = 0;
  60. netmask.addr = 0;
  61. gw.addr = 0;
  62. netif_add(&xnetif, &ipaddr, &netmask, &gw, NULL, &ethernetif_init, &tcpip_input);
  63. netif_set_default(&xnetif);
  64. netif_set_link_up(&xnetif);
  65. netif_set_up(&xnetif);
  66. }
  67. else
  68. {
  69. ipaddr.addr = ipaddr_addr(sSettings.sWebTempParams.ip);
  70. netmask.addr = ipaddr_addr(sSettings.sWebTempParams.mask);
  71. gw.addr = ipaddr_addr(sSettings.sWebTempParams.gate);
  72. sprintf(str, " %s\n\r", sSettings.sWebTempParams.ip);
  73. PRINT_USART("\n\rStatic IP address \n\r");
  74. PRINT_USART(str);
  75. netif_add(&xnetif, &ipaddr, &netmask, &gw, NULL, &ethernetif_init, &tcpip_input);
  76. netif_set_default(&xnetif);
  77. netif_set_link_up(&xnetif);
  78. netif_set_up(&xnetif);
  79. isIpReceived = true;
  80. }
  81. if (sSettings.sWebTempParams.dhcpEnable) {
  82. xTaskCreate(LwIP_DHCP_task, "DHCPClient", configMINIMAL_STACK_SIZE * 2, NULL,
  83. tskIDLE_PRIORITY + 2, &xHandleDHCP);
  84. dhcp = true;
  85. }
  86. }
  87. /* Настройки не менялись, используем обычне настройки из флеш памяти */
  88. else
  89. {
  90. if (sSettings.sWebParams.dhcpEnable)
  91. {
  92. ipaddr.addr = 0;
  93. netmask.addr = 0;
  94. gw.addr = 0;
  95. netif_add(&xnetif, &ipaddr, &netmask, &gw, NULL, &ethernetif_init, &tcpip_input);
  96. netif_set_default(&xnetif);
  97. netif_set_link_up(&xnetif);
  98. netif_set_up(&xnetif);
  99. }
  100. else
  101. {
  102. ipaddr.addr = ipaddr_addr(sSettings.sWebParams.ip);
  103. netmask.addr = ipaddr_addr(sSettings.sWebParams.mask);
  104. gw.addr = ipaddr_addr(sSettings.sWebParams.gate);
  105. /* Обновляем временные настройки */
  106. sSettings.sWebTempParams.dhcpEnable = sSettings.sWebParams.dhcpEnable;
  107. strcpy(sSettings.sWebTempParams.ip, sSettings.sWebParams.ip);
  108. strcpy(sSettings.sWebTempParams.mask, sSettings.sWebParams.mask);
  109. strcpy(sSettings.sWebTempParams.gate, sSettings.sWebParams.gate);
  110. sprintf(str, " %s\n\r", sSettings.sWebParams.ip);
  111. PRINT_USART("\n\rStatic IP address \n\r");
  112. PRINT_USART(str);
  113. netif_add(&xnetif, &ipaddr, &netmask, &gw, NULL, &ethernetif_init, &tcpip_input);
  114. netif_set_default(&xnetif);
  115. netif_set_link_up(&xnetif);
  116. netif_set_up(&xnetif);
  117. isIpReceived = true;
  118. }
  119. if (sSettings.sWebParams.dhcpEnable) {
  120. xTaskCreate(LwIP_DHCP_task, "DHCPClient", configMINIMAL_STACK_SIZE * 2, NULL,
  121. tskIDLE_PRIORITY + 2, &xHandleDHCP);
  122. dhcp = true;
  123. }
  124. }
  125. /* Если настройки изменились, запускаем задачу по отсчету времени реакции пользователя*/
  126. if (sSettings.sFlags.netsettingsChanged == true)
  127. xTaskCreate(vTaskWebReinit, "webReinit", configMINIMAL_STACK_SIZE, NULL,
  128. tskIDLE_PRIORITY, &xHandleWebReinit);
  129. }
  130. /**
  131. * @brief LwIP_DHCP_Process_Handle
  132. * @param None
  133. * @retval None
  134. */
  135. void LwIP_DHCP_task(void * pvParameters)
  136. {
  137. struct ip4_addr ipaddr;
  138. struct ip4_addr netmask;
  139. struct ip4_addr gw;
  140. uint8_t DHCP_state;
  141. DHCP_state = DHCP_START;
  142. for (;;)
  143. {
  144. struct dhcp *dhcp = netif_dhcp_data(&xnetif);
  145. switch (DHCP_state)
  146. {
  147. case DHCP_START:
  148. {
  149. dhcp_start(&xnetif);
  150. DHCP_state = DHCP_WAIT_ADDRESS;
  151. //PRINT_USART("\n\rLooking for DHCP server please wait...\n\r");
  152. }
  153. break;
  154. case DHCP_WAIT_ADDRESS:
  155. {
  156. /* Read the new IP address */
  157. ipaddr = xnetif.ip_addr;
  158. netmask = xnetif.netmask;
  159. gw = xnetif.gw;
  160. if (ipaddr.addr != 0)
  161. {
  162. DHCP_state = DHCP_ADDRESS_ASSIGNED;
  163. dhcp_stop(&xnetif);
  164. /* Сохранение полученных сетевый параметров */
  165. /* Если настройки изменили, то сохраняем во временные настройки */
  166. if (sSettings.sFlags.netsettingsChanged == true)
  167. {
  168. sprintf(sSettings.sWebTempParams.ip, "%s", ipaddr_ntoa(&ipaddr));
  169. sprintf(sSettings.sWebTempParams.mask, "%s", ipaddr_ntoa(&netmask));
  170. sprintf(sSettings.sWebTempParams.gate, "%s", ipaddr_ntoa(&gw));
  171. }
  172. else
  173. {
  174. sprintf(sSettings.sWebParams.ip, "%s", ipaddr_ntoa(&ipaddr));
  175. sprintf(sSettings.sWebParams.mask, "%s", ipaddr_ntoa(&netmask));
  176. sprintf(sSettings.sWebParams.gate, "%s", ipaddr_ntoa(&gw));
  177. /* Обновляем временные настройки */
  178. sSettings.sWebTempParams.dhcpEnable = sSettings.sWebParams.dhcpEnable;
  179. sprintf(sSettings.sWebTempParams.ip, "%s", ipaddr_ntoa(&ipaddr));
  180. sprintf(sSettings.sWebTempParams.mask, "%s", ipaddr_ntoa(&netmask));
  181. sprintf(sSettings.sWebTempParams.gate, "%s", ipaddr_ntoa(&gw));
  182. }
  183. PRINT_USART("Parameters assigned by a DHCP server:\n\r IP: ");
  184. PRINT_USART(ipaddr_ntoa(&ipaddr));
  185. PRINT_USART("\n\r");
  186. PRINT_USART("Netmask: ");
  187. PRINT_USART(ipaddr_ntoa(&netmask));
  188. PRINT_USART("\n\r");
  189. PRINT_USART("Gateway: ");
  190. PRINT_USART(ipaddr_ntoa(&gw));
  191. PRINT_USART("\n\r");
  192. isIpReceived = true;
  193. vTaskDelay(50);
  194. /* Установлен динамический IP, можно отправить трап о перезагрузке устройства */
  195. // SNMP_SendUserTrap(DEVICE_REBOOTED);
  196. vTaskDelete(xHandleDHCP);
  197. }
  198. else
  199. {
  200. /* DHCP timeout */
  201. //if (xnetif.dhcp->tries > MAX_DHCP_TRIES)
  202. if (dhcp->tries > MAX_DHCP_TRIES)
  203. {
  204. DHCP_state = DHCP_TIMEOUT;
  205. /* Stop DHCP */
  206. dhcp_stop(&xnetif);
  207. if (sSettings.sFlags.netsettingsChanged == true)
  208. {
  209. ipaddr.addr = ipaddr_addr(sSettings.sWebTempParams.ip);
  210. netmask.addr = ipaddr_addr(sSettings.sWebTempParams.mask);
  211. gw.addr = ipaddr_addr(sSettings.sWebTempParams.gate);
  212. }
  213. else
  214. {
  215. ipaddr.addr = ipaddr_addr(sSettings.sWebParams.ip);
  216. netmask.addr = ipaddr_addr(sSettings.sWebParams.mask);
  217. gw.addr = ipaddr_addr(sSettings.sWebParams.gate);
  218. }
  219. /* Static address used */
  220. netif_set_addr(&xnetif, &ipaddr , &netmask, &gw);
  221. PRINT_USART("DHCP timeout\n\r");
  222. PRINT_USART("\n\rStatic IP address\n\r");
  223. PRINT_USART(ipaddr_ntoa(&ipaddr));
  224. PRINT_USART("\n\r");
  225. isIpReceived = true;
  226. vTaskDelay(50);
  227. /* Установлен статический IP, можно отправить трап о перезагрузке устройства */
  228. // SNMP_SendUserTrap(DEVICE_REBOOTED);
  229. vTaskDelete(xHandleDHCP);
  230. }
  231. }
  232. }
  233. break;
  234. default: break;
  235. }
  236. vTaskDelay(250);
  237. }
  238. }
  239. /**
  240. * @brief Запуск задачи переинициализации WEB
  241. */
  242. void WEB_StartReinitTask(void)
  243. {
  244. xTaskCreate(vTaskWebReinit, "ReinitWeb", 2*configMINIMAL_STACK_SIZE, NULL,
  245. tskIDLE_PRIORITY, &xHandleWebReinit);
  246. }
  247. /**
  248. * @brief Переинициализация WEB. Задача положенное время отслеживает флаг
  249. * fConfirmWebParams.
  250. * Если флаг устанавливается в положенное время,
  251. * временные настройки web перезаписываются в постоянные, сбрасывается
  252. * флаг sSettings.sFlags.netsettingsChanged и вся структура настроек
  253. * сохраняется в памяти.
  254. * Если флаг не устанавливается в положенное время, то сбрасывается
  255. * флаг sSettings.sFlags.netsettingsChanged, сохраняется вся структура
  256. * настроек в памяти и контроллер перезагружается.
  257. */
  258. void vTaskWebReinit(void * pvParameters)
  259. {
  260. static uint16_t timeCounter = 0;
  261. for (;;)
  262. {
  263. /* Контроль времени работы задачи */
  264. if (timeCounter++ > TIME_COUNTER_10_MIN)
  265. {
  266. SetWebReinitFlag(false);
  267. HTTP_SaveSettings();
  268. vTaskDelay(1010);
  269. Reboot();
  270. }
  271. if (fConfirmWebParams)
  272. {
  273. fConfirmWebParams = false;
  274. /* Сохраняем временные сетевые настройки в постоянные */
  275. sSettings.sWebParams.dhcpEnable = sSettings.sWebTempParams.dhcpEnable;
  276. strcpy(sSettings.sWebParams.ip, sSettings.sWebTempParams.ip);
  277. strcpy(sSettings.sWebParams.gate, sSettings.sWebTempParams.gate);
  278. strcpy(sSettings.sWebParams.mask, sSettings.sWebTempParams.mask);
  279. #ifdef HARDWARE_BT6708
  280. for(uint8_t i = 0; i < MAX_WHITE_LIST; i++){
  281. strcpy(sSettings.sWhiteList[i].ip_range, sSettings.sWhiteListTemp[i].ip_range);
  282. sSettings.sWhiteList[i].ip = sSettings.sWhiteListTemp[i].ip;
  283. sSettings.sWhiteList[i].mask = sSettings.sWhiteListTemp[i].mask;
  284. }
  285. #endif
  286. HTTP_SaveSettings();
  287. vTaskDelete(xHandleWebReinit);
  288. }
  289. vTaskDelay(1000);
  290. }
  291. }
  292. void SaveWEBparam(void)
  293. {
  294. sSettings.sWebParams.dhcpEnable = sSettings.sWebTempParams.dhcpEnable;
  295. strcpy(sSettings.sWebParams.ip, sSettings.sWebTempParams.ip);
  296. strcpy(sSettings.sWebParams.gate, sSettings.sWebTempParams.gate);
  297. strcpy(sSettings.sWebParams.mask, sSettings.sWebTempParams.mask);
  298. }
  299. /**
  300. * @brief Возвращает true если сетевые параметры изменились
  301. */
  302. bool GetStateWebReinit(void)
  303. {
  304. /* Статус dhcp изменился? */
  305. if (sSettings.sWebParams.dhcpEnable != sSettings.sWebTempParams.dhcpEnable)
  306. {
  307. /* Включили dhcp */
  308. if (sSettings.sWebTempParams.dhcpEnable == 1)
  309. {
  310. /* Устанавилваем флаг */
  311. SetWebReinitFlag(true);
  312. return true;
  313. }
  314. /* Выключили dhcp */
  315. else
  316. {
  317. /* Устанавилваем флаг */
  318. SetWebReinitFlag(true);
  319. return true;
  320. }
  321. }
  322. /* Изменился IP? */
  323. if (strstr(sSettings.sWebParams.ip, sSettings.sWebTempParams.ip) == 0)
  324. {
  325. /* Устанавилваем флаг */
  326. SetWebReinitFlag(true);
  327. return true;
  328. }
  329. /* Изменился шлюз? */
  330. if (strstr(sSettings.sWebParams.gate, sSettings.sWebTempParams.gate) == 0)
  331. {
  332. /* Устанавилваем флаг */
  333. SetWebReinitFlag(true);
  334. return true;
  335. }
  336. /* Изменилась маска? */
  337. if (strstr(sSettings.sWebParams.mask, sSettings.sWebTempParams.mask) == 0)
  338. {
  339. /* Устанавилваем флаг */
  340. SetWebReinitFlag(true);
  341. return true;
  342. }
  343. #ifdef HARDWARE_BT6708
  344. /* Изменился диапазон доверительных хостов? */
  345. for(uint8_t i = 0; i < MAX_WHITE_LIST; i++){
  346. if (strstr(sSettings.sWhiteList[i].ip_range, sSettings.sWhiteListTemp[i].ip_range) == 0)
  347. {
  348. // Устанавилваем флаг
  349. SetWebReinitFlag(true);
  350. return true;
  351. }
  352. }
  353. #endif
  354. return false;
  355. }
  356. /*********** Portions COPYRIGHT 2012 Embest Tech. Co., Ltd.*****END OF FILE****/