2025-04-03 15:59:48 +08:00
|
|
|
|
/* USER CODE BEGIN Header */
|
|
|
|
|
|
/**
|
|
|
|
|
|
******************************************************************************
|
|
|
|
|
|
* @file : main.c
|
|
|
|
|
|
* @brief : Main program body
|
|
|
|
|
|
******************************************************************************
|
|
|
|
|
|
* @attention
|
|
|
|
|
|
*
|
|
|
|
|
|
* <h2><center>© Copyright (c) 2021 STMicroelectronics.
|
|
|
|
|
|
* All rights reserved.</center></h2>
|
|
|
|
|
|
*
|
|
|
|
|
|
* This software component is licensed by ST under Ultimate Liberty license
|
|
|
|
|
|
* SLA0044, the "License"; You may not use this file except in compliance with
|
|
|
|
|
|
* the License. You may obtain a copy of the License at:
|
|
|
|
|
|
* www.st.com/SLA0044
|
|
|
|
|
|
*
|
|
|
|
|
|
******************************************************************************
|
|
|
|
|
|
*/
|
|
|
|
|
|
/* USER CODE END Header */
|
|
|
|
|
|
|
|
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
|
|
|
|
#include "includes.h"
|
|
|
|
|
|
|
|
|
|
|
|
const uint8_t CONFIG_BOARD_SELF = CONFIG_BOARD_SINGLE;
|
|
|
|
|
|
|
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>裬<EFBFBD><E8A3AC><EFBFBD><EFBFBD><EFBFBD>жϵ<D0B6>
|
|
|
|
|
|
static void Modules_Open()
|
|
|
|
|
|
{
|
|
|
|
|
|
FRAM_Open();
|
|
|
|
|
|
SFlash_Open();
|
|
|
|
|
|
Config_Open();
|
|
|
|
|
|
Data_Open();
|
|
|
|
|
|
Wakeup_Open();
|
|
|
|
|
|
Key_Open();
|
|
|
|
|
|
Modbus_Open();
|
|
|
|
|
|
RF_Open();
|
|
|
|
|
|
Ethernet_Open();
|
|
|
|
|
|
DTU_Open();
|
|
|
|
|
|
Form_Open();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Private includes ----------------------------------------------------------*/
|
|
|
|
|
|
/* USER CODE BEGIN Includes */
|
|
|
|
|
|
|
|
|
|
|
|
/* 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 ---------------------------------------------------------*/
|
|
|
|
|
|
IWDG_HandleTypeDef hiwdg;
|
|
|
|
|
|
|
|
|
|
|
|
RTC_HandleTypeDef hrtc;
|
|
|
|
|
|
|
|
|
|
|
|
osThreadId_t dtuTaskHandle;
|
|
|
|
|
|
osThreadId_t rfSendTaskHandle;
|
|
|
|
|
|
osThreadId_t rfTranTaskHandle;
|
|
|
|
|
|
osThreadId_t rfGatewayTaskHandle;
|
|
|
|
|
|
osThreadId_t formTaskHandle;
|
|
|
|
|
|
osThreadId_t keyTaskHandle;
|
|
|
|
|
|
osThreadId_t modbusTaskHandle;
|
|
|
|
|
|
/* USER CODE BEGIN PV */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END PV */
|
|
|
|
|
|
|
|
|
|
|
|
/* Private function prototypes -----------------------------------------------*/
|
|
|
|
|
|
void SystemClock_Config(void);
|
|
|
|
|
|
static void MX_GPIO_Init(void);
|
|
|
|
|
|
static void MX_IWDG_Init(void);
|
|
|
|
|
|
static void MX_RTC_Init(void);
|
|
|
|
|
|
static void MX_SPI1_Init(void);
|
|
|
|
|
|
static void MX_SPI2_Init(void);
|
|
|
|
|
|
static void MX_UART4_Init(void);
|
|
|
|
|
|
static void MX_UART7_Init(void);
|
|
|
|
|
|
static void MX_UART8_Init(void);
|
|
|
|
|
|
static void MX_UART10_Init(void);
|
|
|
|
|
|
static void MX_USART1_UART_Init(void);
|
|
|
|
|
|
static void MX_USART2_UART_Init(void);
|
|
|
|
|
|
static void MX_USART3_UART_Init(void);
|
|
|
|
|
|
static void MX_USART6_UART_Init(void);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN PFP */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END PFP */
|
|
|
|
|
|
|
|
|
|
|
|
/* Private user code ---------------------------------------------------------*/
|
|
|
|
|
|
/* USER CODE BEGIN 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief The application entry point.
|
|
|
|
|
|
* @retval int
|
|
|
|
|
|
*/
|
|
|
|
|
|
int main(void)
|
|
|
|
|
|
{
|
2025-05-07 10:53:16 +08:00
|
|
|
|
|
2025-04-03 15:59:48 +08:00
|
|
|
|
/* USER CODE BEGIN 1 */
|
|
|
|
|
|
// <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD>ԭ<EFBFBD><D4AD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
Fetch_ResetFlags();
|
|
|
|
|
|
/* USER CODE END 1 */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* MCU Configuration--------------------------------------------------------*/
|
|
|
|
|
|
|
|
|
|
|
|
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
|
|
|
|
|
HAL_Init();
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN Init */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END Init */
|
|
|
|
|
|
|
|
|
|
|
|
/* Configure the system clock */
|
|
|
|
|
|
SystemClock_Config();
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SysInit */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SysInit */
|
|
|
|
|
|
|
|
|
|
|
|
/* Initialize all configured peripherals */
|
|
|
|
|
|
MX_GPIO_Init();
|
|
|
|
|
|
MX_RTC_Init();
|
|
|
|
|
|
MX_SPI1_Init();
|
|
|
|
|
|
MX_SPI2_Init();
|
|
|
|
|
|
MX_UART4_Init();
|
|
|
|
|
|
MX_UART7_Init();
|
|
|
|
|
|
MX_UART8_Init();
|
|
|
|
|
|
MX_UART10_Init();
|
|
|
|
|
|
MX_USART1_UART_Init();
|
|
|
|
|
|
MX_USART2_UART_Init();
|
|
|
|
|
|
MX_USART3_UART_Init();
|
|
|
|
|
|
MX_USART6_UART_Init();
|
|
|
|
|
|
MX_IWDG_Init();
|
|
|
|
|
|
/* USER CODE BEGIN 2 */
|
|
|
|
|
|
Modules_Open();
|
|
|
|
|
|
printf("\nSYS_RSTSTS = %d\n", SYS_RSTSTS);
|
|
|
|
|
|
/* USER CODE END 2 */
|
|
|
|
|
|
|
|
|
|
|
|
osKernelInitialize();
|
|
|
|
|
|
|
|
|
|
|
|
/* 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 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN RTOS_THREADS */
|
|
|
|
|
|
/* add threads, ... */
|
|
|
|
|
|
const osThreadAttr_t dtuTask_attributes = {
|
|
|
|
|
|
.name = "dtuTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 2048
|
|
|
|
|
|
};
|
|
|
|
|
|
dtuTaskHandle = osThreadNew(DTU_Task, NULL, &dtuTask_attributes);
|
|
|
|
|
|
|
|
|
|
|
|
const osThreadAttr_t rfSendTask_attributes = {
|
|
|
|
|
|
.name = "rfSendTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 1024
|
|
|
|
|
|
};
|
|
|
|
|
|
rfSendTaskHandle = osThreadNew(RF_SendTask, NULL, &rfSendTask_attributes);
|
|
|
|
|
|
|
|
|
|
|
|
const osThreadAttr_t rfTranTask_attributes = {
|
|
|
|
|
|
.name = "rfTranTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 1024
|
|
|
|
|
|
};
|
|
|
|
|
|
rfTranTaskHandle = osThreadNew(RF_TranTask, NULL, &rfTranTask_attributes);
|
|
|
|
|
|
|
|
|
|
|
|
const osThreadAttr_t rfGatewayTask_attributes = {
|
|
|
|
|
|
.name = "rfGatewayTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 1024
|
|
|
|
|
|
};
|
|
|
|
|
|
rfGatewayTaskHandle = osThreadNew(RF_GatewayTask, NULL, &rfGatewayTask_attributes);
|
|
|
|
|
|
|
|
|
|
|
|
const osThreadAttr_t formTask_attributes = {
|
|
|
|
|
|
.name = "formTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 1024
|
|
|
|
|
|
};
|
|
|
|
|
|
formTaskHandle = osThreadNew(Form_Task, NULL, &formTask_attributes);
|
|
|
|
|
|
|
|
|
|
|
|
const osThreadAttr_t keyTask_attributes = {
|
|
|
|
|
|
.name = "keyTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 1024
|
|
|
|
|
|
};
|
|
|
|
|
|
keyTaskHandle = osThreadNew(Key_Task, NULL, &keyTask_attributes);
|
|
|
|
|
|
const osThreadAttr_t modbusTask_attributes = {
|
|
|
|
|
|
.name = "modbusTask",
|
|
|
|
|
|
.priority = (osPriority_t) osPriorityNormal,
|
|
|
|
|
|
.stack_size = 1024
|
|
|
|
|
|
};
|
|
|
|
|
|
modbusTaskHandle = osThreadNew(Modbus_Task, NULL, &modbusTask_attributes);
|
|
|
|
|
|
/* USER CODE END RTOS_THREADS */
|
|
|
|
|
|
|
|
|
|
|
|
/* Start scheduler */
|
|
|
|
|
|
osKernelStart();
|
|
|
|
|
|
|
|
|
|
|
|
/* We should never get here as control is now taken by the scheduler */
|
|
|
|
|
|
|
|
|
|
|
|
/* Infinite loop */
|
|
|
|
|
|
/* USER CODE BEGIN WHILE */
|
|
|
|
|
|
while (1)
|
|
|
|
|
|
{
|
|
|
|
|
|
/* USER CODE END WHILE */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN 3 */
|
|
|
|
|
|
}
|
|
|
|
|
|
/* USER CODE END 3 */
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief System Clock Configuration
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
void SystemClock_Config(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
LL_FLASH_SetLatency(LL_FLASH_LATENCY_2);
|
|
|
|
|
|
|
|
|
|
|
|
if(LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
LL_PWR_SetRegulVoltageScaling(LL_PWR_REGU_VOLTAGE_SCALE1);
|
|
|
|
|
|
LL_RCC_HSI_SetCalibTrimming(16);
|
|
|
|
|
|
LL_RCC_HSI_Enable();
|
|
|
|
|
|
|
|
|
|
|
|
/* Wait till HSI is ready */
|
|
|
|
|
|
while(LL_RCC_HSI_IsReady() != 1)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
LL_RCC_LSI_Enable();
|
|
|
|
|
|
|
|
|
|
|
|
/* Wait till LSI is ready */
|
|
|
|
|
|
while(LL_RCC_LSI_IsReady() != 1)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
LL_PWR_EnableBkUpAccess();
|
|
|
|
|
|
LL_RCC_ForceBackupDomainReset();
|
|
|
|
|
|
LL_RCC_ReleaseBackupDomainReset();
|
|
|
|
|
|
LL_RCC_LSE_Enable();
|
|
|
|
|
|
|
|
|
|
|
|
/* Wait till LSE is ready */
|
|
|
|
|
|
while(LL_RCC_LSE_IsReady() != 1)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
LL_RCC_SetRTCClockSource(LL_RCC_RTC_CLKSOURCE_LSE);
|
|
|
|
|
|
LL_RCC_EnableRTC();
|
|
|
|
|
|
LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSI, LL_RCC_PLLM_DIV_8, 64, LL_RCC_PLLP_DIV_2);
|
|
|
|
|
|
LL_RCC_PLL_Enable();
|
|
|
|
|
|
|
|
|
|
|
|
/* Wait till PLL is ready */
|
|
|
|
|
|
while(LL_RCC_PLL_IsReady() != 1)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1);
|
|
|
|
|
|
LL_RCC_SetAPB1Prescaler(LL_RCC_APB1_DIV_2);
|
|
|
|
|
|
LL_RCC_SetAPB2Prescaler(LL_RCC_APB2_DIV_1);
|
|
|
|
|
|
LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL);
|
|
|
|
|
|
|
|
|
|
|
|
/* Wait till System clock is ready */
|
|
|
|
|
|
while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
LL_SetSystemCoreClock(64000000);
|
|
|
|
|
|
LL_RCC_SetTIMPrescaler(LL_RCC_TIM_PRESCALER_TWICE);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief IWDG Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_IWDG_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN IWDG_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END IWDG_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN IWDG_Init 1 */
|
|
|
|
|
|
// <20><><EFBFBD>Ź<EFBFBD>ʱ<EFBFBD><CAB1>Ϊ32K<32><4B><EFBFBD><EFBFBD>ʱʱ<CAB1><CAB1>Ϊ4095/(32K/256)=32<33><32>
|
|
|
|
|
|
/* USER CODE END IWDG_Init 1 */
|
|
|
|
|
|
hiwdg.Instance = IWDG;
|
|
|
|
|
|
hiwdg.Init.Prescaler = IWDG_PRESCALER_256;
|
|
|
|
|
|
hiwdg.Init.Reload = 4095;
|
|
|
|
|
|
if (HAL_IWDG_Init(&hiwdg) != HAL_OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
/* USER CODE BEGIN IWDG_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END IWDG_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief RTC Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_RTC_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN RTC_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END RTC_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
RTC_TimeTypeDef sTime = {0};
|
|
|
|
|
|
RTC_DateTypeDef sDate = {0};
|
|
|
|
|
|
RTC_AlarmTypeDef sAlarm = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN RTC_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END RTC_Init 1 */
|
|
|
|
|
|
/** Initialize RTC Only
|
|
|
|
|
|
*/
|
|
|
|
|
|
hrtc.Instance = RTC;
|
|
|
|
|
|
hrtc.Init.HourFormat = RTC_HOURFORMAT_24;
|
|
|
|
|
|
hrtc.Init.AsynchPrediv = 127;
|
|
|
|
|
|
hrtc.Init.SynchPrediv = 255;
|
|
|
|
|
|
hrtc.Init.OutPut = RTC_OUTPUT_DISABLE;
|
|
|
|
|
|
hrtc.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH;
|
|
|
|
|
|
hrtc.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN;
|
|
|
|
|
|
if (HAL_RTC_Init(&hrtc) != HAL_OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN Check_RTC_BKUP */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END Check_RTC_BKUP */
|
|
|
|
|
|
|
|
|
|
|
|
/** Initialize RTC and set the Time and Date
|
|
|
|
|
|
*/
|
|
|
|
|
|
sTime.Hours = 0x0;
|
|
|
|
|
|
sTime.Minutes = 0x0;
|
|
|
|
|
|
sTime.Seconds = 0x0;
|
|
|
|
|
|
sTime.DayLightSaving = RTC_DAYLIGHTSAVING_NONE;
|
|
|
|
|
|
sTime.StoreOperation = RTC_STOREOPERATION_RESET;
|
|
|
|
|
|
if (HAL_RTC_SetTime(&hrtc, &sTime, RTC_FORMAT_BCD) != HAL_OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
sDate.WeekDay = RTC_WEEKDAY_MONDAY;
|
|
|
|
|
|
sDate.Month = RTC_MONTH_JANUARY;
|
|
|
|
|
|
sDate.Date = 0x1;
|
|
|
|
|
|
sDate.Year = 0x0;
|
|
|
|
|
|
|
|
|
|
|
|
if (HAL_RTC_SetDate(&hrtc, &sDate, RTC_FORMAT_BCD) != HAL_OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
/** Enable the Alarm A
|
|
|
|
|
|
*/
|
|
|
|
|
|
sAlarm.AlarmTime.Hours = 0x0;
|
|
|
|
|
|
sAlarm.AlarmTime.Minutes = 0x0;
|
|
|
|
|
|
sAlarm.AlarmTime.Seconds = 0x0;
|
|
|
|
|
|
sAlarm.AlarmTime.SubSeconds = 0x0;
|
|
|
|
|
|
sAlarm.AlarmTime.DayLightSaving = RTC_DAYLIGHTSAVING_NONE;
|
|
|
|
|
|
sAlarm.AlarmTime.StoreOperation = RTC_STOREOPERATION_RESET;
|
|
|
|
|
|
sAlarm.AlarmMask = RTC_ALARMMASK_NONE;
|
|
|
|
|
|
sAlarm.AlarmSubSecondMask = RTC_ALARMSUBSECONDMASK_ALL;
|
|
|
|
|
|
sAlarm.AlarmDateWeekDaySel = RTC_ALARMDATEWEEKDAYSEL_DATE;
|
|
|
|
|
|
sAlarm.AlarmDateWeekDay = 0x1;
|
|
|
|
|
|
sAlarm.Alarm = RTC_ALARM_A;
|
|
|
|
|
|
if (HAL_RTC_SetAlarm_IT(&hrtc, &sAlarm, RTC_FORMAT_BCD) != HAL_OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
/** Enable the Alarm B
|
|
|
|
|
|
*/
|
|
|
|
|
|
sAlarm.AlarmDateWeekDay = 0x1;
|
|
|
|
|
|
sAlarm.Alarm = RTC_ALARM_B;
|
|
|
|
|
|
if (HAL_RTC_SetAlarm_IT(&hrtc, &sAlarm, RTC_FORMAT_BCD) != HAL_OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
Error_Handler();
|
|
|
|
|
|
}
|
|
|
|
|
|
/* USER CODE BEGIN RTC_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END RTC_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief SPI1 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_SPI1_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SPI1_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SPI1_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_SPI_InitTypeDef SPI_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_SPI1);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOA);
|
|
|
|
|
|
/**SPI1 GPIO Configuration
|
|
|
|
|
|
PA5 ------> SPI1_SCK
|
|
|
|
|
|
PA6 ------> SPI1_MISO
|
|
|
|
|
|
PA7 ------> SPI1_MOSI
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_5|LL_GPIO_PIN_6|LL_GPIO_PIN_7;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_5;
|
|
|
|
|
|
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SPI1_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SPI1_Init 1 */
|
|
|
|
|
|
/* SPI1 parameter configuration*/
|
|
|
|
|
|
SPI_InitStruct.TransferDirection = LL_SPI_FULL_DUPLEX;
|
|
|
|
|
|
SPI_InitStruct.Mode = LL_SPI_MODE_MASTER;
|
|
|
|
|
|
SPI_InitStruct.DataWidth = LL_SPI_DATAWIDTH_8BIT;
|
|
|
|
|
|
SPI_InitStruct.ClockPolarity = LL_SPI_POLARITY_LOW;
|
|
|
|
|
|
SPI_InitStruct.ClockPhase = LL_SPI_PHASE_1EDGE;
|
|
|
|
|
|
SPI_InitStruct.NSS = LL_SPI_NSS_SOFT;
|
|
|
|
|
|
SPI_InitStruct.BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV2; // 32M<32><4D><EFBFBD><EFBFBD><EFBFBD><EFBFBD>32M
|
|
|
|
|
|
SPI_InitStruct.BitOrder = LL_SPI_MSB_FIRST;
|
|
|
|
|
|
SPI_InitStruct.CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE;
|
|
|
|
|
|
SPI_InitStruct.CRCPoly = 10;
|
|
|
|
|
|
LL_SPI_Init(SPI1, &SPI_InitStruct);
|
|
|
|
|
|
LL_SPI_SetStandard(SPI1, LL_SPI_PROTOCOL_MOTOROLA);
|
|
|
|
|
|
/* USER CODE BEGIN SPI1_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SPI1_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief SPI2 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_SPI2_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SPI2_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SPI2_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_SPI_InitTypeDef SPI_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_SPI2);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOC);
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOB);
|
|
|
|
|
|
/**SPI2 GPIO Configuration
|
|
|
|
|
|
PC2 ------> SPI2_MISO
|
|
|
|
|
|
PC3 ------> SPI2_MOSI
|
|
|
|
|
|
PB10 ------> SPI2_SCK
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_2|LL_GPIO_PIN_3;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_5;
|
|
|
|
|
|
LL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_10;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_5;
|
|
|
|
|
|
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SPI2_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SPI2_Init 1 */
|
|
|
|
|
|
/* SPI2 parameter configuration*/
|
|
|
|
|
|
SPI_InitStruct.TransferDirection = LL_SPI_FULL_DUPLEX;
|
|
|
|
|
|
SPI_InitStruct.Mode = LL_SPI_MODE_MASTER;
|
|
|
|
|
|
SPI_InitStruct.DataWidth = LL_SPI_DATAWIDTH_8BIT;
|
|
|
|
|
|
SPI_InitStruct.ClockPolarity = LL_SPI_POLARITY_LOW;
|
|
|
|
|
|
SPI_InitStruct.ClockPhase = LL_SPI_PHASE_1EDGE;
|
|
|
|
|
|
SPI_InitStruct.NSS = LL_SPI_NSS_SOFT;
|
|
|
|
|
|
SPI_InitStruct.BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV2; // 16M<36><4D><EFBFBD><EFBFBD><EFBFBD><EFBFBD>16M
|
|
|
|
|
|
SPI_InitStruct.BitOrder = LL_SPI_MSB_FIRST;
|
|
|
|
|
|
SPI_InitStruct.CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE;
|
|
|
|
|
|
SPI_InitStruct.CRCPoly = 10;
|
|
|
|
|
|
LL_SPI_Init(SPI2, &SPI_InitStruct);
|
|
|
|
|
|
LL_SPI_SetStandard(SPI2, LL_SPI_PROTOCOL_MOTOROLA);
|
|
|
|
|
|
/* USER CODE BEGIN SPI2_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END SPI2_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief UART4 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_UART4_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART4_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART4_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_UART4);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOA);
|
|
|
|
|
|
/**UART4 GPIO Configuration
|
|
|
|
|
|
PA0 ------> UART4_TX
|
|
|
|
|
|
PA1 ------> UART4_RX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_0|LL_GPIO_PIN_1;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_8;
|
|
|
|
|
|
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* UART4 interrupt Init */
|
2025-05-07 10:50:40 +08:00
|
|
|
|
NVIC_SetPriority(UART4_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(UART4_IRQn);
|
2025-04-03 15:59:48 +08:00
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART4_Init 1 */
|
2025-05-07 10:50:40 +08:00
|
|
|
|
huart4.RxISR = Slave_IRQHandler;
|
2025-04-03 15:59:48 +08:00
|
|
|
|
/* USER CODE END UART4_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 9600;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(UART4, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(UART4);
|
2025-05-07 10:50:40 +08:00
|
|
|
|
|
|
|
|
|
|
// LL_USART_EnableDEMode(USART3);
|
|
|
|
|
|
// LL_USART_SetDESignalPolarity(USART3, LL_USART_DE_POLARITY_HIGH);
|
|
|
|
|
|
// LL_USART_SetDEAssertionTime(USART3, 0);
|
|
|
|
|
|
// LL_USART_SetDEDeassertionTime(USART3, 0);
|
|
|
|
|
|
// LL_USART_ConfigAsyncMode(USART3);
|
|
|
|
|
|
SET_BIT(UART4->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE);
|
|
|
|
|
|
|
2025-04-03 15:59:48 +08:00
|
|
|
|
LL_USART_Enable(UART4);
|
|
|
|
|
|
/* USER CODE BEGIN UART4_Init 2 */
|
2025-05-07 10:50:40 +08:00
|
|
|
|
// LL_USART_Init(USART3, &USART_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-04-03 15:59:48 +08:00
|
|
|
|
|
2025-05-07 10:50:40 +08:00
|
|
|
|
// LL_USART_Enable(USART3);
|
2025-04-03 15:59:48 +08:00
|
|
|
|
/* USER CODE END UART4_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief UART7 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_UART7_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART7_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART7_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_UART7);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOB);
|
|
|
|
|
|
/**UART7 GPIO Configuration
|
|
|
|
|
|
PB3 ------> UART7_RX
|
|
|
|
|
|
PB4 ------> UART7_TX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_3|LL_GPIO_PIN_4;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_8;
|
|
|
|
|
|
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART7_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART7_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 9600;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(UART7, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(UART7);
|
|
|
|
|
|
LL_USART_Enable(UART7);
|
|
|
|
|
|
/* USER CODE BEGIN UART7_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART7_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief UART8 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_UART8_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART8_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART8_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_UART8);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOE);
|
|
|
|
|
|
/**UART8 GPIO Configuration
|
|
|
|
|
|
PE0 ------> UART8_RX
|
|
|
|
|
|
PE1 ------> UART8_TX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_0|LL_GPIO_PIN_1;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_8;
|
|
|
|
|
|
LL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* UART8 interrupt Init */
|
|
|
|
|
|
NVIC_SetPriority(UART8_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(UART8_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART8_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART8_Init 1 */
|
|
|
|
|
|
/* USER CODE BEGIN UART8_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART8_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief UART10 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_UART10_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART10_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART10_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_UART10);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOE);
|
|
|
|
|
|
/**UART10 GPIO Configuration
|
|
|
|
|
|
PE2 ------> UART10_RX
|
|
|
|
|
|
PE3 ------> UART10_TX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_2|LL_GPIO_PIN_3;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_11;
|
|
|
|
|
|
LL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* UART10 interrupt Init */
|
|
|
|
|
|
NVIC_SetPriority(UART10_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(UART10_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN UART10_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART10_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 115200;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(UART10, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(UART10);
|
|
|
|
|
|
/* USER CODE BEGIN UART10_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END UART10_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief USART1 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_USART1_UART_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART1_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART1_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_USART1);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOA);
|
|
|
|
|
|
/**USART1 GPIO Configuration
|
|
|
|
|
|
PA9 ------> USART1_TX
|
|
|
|
|
|
PA10 ------> USART1_RX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_9|LL_GPIO_PIN_10;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_7;
|
|
|
|
|
|
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USART1 interrupt Init */
|
|
|
|
|
|
NVIC_SetPriority(USART1_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(USART1_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART1_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART1_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 115200;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(USART1, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(USART1);
|
|
|
|
|
|
/* USER CODE BEGIN USART1_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART1_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief USART2 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_USART2_UART_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART2_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART2_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_USART2);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOA);
|
|
|
|
|
|
/**USART2 GPIO Configuration
|
|
|
|
|
|
PA2 ------> USART2_TX
|
|
|
|
|
|
PA3 ------> USART2_RX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_2|LL_GPIO_PIN_3;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_7;
|
|
|
|
|
|
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USART2 interrupt Init */
|
|
|
|
|
|
NVIC_SetPriority(USART2_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(USART2_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART2_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART2_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 115200;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(USART2, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(USART2);
|
|
|
|
|
|
LL_USART_Enable(USART2);
|
|
|
|
|
|
/* USER CODE BEGIN USART2_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART2_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief USART3 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_USART3_UART_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART3_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART3_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_USART3);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOC);
|
|
|
|
|
|
/**USART3 GPIO Configuration
|
|
|
|
|
|
PC10 ------> USART3_TX
|
|
|
|
|
|
PC11 ------> USART3_RX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_10|LL_GPIO_PIN_11;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_7;
|
|
|
|
|
|
LL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USART3 interrupt Init */
|
|
|
|
|
|
NVIC_SetPriority(USART3_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(USART3_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART3_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART3_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 115200;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(USART3, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(USART3);
|
|
|
|
|
|
/* USER CODE BEGIN USART3_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART3_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief USART6 Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_USART6_UART_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART6_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART6_Init 0 */
|
|
|
|
|
|
|
|
|
|
|
|
LL_USART_InitTypeDef USART_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
|
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_USART6);
|
|
|
|
|
|
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOA);
|
|
|
|
|
|
/**USART6 GPIO Configuration
|
|
|
|
|
|
PA11 ------> USART6_TX
|
|
|
|
|
|
PA12 ------> USART6_RX
|
|
|
|
|
|
*/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_11|LL_GPIO_PIN_12;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
|
|
|
|
|
|
GPIO_InitStruct.Alternate = LL_GPIO_AF_8;
|
|
|
|
|
|
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/* USART6 interrupt Init */
|
|
|
|
|
|
NVIC_SetPriority(USART6_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(USART6_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE BEGIN USART6_Init 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART6_Init 1 */
|
|
|
|
|
|
USART_InitStruct.BaudRate = 115200;
|
|
|
|
|
|
USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
|
|
|
|
|
|
USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
|
|
|
|
|
|
USART_InitStruct.Parity = LL_USART_PARITY_NONE;
|
|
|
|
|
|
USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
|
|
|
|
|
|
USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
|
|
|
|
|
|
USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
|
|
|
|
|
|
LL_USART_Init(USART6, &USART_InitStruct);
|
|
|
|
|
|
LL_USART_ConfigAsyncMode(USART6);
|
|
|
|
|
|
LL_USART_Enable(USART6);
|
|
|
|
|
|
/* USER CODE BEGIN USART6_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END USART6_Init 2 */
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief GPIO Initialization Function
|
|
|
|
|
|
* @param None
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
static void MX_GPIO_Init(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
LL_EXTI_InitTypeDef EXTI_InitStruct = {0};
|
|
|
|
|
|
LL_GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
|
|
|
|
|
|
|
|
/* GPIO Ports Clock Enable */
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOE);
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOC);
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOH);
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOA);
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOB);
|
|
|
|
|
|
LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_GPIOD);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(GPIOC, LL_GPIO_PIN_1|LL_GPIO_PIN_4|LL_GPIO_PIN_7|LL_GPIO_PIN_8
|
|
|
|
|
|
|LL_GPIO_PIN_12);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(GPIOB, LL_GPIO_PIN_0|LL_GPIO_PIN_5|LL_GPIO_PIN_6|LL_GPIO_PIN_8
|
|
|
|
|
|
|LL_GPIO_PIN_9);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
LL_GPIO_ResetOutputPin(GPIOD, LL_GPIO_PIN_12|LL_GPIO_PIN_5|LL_GPIO_PIN_6);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_4|LL_GPIO_PIN_6|LL_GPIO_PIN_7
|
|
|
|
|
|
|LL_GPIO_PIN_8|LL_GPIO_PIN_9|LL_GPIO_PIN_10|LL_GPIO_PIN_11
|
|
|
|
|
|
|LL_GPIO_PIN_12|LL_GPIO_PIN_13|LL_GPIO_PIN_14|LL_GPIO_PIN_15;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ANALOG;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_13|LL_GPIO_PIN_0|LL_GPIO_PIN_5|LL_GPIO_PIN_6
|
|
|
|
|
|
|LL_GPIO_PIN_9;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ANALOG;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_1|LL_GPIO_PIN_4|LL_GPIO_PIN_7|LL_GPIO_PIN_8
|
|
|
|
|
|
|LL_GPIO_PIN_12;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_OUTPUT;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_4|LL_GPIO_PIN_8|LL_GPIO_PIN_15;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ANALOG;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_0|LL_GPIO_PIN_5|LL_GPIO_PIN_6|LL_GPIO_PIN_8
|
|
|
|
|
|
|LL_GPIO_PIN_9;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_OUTPUT;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_1|LL_GPIO_PIN_2|LL_GPIO_PIN_12|LL_GPIO_PIN_13
|
|
|
|
|
|
|LL_GPIO_PIN_14|LL_GPIO_PIN_15|LL_GPIO_PIN_7;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ANALOG;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_8|LL_GPIO_PIN_9|LL_GPIO_PIN_10|LL_GPIO_PIN_11
|
|
|
|
|
|
|LL_GPIO_PIN_13|LL_GPIO_PIN_14|LL_GPIO_PIN_15|LL_GPIO_PIN_0
|
|
|
|
|
|
|LL_GPIO_PIN_1|LL_GPIO_PIN_2|LL_GPIO_PIN_3|LL_GPIO_PIN_4
|
|
|
|
|
|
|LL_GPIO_PIN_7;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_ANALOG;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
GPIO_InitStruct.Pin = LL_GPIO_PIN_12|LL_GPIO_PIN_5|LL_GPIO_PIN_6;
|
|
|
|
|
|
GPIO_InitStruct.Mode = LL_GPIO_MODE_OUTPUT;
|
|
|
|
|
|
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
|
|
|
|
|
|
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
|
|
|
|
|
|
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
|
|
|
|
|
|
LL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
LL_SYSCFG_SetEXTISource(LL_SYSCFG_EXTI_PORTE, LL_SYSCFG_EXTI_LINE5);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
EXTI_InitStruct.Line_0_31 = LL_EXTI_LINE_5;
|
|
|
|
|
|
EXTI_InitStruct.LineCommand = ENABLE;
|
|
|
|
|
|
EXTI_InitStruct.Mode = LL_EXTI_MODE_IT;
|
|
|
|
|
|
EXTI_InitStruct.Trigger = LL_EXTI_TRIGGER_FALLING;
|
|
|
|
|
|
LL_EXTI_Init(&EXTI_InitStruct);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
LL_GPIO_SetPinPull(GPIOE, LL_GPIO_PIN_5, LL_GPIO_PULL_NO);
|
|
|
|
|
|
|
|
|
|
|
|
/**/
|
|
|
|
|
|
LL_GPIO_SetPinMode(GPIOE, LL_GPIO_PIN_5, LL_GPIO_MODE_INPUT);
|
|
|
|
|
|
|
|
|
|
|
|
/* EXTI interrupt init*/
|
|
|
|
|
|
NVIC_SetPriority(EXTI9_5_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(),5, 0));
|
|
|
|
|
|
NVIC_EnableIRQ(EXTI9_5_IRQn);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief Period elapsed callback in non blocking mode
|
|
|
|
|
|
* @note This function is called when TIM1 interrupt took place, inside
|
|
|
|
|
|
* HAL_TIM_IRQHandler(). It makes a direct call to HAL_IncTick() to increment
|
|
|
|
|
|
* a global variable "uwTick" used as application time base.
|
|
|
|
|
|
* @param htim : TIM handle
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
|
|
|
|
|
|
{
|
|
|
|
|
|
/* USER CODE BEGIN Callback 0 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END Callback 0 */
|
|
|
|
|
|
if (htim->Instance == TIM1) {
|
|
|
|
|
|
HAL_IncTick();
|
|
|
|
|
|
}
|
|
|
|
|
|
/* USER CODE BEGIN Callback 1 */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END Callback 1 */
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief This function is executed in case of error occurrence.
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
void Error_Handler(void)
|
|
|
|
|
|
{
|
|
|
|
|
|
/* USER CODE BEGIN Error_Handler_Debug */
|
|
|
|
|
|
/* User can add his own implementation to report the HAL error return state */
|
|
|
|
|
|
|
|
|
|
|
|
/* USER CODE END Error_Handler_Debug */
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef USE_FULL_ASSERT
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @brief Reports the name of the source file and the source line number
|
|
|
|
|
|
* where the assert_param error has occurred.
|
|
|
|
|
|
* @param file: pointer to the source file name
|
|
|
|
|
|
* @param line: assert_param error line source number
|
|
|
|
|
|
* @retval None
|
|
|
|
|
|
*/
|
|
|
|
|
|
void assert_failed(uint8_t *file, uint32_t line)
|
|
|
|
|
|
{
|
|
|
|
|
|
/* USER CODE BEGIN 6 */
|
|
|
|
|
|
/* User can add his own implementation to report the file name and line number,
|
|
|
|
|
|
tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
|
|
|
|
|
/* USER CODE END 6 */
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif /* USE_FULL_ASSERT */
|
|
|
|
|
|
|
|
|
|
|
|
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|