main.cpp 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422
  1. #include "at32f403a_407.h"
  2. #include "at32f403a_407_board.h"
  3. #include "at32f403a_407_clock.h"
  4. #include "common_config.h"
  5. #include "FreeRTOS.h"
  6. #include "task.h"
  7. #include "queue.h"
  8. #include "semphr.h"
  9. extern "C" {
  10. #include "usb_eth.h"
  11. #include "mux.h"
  12. #include "misc.h"
  13. #include "spi_common.h"
  14. #include "user_fatfs.h"
  15. #include "spi_flash.h"
  16. #include "usb_eth.h"
  17. #include "extended_sram.h"
  18. #include "modbus.h"
  19. #include "common_gpio.h"
  20. #include "io.h"
  21. #include "input.h"
  22. #include "output.h"
  23. #include "sys_api.h"
  24. #include "settings_api.h"
  25. #include "update.h"
  26. #include "uptime.h"
  27. #include "rtc.h"
  28. #include "mb.h"
  29. #include "io_utils.h"
  30. #include "buttons.h"
  31. #include "adc_transport.h"
  32. #include "shift_reg.h"
  33. #include "analog_input.h"
  34. #include "dac_transport.h"
  35. #include "log.h"
  36. #include "swap.h"
  37. }
  38. #include "terminal_sbs.h"
  39. #include "terminal_usartbridge.h"
  40. #include <stdio.h>
  41. #include <stdbool.h>
  42. #include <string.h>
  43. #include <stdlib.h>
  44. void init_task(void *argument);
  45. void test_hw_task(void *argument);
  46. void soft_wdt(void *params);
  47. void test_gpio(void *params);
  48. void misc_task(void *params); // TODO перенести в другой модуль
  49. void usb_clock48m_select(usb_clk48_s clk_s);
  50. //
  51. int main(void)
  52. {
  53. __disable_irq();
  54. nvic_vector_table_set(NVIC_VECTTAB_FLASH, 0x08021000);
  55. nvic_priority_group_config(NVIC_PRIORITY_GROUP_4);
  56. __enable_irq();
  57. extend_SRAM();
  58. system_clock_config();
  59. delay_init();
  60. // -------------------------------------------------------------------------
  61. // CLI
  62. sbsTerminal.configure();
  63. terminalUsartBridge.configure();
  64. // -------------------------------------------------------------------------
  65. // USB
  66. #ifdef USB_RNDIS
  67. usb_clock48m_select(USB_CLK_HEXT);
  68. crm_periph_clock_enable(CRM_USB_PERIPH_CLOCK, TRUE);
  69. usb_init();
  70. #endif
  71. #if 1
  72. taskENTER_CRITICAL();
  73. xTaskCreate(soft_wdt, "soft_wdt", configMINIMAL_STACK_SIZE, NULL, configMAX_PRIORITIES - 1, NULL);
  74. xTaskCreate(init_task, "init_task", 10*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  75. //xTaskCreate(test_hw_task, "hw_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  76. xTaskCreate(test_gpio, "gpio_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  77. xTaskCreate(input_task, "input_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  78. xTaskCreate(misc_task, "misc_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  79. xTaskCreate(button_task, "button_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  80. #if defined (MAI_12)
  81. xTaskCreate(adc_task, "adc_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  82. #endif
  83. #if defined (MAO_8)
  84. xTaskCreate(dac_task, "dac_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  85. #endif
  86. taskEXIT_CRITICAL();
  87. vTaskStartScheduler();
  88. #endif
  89. while (1) {}
  90. }
  91. void init_task(void *argument)
  92. {
  93. // -------------------------------------------------------------------------- //
  94. // Для теста
  95. //sys_clear();
  96. // -------------------------------------------------------------------------- //
  97. // Загрузка и проверка настроек
  98. crm_periph_clock_enable(CRM_CRC_PERIPH_CLOCK, TRUE);
  99. // Мьютекс для работы с настройками
  100. init_settings();
  101. // Системные настройки и копия
  102. sys_settings_load(&sys_settings);
  103. memcpy(&temp_sys_settings, &sys_settings, sizeof(sys_settings_t));
  104. // Основные настройки
  105. settings_load(&settings);
  106. // Настройки параметров порта Modbus
  107. settings_set_modbus_params(settings.com_settings.mb_port);
  108. #if 0
  109. settings_set_all_default();
  110. settings_save(&settings);
  111. #endif
  112. // -------------------------------------------------------------------------- //
  113. // Безопасный режим, входы, выходы
  114. save_mode_init();
  115. // TODO Для теста отключаем безопасный режим работы
  116. save_mode_set(false);
  117. io_port_init();
  118. //in_exint_init();
  119. gpio_wdt_init();
  120. gpio_mbaddr_init();
  121. // -------------------------------------------------------------------------- //
  122. // Кнопки
  123. button_init();
  124. // -------------------------------------------------------------------------- //
  125. // Uptime
  126. uptime_init();
  127. // -------------------------------------------------------------------------- //
  128. // RTC
  129. TM_RTC_Init();
  130. rtc_subtim_init();
  131. // -------------------------------------------------------------------------- //
  132. // Мультиплексор
  133. mux_gpio_init();
  134. // -------------------------------------------------------------------------- //
  135. // Modbus
  136. mb_init();
  137. // -------------------------------------------------------------------------- //
  138. // Базовая инициализация входов/выходов
  139. // TODO потом брать значения из настроек
  140. io_init();
  141. // -------------------------------------------------------------------------- //
  142. // Сброс счетчика попыток загрузок
  143. update_reset_boot_try();
  144. // -------------------------------------------------------------------------- //
  145. // Тесты
  146. //pwm_test(); // тесы PWM
  147. gpio_get_rev();
  148. // -------------------------------------------------------------------------- //
  149. // Сдвиговые регистры и мультиплексоры
  150. //sh_init();
  151. // Тесты аналоговых входов
  152. //ai_connect_test();
  153. //ai_mode_test();
  154. //ai_connect_channel(V_ISO);
  155. //ai_connect_channel(AN_INP_1);
  156. //ai_connect_channel(AN_INP_7);
  157. // -------------------------------------------------------------------------- //
  158. // DAC
  159. /*
  160. dac_gpio_init();
  161. dac_test(CH_DAC_1, 30000);
  162. */
  163. /*
  164. dac_test(CH_DAC_2, 10000);
  165. dac_test(CH_DAC_3, 10000);
  166. dac_test(CH_DAC_4, 10000);
  167. */
  168. /*
  169. dac_test(CH_DAC_1, 10000);
  170. dac_test(CH_DAC_2, 10000);
  171. dac_test(CH_DAC_3, 10000);
  172. dac_test(CH_DAC_4, 10000);
  173. */
  174. // -------------------------------------------------------------------------- //
  175. // RNDIS
  176. //usb_eth_init();
  177. // Тесты таймеров
  178. //mux_led_test_init();
  179. // -------------------------------------------------------------------------- //
  180. // SPI flash
  181. #if 1
  182. // Тесты SPI flash
  183. common_spi_init();
  184. spi_flash_init();
  185. //InitFS(PRIM_DRIVE);
  186. //spi_flash_test();
  187. #endif
  188. // -------------------------------------------------------------------------- //
  189. // LOG
  190. log_init(false);
  191. // -------------------------------------------------------------------------- //
  192. // EVENT. Обновление FW.
  193. uint16_t update_status = bpr_data_read(BACKUP_UPDATE_STATUS);
  194. if (update_status == IAP_UPDATE_OK)
  195. log_add_entry(LOG_UPDATE_FW, LOG_EVENT_STATE_OK, 0, atof(FW_VERSION));
  196. else if (update_status == IAP_UPDATE_ERROR)
  197. log_add_entry(LOG_UPDATE_FW, LOG_EVENT_STATE_ERR, 0, atof(FW_VERSION));
  198. bpr_data_write(BACKUP_UPDATE_STATUS, IAP_UPDATE_NO);
  199. // -------------------------------------------------------------------------- //
  200. // EVENT. Включение питания/перезагрузка.
  201. log_add_entry(LOG_SYSTEM_BOOT, (log_event_state_t)0, 0, 0);
  202. // -------------------------------------------------------------------------- //
  203. // Тесты USB
  204. //usb_eth_init();
  205. //vTaskDelete(NULL);
  206. settings_is_changed(&settings);
  207. for (;;)
  208. {
  209. mux_led_proc();
  210. }
  211. // -----------------------------------------------------------------------------
  212. //taskYIELD();
  213. }
  214. void test_hw_task(void *argument)
  215. {
  216. for (;;)
  217. {
  218. vTaskDelay(1000);
  219. printf("\r\n");
  220. for (uint8_t i = 0; i < 8; i++)
  221. {
  222. printf("Channel: %u, state = %u\r\n", i + 1, in_get(i));
  223. }
  224. #if 0
  225. vTaskDelay(100);
  226. mux_led_blink();
  227. #endif
  228. //adc_test();
  229. }
  230. }
  231. //
  232. void soft_wdt(void *params)
  233. {
  234. (void)params;
  235. for (;;)
  236. {
  237. extern_wdt_togle(); // extern WDT
  238. vTaskDelay(100);
  239. }
  240. }
  241. //
  242. void test_gpio(void *params)
  243. {
  244. (void)params;
  245. for (;;)
  246. {
  247. vTaskDelay(100);
  248. //printf("%" PRId64 " \r\n", rtc_get_ms());
  249. //en_crnt_alrm_in(0x02);
  250. //io_test();
  251. //out_test();
  252. //load_test();
  253. //printf("HW rev: %u\r\n", cm_gpio_get_rev());
  254. //printf("Save mode: %u\r\n", save_mode_get());
  255. }
  256. }
  257. //
  258. void misc_task(void *params)
  259. {
  260. (void)params;
  261. for (;;)
  262. {
  263. vTaskDelay(1000);
  264. eMBSetSlaveAddr(gpio_get_mbaddr());
  265. }
  266. }
  267. //
  268. void usb_clock48m_select(usb_clk48_s clk_s)
  269. {
  270. if(clk_s == USB_CLK_HICK)
  271. {
  272. crm_usb_clock_source_select(CRM_USB_CLOCK_SOURCE_HICK);
  273. /* enable the acc calibration ready interrupt */
  274. crm_periph_clock_enable(CRM_ACC_PERIPH_CLOCK, TRUE);
  275. /* update the c1\c2\c3 value */
  276. acc_write_c1(7980);
  277. acc_write_c2(8000);
  278. acc_write_c3(8020);
  279. /* open acc calibration */
  280. acc_calibration_mode_enable(ACC_CAL_HICKTRIM, TRUE);
  281. }
  282. else
  283. {
  284. switch(system_core_clock)
  285. {
  286. /* 48MHz */
  287. case 48000000:
  288. crm_usb_clock_div_set(CRM_USB_DIV_1);
  289. break;
  290. /* 72MHz */
  291. case 72000000:
  292. crm_usb_clock_div_set(CRM_USB_DIV_1_5);
  293. break;
  294. /* 96MHz */
  295. case 96000000:
  296. crm_usb_clock_div_set(CRM_USB_DIV_2);
  297. break;
  298. /* 120MHz */
  299. case 120000000:
  300. crm_usb_clock_div_set(CRM_USB_DIV_2_5);
  301. break;
  302. /* 144MHz */
  303. case 144000000:
  304. crm_usb_clock_div_set(CRM_USB_DIV_3);
  305. break;
  306. /* 168MHz */
  307. case 168000000:
  308. crm_usb_clock_div_set(CRM_USB_DIV_3_5);
  309. break;
  310. /* 192MHz */
  311. case 192000000:
  312. crm_usb_clock_div_set(CRM_USB_DIV_4);
  313. break;
  314. default:
  315. break;
  316. }
  317. }
  318. }