main.cpp 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  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. 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. #ifdef USB_RNDIS
  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. // Для теста
  94. //sys_clear();
  95. // -------------------------------------------------------------------------- //
  96. // Загрузка и проверка настроек
  97. crm_periph_clock_enable(CRM_CRC_PERIPH_CLOCK, TRUE);
  98. // Мьютекс для работы с настройками
  99. init_settings();
  100. // Системные настройки и копия
  101. sys_settings_load(&sys_settings);
  102. memcpy(&temp_sys_settings, &sys_settings, sizeof(sys_settings_t));
  103. // Основные настройки
  104. settings_load(&settings);
  105. // Настройки параметров порта Modbus
  106. settings_set_modbus_params(settings.com_settings.mb_port);
  107. #if 0
  108. settings_set_all_default();
  109. settings_save(&settings);
  110. #endif
  111. // -------------------------------------------------------------------------- //
  112. // Безопасный режим, входы, выходы
  113. save_mode_init();
  114. // TODO Для теста отключаем безопасный режим работы
  115. save_mode_set(false);
  116. io_port_init();
  117. //in_exint_init();
  118. gpio_wdt_init();
  119. gpio_mbaddr_init();
  120. // -------------------------------------------------------------------------- //
  121. // Кнопки
  122. button_init();
  123. // -------------------------------------------------------------------------- //
  124. // Uptime
  125. uptime_init();
  126. // -------------------------------------------------------------------------- //
  127. // RTC
  128. TM_RTC_Init();
  129. rtc_subtim_init();
  130. // -------------------------------------------------------------------------- //
  131. // Мультиплексор
  132. mux_gpio_init();
  133. // -------------------------------------------------------------------------- //
  134. // Modbus
  135. mb_init();
  136. // -------------------------------------------------------------------------- //
  137. // Базовая инициализация входов/выходов
  138. // TODO потом брать значения из настроек
  139. io_init();
  140. // -------------------------------------------------------------------------- //
  141. // Сброс счетчика попыток загрузок
  142. update_reset_boot_try();
  143. // -------------------------------------------------------------------------- //
  144. // Тесты
  145. //pwm_test(); // тесы PWM
  146. gpio_get_rev();
  147. // -------------------------------------------------------------------------- //
  148. // Сдвиговые регистры и мультиплексоры
  149. //sh_init();
  150. // Тесты аналоговых входов
  151. //ai_connect_test();
  152. //ai_mode_test();
  153. //ai_connect_channel(V_ISO);
  154. //ai_connect_channel(AN_INP_1);
  155. //ai_connect_channel(AN_INP_7);
  156. // -------------------------------------------------------------------------- //
  157. // DAC
  158. /*
  159. dac_gpio_init();
  160. dac_test(CH_DAC_1, 30000);
  161. */
  162. /*
  163. dac_test(CH_DAC_2, 10000);
  164. dac_test(CH_DAC_3, 10000);
  165. dac_test(CH_DAC_4, 10000);
  166. */
  167. /*
  168. dac_test(CH_DAC_1, 10000);
  169. dac_test(CH_DAC_2, 10000);
  170. dac_test(CH_DAC_3, 10000);
  171. dac_test(CH_DAC_4, 10000);
  172. */
  173. // -------------------------------------------------------------------------- //
  174. // RNDIS
  175. //usb_eth_init();
  176. // Тесты таймеров
  177. //mux_led_test_init();
  178. // -------------------------------------------------------------------------- //
  179. // SPI flash
  180. #if 1
  181. // Тесты SPI flash
  182. common_spi_init();
  183. spi_flash_init();
  184. //InitFS(PRIM_DRIVE);
  185. //spi_flash_test();
  186. #endif
  187. // -------------------------------------------------------------------------- //
  188. // LOG
  189. log_init(false);
  190. // Тесты USB
  191. //usb_eth_init();
  192. //vTaskDelete(NULL);
  193. for (;;)
  194. {
  195. mux_led_proc();
  196. }
  197. // -----------------------------------------------------------------------------
  198. //taskYIELD();
  199. }
  200. void test_hw_task(void *argument)
  201. {
  202. for (;;)
  203. {
  204. vTaskDelay(100);
  205. #if 0
  206. vTaskDelay(100);
  207. mux_led_blink();
  208. #endif
  209. //adc_test();
  210. }
  211. }
  212. //
  213. void soft_wdt(void *params)
  214. {
  215. (void)params;
  216. for (;;)
  217. {
  218. extern_wdt_togle(); // extern WDT
  219. vTaskDelay(100);
  220. }
  221. }
  222. //
  223. void test_gpio(void *params)
  224. {
  225. (void)params;
  226. for (;;)
  227. {
  228. vTaskDelay(100);
  229. //printf("%" PRId64 " \r\n", rtc_get_ms());
  230. //en_crnt_alrm_in(0x02);
  231. //io_test();
  232. //out_test();
  233. //load_test();
  234. //printf("HW rev: %u\r\n", cm_gpio_get_rev());
  235. //printf("Save mode: %u\r\n", save_mode_get());
  236. }
  237. }
  238. //
  239. void misc_task(void *params)
  240. {
  241. (void)params;
  242. for (;;)
  243. {
  244. vTaskDelay(1000);
  245. eMBSetSlaveAddr(gpio_get_mbaddr());
  246. }
  247. }
  248. //
  249. void usb_clock48m_select(usb_clk48_s clk_s)
  250. {
  251. if(clk_s == USB_CLK_HICK)
  252. {
  253. crm_usb_clock_source_select(CRM_USB_CLOCK_SOURCE_HICK);
  254. /* enable the acc calibration ready interrupt */
  255. crm_periph_clock_enable(CRM_ACC_PERIPH_CLOCK, TRUE);
  256. /* update the c1\c2\c3 value */
  257. acc_write_c1(7980);
  258. acc_write_c2(8000);
  259. acc_write_c3(8020);
  260. /* open acc calibration */
  261. acc_calibration_mode_enable(ACC_CAL_HICKTRIM, TRUE);
  262. }
  263. else
  264. {
  265. switch(system_core_clock)
  266. {
  267. /* 48MHz */
  268. case 48000000:
  269. crm_usb_clock_div_set(CRM_USB_DIV_1);
  270. break;
  271. /* 72MHz */
  272. case 72000000:
  273. crm_usb_clock_div_set(CRM_USB_DIV_1_5);
  274. break;
  275. /* 96MHz */
  276. case 96000000:
  277. crm_usb_clock_div_set(CRM_USB_DIV_2);
  278. break;
  279. /* 120MHz */
  280. case 120000000:
  281. crm_usb_clock_div_set(CRM_USB_DIV_2_5);
  282. break;
  283. /* 144MHz */
  284. case 144000000:
  285. crm_usb_clock_div_set(CRM_USB_DIV_3);
  286. break;
  287. /* 168MHz */
  288. case 168000000:
  289. crm_usb_clock_div_set(CRM_USB_DIV_3_5);
  290. break;
  291. /* 192MHz */
  292. case 192000000:
  293. crm_usb_clock_div_set(CRM_USB_DIV_4);
  294. break;
  295. default:
  296. break;
  297. }
  298. }
  299. }