main.cpp 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  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. }
  37. #include "terminal_sbs.h"
  38. #include "terminal_usartbridge.h"
  39. #include <stdio.h>
  40. #include <stdbool.h>
  41. #include <string.h>
  42. void init_task(void *argument);
  43. void test_hw_task(void *argument);
  44. void soft_wdt(void *params);
  45. void test_gpio(void *params);
  46. void misc_task(void *params); // TODO перенести в другой модуль
  47. void usb_clock48m_select(usb_clk48_s clk_s);
  48. //
  49. int main(void)
  50. {
  51. __disable_irq();
  52. nvic_vector_table_set(NVIC_VECTTAB_FLASH, 0x08021000);
  53. nvic_priority_group_config(NVIC_PRIORITY_GROUP_4);
  54. __enable_irq();
  55. extend_SRAM();
  56. system_clock_config();
  57. delay_init();
  58. // -------------------------------------------------------------------------
  59. // CLI
  60. sbsTerminal.configure();
  61. terminalUsartBridge.configure();
  62. // -------------------------------------------------------------------------
  63. // USB
  64. #if 0
  65. usb_clock48m_select(USB_CLK_HEXT);
  66. crm_periph_clock_enable(CRM_USB_PERIPH_CLOCK, TRUE);
  67. usb_init();
  68. #endif
  69. #if 1
  70. taskENTER_CRITICAL();
  71. xTaskCreate(soft_wdt, "soft_wdt", configMINIMAL_STACK_SIZE, NULL, configMAX_PRIORITIES - 1, NULL);
  72. xTaskCreate(init_task, "init_task", 10*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  73. //xTaskCreate(test_hw_task, "hw_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  74. xTaskCreate(test_gpio, "gpio_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  75. xTaskCreate(input_task, "input_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  76. xTaskCreate(misc_task, "misc_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  77. xTaskCreate(button_task, "button_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  78. #if defined (MAI_12)
  79. xTaskCreate(adc_task, "adc_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  80. #endif
  81. #if defined (MAO_8)
  82. xTaskCreate(dac_task, "dac_task", 2*configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL);
  83. #endif
  84. taskEXIT_CRITICAL();
  85. vTaskStartScheduler();
  86. #endif
  87. while (1) {}
  88. }
  89. void init_task(void *argument)
  90. {
  91. // Для теста
  92. //sys_clear();
  93. // -------------------------------------------------------------------------- //
  94. // Загрузка и проверка настроек
  95. crm_periph_clock_enable(CRM_CRC_PERIPH_CLOCK, TRUE);
  96. // Мьютекс для работы с настройками
  97. init_settings();
  98. // Системные настройки и копия
  99. sys_settings_load(&sys_settings);
  100. memcpy(&temp_sys_settings, &sys_settings, sizeof(sys_settings_t));
  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. /*
  157. dac_gpio_init();
  158. dac_test(CH_DAC_1, 30000);
  159. */
  160. /*
  161. dac_test(CH_DAC_2, 10000);
  162. dac_test(CH_DAC_3, 10000);
  163. dac_test(CH_DAC_4, 10000);
  164. */
  165. /*
  166. dac_test(CH_DAC_1, 10000);
  167. dac_test(CH_DAC_2, 10000);
  168. dac_test(CH_DAC_3, 10000);
  169. dac_test(CH_DAC_4, 10000);
  170. */
  171. // -------------------------------------------------------------------------- //
  172. // RNDIS
  173. //usb_eth_init();
  174. // Тесты таймеров
  175. //mux_led_test_init();
  176. // -------------------------------------------------------------------------- //
  177. // SPI flash
  178. #if 1
  179. // Тесты SPI flash
  180. common_spi_init();
  181. spi_flash_init();
  182. //InitFS(PRIM_DRIVE);
  183. //spi_flash_test();
  184. #endif
  185. // -------------------------------------------------------------------------- //
  186. // LOG
  187. log_init(false);
  188. // Тесты USB
  189. //usb_eth_init();
  190. //vTaskDelete(NULL);
  191. for (;;)
  192. {
  193. mux_led_proc();
  194. }
  195. // -----------------------------------------------------------------------------
  196. //taskYIELD();
  197. }
  198. void test_hw_task(void *argument)
  199. {
  200. for (;;)
  201. {
  202. vTaskDelay(100);
  203. #if 0
  204. vTaskDelay(100);
  205. mux_led_blink();
  206. #endif
  207. //adc_test();
  208. }
  209. }
  210. //
  211. void soft_wdt(void *params)
  212. {
  213. (void)params;
  214. for (;;)
  215. {
  216. extern_wdt_togle(); // extern WDT
  217. vTaskDelay(100);
  218. }
  219. }
  220. //
  221. void test_gpio(void *params)
  222. {
  223. (void)params;
  224. for (;;)
  225. {
  226. vTaskDelay(100);
  227. //printf("%" PRId64 " \r\n", rtc_get_ms());
  228. //en_crnt_alrm_in(0x02);
  229. //io_test();
  230. //out_test();
  231. //load_test();
  232. //printf("HW rev: %u\r\n", cm_gpio_get_rev());
  233. //printf("Save mode: %u\r\n", save_mode_get());
  234. }
  235. }
  236. //
  237. void misc_task(void *params)
  238. {
  239. (void)params;
  240. for (;;)
  241. {
  242. vTaskDelay(1000);
  243. eMBSetSlaveAddr(gpio_get_mbaddr());
  244. }
  245. }
  246. //
  247. void usb_clock48m_select(usb_clk48_s clk_s)
  248. {
  249. if(clk_s == USB_CLK_HICK)
  250. {
  251. crm_usb_clock_source_select(CRM_USB_CLOCK_SOURCE_HICK);
  252. /* enable the acc calibration ready interrupt */
  253. crm_periph_clock_enable(CRM_ACC_PERIPH_CLOCK, TRUE);
  254. /* update the c1\c2\c3 value */
  255. acc_write_c1(7980);
  256. acc_write_c2(8000);
  257. acc_write_c3(8020);
  258. /* open acc calibration */
  259. acc_calibration_mode_enable(ACC_CAL_HICKTRIM, TRUE);
  260. }
  261. else
  262. {
  263. switch(system_core_clock)
  264. {
  265. /* 48MHz */
  266. case 48000000:
  267. crm_usb_clock_div_set(CRM_USB_DIV_1);
  268. break;
  269. /* 72MHz */
  270. case 72000000:
  271. crm_usb_clock_div_set(CRM_USB_DIV_1_5);
  272. break;
  273. /* 96MHz */
  274. case 96000000:
  275. crm_usb_clock_div_set(CRM_USB_DIV_2);
  276. break;
  277. /* 120MHz */
  278. case 120000000:
  279. crm_usb_clock_div_set(CRM_USB_DIV_2_5);
  280. break;
  281. /* 144MHz */
  282. case 144000000:
  283. crm_usb_clock_div_set(CRM_USB_DIV_3);
  284. break;
  285. /* 168MHz */
  286. case 168000000:
  287. crm_usb_clock_div_set(CRM_USB_DIV_3_5);
  288. break;
  289. /* 192MHz */
  290. case 192000000:
  291. crm_usb_clock_div_set(CRM_USB_DIV_4);
  292. break;
  293. default:
  294. break;
  295. }
  296. }
  297. }