freertos.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344
  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. /* USER CODE END PM */
  48. /* Private variables ---------------------------------------------------------*/
  49. /* USER CODE BEGIN Variables */
  50. /* USER CODE END Variables */
  51. osThreadId ScanKeyTaskHandle;
  52. osThreadId BT4GTaskHandle;
  53. osThreadId testTaskHandle;
  54. osThreadId loginfoTaskHandle;
  55. /* Private function prototypes -----------------------------------------------*/
  56. /* USER CODE BEGIN FunctionPrototypes */
  57. /* USER CODE END FunctionPrototypes */
  58. void StartScanKeyTask(void const * argument);
  59. void StarBT4GTask(void const * argument);
  60. void StartTestTask(void const * argument);
  61. void StartloginfoTaskTask(void const * argument);
  62. void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) */
  63. /* GetIdleTaskMemory prototype (linked to static allocation support) */
  64. void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize );
  65. /* USER CODE BEGIN GET_IDLE_TASK_MEMORY */
  66. static StaticTask_t xIdleTaskTCBBuffer;
  67. static StackType_t xIdleStack[configMINIMAL_STACK_SIZE];
  68. void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize )
  69. {
  70. *ppxIdleTaskTCBBuffer = &xIdleTaskTCBBuffer;
  71. *ppxIdleTaskStackBuffer = &xIdleStack[0];
  72. *pulIdleTaskStackSize = configMINIMAL_STACK_SIZE;
  73. /* place for user code */
  74. }
  75. /* USER CODE END GET_IDLE_TASK_MEMORY */
  76. /**
  77. * @brief FreeRTOS initialization
  78. * @param None
  79. * @retval None
  80. */
  81. void MX_FREERTOS_Init(void) {
  82. /* USER CODE BEGIN Init */
  83. /* USER CODE END Init */
  84. /* USER CODE BEGIN RTOS_MUTEX */
  85. /* add mutexes, ... */
  86. /* USER CODE END RTOS_MUTEX */
  87. /* USER CODE BEGIN RTOS_SEMAPHORES */
  88. /* add semaphores, ... */
  89. /* USER CODE END RTOS_SEMAPHORES */
  90. /* USER CODE BEGIN RTOS_TIMERS */
  91. /* start timers, add new ones, ... */
  92. /* USER CODE END RTOS_TIMERS */
  93. /* USER CODE BEGIN RTOS_QUEUES */
  94. /* add queues, ... */
  95. /* USER CODE END RTOS_QUEUES */
  96. /* Create the thread(s) */
  97. /* definition and creation of ScanKeyTask */
  98. osThreadDef(ScanKeyTask, StartScanKeyTask, osPriorityRealtime, 0, 128);
  99. ScanKeyTaskHandle = osThreadCreate(osThread(ScanKeyTask), NULL);
  100. /* definition and creation of BT4GTask */
  101. osThreadDef(BT4GTask, StarBT4GTask, osPriorityRealtime, 0, 128);
  102. BT4GTaskHandle = osThreadCreate(osThread(BT4GTask), NULL);
  103. /* definition and creation of testTask */
  104. osThreadDef(testTask, StartTestTask, osPriorityRealtime, 0, 128);
  105. testTaskHandle = osThreadCreate(osThread(testTask), NULL);
  106. /* definition and creation of loginfoTask */
  107. osThreadDef(loginfoTask, StartloginfoTaskTask, osPriorityRealtime, 0, 128);
  108. loginfoTaskHandle = osThreadCreate(osThread(loginfoTask), NULL);
  109. /* USER CODE BEGIN RTOS_THREADS */
  110. /* add threads, ... */
  111. /* USER CODE END RTOS_THREADS */
  112. }
  113. /* USER CODE BEGIN Header_StartScanKeyTask */
  114. /**
  115. * @brief Function implementing the ScanKeyTask thread.
  116. * @param argument: Not used
  117. * @retval None
  118. */
  119. /* USER CODE END Header_StartScanKeyTask */
  120. void StartScanKeyTask(void const * argument)
  121. {
  122. /* USER CODE BEGIN StartScanKeyTask */
  123. /* Infinite loop */
  124. for(;;)
  125. {
  126. osDelay(1);
  127. updatekeystate(); //扫描键值
  128. Jump_interface(menu); //跳转界面
  129. OLED_Refresh(); //刷新界面
  130. HANDLE_RETURN_INTERFACE(); //界面超时
  131. modifyOledBmp(); //修改锁图
  132. open_close_lock(); //施解操作
  133. RESET_4G_MODULE(); //4G启动(复位)
  134. }
  135. /* USER CODE END StartScanKeyTask */
  136. }
  137. /* USER CODE BEGIN Header_StarBT4GTask */
  138. /**
  139. * @brief Function implementing the BT4GTask thread.
  140. * @param argument: Not used
  141. * @retval None
  142. */
  143. /* USER CODE END Header_StarBT4GTask */
  144. void StarBT4GTask(void const * argument)
  145. {
  146. /* USER CODE BEGIN StarBT4GTask */
  147. /* Infinite loop */
  148. for(;;)
  149. {
  150. osDelay(1);
  151. //TCPCenterDownward();
  152. if(U4re)
  153. {
  154. //replyCenter();
  155. // CONNTCP();
  156. }
  157. if(newmac)
  158. {
  159. //换MAC
  160. newmac=false;
  161. newMacchange();
  162. }
  163. if(u4RecvFlag)
  164. {
  165. u4RecvFlag=false;
  166. HAL_UART_Transmit(&huart1,g_ML307A_8buf_Down,u4length,0xFFFF);//有信息就吐
  167. }
  168. if(btreflag)
  169. {
  170. btreflag=false;
  171. HAL_UART_Transmit(&huart1,g_MBA32A_8buf,u5length,0xFFFF);
  172. }
  173. if(g_ML307A_8buf_Down[1]==0x4D && g_ML307A_8buf_Down[2]==0x4C && g_ML307A_8buf_Down[3]==0x42 \
  174. && g_ML307A_8buf_Down[4]==0x53 && g_ML307A_8buf_Down[5]==0x4C && g_ML307A_8buf_Down[6]==0x4F \
  175. && g_ML307A_8buf_Down[7]==0x43 && g_ML307A_8buf_Down[8]==0x3A)//检测MLBSLOC:
  176. {
  177. memcpy(JD_str, &g_ML307A_8buf_Down[14], 12);
  178. memcpy(WD_str, &g_ML307A_8buf_Down[27], 11);
  179. double num;
  180. double num1;
  181. num = atof(JD_str);
  182. num1 = atof(WD_str);
  183. num = num* 1000000;
  184. num1= num1* 1000000;
  185. JD_dw = (uint32_t)num;
  186. WD_dw = (uint32_t)num1;
  187. }
  188. //4D 49 50 55 52 43
  189. if(g_ML307A_8buf_Down[1]==0x4D && g_ML307A_8buf_Down[2]==0x49 && g_ML307A_8buf_Down[3]==0x50 \
  190. && g_ML307A_8buf_Down[4]==0x55 && g_ML307A_8buf_Down[5]==0x52 && g_ML307A_8buf_Down[6]==0x43 )
  191. {
  192. uint8_t high_byte = (g_ML307A_8buf_Down[18]&0x0f) *10;
  193. uint8_t low_byte = g_ML307A_8buf_Down[19]&0x0f;
  194. hccd = high_byte + low_byte;
  195. memcpy(MIPurc,&g_ML307A_8buf_Down[21],hccd*2);
  196. const char *hex = (const char *)MIPurc; // 将 uint8_t * 转换为 const char *
  197. int size = strlen(hex) / 2; // 计算二进制数据的长度
  198. unsigned char *bin = (unsigned char *)malloc(size); // 分配足够的内存用于存储二进制数据
  199. rlt = hex2bin(bin, hex); // 调用hex2bin函数进行转换
  200. memcpy(MIPurc1, bin, rlt); // 将 bin 中的 rlt 个字节复制到 MIPurc1 中 接收到的数据放入MIPurc1中
  201. free(bin); // 释放内存
  202. memset(g_ML307A_8buf_Down,0,u4length);
  203. }
  204. /*********对平台的应答做处理**********/
  205. if(MIPurc1[0]==0x7E)
  206. {
  207. uint16_t PTXXID = MIPurc1[1]<<8 | MIPurc1[2]; //消息ID
  208. uint16_t xxtcLen = MIPurc1[3]<<8 | MIPurc1[4]; //数据长度
  209. if(PTXXID==XXIDpttyyd)//平台通用应答
  210. {
  211. }
  212. else if(PTXXID == XXIDptxxtc)
  213. {
  214. memcpy(MIPurcXXTCSJ,&MIPurc1[13],xxtcLen);
  215. }
  216. }
  217. }
  218. /* USER CODE END StarBT4GTask */
  219. }
  220. /* USER CODE BEGIN Header_StartTestTask */
  221. /**
  222. * @brief Function implementing the testTask thread.
  223. * @param argument: Not used
  224. * @retval None
  225. */
  226. /* USER CODE END Header_StartTestTask */
  227. void StartTestTask(void const * argument)
  228. {
  229. /* USER CODE BEGIN StartTestTask */
  230. /* Infinite loop */
  231. for(;;)
  232. {
  233. osDelay(10000);
  234. }
  235. /* USER CODE END StartTestTask */
  236. }
  237. /* USER CODE BEGIN Header_StartloginfoTaskTask */
  238. /**
  239. * @brief Function implementing the loginfoTask thread.
  240. * @param argument: Not used
  241. * @retval None
  242. */
  243. /* USER CODE END Header_StartloginfoTaskTask */
  244. void StartloginfoTaskTask(void const * argument)
  245. {
  246. /* USER CODE BEGIN StartloginfoTaskTask */
  247. /* Infinite loop */
  248. for(;;)
  249. {
  250. osDelay(1500);
  251. if(module4G_F)
  252. {
  253. module4G_F=false;
  254. tt808FsFunc(ICCID,22);
  255. }
  256. }
  257. /* USER CODE END StartloginfoTaskTask */
  258. }
  259. /* Private application code --------------------------------------------------*/
  260. /* USER CODE BEGIN Application */
  261. /* USER CODE END Application */