freertos.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * File Name : freertos.c
  5. * Description : Code for freertos applications
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2024 STMicroelectronics.
  10. * All rights reserved.
  11. *
  12. * This software is licensed under terms that can be found in the LICENSE file
  13. * in the root directory of this software component.
  14. * If no LICENSE file comes with this software, it is provided AS-IS.
  15. *
  16. ******************************************************************************
  17. */
  18. /* USER CODE END Header */
  19. /* Includes ------------------------------------------------------------------*/
  20. #include "FreeRTOS.h"
  21. #include "task.h"
  22. #include "main.h"
  23. #include "cmsis_os.h"
  24. /* Private includes ----------------------------------------------------------*/
  25. /* USER CODE BEGIN Includes */
  26. #include "key.h"
  27. #include "usart.h"
  28. #include <stdlib.h>
  29. #include "tt808.h"
  30. extern Menu_table menu;
  31. extern TT808 tt808;
  32. void Jump_interface(Menu_table menu);
  33. /* USER CODE END Includes */
  34. /* Private typedef -----------------------------------------------------------*/
  35. /* USER CODE BEGIN PTD */
  36. double JD_double;
  37. double WD_double;
  38. /* USER CODE END PTD */
  39. /* Private define ------------------------------------------------------------*/
  40. /* USER CODE BEGIN PD */
  41. /* USER CODE END PD */
  42. /* Private macro -------------------------------------------------------------*/
  43. /* USER CODE BEGIN PM */
  44. extern TCPClientD tcpc;
  45. uint8_t hex_array[]={0};
  46. uint8_t i =0;
  47. bool locDw = false;
  48. uint8_t temp=0;
  49. uint8_t MIPurcU1[100]={0};
  50. /* USER CODE END PM */
  51. /* Private variables ---------------------------------------------------------*/
  52. /* USER CODE BEGIN Variables */
  53. /* USER CODE END Variables */
  54. osThreadId ScanKeyTaskHandle;
  55. osThreadId BT4GTaskHandle;
  56. osThreadId testTaskHandle;
  57. osThreadId loginfoTaskHandle;
  58. /* Private function prototypes -----------------------------------------------*/
  59. /* USER CODE BEGIN FunctionPrototypes */
  60. /* USER CODE END FunctionPrototypes */
  61. void StartScanKeyTask(void const * argument);
  62. void StarBT4GTask(void const * argument);
  63. void StartTestTask(void const * argument);
  64. void StartloginfoTaskTask(void const * argument);
  65. void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) */
  66. /* GetIdleTaskMemory prototype (linked to static allocation support) */
  67. void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize );
  68. /* USER CODE BEGIN GET_IDLE_TASK_MEMORY */
  69. static StaticTask_t xIdleTaskTCBBuffer;
  70. static StackType_t xIdleStack[configMINIMAL_STACK_SIZE];
  71. void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize )
  72. {
  73. *ppxIdleTaskTCBBuffer = &xIdleTaskTCBBuffer;
  74. *ppxIdleTaskStackBuffer = &xIdleStack[0];
  75. *pulIdleTaskStackSize = configMINIMAL_STACK_SIZE;
  76. /* place for user code */
  77. }
  78. /* USER CODE END GET_IDLE_TASK_MEMORY */
  79. /**
  80. * @brief FreeRTOS initialization
  81. * @param None
  82. * @retval None
  83. */
  84. void MX_FREERTOS_Init(void) {
  85. /* USER CODE BEGIN Init */
  86. /* USER CODE END Init */
  87. /* USER CODE BEGIN RTOS_MUTEX */
  88. /* add mutexes, ... */
  89. /* USER CODE END RTOS_MUTEX */
  90. /* USER CODE BEGIN RTOS_SEMAPHORES */
  91. /* add semaphores, ... */
  92. /* USER CODE END RTOS_SEMAPHORES */
  93. /* USER CODE BEGIN RTOS_TIMERS */
  94. /* start timers, add new ones, ... */
  95. /* USER CODE END RTOS_TIMERS */
  96. /* USER CODE BEGIN RTOS_QUEUES */
  97. /* add queues, ... */
  98. /* USER CODE END RTOS_QUEUES */
  99. /* Create the thread(s) */
  100. /* definition and creation of ScanKeyTask */
  101. osThreadDef(ScanKeyTask, StartScanKeyTask, osPriorityRealtime, 0, 128);
  102. ScanKeyTaskHandle = osThreadCreate(osThread(ScanKeyTask), NULL);
  103. /* definition and creation of BT4GTask */
  104. osThreadDef(BT4GTask, StarBT4GTask, osPriorityRealtime, 0, 128);
  105. BT4GTaskHandle = osThreadCreate(osThread(BT4GTask), NULL);
  106. /* definition and creation of testTask */
  107. osThreadDef(testTask, StartTestTask, osPriorityRealtime, 0, 128);
  108. testTaskHandle = osThreadCreate(osThread(testTask), NULL);
  109. /* definition and creation of loginfoTask */
  110. osThreadDef(loginfoTask, StartloginfoTaskTask, osPriorityRealtime, 0, 128);
  111. loginfoTaskHandle = osThreadCreate(osThread(loginfoTask), NULL);
  112. /* USER CODE BEGIN RTOS_THREADS */
  113. /* add threads, ... */
  114. /* USER CODE END RTOS_THREADS */
  115. }
  116. /* USER CODE BEGIN Header_StartScanKeyTask */
  117. /**
  118. * @brief Function implementing the ScanKeyTask thread.
  119. * @param argument: Not used
  120. * @retval None
  121. */
  122. /* USER CODE END Header_StartScanKeyTask */
  123. void StartScanKeyTask(void const * argument)
  124. {
  125. /* USER CODE BEGIN StartScanKeyTask */
  126. /* Infinite loop */
  127. for(;;)
  128. {
  129. osDelay(1);
  130. updatekeystate(); //扫描键值
  131. Jump_interface(menu); //跳转界面
  132. OLED_Refresh(); //刷新界面
  133. HANDLE_RETURN_INTERFACE(); //界面超时
  134. modifyOledBmp(); //修改锁图
  135. open_close_lock(); //施解操作
  136. RESET_4G_MODULE(); //4G启动(复位)
  137. }
  138. /* USER CODE END StartScanKeyTask */
  139. }
  140. /* USER CODE BEGIN Header_StarBT4GTask */
  141. /**
  142. * @brief Function implementing the BT4GTask thread.
  143. * @param argument: Not used
  144. * @retval None
  145. */
  146. /* USER CODE END Header_StarBT4GTask */
  147. void StarBT4GTask(void const * argument)
  148. {
  149. /* USER CODE BEGIN StarBT4GTask */
  150. /* Infinite loop */
  151. for(;;)
  152. {
  153. osDelay(1);
  154. if(u4RecvFlag)
  155. {
  156. u4RecvFlag=false;
  157. HAL_UART_Transmit(&huart1,g_ML307A_8buf_Down,u4length,0xFFFF);//有信息就吐
  158. }
  159. if(btreflag)
  160. {
  161. btreflag=false;
  162. HAL_UART_Transmit(&huart1,g_MBA32A_8buf,u5length,0xFFFF);
  163. }
  164. }
  165. /* USER CODE END StarBT4GTask */
  166. }
  167. /* USER CODE BEGIN Header_StartTestTask */
  168. /**
  169. * @brief Function implementing the testTask thread.
  170. * @param argument: Not used
  171. * @retval None
  172. */
  173. /* USER CODE END Header_StartTestTask */
  174. void StartTestTask(void const * argument)
  175. {
  176. /* USER CODE BEGIN StartTestTask */
  177. /* Infinite loop */
  178. for(;;)
  179. {
  180. osDelay(8000);
  181. if(locDw && menu.current!=4 && menu.current!=5 && menu.current!=6 && menu.current!=7)
  182. {
  183. sendCmd_4G("AT+MLBSLOC\r\n", "OK", 1, 1);
  184. // if(sendCmd_4G("AT+MGNSSLOC\r\n", "+CME ERROR: 953", 1, 1))
  185. // {
  186. // sendCmd_4G("AT+MGNSSCFG=\"nmea/mask\",63\r\n", "OK", 2, 2);
  187. // sendCmd_4G("AT+MGNSS=1\r\n", "OK", 2, 2);
  188. // }
  189. }
  190. }
  191. /* USER CODE END StartTestTask */
  192. }
  193. /* USER CODE BEGIN Header_StartloginfoTaskTask */
  194. /**
  195. * @brief Function implementing the loginfoTask thread.
  196. * @param argument: Not used
  197. * @retval None
  198. */
  199. /* USER CODE END Header_StartloginfoTaskTask */
  200. void StartloginfoTaskTask(void const * argument)
  201. {
  202. /* USER CODE BEGIN StartloginfoTaskTask */
  203. /* Infinite loop */
  204. for(;;)
  205. {
  206. osDelay(1);
  207. /*********监测LBS定位信息**********/
  208. ReMLBSLOC();
  209. /*********监测平台回复**********/
  210. ReMIPURC();
  211. /*********对平台的应答做处理**********/
  212. MIPURCHandle();
  213. /*********手动解封紧急应答**********/
  214. if(SdjfEmergency)
  215. {
  216. SdjfEmergency=false;
  217. //HAL_Delay(200);
  218. uploadtime = HAL_GetTick();//再次重置发送状态信息基准时间
  219. gettimeupload_Emergency();
  220. }
  221. if(U1reFlag)//+MIPURC: "rtcp",1,47,7E030000200000160000082890252A153200000010000000000000000000000000000000000000000000002300237E //test
  222. {
  223. U1reFlag=false;
  224. memcpy(MIPurc,&U1recvBuff[21],U1recvLength);
  225. const char *hex = (const char *)MIPurc; // 将 uint8_t * 转换为 const char *
  226. int size = strlen(hex) / 2; // 计算二进制数据的长度
  227. unsigned char *bin = (unsigned char *)malloc(size); // 分配足够的内存用于存储二进制数据
  228. rlt = hex2bin(bin, hex); // 调用hex2bin函数进行转换
  229. memcpy(MIPurc1, bin, rlt); // 将 bin 中的 rlt 个字节复制到 MIPurc1 中 接收到的数据放入MIPurc1中
  230. free(bin); // 释放内存
  231. }
  232. if(module4G_F) //4G启动位 tcp链接位 鉴权非位
  233. {
  234. module4G_F=false; //鉴权操作
  235. tt808FsFunc(ICCID,22,XXIDzdjq);
  236. }
  237. if(JQflag)
  238. {
  239. JQflag = false;
  240. uint8_t test[] = {0xAA}; //test心跳
  241. tt808FsFunc(test,1,XXIDzdxt); //test心跳
  242. uploadtime = HAL_GetTick();//获取首次发送状态信息基准时间
  243. }
  244. if(XTflag && menu.current!=4 && menu.current!=5 && menu.current!=6 && menu.current!=7)
  245. {
  246. locDw =false;
  247. gettimeupload_Normal();//定时上传锁状态
  248. locDw =true;
  249. }
  250. if(Ptsjf)
  251. {
  252. Ptsjf = false;
  253. menu.enter=4;
  254. locDw =true;
  255. XTflag = true;
  256. }
  257. if(genghaunmac)
  258. {
  259. genghaunmac = false;
  260. newMacchange(MIPurc1);//处理MAC数据
  261. memset(MIPurc1,0,rlt);//rlt下发长度
  262. }
  263. }
  264. /* USER CODE END StartloginfoTaskTask */
  265. }
  266. /* Private application code --------------------------------------------------*/
  267. /* USER CODE BEGIN Application */
  268. /* USER CODE END Application */