main.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353
  1. /*
  2. *********************************************************************************************************
  3. * 函 数 名: main
  4. * 功能说明: c程序入口
  5. * 形 参:无
  6. * 返 回 值: 错误代码(无需处理)
  7. *********************************************************************************************************
  8. */
  9. #include "main.h"
  10. #include "net.h"
  11. #include "os_cpu.h"
  12. int32_t g_recv_msg_flag = 0;
  13. void dump_hex(uint8_t *buffer, uint32_t len)
  14. {
  15. uint32_t i;
  16. printf("[DumpHEX]Length:%d ", len);
  17. for (i = 0; i < len; i++)
  18. {
  19. if (i % 16 == 0)
  20. printf("\r\n");
  21. else if (i % 8 == 0)
  22. printf(" ");
  23. else
  24. printf(":");
  25. printf("%02x", buffer[i]);
  26. }
  27. printf("\r\n");
  28. }
  29. int main(void)
  30. {
  31. #if 0
  32. /* 打开GOIOI 端口时钟 */
  33. *(unsigned int *)(0x40023800 + 0x30) |= (1 << 8);
  34. /* PI10 为输出 */
  35. *(unsigned int *)(0x40022000 + 0x00) &= ~((0x03) << (2 * 10));
  36. *(unsigned int *)(0x40022000 + 0x00) |= (1 << (2 * 10));
  37. /* PI10 输出高电平 */
  38. *(unsigned int *)(0x40022000 + 0x14) |= (1 << 10);
  39. /* PI10 输出低电平 */
  40. *(unsigned int *)(0x40022000 + 0x14) &= ~(1 << 10);
  41. #elif 0
  42. bsp_init();
  43. while (1)
  44. {
  45. GPIO_ResetBits(GPIOI, GPIO_Pin_10);
  46. Delay(0xFFFFFFFF);
  47. // GPIO_SetBits(GPIOI, GPIO_Pin_10);
  48. // Delay(0xFFFFFFFF);
  49. GPIO_ResetBits(GPIOF, GPIO_Pin_7);
  50. Delay(0xFFFFFF);
  51. // GPIO_SetBits(GPIOF, GPIO_Pin_7);
  52. // Delay(0xFFFFFF);
  53. GPIO_ResetBits(GPIOF, GPIO_Pin_8);
  54. Delay(0xFFFFFF);
  55. // GPIO_SetBits(GPIOF, GPIO_Pin_8);
  56. // Delay(0xFFFFFF);
  57. GPIO_ResetBits(GPIOC, GPIO_Pin_2);
  58. Delay(0xFFFFFF);
  59. // GPIO_SetBits(GPIOC, GPIO_Pin_2);
  60. // Delay(0xFFFFFF);
  61. };
  62. #elif 1
  63. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);
  64. OSInit();
  65. bsp_init();
  66. iec10x_regist();
  67. /* init task */
  68. /* 创建一个启动任务(也就是主任务)。启动任务会创建所有的应用程序任务 */
  69. OSTaskCreateExt(init_task, /* 启动任务函数指针 */
  70. (void *)0, /* 传递给任务的参数 */
  71. (OS_STK *)&init_task_stk[INIT_STK_SIZE - 1], /* 指向任务栈栈顶的指针 */
  72. INIT_TASK_PRIO, /* 任务的优先级,必须唯一,数字越低优先级越高 */
  73. INIT_TASK_PRIO, /* 任务ID,一般和任务优先级相同 */
  74. (OS_STK *)&init_task_stk[0], /* 指向任务栈栈底的指针。OS_STK_GROWTH
  75. 决定堆栈增长方向 */
  76. INIT_STK_SIZE, /* 任务栈大小 */
  77. (void *)0, /* 一块用户内存区的指针,用于任务控制块TCB的扩展功能
  78. (如任务切换时保存CPU浮点寄存器的数据)。一般不用,填0即可 */
  79. OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR); /* 任务选项字 */
  80. OSStart();
  81. #endif
  82. }
  83. /*!
  84. \brief init task
  85. \param[in] pvParameters not used
  86. \param[out] none
  87. \retval none
  88. */
  89. void init_task(void *pvParameters)
  90. {
  91. uint8_t *p;
  92. p = pvParameters;
  93. SysTick_Config(SystemCoreClock / OS_TICKS_PER_SEC);
  94. /* configure the systick handler priority */
  95. NVIC_SetPriority(SysTick_IRQn, 0x00U);
  96. OSTaskCreateExt((void (*)(void *))misc_task, /* 启动任务函数指针 */
  97. (void *)0, /* 传递给任务的参数 */
  98. (OS_STK *)&misc_task_stk[MISC_TASK_STK_SIZE - 1], /* 指向任务栈栈顶的指针 */
  99. (INT8U)MISC_PRIO, /* 任务的优先级,必须唯一,数字越低优先级越高 */
  100. (INT16U)MISC_PRIO, /* 任务ID,一般和任务优先级相同 */
  101. (OS_STK *)&misc_task_stk[0], /* 指向任务栈栈底的指针。OS_STK_GROWTH 决定堆栈增长方向 */
  102. (INT32U)MISC_TASK_STK_SIZE, /* 任务栈大小 */
  103. (void *)0, /* 一块用户内存区的指针,用于任务控制块TCB的扩展功能
  104. (如任务切换时保存CPU浮点寄存器的数据)。一般不用,填0即可 */
  105. (INT16U)OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR | OS_TASK_OPT_SAVE_FP); /* 任务选项字 */
  106. // OSTaskCreateExt((void (*)(void *))modbus_master_task,
  107. // (void *)0,
  108. // (OS_STK *)&uart1_task_stk[UART1_TASK_STK_SIZE - 1],
  109. // (INT8U)UART1_TASK_PRIO,
  110. // (INT16U)UART1_TASK_PRIO,
  111. // (OS_STK *)&uart1_task_stk[0],
  112. // (INT32U)UART1_TASK_STK_SIZE,
  113. // (void *)0,
  114. // (INT16U)OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR | OS_TASK_OPT_SAVE_FP);
  115. /* 485 modbus从机模式 */
  116. // OSTaskCreateExt((void (*)(void *))modbus_slave_task,
  117. // (void *)0,
  118. // (OS_STK *)&uart3_task_stk[UART3_TASK_STK_SIZE - 1],
  119. // (INT8U)UART3_TASK_PRIO,
  120. // (INT16U)UART3_TASK_PRIO,
  121. // (OS_STK *)&uart3_task_stk[0],
  122. // (INT32U)UART3_TASK_STK_SIZE,
  123. // (void *)0,
  124. // (INT16U)OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR | OS_TASK_OPT_SAVE_FP);
  125. OSTaskCreateExt((void (*)(void *))iec104_task,
  126. (void *)0,
  127. (OS_STK *)&iec104_task_stk[IEC_TASK_STK_SIZE - 1],
  128. (INT8U)IEC_PRIO,
  129. (INT16U)IEC_PRIO,
  130. (OS_STK *)&iec104_task_stk[0],
  131. (INT32U)IEC_TASK_STK_SIZE,
  132. (void *)0,
  133. (INT16U)OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR | OS_TASK_OPT_SAVE_FP);
  134. OSTaskCreateExt((void (*)(void *))modbus_tcp_task,
  135. (void *)0,
  136. (OS_STK *)&tcp_task_stk[TCP_TASK_STK_SIZE - 1],
  137. (INT8U)TCP_PRIO,
  138. (INT16U)TCP_PRIO,
  139. (OS_STK *)&tcp_task_stk[0],
  140. (INT32U)TCP_TASK_STK_SIZE,
  141. (void *)0,
  142. (INT16U)OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR | OS_TASK_OPT_SAVE_FP);
  143. }
  144. void misc_task(void)
  145. {
  146. INT8U cnt = 0;
  147. INT16U save_cnt = 0;
  148. INT8U temperature;
  149. INT8U humidity;
  150. INT8U ret;
  151. // INT8U key_state;
  152. AD7606_SetOS(AD_OS_NO); /* 无过采样 */
  153. AD7606_SetInputRange(0); /* 0表示输入量程为正负5V, 1表示正负10V */
  154. // bsp_StartAutoTimer(0, 500); /* 启动1个200ms的自动重装的定时器 */
  155. AD7606_ReadNowAdc(); /* 读取采样结果 */
  156. AD7606_StartConvst(); /* 启动1次转换 */
  157. while (1)
  158. {
  159. iwdg_feed(MISC_DOG);
  160. // key_scan();
  161. USBH_Process(&USB_OTG_Core, &USB_Host);
  162. // key_state = key_get();
  163. // if (key_state != KEY_NONE)
  164. // {
  165. // switch (key_state)
  166. // {
  167. // case KEY_1_UP:
  168. // printf("1111111\r\n");
  169. // break;
  170. // case KEY_1_DOWN:
  171. // printf("wwwwwwwwwwww\r\n");
  172. // break;
  173. // case KEY_1_LONG:
  174. // printf("333333333\r\n");
  175. // break;
  176. // default:
  177. // printf("44444444\r\n");
  178. // break;
  179. // }
  180. // }
  181. if ((cnt % 10 == 0) && (cnt != 0))
  182. {
  183. // printf("%ld\r\n", NAND_ReadID());
  184. // printf("%c\r\n", NOR_ReadByte(0x4000));
  185. }
  186. if ((cnt % 25 == 0) && (cnt != 0))
  187. {
  188. // printf("%ld\r\n", NAND_ReadID());
  189. LED2_RUN_TOGGLE;
  190. }
  191. if ((cnt % 15 == 0) && (cnt != 0))
  192. {
  193. // if (NOR_EraseSector(0x4000) == 0)
  194. // {
  195. // NOR_WriteByte(0x4000, 0xFF);
  196. // }
  197. }
  198. if (cnt == 10)
  199. {
  200. // if (am2303_init())
  201. // {
  202. // printf("error\r\n");
  203. // }
  204. // else
  205. // {
  206. ret = am2303_read_data(&temperature, &humidity); // 读取温湿度值
  207. // if (ret == 1)
  208. // {
  209. // printf("Temp: (%d).\n", temperature);
  210. // printf("Humi: (%d).\n", humidity);
  211. // }
  212. // else
  213. // {
  214. // printf("\r\n未发现DHT11温湿度传感器\r\n");
  215. // }
  216. // }
  217. }
  218. if (cnt >= 25)
  219. {
  220. /* 每隔500ms 进来一次. 由软件启动转换 */
  221. AD7606_ReadNowAdc(); /* 读取采样结果 */
  222. AD7606_StartConvst(); /* 启动下次转换 */
  223. cnt = 0; /* 刷新显示 */
  224. }
  225. else
  226. {
  227. cnt++;
  228. }
  229. if (save_cnt >= 25)
  230. {
  231. save_cnt = 0;
  232. }
  233. else
  234. {
  235. save_cnt++;
  236. }
  237. if (g_iec104_socket > 0)
  238. {
  239. iec104_scheduled(g_iec104_socket);
  240. }
  241. iec104_state_machine();
  242. OSTimeDly(20);
  243. };
  244. }
  245. // void iec104_task(void)
  246. // {
  247. // INT8U buf[MAX_RECV_SIZE] = {0};
  248. // INT32S ret = 0;
  249. // INT32U len = 0;
  250. // while (1)
  251. // {
  252. // if (g_iec104_socket < 0)
  253. // {
  254. // ret = iec104_connect_module();
  255. // if (ret < 0)
  256. // {
  257. // goto TASK_DELAY;
  258. // }
  259. // g_data_req_flag = 0;
  260. // }
  261. // else
  262. // {
  263. // ret = iec104_rec_master(buf);
  264. // if (ret <= 0)
  265. // {
  266. // closesocket(g_iec104_socket);
  267. // goto TASK_DELAY;
  268. // }
  269. // }
  270. // TASK_DELAY:
  271. // OSTimeDly(100);
  272. // }
  273. // }
  274. void modbus_tcp_task(void)
  275. {
  276. INT8U buf[MAX_RECV_SIZE] = {0};
  277. INT32S ret = 0;
  278. INT16U temp_buf_len;
  279. INT16U msg_data_len;
  280. INT32U len;
  281. while (1)
  282. {
  283. if (g_modbus_tcp_socket < 0)
  284. {
  285. ret = modbus_tcp_connect_module();
  286. if (ret < 0)
  287. {
  288. goto TASK_DELAY;
  289. }
  290. g_data_req_flag = 0;
  291. }
  292. else
  293. {
  294. ret = modbus_tcp_rec_module(buf);
  295. if (ret < 2)
  296. {
  297. if (g_recv_msg_flag == 1)
  298. {
  299. fly_mosbus_init_flag();
  300. closesocket(g_iec104_socket);
  301. g_recv_msg_flag = 0;
  302. }
  303. goto TASK_DELAY;
  304. }
  305. g_recv_msg_flag = 0;
  306. temp_buf_len = 0;
  307. while (temp_buf_len < ret)
  308. {
  309. len = 0;
  310. msg_data_len = ((buf[temp_buf_len + 1] & 0xff) | ((buf[temp_buf_len + 2] << 8) & 0xff00));
  311. len = msg_data_len + 3;
  312. if (fly_test_process(&(buf[temp_buf_len]), len) != 0)
  313. {
  314. goto TASK_DELAY;
  315. }
  316. temp_buf_len += msg_data_len + 3;
  317. }
  318. }
  319. TASK_DELAY:
  320. OSTimeDly(100);
  321. }
  322. }