main.cpp 9.0 KB

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