sggt/Core/Src/freertos.c

290 lines
7.9 KiB
C

/* USER CODE BEGIN Header */
/**
******************************************************************************
* File Name : freertos.c
* Description : Code for freertos applications
******************************************************************************
* @attention
*
* Copyright (c) 2024 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 <string.h>
#include "gpio.h"
#include "JLX240-00301-BN.h"
#include "modbus.h"
#include "ble.h"
#include "hart.h"
#include "mux_signal.h"
#include "rn7302.h"
#include "SIG24130.h"
#include "tm1650.h"
#include "lvgl.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 */
/* USER CODE END Variables */
osThreadId defaultTaskHandle;
osThreadId task_lcdHandle;
osThreadId task_hartHandle;
osThreadId task_bleHandle;
osThreadId task_rs485Handle;
osThreadId task_mux_analogHandle;
osMessageQId myQueue01Handle;
/* Private function prototypes -----------------------------------------------*/
/* USER CODE BEGIN FunctionPrototypes */
/* USER CODE END FunctionPrototypes */
void StartDefaultTask(void const * argument);
void start_task_lcd(void const * argument);
void start_task_hart(void const * argument);
void start_task_ble(void const * argument);
void start_rs485(void const * argument);
void start_mux_analog(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 */
/* Create the queue(s) */
/* definition and creation of myQueue01 */
osMessageQDef(myQueue01, 16, uint16_t);
myQueue01Handle = osMessageCreate(osMessageQ(myQueue01), NULL);
/* USER CODE BEGIN RTOS_QUEUES */
/* add queues, ... */
/* USER CODE END RTOS_QUEUES */
/* Create the thread(s) */
/* definition and creation of defaultTask */
osThreadDef(defaultTask, StartDefaultTask, osPriorityNormal, 0, 128);
defaultTaskHandle = osThreadCreate(osThread(defaultTask), NULL);
/* definition and creation of task_lcd */
osThreadDef(task_lcd, start_task_lcd, osPriorityLow, 0, 256);
task_lcdHandle = osThreadCreate(osThread(task_lcd), NULL);
/* definition and creation of task_hart */
osThreadDef(task_hart, start_task_hart, osPriorityNormal, 0, 128);
task_hartHandle = osThreadCreate(osThread(task_hart), NULL);
/* definition and creation of task_ble */
osThreadDef(task_ble, start_task_ble, osPriorityIdle, 0, 128);
task_bleHandle = osThreadCreate(osThread(task_ble), NULL);
/* definition and creation of task_rs485 */
osThreadDef(task_rs485, start_rs485, osPriorityIdle, 0, 128);
task_rs485Handle = osThreadCreate(osThread(task_rs485), NULL);
/* definition and creation of task_mux_analog */
osThreadDef(task_mux_analog, start_mux_analog, osPriorityAboveNormal, 0, 128);
task_mux_analogHandle = osThreadCreate(osThread(task_mux_analog), NULL);
/* USER CODE BEGIN RTOS_THREADS */
/* 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 (;;)
{
LIGHT_PWR(OFF);
// pwr_cosume(kp_flag, 20000);
tm1650_read_key(&hi2c1, &kp_flag, COMMAND_READ_KEY_DATA, &key);
osDelay(500);
}
/* USER CODE END StartDefaultTask */
}
/* USER CODE BEGIN Header_start_task_lcd */
/**
* @brief Function implementing the task_lcd thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_start_task_lcd */
void start_task_lcd(void const * argument)
{
/* USER CODE BEGIN start_task_lcd */
lcd_initial();
/* Infinite loop */
for (;;)
{
lcd_menu();
lv_timer_handler(); //LVGL刷新任务
osDelay(10);
}
/* USER CODE END start_task_lcd */
}
/* USER CODE BEGIN Header_start_task_hart */
/**
* @brief Function implementing the task_hart thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_start_task_hart */
void start_task_hart(void const * argument)
{
/* USER CODE BEGIN start_task_hart */
/* Infinite loop */
for (;;)
{
hart_communicate(&scom1_hart);
osDelay(10);
}
/* USER CODE END start_task_hart */
}
/* USER CODE BEGIN Header_start_task_ble */
/**
* @brief Function implementing the task_ble thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_start_task_ble */
void start_task_ble(void const * argument)
{
/* USER CODE BEGIN start_task_ble */
/* Infinite loop */
for (;;)
{
strcpy((char *)(scom6_ble.tx_buff), "hellow I am ble.\r\n");
ble_send(&huart6, scom6_ble.tx_buff);
osDelay(1000);
}
/* USER CODE END start_task_ble */
}
/* USER CODE BEGIN Header_start_rs485 */
/**
* @brief Function implementing the task_rs485 thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_start_rs485 */
void start_rs485(void const * argument)
{
/* USER CODE BEGIN start_rs485 */
RS485_RW(RS485_RD); // rs485从机
/* Infinite loop */
for (;;)
{
parse_scom_485(&scom2_rs485);
osDelay(1);
}
/* USER CODE END start_rs485 */
}
/* USER CODE BEGIN Header_start_mux_analog */
/**
* @brief Function implementing the task_mux_analog thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_start_mux_analog */
void start_mux_analog(void const * argument)
{
/* USER CODE BEGIN start_mux_analog */
// rn7302_Init();
SIG24130_Init();
/* Infinite loop */
for (;;)
{
// get_rn7302_ch_value();
mux_signal_switch(&mux_signal);
osDelay(50);
}
/* USER CODE END start_mux_analog */
}
/* Private application code --------------------------------------------------*/
/* USER CODE BEGIN Application */
/* USER CODE END Application */