micro_climate/Core/Src/freertos.c

248 lines
6.7 KiB
C
Raw Blame History

/* USER CODE BEGIN Header */
void task_shell_term_main_loop(void const * argument);
/**
******************************************************************************
* File Name : freertos.c
* Description : Code for freertos applications
******************************************************************************
* @attention
*
* Copyright (c) 2022 STMicroelectronics.
* All rights reserved.
*
* This software is licensed under terms that can be found in the LICENSE file
* in the root directory of this software component.
* If no LICENSE file comes with this software, it is provided AS-IS.
*
******************************************************************************
*/
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "FreeRTOS.h"
#include "task.h"
#include "main.h"
#include "cmsis_os.h"
/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "anemometer_dev.h"
#include "uart_dev.h"
#include "frt_protocol.h"
#include "inflash.h"
#include "hp203b.h"
#include "EC801E.h"
/* USER CODE END Includes */
/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */
/* USER CODE END PTD */
/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
/* USER CODE END PD */
/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */
/* USER CODE END PM */
/* Private variables ---------------------------------------------------------*/
/* USER CODE BEGIN Variables */
osThreadId defaultTaskHandle;
osThreadId anemometerHandle;
osThreadId sensorTaskHandle;
osThreadId Trans_4g_taskHandle;
osThreadId ledTaskHandle;
//osThreadId TermShellHandle;
/* USER CODE END Variables */
osThreadId defaultTaskHandle;
osThreadId temhum_update_taskHandle;
osThreadId wind_update_taskHandle;
/* Private function prototypes -----------------------------------------------*/
/* USER CODE BEGIN FunctionPrototypes */
/* USER CODE END FunctionPrototypes */
void Trans_4g_Task(void const * argument);
void StartDefaultTask(void const * argument);
void LEDTask(void const * argument);
void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) */
/* GetIdleTaskMemory prototype (linked to static allocation support) */
void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize );
/* USER CODE BEGIN GET_IDLE_TASK_MEMORY */
static StaticTask_t xIdleTaskTCBBuffer;
static StackType_t xIdleStack[configMINIMAL_STACK_SIZE];
void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize )
{
*ppxIdleTaskTCBBuffer = &xIdleTaskTCBBuffer;
*ppxIdleTaskStackBuffer = &xIdleStack[0];
*pulIdleTaskStackSize = configMINIMAL_STACK_SIZE;
/* place for user code */
}
/* USER CODE END GET_IDLE_TASK_MEMORY */
/**
* @brief FreeRTOS initialization
* @param None
* @retval None
*/
void MX_FREERTOS_Init(void) {
/* USER CODE BEGIN Init */
/* USER CODE END Init */
/* USER CODE BEGIN RTOS_MUTEX */
/* add mutexes, ... */
/* USER CODE END RTOS_MUTEX */
/* USER CODE BEGIN RTOS_SEMAPHORES */
/* add semaphores, ... */
/* USER CODE END RTOS_SEMAPHORES */
/* USER CODE BEGIN RTOS_TIMERS */
/* start timers, add new ones, ... */
/* USER CODE END RTOS_TIMERS */
/* USER CODE BEGIN RTOS_QUEUES */
/* add queues, ... */
/* USER CODE END RTOS_QUEUES */
/* Create the thread(s) */
/* definition and creation of defaultTask */
osThreadDef(defaultTask, StartDefaultTask, osPriorityRealtime, 0, 512);//ͨѶ
defaultTaskHandle = osThreadCreate(osThread(defaultTask), NULL);
osThreadDef(ledTask, LEDTask, osPriorityIdle, 0, 32);//LED
ledTaskHandle = osThreadCreate(osThread(ledTask), NULL);
/* USER CODE BEGIN RTOS_THREADS */
osThreadDef(anemometer, wind_task, osPriorityHigh, 0, 128);// <20><><EFBFBD>ٷ<EFBFBD><D9B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʪ<EFBFBD>ȸ<EFBFBD><C8B8><EFBFBD>
anemometerHandle = osThreadCreate(osThread(anemometer), NULL);
osThreadDef(temhum_update_task, tem_hum_update_task, osPriorityAboveNormal, 0, 128);//<2F><>ʪ<EFBFBD>ȸ<EFBFBD><C8B8><EFBFBD>
temhum_update_taskHandle = osThreadCreate(osThread(temhum_update_task), NULL);
osThreadDef(trans_4g_task, Trans_4g_Task, osPriorityRealtime, 0, 256);//4G<34><47><EFBFBD><EFBFBD>
Trans_4g_taskHandle = osThreadCreate(osThread(trans_4g_task), NULL);
// osThreadDef(sensorTask, SensorTask, osPriorityRealtime, 0, 128);
// sensorTaskHandle = osThreadCreate(osThread(anemometer), NULL);
//osThreadDef(TermShellHandle, task_shell_term_main_loop, osPriorityAboveNormal, 0, 128);
//TermShellHandle = osThreadCreate(osThread(TermShellHandle), NULL);
/* add threads, ... */
/* USER CODE END RTOS_THREADS */
}
/* USER CODE BEGIN Header_StartDefaultTask */
/**
* @brief Function implementing the defaultTask thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartDefaultTask */
void StartDefaultTask(void const * argument)
{
/* USER CODE BEGIN StartDefaultTask */
/* Infinite loop */
for(;;)
{
read_and_process_uart_data(g_rs485_uart_handle);
read_and_process_uart_data(g_term_uart_handle);
if(time_get_ok)
{
parse_4g_receive_data();
}
osDelay(200);
}
/* USER CODE END StartDefaultTask */
}
/* Private application code --------------------------------------------------*/
/* USER CODE BEGIN Application */
#if 0
void task_shell_term_main_loop(void const * argument)
{
shell_init();
for(;;)
{
shell_main_loop("climate:~$ ");
osDelay(500);
}
}
#endif
void SensorTask(void const * argument)
{
/* USER CODE BEGIN StartDefaultTask */
/* Infinite loop */
for(;;)
{
read_and_process_uart_data(g_term_uart_handle);
osDelay(100);
}
/* USER CODE END StartDefaultTask */
}
/* USER CODE END Application */
void LEDTask(void const * argument)
{
/* USER CODE BEGIN StartDefaultTask */
/* Infinite loop */
for(;;)
{
osDelay(1000);
HAL_GPIO_TogglePin(GPIOC,GPIO_LED_CTRL_Pin);
}
/* USER CODE END StartDefaultTask */
}
/* USER CODE END Application */
int trans_4g_flag = 0;
void Trans_4g_Task(void const * argument)
{
/* USER CODE BEGIN StartDefaultTask */
EC801_start();
MQTT_Trans_Data();
int temp_1s = 0;
/* Infinite loop */
for(;;)
{
osDelay(1000);
temp_1s++;
if(temp_1s >= 600)
{
temp_1s = 0;
trans_4g_flag = 1;
}
if(trans_4g_flag == 1)
{
MQTT_Trans_Data();
trans_4g_flag = 0;
}
}
/* USER CODE END StartDefaultTask */
}
/* USER CODE END Application */