settings_api.c 35 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133
  1. #include "at32f403a_407.h"
  2. #include "settings_api.h"
  3. #include "sys_api.h"
  4. #include "FreeRTOS.h"
  5. #include "task.h"
  6. #include "queue.h"
  7. #include "semphr.h"
  8. #include "common_config.h"
  9. #include "common.h"
  10. #include "at32_uid.h"
  11. #include "hash.h"
  12. #include <math.h>
  13. #include <string.h>
  14. #include <stdlib.h>
  15. #include <stdio.h>
  16. SemaphoreHandle_t flash_mutex;
  17. // Флаг подтверждения новых сетевых параметров пользователем
  18. bool fConfirmWebParams = false;
  19. // Системные настройки
  20. sys_settings_t sys_settings;
  21. // Общая структура настроек
  22. settings_t settings;
  23. //
  24. void init_settings(void)
  25. {
  26. flash_mutex = xSemaphoreCreateMutex();
  27. }
  28. // Загрузка структуры настроек из flesh
  29. void settings_load(settings_t *settings)
  30. {
  31. uint32_t loadCRC; // CRC из flash
  32. uint32_t newCRC; // CRC загруженной структуры настроек
  33. bool need_default = false;
  34. settings_read_from_flash((uint8_t*)settings, sizeof(settings_t));
  35. // Считываем CRC из флеш памяти
  36. loadCRC = (*(uint32_t*)CRC_ADDRESS);
  37. // Рассчитываем CRC для структуры настроек
  38. newCRC = settings_get_crc(settings);
  39. // Если CRC не совпадают нужно прошивать дефолтные настройки
  40. if (loadCRC != newCRC) {
  41. need_default = true;
  42. }
  43. // CRC совпала, проверяем контрольное слово если слово не совпадает
  44. // то это значит, что поплыла структура нстроек, прошиваем дефолт
  45. else if (settings->control_word != SETTINGS_CONTROL_WORD)
  46. {
  47. need_default = true;
  48. }
  49. // CRC и контрольное слово совпали, проверяем номер версии настроек.
  50. // Если версия в настройках и прошивке не совпадают
  51. // (при обновлении изменили структуру настроек), прошиваем дефолт
  52. else if (settings->settings_version != SETTINGS_VERSION)
  53. {
  54. need_default = true;
  55. }
  56. // Прошиваем дефолтные настройки если нужно
  57. if (need_default)
  58. {
  59. settings_set_all_default();
  60. settings_save(settings);
  61. }
  62. #if 1
  63. //SETTINGS_Print();
  64. #endif
  65. }
  66. //
  67. void settings_read_from_flash(uint8_t *data, uint32_t size)
  68. {
  69. uint32_t baseAddress = SETTINGS_SECTOR;
  70. for (uint32_t i = 0; i < size; i++)
  71. *data++ = (*(uint32_t*)baseAddress++);;
  72. }
  73. //
  74. uint32_t settings_get_crc(settings_t *settings)
  75. {
  76. crc_data_reset();
  77. return crc_block_calculate((uint32_t*)settings, sizeof(settings_t)/4 - 1);
  78. }
  79. //
  80. uint32_t settings_get_crit_sec_crc(settings_t *settings)
  81. {
  82. crc_data_reset();
  83. uint32_t critsec_len = (uint32_t)((uint8_t *)(&settings->critical_section_crc) - (uint8_t *)settings) / 4;
  84. return crc_block_calculate((uint32_t *)settings, critsec_len);
  85. }
  86. // Сброс всех настроек в значения по умолчанию
  87. void settings_set_all_default(void)
  88. {
  89. settings_set_modbus_def(&settings.com_settings.mb_port);
  90. settings.settings_version = SETTINGS_VERSION;
  91. settings.critical_section_crc = settings_get_crit_sec_crc(&settings);
  92. settings.control_word = SETTINGS_CONTROL_WORD;
  93. #if 0
  94. SETTINGS_SetWebParamsDef();
  95. SETTINGS_SetTempWebParamsDef();
  96. SETTINGS_SetInfoDef();
  97. SETTINGS_SetGSMDef();
  98. SETTINGS_SetFlagsDef();
  99. SETTINGS_SetEthternetSwitchDef();
  100. SETTINGS_SetSntpDef();
  101. SETTINGS_SetServerParamsDef();
  102. SETTINGS_SetProxyParamsDef();
  103. SETTINGS_SetPortGwDef();
  104. SETTINGS_SetPSDDef();
  105. SETTINGS_SetServiceDef();
  106. sSettings.settVer = SETTINGS_VERSION;
  107. sSettings.CritSecCRC = settings_get_crit_sec_crc();
  108. sSettings.controlWorld = SETTINGS_CONTROL_WORD;
  109. #endif
  110. }
  111. // -------------------------------------------------------------------------- //
  112. // Настройки по умолчанию
  113. //
  114. void settings_set_modbus_def(uint16_t *mb_port)
  115. {
  116. modbus_t mb_settings;
  117. mb_settings.baud = BRD_115200;
  118. mb_settings.parity = NO_PAR;
  119. mb_settings.databits = DATABITS_8;
  120. mb_settings.stopbits = STOP_1;
  121. settings_conv_modbus_def(&mb_settings, mb_port);
  122. }
  123. //
  124. void settings_conv_modbus_def(modbus_t *mb_settings, uint16_t *mb_port)
  125. {
  126. uint16_t param = 0;
  127. // Количестро стоп бит (0-1 биты)
  128. if (mb_settings->stopbits == STOP_1)
  129. param = 0x00;
  130. else if (mb_settings->stopbits == STOP_2)
  131. param = 0x02;
  132. // Длина слова (2ой бит)
  133. param |= 0x00 << 2;
  134. // Контроль четности (3-4 биты)
  135. if (mb_settings->parity == NO_PAR)
  136. param |= 0x00 << 3;
  137. else if (mb_settings->parity == EVEN_PAR)
  138. param |= 0x02 << 3;
  139. else if (mb_settings->parity == ODD_PAR)
  140. param |= 0x03 << 3;
  141. // Скорость (5 - 7 биты)
  142. switch (mb_settings->baud)
  143. {
  144. case BRD_2400 :
  145. param |= 0x00 << 5;
  146. break;
  147. case BRD_4800 :
  148. param |= 0x01 << 5;
  149. break;
  150. case BRD_9600 :
  151. param |= 0x02 << 5;
  152. break;
  153. case BRD_19200 :
  154. param |= 0x03 << 5;
  155. break;
  156. case BRD_38400 :
  157. param |= 0x04 << 5;
  158. break;
  159. case BRD_57600 :
  160. param |= 0x05 << 5;
  161. break;
  162. case BRD_115200 :
  163. param |= 0x06 << 5;
  164. break;
  165. default : break;
  166. }
  167. *mb_port = param;
  168. }
  169. // -------------------------------------------------------------------------- //
  170. // Запись структуры настроек во flash
  171. void settings_save(settings_t *settings)
  172. {
  173. xSemaphoreTake(flash_mutex, portMAX_DELAY);
  174. settings->critical_section_crc = settings_get_crit_sec_crc(settings);
  175. settings_write_to_flash((uint8_t*)settings, sizeof(settings_t));
  176. xSemaphoreGive(flash_mutex);
  177. }
  178. //
  179. void settings_write_to_flash(uint8_t *data, uint32_t size)
  180. {
  181. uint32_t baseAddress = SETTINGS_SECTOR;
  182. uint32_t checkCrc = 0;
  183. uint32_t crc = settings_get_crc((settings_t*)data);
  184. flash_status_type status;
  185. uint8_t *ptr = data;
  186. for (uint8_t i = 0; i < 3; i++)
  187. {
  188. flash_unlock();
  189. settings_erase_flash_sector();
  190. for (uint32_t i = 0; i < size; i++)
  191. if ((status = flash_byte_program(baseAddress++, *data++)) != FLASH_OPERATE_DONE) {
  192. DBG printf("FLASH_ProgramByte error: status = %d\r\n", status);
  193. break;
  194. }
  195. if ((status = flash_word_program((uint32_t)CRC_ADDRESS, crc)) != FLASH_OPERATE_DONE) {
  196. DBG printf("FLASH_ProgramWord error: status = %d\r\n", status);
  197. }
  198. flash_lock();
  199. /* Считываем что записали */
  200. settings_read_from_flash(ptr, sizeof(settings_t));
  201. checkCrc = settings_get_crc((settings_t*)ptr);
  202. /* Проверяем CRC того что было записано */
  203. if (checkCrc == crc)
  204. break;
  205. }
  206. }
  207. // Очистка сектора настроек
  208. void settings_erase_flash_sector(void)
  209. {
  210. flash_status_type status;
  211. if ((status = flash_sector_erase(SETTINGS_SECTOR)) != FLASH_OPERATE_DONE) {
  212. DBG printf("SETTINGS_EraseFlashSector error: status = %d/r/n", status);
  213. }
  214. }
  215. #if 0
  216. // Установить параметры сетевого подключения по умолчанию
  217. void SETTINGS_SetWebParamsDef(void)
  218. {
  219. strcpy(sSettings.sWebParams.ip, "192.168.10.254");
  220. strcpy(sSettings.sWebParams.gate, "192.168.10.1");
  221. strcpy(sSettings.sWebParams.mask, "255.255.255.0");
  222. strcpy(sSettings.sWebParams.dns1, "8.8.8.8");
  223. strcpy(sSettings.sWebParams.dns2, "8.8.4.4");
  224. sSettings.sWebParams.dhcpEnable = 1;
  225. }
  226. // Установить временные параметры сетевого подключения по умолчанию
  227. void SETTINGS_SetTempWebParamsDef(void)
  228. {
  229. strcpy(sSettings.sWebTempParams.ip, "192.168.10.254");
  230. strcpy(sSettings.sWebTempParams.gate, "192.168.10.1");
  231. strcpy(sSettings.sWebTempParams.mask, "255.255.255.0");
  232. strcpy(sSettings.sWebTempParams.dns1, "8.8.8.8");
  233. strcpy(sSettings.sWebTempParams.dns2, "8.8.4.4");
  234. sSettings.sWebTempParams.dhcpEnable = 1;
  235. }
  236. // Установить Информацию об устройстве по умолчанию
  237. void SETTINGS_SetInfoDef(void)
  238. {
  239. #if 0
  240. sys_settings_t *sSys = NULL;
  241. sSys = pvPortMalloc(sizeof(*sSys));
  242. if (sSys)
  243. {
  244. SYS_Load(sSys);
  245. strcpy(sSettings.sInfo.mac, sSys->mac);
  246. strcpy(sSettings.sInfo.serialNumber, sSys->serial);
  247. strcpy(sSettings.sInfo.productionData, sSys->proddate);
  248. strcpy(sSettings.sFlags.testState, sSys->testState);
  249. vPortFree(sSys);
  250. }
  251. else
  252. {
  253. strcpy(sSettings.sInfo.productionData, "00.00.00 00:00");
  254. strcpy(sSettings.sInfo.mac, DEVICE_MAC);
  255. strcpy(sSettings.sInfo.serialNumber, DEVICE_SERIAL);
  256. memset(sSettings.sFlags.testState, 0, 16);
  257. }
  258. sSettings.sInfo.id = 0;
  259. strcpy(sSettings.sInfo.location, "");
  260. strcpy(sSettings.sInfo.owner, "");
  261. strcpy(sSettings.sInfo.comments, "");
  262. strcpy(sSettings.sInfo.incharge, "");
  263. #endif
  264. }
  265. /**
  266. * @brief Установить флаги по умолчанию
  267. */
  268. void SETTINGS_SetFlagsDef(void)
  269. {
  270. sSettings.sFlags.netsettingsChanged = false;
  271. }
  272. /**
  273. * @brief Установить параметры сетевого подключения по умолчанию
  274. */
  275. void SETTINGS_SetEthternetSwitchDef(void)
  276. {
  277. sSettings.sEthernet.Enabled = true;
  278. sSettings.sEthernet.prior = 1;
  279. strcpy(sSettings.sEthernet.ip_test, "10.254.0.33");
  280. }
  281. /**
  282. * @brief Установить параметры GSM подключения по умолчанию
  283. */
  284. void SETTINGS_SetGSMDef(void)
  285. {
  286. for(uint8_t i = 0; i < NUM_GSM; i++)
  287. {
  288. sSettings.sGSM[i].Enabled = true;
  289. sSettings.sGSM[i].prior = 0;
  290. sSettings.sGSM[i].type_profile = USER;
  291. strcpy(sSettings.sGSM[i].ip_test, "10.254.0.33");
  292. strcpy(sSettings.sGSM[i].APNaddr, "MDUDPTN");
  293. strcpy(sSettings.sGSM[i].APNlogin, "");
  294. strcpy(sSettings.sGSM[i].APNpass, "");
  295. strcpy(sSettings.sGSM[i].msisdn, "");
  296. sSettings.sGSM[i].timeout = 30;
  297. sSettings.sGSM[i].period_test = 100;
  298. sSettings.sGSM[i].num_bad_connect = 3;
  299. sSettings.sGSM[i].modem_mode = AUTOMATIC;
  300. }
  301. sSettings.sGSM[0].prior = 3;
  302. sSettings.sGSM[1].prior = 2;
  303. }
  304. /**
  305. * @brief Установить параметры SNTP по умолчанию
  306. */
  307. void SETTINGS_SetSntpDef(void)
  308. {
  309. sSettings.sSNTP.sntpEnable = true;
  310. strcpy(sSettings.sSNTP.ip1, "10.254.0.50");
  311. strcpy(sSettings.sSNTP.ip2, "10.254.0.50");
  312. sSettings.sSNTP.timeZone = 3.0;
  313. strcpy(sSettings.sSNTP.data, "none");
  314. }
  315. /**
  316. * @brief Установить параметры подключения к серверу по умолчанию
  317. */
  318. void SETTINGS_SetServerParamsDef(void)
  319. {
  320. strcpy(sSettings.sServer.ip, "10.254.0.69");
  321. sSettings.sServer.port = 1884;
  322. sSettings.sServer.serverEnable = true;
  323. sSettings.sServer.controlConnect = true;
  324. }
  325. /**
  326. * @brief Установить параметры PROXY по умолчанию
  327. */
  328. void SETTINGS_SetProxyParamsDef(void)
  329. {
  330. strcpy(sSettings.sProxy.ip, "79.135.245.84");
  331. sSettings.sProxy.port = 55679;
  332. sSettings.sProxy.local_port = 0;
  333. }
  334. /**
  335. * @brief Установить значение настроек прозрачного порта по умолчанию
  336. */
  337. void SETTINGS_SetPortGwDef(void)
  338. {
  339. for(uint8_t i = 0; i < NUM_PORTGW; i ++)
  340. {
  341. sSettings.sPortGw[i].enableDispatch = false; // Параллельная диспетчеризация (Вкл./Выкл.)
  342. sSettings.sPortGw[i].type_port = ACCOUNT_METER; // Тип порта (Модем / Прибор учета)
  343. sSettings.sPortGw[i].connect_port = 2; // Связанный порт (#1-#3)
  344. strcpy(sSettings.sPortGw[i].description, ""); // Описание
  345. sSettings.sPortGw[i].enabled = true; // Вкл/Откл
  346. sSettings.sPortGw[i].transtype = GW_TCP; // Тип транспорта (TCP/UDP)
  347. sSettings.sPortGw[i].mode = GW_SERVER; // Режим: Клиент/Сервер
  348. strcpy(sSettings.sPortGw[i].ip, "192.168.1.2"); // IP-адрес сервера (для клиента)
  349. sSettings.sPortGw[i].port = 1001; // Порт
  350. sSettings.sPortGw[i].rs_mode = RS_485_1; // Режим (RS-232/RS-485)
  351. sSettings.sPortGw[i].uart_set.baud = BRD_9600; // Скорость порта
  352. sSettings.sPortGw[i].uart_set.parity = NO_PAR; // Четность
  353. sSettings.sPortGw[i].uart_set.databits = DATABITS_8; // Число бит данных
  354. sSettings.sPortGw[i].uart_set.stopbits = STOP_1; // Число стоп-бит
  355. }
  356. sSettings.sPortGw[0].rs_mode = RS_232_1;
  357. sSettings.sPortGw[0].port = 1001;
  358. sSettings.sPortGw[0].connect_port = 1;
  359. sSettings.sPortGw[1].rs_mode = RS_485_1;
  360. sSettings.sPortGw[1].port = 1002;
  361. sSettings.sPortGw[1].connect_port = 2;
  362. sSettings.sPortGw[1].enabled = false;
  363. sSettings.sPortGw[2].rs_mode = RS_232_2;
  364. sSettings.sPortGw[2].port = 1003;
  365. sSettings.sPortGw[2].connect_port = 0;
  366. sSettings.sPortGw[2].enabled = false;
  367. }
  368. /**
  369. * @brief Установить значение системы параллельной диспетчеризации по умолчанию
  370. */
  371. void SETTINGS_SetPSDDef(void)
  372. {
  373. sSettings.sPSD.enabled = false;
  374. sSettings.sPSD.mux_mode = PSD_MODE_7;
  375. sSettings.sPSD.rs_mode = RS_232_1;
  376. sSettings.sPSD.web_port = 0;
  377. sSettings.sPSD.assd_timeout = 120;
  378. }
  379. /**
  380. * @brief Установить значение пароля по умолчанию
  381. */
  382. void SETTINGS_SetServiceDef(void)
  383. {
  384. sSettings.sAuth[0].level = ADMIN;
  385. strcpy(sSettings.sAuth[0].login, "user");
  386. //"b26b1868 705a3f0a a82cbd79 7cd58b4e" uchetmo
  387. *(uint32_t *)sSettings.sAuth[0].hash = 0x68186bb2;
  388. *(uint32_t *)(sSettings.sAuth[0].hash + 4) = 0x0a3f5a70;
  389. *(uint32_t *)(sSettings.sAuth[0].hash + 8) = 0x79bd2ca8;
  390. *(uint32_t *)(sSettings.sAuth[0].hash + 12) = 0x4e8bd57c;
  391. }
  392. /**
  393. * @brief Сброс всех настроек в значения по умолчанию кроме сетевых настроек
  394. */
  395. void SETTINGS_SetPartDefault(void)
  396. {
  397. SETTINGS_SetFlagsDef();
  398. SETTINGS_SetEthternetSwitchDef();
  399. SETTINGS_SetWebParamsDef();
  400. SETTINGS_SetTempWebParamsDef();
  401. SETTINGS_SetGSMDef();
  402. SETTINGS_SetSntpDef();
  403. SETTINGS_SetServerParamsDef();
  404. SETTINGS_SetProxyParamsDef();
  405. SETTINGS_SetPortGwDef();
  406. SETTINGS_SetPSDDef();
  407. sSettings.settVer = SETTINGS_VERSION;
  408. sSettings.CritSecCRC = settings_get_crit_sec_crc();
  409. sSettings.controlWorld = SETTINGS_CONTROL_WORD;
  410. }
  411. #endif
  412. #if 0
  413. /**
  414. * @brief
  415. */
  416. /**
  417. * @brief Сброс флага boottry в регистре RTC
  418. */
  419. void SETTINGS_ResetBootTry(void)
  420. {
  421. uint8_t bootTry = (uint8_t)bpr_data_read(BPR_DATA2);
  422. #if 0
  423. if (bootTry > 0 )
  424. {
  425. bootTry = 0;
  426. bpr_data_write(BPR_DATA2, 0);
  427. // Check FW update flag
  428. if (bpr_data_read(BPR_DATA3)) {
  429. log_add_record(UPDATED_FW, 0);
  430. // Clear FW update flag
  431. bpr_data_write(BPR_DATA3, 0);
  432. }
  433. }
  434. #endif
  435. }
  436. /**
  437. * @brief Преобразует mac адрес строкового формата в массив uint8_t
  438. * @param mac - буфер для вывода mac адреса
  439. */
  440. void SETTINGS_GetMac(uint8_t *mac)
  441. {
  442. char dummy[2];
  443. char *macPtr = sSettings.sInfo.mac;
  444. for (uint8_t i = 0; i < 6; i++)
  445. {
  446. strncpy(dummy, macPtr+i*3, 2);
  447. mac[i] = (uint8_t)strtol(dummy, NULL, 16);
  448. }
  449. }
  450. /**
  451. * @brief Установить дату производства
  452. */
  453. void SETTINGS_SetProDate(char *proDate, uint8_t len)
  454. {
  455. #if 0
  456. sys_settings_t *sSys = NULL;
  457. sSys = pvPortMalloc(sizeof(*sys_settings_t));
  458. if (sSys)
  459. {
  460. SYS_Load(sSys);
  461. strcpy(sSys->proddate, proDate);
  462. sys_save(sSys);
  463. memset(sSettings.sInfo.productionData, 0, 40);
  464. memcpy(sSettings.sInfo.productionData, proDate, len);
  465. vPortFree(sSys);
  466. //SETTINGS_Save();
  467. }
  468. #endif
  469. }
  470. /**
  471. * @brief Установить серийный номер
  472. */
  473. void SETTINGS_SetSerialNumber(char *sn, uint8_t len)
  474. {
  475. #if 0
  476. sys_settings_t *sSys = NULL;
  477. sSys = pvPortMalloc(sizeof(*sSys));
  478. if (sSys)
  479. {
  480. SYS_Load(sSys);
  481. strcpy(sSys->serial, sn);
  482. sys_save(sSys);
  483. memset(sSettings.sInfo.serialNumber, 0, 16);
  484. memcpy(sSettings.sInfo.serialNumber, sn, len);
  485. vPortFree(sSys);
  486. //SETTINGS_Save();
  487. }
  488. #endif
  489. }
  490. /**
  491. * @brief Установить MAC
  492. */
  493. void SysSETTINGS_SetMAC(char *mac, uint8_t len)
  494. {
  495. #if 0
  496. sys_settings_t *sSys = NULL;
  497. sSys = pvPortMalloc(sizeof(*sSys));
  498. if (sSys)
  499. {
  500. SYS_Load(sSys);
  501. strcpy(sSys->mac, mac);
  502. sys_save(sSys);
  503. memset(sSettings.sInfo.mac, 0, 18);
  504. memcpy(sSettings.sInfo.mac, mac, len);
  505. vPortFree(sSys);
  506. //SETTINGS_Save();
  507. }
  508. #endif
  509. }
  510. /**
  511. * @brief Установить статус тестирования
  512. */
  513. void SETTINGS_StatusTest(char *status, uint8_t len)
  514. {
  515. #if 0
  516. SYS_t *sSys = NULL;
  517. sSys = pvPortMalloc(sizeof(*sSys));
  518. if (sSys)
  519. {
  520. SYS_Load(sSys);
  521. strcpy(sSys->testState, status);
  522. sys_save(sSys);
  523. memset(sSettings.sFlags.testState, 0, 16);
  524. memcpy(sSettings.sFlags.testState, status, len);
  525. vPortFree(sSys);
  526. SETTINGS_Save();
  527. }
  528. #endif
  529. }
  530. /**
  531. * @brief Установить статус тестирования "T2OK"
  532. */
  533. void SETTINGS_SetT2OK(void)
  534. {
  535. #if 0
  536. SYS_t *sSys = NULL;
  537. sSys = pvPortMalloc(sizeof(*sSys));
  538. if (sSys)
  539. {
  540. SYS_Load(sSys);
  541. //SETTINGS_SetEthternetSwitchDef(); // TODO временное решение
  542. memset(sSettings.sFlags.testState, 0, 16);
  543. memcpy(sSettings.sFlags.testState, "T2OK", 4);
  544. strcpy(sSys->testState, sSettings.sFlags.testState);
  545. sys_save(sSys);
  546. vPortFree(sSys);
  547. SETTINGS_Save();
  548. }
  549. #endif
  550. }
  551. /**
  552. * @brief Сбросить статус тестирования "T2OK"
  553. */
  554. void SETTINGS_ResetT2OK(void)
  555. {
  556. #if 0
  557. SYS_t *sSys = NULL;
  558. sSys = pvPortMalloc(sizeof(*sSys));
  559. if (sSys)
  560. {
  561. SYS_Load(sSys);
  562. SETTINGS_SetEthternetSwitchDef(); // TODO временное решение
  563. memset(sSettings.sFlags.testState, 0, 16);
  564. strcpy(sSys->testState, sSettings.sFlags.testState);
  565. sys_save(sSys);
  566. vPortFree(sSys);
  567. SETTINGS_Save();
  568. }
  569. #endif
  570. }
  571. /**
  572. * @brief Устанавливает mac адрес исходя из unique id
  573. */
  574. void COM_SetTestMAC(void)
  575. {
  576. uint8_t octet1 = 0;
  577. uint8_t octet2 = 0;
  578. uint8_t octet3 = 0;
  579. uint8_t octet4 = 0;
  580. uint8_t octet5 = 0;
  581. char AT_ID_HEX[12];
  582. uint8_t hash[16];
  583. GetAT32IDInt(AT_ID_HEX);
  584. md5hash(hash, (unsigned char*)AT_ID_HEX, sizeof(AT_ID_HEX));
  585. octet1 = hash[0];
  586. octet2 = hash[1];
  587. octet3 = hash[2];
  588. octet4 = hash[3];
  589. octet5 = hash[4];
  590. /* Устанавливаем MAC, но не сохраняем */
  591. //snprintf(sSettings.sInfo.mac, MAC_LEN, "%02X-%02X-%02X-%02X-%02X-00", octet1 & 0xFE, octet2, octet3, octet4, octet5);
  592. }
  593. /**
  594. * @brief Включить DHCP
  595. */
  596. void SETTINGS_SetDHCPOn(void)
  597. {
  598. sSettings.sWebTempParams.dhcpEnable = 1;
  599. }
  600. //
  601. void SETTINGS_Print(void)
  602. {
  603. printf("\r\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n");
  604. printf(" Общие настройки для bootloader и FW");
  605. printf("\r\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n\n");
  606. printf("Сетевые настройки:\r\n");
  607. printf("\tIP: ");
  608. printf("%s\r\n", sSettings.sWebParams.ip);
  609. printf("\tGate: ");
  610. printf("%s\r\n", sSettings.sWebParams.gate);
  611. printf("\tMask: ");
  612. printf("%s\r\n", sSettings.sWebParams.mask);
  613. printf("\tDNS1: ");
  614. printf("%s\r\n", sSettings.sWebParams.dns1);
  615. printf("\tDNS2: ");
  616. printf("%s\r\n", sSettings.sWebParams.dns2);
  617. if (sSettings.sWebParams.dhcpEnable)
  618. printf("\tDHCP: On\r\n");
  619. else
  620. printf("\tDHCP: Off\r\n");
  621. // -------------------------------------------------------------------------- //
  622. printf("\r\nИнформация об устройстве:\r\n");
  623. printf("\tID: ");
  624. printf("%u\r\n", sSettings.sInfo.id);
  625. printf("\tДата производства: ");
  626. printf("%s\r\n", sSettings.sInfo.productionData);
  627. printf("\tMAC: ");
  628. printf("%s\r\n", sSettings.sInfo.mac);
  629. printf("\tСерийный номер: ");
  630. printf("%s\r\n", sSettings.sInfo.serialNumber);
  631. printf("\tВладелец: ");
  632. printf("%s\r\n", sSettings.sInfo.owner);
  633. printf("\tАдрес: ");
  634. printf("%s\r\n", sSettings.sInfo.location);
  635. printf("\tКомментарии: ");
  636. printf("%s\r\n", sSettings.sInfo.comments);
  637. printf("\tОтветственное лицо: ");
  638. printf("%s\r\n", sSettings.sInfo.incharge);
  639. // -------------------------------------------------------------------------- //
  640. for (uint8_t i = 0; i < NUM_GSM; i++)
  641. {
  642. printf("\r\nНастройки GSM модема:\r\n");
  643. printf("Профиль GSM %u:\r\n", i + 1);
  644. if (sSettings.sGSM[i].Enabled)
  645. printf("\tChannel: On\r\n");
  646. else
  647. printf("\tChannel: Off\r\n");
  648. printf("\tПриоритет: %u\r\n", sSettings.sGSM[i].prior);
  649. switch (sSettings.sGSM[i].type_profile)
  650. {
  651. case BEELINE :
  652. printf("\tТип профиля: BEELINE\r\n");
  653. break;
  654. case MTS :
  655. printf("\tТип профиля: MTS\r\n");
  656. break;
  657. case MEGAFON :
  658. printf("\tТип профиля: MEGAFON\r\n");
  659. break;
  660. case TELE2 :
  661. printf("\tТип профиля: TELE2\r\n");
  662. break;
  663. case USER :
  664. printf("\tТип профиля: USER\r\n");
  665. break;
  666. }
  667. printf("\tAPN: %s\r\n", sSettings.sGSM[i].APNaddr);
  668. printf("\tAPN логин: %s\r\n", sSettings.sGSM[i].APNlogin);
  669. printf("\tAPN пароль: %s\r\n", sSettings.sGSM[i].APNpass);
  670. printf("\tIP для проверки связи: %s\r\n", sSettings.sGSM[i].ip_test);
  671. printf("\tНомер SIM карты: %s\r\n", sSettings.sGSM[i].msisdn);
  672. printf("\tТаймаут ожидания ответа: %u, с\r\n", sSettings.sGSM[i].timeout);
  673. printf("\tВремя проверки каналов связи: %u\r\n", sSettings.sGSM[i].period_test);
  674. printf("\tКоличество неудачных попыток: %u\r\n", sSettings.sGSM[i].num_bad_connect);
  675. printf("\tРежим работы GSM модема: ");
  676. switch (sSettings.sGSM[i].modem_mode)
  677. {
  678. case AUTOMATIC :
  679. printf("Automatic\r\n");
  680. break;
  681. case GSM_3G :
  682. printf("GSM + 3G\r\n");
  683. break;
  684. case LTE :
  685. printf("LTE only\r\n");
  686. break;
  687. case WCDMA :
  688. printf("3G only\r\n");
  689. break;
  690. case GSM :
  691. printf("GSM only\r\n");
  692. break;
  693. }
  694. }
  695. // -------------------------------------------------------------------------- //
  696. printf("\r\nCRC критической секции: %X\r\n", sSettings.CritSecCRC);
  697. // -------------------------------------------------------------------------- //
  698. printf("\r\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n");
  699. printf(" Секция настрок для FW");
  700. printf("\r\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n\n");
  701. // -------------------------------------------------------------------------- //
  702. printf("\r\nФлаги:\r\n");
  703. printf("\tИзменение сетевых настроек: %u\r\n", sSettings.sFlags.netsettingsChanged);
  704. printf("\tСтатус тестирования: %s\r\n", sSettings.sFlags.testState);
  705. // -------------------------------------------------------------------------- //
  706. printf("\r\nEthernet канал:\r\n");
  707. if (sSettings.sEthernet.Enabled)
  708. printf("\tКанал: вкл\r\n");
  709. else
  710. printf("\tКанал: выкл\r\n");
  711. printf("\tПриоритет: %u\r\n", sSettings.sEthernet.prior);
  712. printf("\tIP для проверки связи: %s\r\n", sSettings.sEthernet.ip_test);
  713. // -------------------------------------------------------------------------- //
  714. printf("\r\nСервер:\r\n");
  715. if (sSettings.sServer.serverEnable)
  716. printf("\tСервер: вкл\r\n");
  717. else
  718. printf("\tСервер: выкл\r\n");
  719. printf("\tIP: %s\r\n", sSettings.sServer.ip);
  720. printf("\tPort: %u\r\n", sSettings.sServer.port);
  721. if (sSettings.sServer.controlConnect)
  722. printf("\tКонтроль соединения: вкл\r\n");
  723. else
  724. printf("\tКонтроль соединения: выкл\r\n");
  725. // -------------------------------------------------------------------------- //
  726. printf("\r\nProxy:\r\n");
  727. printf("\tIP: %s\r\n", sSettings.sProxy.ip);
  728. printf("\tPort: %u\r\n", sSettings.sProxy.port);
  729. printf("\tLocal port: %u\r\n", sSettings.sProxy.local_port);
  730. // -------------------------------------------------------------------------- //
  731. for (uint8_t i = 0; i < MAX_WEB_USERS; i++)
  732. {
  733. printf("\r\nНастройки аутентификации пользователя %u:\r\n", i + 1);
  734. switch (sSettings.sAuth[i].level)
  735. {
  736. case FACTORY :
  737. printf("\tУровень пользователя: FACTORY\r\n");
  738. break;
  739. case ADMIN :
  740. printf("\tУровень пользователя: ADMIN\r\n");
  741. break;
  742. }
  743. printf("\tlogin: %s\r\n", sSettings.sAuth[i].login);
  744. printf("\thash: %X\r\n", sSettings.sAuth[i].hash);
  745. }
  746. // -------------------------------------------------------------------------- //
  747. for (uint8_t i = 0; i < NUM_PORTGW; i++)
  748. {
  749. printf("\r\nНастройки прозрачного порта %u:\r\n", i + 1);
  750. if (sSettings.sPortGw[i].enableDispatch)
  751. printf("\tПараллельная диспетчеризация: вкл\r\n");
  752. else
  753. printf("\tПараллельная диспетчеризация: выкл\r\n");
  754. if (sSettings.sPortGw[i].enabled)
  755. printf("\tПрозрачный порт: вкл\r\n");
  756. else
  757. printf("\tПрозрачный порт: выкл\r\n");
  758. switch (sSettings.sPortGw[i].type_port)
  759. {
  760. case MODEM :
  761. printf("\tТип порта: Модем\r\n");
  762. break;
  763. case ACCOUNT_METER :
  764. printf("\tТип порта: Прибор учета\r\n");
  765. break;
  766. }
  767. printf("\tСвязанный порт %u:\r\n", sSettings.sPortGw[i].connect_port);
  768. printf("\tОписание: %s\r\n", sSettings.sPortGw[i].description);
  769. switch (sSettings.sPortGw[i].transtype)
  770. {
  771. case GW_UDP :
  772. printf("\tТип транспорта: UDP\r\n");
  773. break;
  774. case GW_TCP :
  775. printf("\tТип транспорта: TCP\r\n");
  776. break;
  777. }
  778. switch (sSettings.sPortGw[i].mode)
  779. {
  780. case GW_SERVER :
  781. printf("\tРежим: сервер\r\n");
  782. break;
  783. case GW_CLIENT :
  784. printf("\tРежим: клиент\r\n");
  785. break;
  786. }
  787. printf("\tIP сервера (режим клиента): %s\r\n", sSettings.sPortGw[i].ip);
  788. printf("\tПорт: %u\r\n", sSettings.sPortGw[i].port);
  789. switch (sSettings.sPortGw[i].rs_mode)
  790. {
  791. case RS_232_1 :
  792. printf("\tРежим (RS-232/RS-485): RS_232_1\r\n");
  793. break;
  794. case RS_232_2 :
  795. printf("\tРежим (RS-232/RS-485): RS_232_2\r\n");
  796. break;
  797. case RS_232_3 :
  798. printf("\tРежим (RS-232/RS-485): RS_232_3\r\n");
  799. break;
  800. case RS_485_1 :
  801. printf("\tРежим (RS-232/RS-485): RS_485_1\r\n");
  802. break;
  803. case RS_485_2 :
  804. printf("\tРежим (RS-232/RS-485): RS_485_2\r\n");
  805. break;
  806. }
  807. switch (sSettings.sPortGw[i].uart_set.baud)
  808. {
  809. case BRD_1200 :
  810. printf("\tBaudrate: 1200\r\n");
  811. break;
  812. case BRD_2400 :
  813. printf("\tBaudrate: 2400\r\n");
  814. break;
  815. case BRD_4800 :
  816. printf("\tBaudrate: 4800\r\n");
  817. break;
  818. case BRD_9600 :
  819. printf("\tBaudrate: 9600\r\n");
  820. break;
  821. case BRD_19200 :
  822. printf("\tBaudrate: 19200\r\n");
  823. break;
  824. case BRD_38400 :
  825. printf("\tBaudrate: 38400\r\n");
  826. break;
  827. case BRD_57600 :
  828. printf("\tBaudrate: 57600\r\n");
  829. break;
  830. case BRD_115200 :
  831. printf("\tBaudrate: 115200\r\n");
  832. break;
  833. case BRD_230400 :
  834. printf("\tBaudrate: 230400\r\n");
  835. break;
  836. case BRD_460800 :
  837. printf("\tBaudrate: 460800\r\n");
  838. break;
  839. }
  840. switch (sSettings.sPortGw[i].uart_set.databits)
  841. {
  842. case DATABITS_7 :
  843. printf("\tData bits: 7\r\n");
  844. break;
  845. case DATABITS_8 :
  846. printf("\tData bits: 8\r\n");
  847. break;
  848. }
  849. switch (sSettings.sPortGw[i].uart_set.stopbits)
  850. {
  851. case STOP_0_5 :
  852. printf("\tStop bits: 0_5\r\n");
  853. break;
  854. case STOP_1 :
  855. printf("\tStop bits: 1\r\n");
  856. break;
  857. case STOP_1_5 :
  858. printf("\tStop bits: 1_5\r\n");
  859. break;
  860. case STOP_2 :
  861. printf("\tStop bits: 2\r\n");
  862. break;
  863. }
  864. }
  865. // -------------------------------------------------------------------------- //
  866. printf("\r\nПротокол SNTP:\r\n");
  867. if (sSettings.sSNTP.sntpEnable)
  868. printf("\tSNTP: вкл\r\n");
  869. else
  870. printf("\tSNTP: выкл\r\n");
  871. printf("\tСервер 1 IP: %s\r\n", sSettings.sSNTP.ip1);
  872. printf("\tСервер 2 IP: %s\r\n", sSettings.sSNTP.ip2);
  873. printf("\tДата последней синхронизации: %s\r\n", sSettings.sSNTP.data);
  874. printf("\tЧасовой пояс (utc): %f\r\n", sSettings.sSNTP.timeZone);
  875. // -------------------------------------------------------------------------- //
  876. printf("\r\nПараллельная диспетчеризация:\r\n");
  877. if (sSettings.sPSD.enabled)
  878. printf("\tДиспечеризация: вкл\r\n");
  879. else
  880. printf("\tДиспечеризация: выкл\r\n");
  881. switch (sSettings.sPSD.mux_mode)
  882. {
  883. case PSD_MODE_1 :
  884. printf("\tРежим (управление мультиплексором): MODE_1 - RS232#1 <-> RS232#2, USART6 <-> RS232#3\r\n");
  885. break;
  886. case PSD_MODE_2 :
  887. printf("\tРежим (управление мультиплексором): MODE_2 - RS485#1 <-> RS232#2, USART6 <-> RS232#3\r\n");
  888. break;
  889. case PSD_MODE_3 :
  890. printf("\tРежим (управление мультиплексором): MODE_3 - RS232#1 <-> RS485#2, USART6 <-> RS232#3\r\n");
  891. break;
  892. case PSD_MODE_4 :
  893. printf("\tРежим (управление мультиплексором): MODE_4 - RS485#1 <-> RS485#2, USART6 <-> RS232#3\r\n");
  894. break;
  895. case PSD_MODE_5 :
  896. printf("\tРежим (управление мультиплексором): MODE_5 - RS232#1 <-> RS232#3\r\n");
  897. break;
  898. case PSD_MODE_6 :
  899. printf("\tРежим (управление мультиплексором): MODE_6 - RS485#1 <-> RS232#3\r\n");
  900. break;
  901. case PSD_MODE_7 :
  902. printf("\tРежим (управление мультиплексором): MODE_7 - USART1 <-> RS485#1, \r\n\t\tUSART3 <-> RS485#2, USART4 <-> RS232#1, \r\n\t\tUSART5 <-> RS232#2, USART6 <-> RS232#3\r\n");
  903. break;
  904. }
  905. switch (sSettings.sPSD.rs_mode)
  906. {
  907. case RS_232_1 :
  908. printf("\tРежим (RS-232/RS-485): RS_232_1\r\n");
  909. break;
  910. case RS_232_2 :
  911. printf("\tРежим (RS-232/RS-485): RS_232_2\r\n");
  912. break;
  913. case RS_232_3 :
  914. printf("\tРежим (RS-232/RS-485): RS_232_3\r\n");
  915. break;
  916. case RS_485_1 :
  917. printf("\tРежим (RS-232/RS-485): RS_485_1\r\n");
  918. break;
  919. case RS_485_2 :
  920. printf("\tРежим (RS-232/RS-485): RS_485_2\r\n");
  921. break;
  922. }
  923. printf("\tНомер прозрачного порта: %u\r\n", sSettings.sPSD.web_port);
  924. printf("\tТаймаут: %u, сек\r\n", sSettings.sPSD.assd_timeout);
  925. // -------------------------------------------------------------------------- //
  926. printf("\r\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\r\n");
  927. printf("\tКонтрольное слово: %u\r\n", sSettings.controlWorld);
  928. printf("\tCRC: %X\r\n", *(uint32_t*)CRC_ADDRESS);
  929. }
  930. #endif