STM32G474RB firmware for solar buck converter with MPPT, CC control, Vfly compensation, and adaptive deadtime. Includes Textual TUI debug console for real-time telemetry, parameter tuning, and SQLite logging. Added pyproject.toml for uv: `cd code64 && uv run debug-console` Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
1442 lines
38 KiB
C
1442 lines
38 KiB
C
/* USER CODE BEGIN Header */
|
|
/**
|
|
******************************************************************************
|
|
* @file stm32g4xx_hal_msp.c
|
|
* @brief This file provides code for the MSP Initialization
|
|
* and de-Initialization codes.
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* Copyright (c) 2025 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 "main.h"
|
|
/* USER CODE BEGIN Includes */
|
|
|
|
/* USER CODE END Includes */
|
|
extern DMA_HandleTypeDef hdma_adc1;
|
|
|
|
extern DMA_HandleTypeDef hdma_adc2;
|
|
|
|
extern DMA_HandleTypeDef hdma_adc3;
|
|
|
|
extern DMA_HandleTypeDef hdma_adc4;
|
|
|
|
extern DMA_HandleTypeDef hdma_adc5;
|
|
|
|
/* Private typedef -----------------------------------------------------------*/
|
|
/* USER CODE BEGIN TD */
|
|
|
|
/* USER CODE END TD */
|
|
|
|
/* Private define ------------------------------------------------------------*/
|
|
/* USER CODE BEGIN Define */
|
|
|
|
/* USER CODE END Define */
|
|
|
|
/* Private macro -------------------------------------------------------------*/
|
|
/* USER CODE BEGIN Macro */
|
|
|
|
/* USER CODE END Macro */
|
|
|
|
/* Private variables ---------------------------------------------------------*/
|
|
/* USER CODE BEGIN PV */
|
|
|
|
/* USER CODE END PV */
|
|
|
|
/* Private function prototypes -----------------------------------------------*/
|
|
/* USER CODE BEGIN PFP */
|
|
|
|
/* USER CODE END PFP */
|
|
|
|
/* External functions --------------------------------------------------------*/
|
|
/* USER CODE BEGIN ExternalFunctions */
|
|
|
|
/* USER CODE END ExternalFunctions */
|
|
|
|
/* USER CODE BEGIN 0 */
|
|
|
|
/* USER CODE END 0 */
|
|
|
|
void HAL_HRTIM_MspPostInit(HRTIM_HandleTypeDef *hhrtim);
|
|
|
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
|
|
/**
|
|
* Initializes the Global MSP.
|
|
*/
|
|
void HAL_MspInit(void)
|
|
{
|
|
|
|
/* USER CODE BEGIN MspInit 0 */
|
|
|
|
/* USER CODE END MspInit 0 */
|
|
|
|
__HAL_RCC_SYSCFG_CLK_ENABLE();
|
|
__HAL_RCC_PWR_CLK_ENABLE();
|
|
|
|
/* System interrupt init*/
|
|
|
|
/** Configure the internal voltage reference buffer voltage scale
|
|
*/
|
|
HAL_SYSCFG_VREFBUF_VoltageScalingConfig(SYSCFG_VREFBUF_VOLTAGE_SCALE1);
|
|
|
|
/** Configure the internal voltage reference buffer high impedance mode
|
|
*/
|
|
HAL_SYSCFG_VREFBUF_HighImpedanceConfig(SYSCFG_VREFBUF_HIGH_IMPEDANCE_DISABLE);
|
|
|
|
/** Enable the Internal Voltage Reference buffer
|
|
*/
|
|
HAL_SYSCFG_EnableVREFBUF();
|
|
|
|
/** Disable the internal Pull-Up in Dead Battery pins of UCPD peripheral
|
|
*/
|
|
HAL_PWREx_DisableUCPDDeadBattery();
|
|
|
|
/* USER CODE BEGIN MspInit 1 */
|
|
|
|
/* USER CODE END MspInit 1 */
|
|
}
|
|
|
|
static uint32_t HAL_RCC_ADC12_CLK_ENABLED=0;
|
|
static uint32_t HAL_RCC_ADC345_CLK_ENABLED=0;
|
|
|
|
/**
|
|
* @brief ADC MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hadc: ADC handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
|
if(hadc->Instance==ADC1)
|
|
{
|
|
/* USER CODE BEGIN ADC1_MspInit 0 */
|
|
|
|
/* USER CODE END ADC1_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC12;
|
|
PeriphClkInit.Adc12ClockSelection = RCC_ADC12CLKSOURCE_SYSCLK;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
HAL_RCC_ADC12_CLK_ENABLED++;
|
|
if(HAL_RCC_ADC12_CLK_ENABLED==1){
|
|
__HAL_RCC_ADC12_CLK_ENABLE();
|
|
}
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
/**ADC1 GPIO Configuration
|
|
PC0 ------> ADC1_IN6
|
|
PC1 ------> ADC1_IN7
|
|
PC2 ------> ADC1_IN8
|
|
PA2 ------> ADC1_IN3
|
|
*/
|
|
GPIO_InitStruct.Pin = V_IN_ADC_Pin|I_IN_COMP_ADC_Pin|NTC_BOARD_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = TEMP_OUT_ADC_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(TEMP_OUT_ADC_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* ADC1 DMA Init */
|
|
/* ADC1 Init */
|
|
hdma_adc1.Instance = DMA1_Channel2;
|
|
hdma_adc1.Init.Request = DMA_REQUEST_ADC1;
|
|
hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_adc1.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_adc1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_adc1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_adc1.Init.Mode = DMA_CIRCULAR;
|
|
hdma_adc1.Init.Priority = DMA_PRIORITY_HIGH;
|
|
if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(hadc,DMA_Handle,hdma_adc1);
|
|
|
|
/* USER CODE BEGIN ADC1_MspInit 1 */
|
|
|
|
/* USER CODE END ADC1_MspInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC2)
|
|
{
|
|
/* USER CODE BEGIN ADC2_MspInit 0 */
|
|
|
|
/* USER CODE END ADC2_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC12;
|
|
PeriphClkInit.Adc12ClockSelection = RCC_ADC12CLKSOURCE_SYSCLK;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
HAL_RCC_ADC12_CLK_ENABLED++;
|
|
if(HAL_RCC_ADC12_CLK_ENABLED==1){
|
|
__HAL_RCC_ADC12_CLK_ENABLE();
|
|
}
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
/**ADC2 GPIO Configuration
|
|
PA6 ------> ADC2_IN3
|
|
PC4 ------> ADC2_IN5
|
|
*/
|
|
GPIO_InitStruct.Pin = VFLY_OUT_ADC_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(VFLY_OUT_ADC_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = I_LOAD_ADC_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(I_LOAD_ADC_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* ADC2 DMA Init */
|
|
/* ADC2 Init */
|
|
hdma_adc2.Instance = DMA1_Channel3;
|
|
hdma_adc2.Init.Request = DMA_REQUEST_ADC2;
|
|
hdma_adc2.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_adc2.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_adc2.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_adc2.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_adc2.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_adc2.Init.Mode = DMA_CIRCULAR;
|
|
hdma_adc2.Init.Priority = DMA_PRIORITY_HIGH;
|
|
if (HAL_DMA_Init(&hdma_adc2) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(hadc,DMA_Handle,hdma_adc2);
|
|
|
|
/* USER CODE BEGIN ADC2_MspInit 1 */
|
|
|
|
/* USER CODE END ADC2_MspInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC3)
|
|
{
|
|
/* USER CODE BEGIN ADC3_MspInit 0 */
|
|
|
|
/* USER CODE END ADC3_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC345;
|
|
PeriphClkInit.Adc345ClockSelection = RCC_ADC345CLKSOURCE_SYSCLK;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
HAL_RCC_ADC345_CLK_ENABLED++;
|
|
if(HAL_RCC_ADC345_CLK_ENABLED==1){
|
|
__HAL_RCC_ADC345_CLK_ENABLE();
|
|
}
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**ADC3 GPIO Configuration
|
|
PB1 ------> ADC3_IN1
|
|
*/
|
|
GPIO_InitStruct.Pin = V_OUT_COMP_ADC3_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(V_OUT_COMP_ADC3_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* ADC3 DMA Init */
|
|
/* ADC3 Init */
|
|
hdma_adc3.Instance = DMA2_Channel1;
|
|
hdma_adc3.Init.Request = DMA_REQUEST_ADC3;
|
|
hdma_adc3.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_adc3.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_adc3.Init.MemInc = DMA_MINC_DISABLE;
|
|
hdma_adc3.Init.PeriphDataAlignment = DMA_PDATAALIGN_WORD;
|
|
hdma_adc3.Init.MemDataAlignment = DMA_MDATAALIGN_WORD;
|
|
hdma_adc3.Init.Mode = DMA_CIRCULAR;
|
|
hdma_adc3.Init.Priority = DMA_PRIORITY_VERY_HIGH;
|
|
if (HAL_DMA_Init(&hdma_adc3) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(hadc,DMA_Handle,hdma_adc3);
|
|
|
|
/* USER CODE BEGIN ADC3_MspInit 1 */
|
|
|
|
/* USER CODE END ADC3_MspInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC4)
|
|
{
|
|
/* USER CODE BEGIN ADC4_MspInit 0 */
|
|
|
|
/* USER CODE END ADC4_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC345;
|
|
PeriphClkInit.Adc345ClockSelection = RCC_ADC345CLKSOURCE_SYSCLK;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
HAL_RCC_ADC345_CLK_ENABLED++;
|
|
if(HAL_RCC_ADC345_CLK_ENABLED==1){
|
|
__HAL_RCC_ADC345_CLK_ENABLE();
|
|
}
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**ADC4 GPIO Configuration
|
|
PB12 ------> ADC4_IN3
|
|
*/
|
|
GPIO_InitStruct.Pin = VBAT_ADC_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(VBAT_ADC_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* ADC4 DMA Init */
|
|
/* ADC4 Init */
|
|
hdma_adc4.Instance = DMA1_Channel1;
|
|
hdma_adc4.Init.Request = DMA_REQUEST_ADC4;
|
|
hdma_adc4.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_adc4.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_adc4.Init.MemInc = DMA_MINC_DISABLE;
|
|
hdma_adc4.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_adc4.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_adc4.Init.Mode = DMA_CIRCULAR;
|
|
hdma_adc4.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_adc4) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(hadc,DMA_Handle,hdma_adc4);
|
|
|
|
/* USER CODE BEGIN ADC4_MspInit 1 */
|
|
|
|
/* USER CODE END ADC4_MspInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC5)
|
|
{
|
|
/* USER CODE BEGIN ADC5_MspInit 0 */
|
|
|
|
/* USER CODE END ADC5_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC345;
|
|
PeriphClkInit.Adc345ClockSelection = RCC_ADC345CLKSOURCE_SYSCLK;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
HAL_RCC_ADC345_CLK_ENABLED++;
|
|
if(HAL_RCC_ADC345_CLK_ENABLED==1){
|
|
__HAL_RCC_ADC345_CLK_ENABLE();
|
|
}
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
/**ADC5 GPIO Configuration
|
|
PA9 ------> ADC5_IN2
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_9;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
/* ADC5 DMA Init */
|
|
/* ADC5 Init */
|
|
hdma_adc5.Instance = DMA1_Channel4;
|
|
hdma_adc5.Init.Request = DMA_REQUEST_ADC5;
|
|
hdma_adc5.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_adc5.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_adc5.Init.MemInc = DMA_MINC_DISABLE;
|
|
hdma_adc5.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_adc5.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_adc5.Init.Mode = DMA_CIRCULAR;
|
|
hdma_adc5.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_adc5) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(hadc,DMA_Handle,hdma_adc5);
|
|
|
|
/* USER CODE BEGIN ADC5_MspInit 1 */
|
|
|
|
/* USER CODE END ADC5_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief ADC MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hadc: ADC handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_ADC_MspDeInit(ADC_HandleTypeDef* hadc)
|
|
{
|
|
if(hadc->Instance==ADC1)
|
|
{
|
|
/* USER CODE BEGIN ADC1_MspDeInit 0 */
|
|
|
|
/* USER CODE END ADC1_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
HAL_RCC_ADC12_CLK_ENABLED--;
|
|
if(HAL_RCC_ADC12_CLK_ENABLED==0){
|
|
__HAL_RCC_ADC12_CLK_DISABLE();
|
|
}
|
|
|
|
/**ADC1 GPIO Configuration
|
|
PC0 ------> ADC1_IN6
|
|
PC1 ------> ADC1_IN7
|
|
PC2 ------> ADC1_IN8
|
|
PA2 ------> ADC1_IN3
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOC, V_IN_ADC_Pin|I_IN_COMP_ADC_Pin|NTC_BOARD_Pin);
|
|
|
|
HAL_GPIO_DeInit(TEMP_OUT_ADC_GPIO_Port, TEMP_OUT_ADC_Pin);
|
|
|
|
/* ADC1 DMA DeInit */
|
|
HAL_DMA_DeInit(hadc->DMA_Handle);
|
|
/* USER CODE BEGIN ADC1_MspDeInit 1 */
|
|
|
|
/* USER CODE END ADC1_MspDeInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC2)
|
|
{
|
|
/* USER CODE BEGIN ADC2_MspDeInit 0 */
|
|
|
|
/* USER CODE END ADC2_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
HAL_RCC_ADC12_CLK_ENABLED--;
|
|
if(HAL_RCC_ADC12_CLK_ENABLED==0){
|
|
__HAL_RCC_ADC12_CLK_DISABLE();
|
|
}
|
|
|
|
/**ADC2 GPIO Configuration
|
|
PA6 ------> ADC2_IN3
|
|
PC4 ------> ADC2_IN5
|
|
*/
|
|
HAL_GPIO_DeInit(VFLY_OUT_ADC_GPIO_Port, VFLY_OUT_ADC_Pin);
|
|
|
|
HAL_GPIO_DeInit(I_LOAD_ADC_GPIO_Port, I_LOAD_ADC_Pin);
|
|
|
|
/* ADC2 DMA DeInit */
|
|
HAL_DMA_DeInit(hadc->DMA_Handle);
|
|
/* USER CODE BEGIN ADC2_MspDeInit 1 */
|
|
|
|
/* USER CODE END ADC2_MspDeInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC3)
|
|
{
|
|
/* USER CODE BEGIN ADC3_MspDeInit 0 */
|
|
|
|
/* USER CODE END ADC3_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
HAL_RCC_ADC345_CLK_ENABLED--;
|
|
if(HAL_RCC_ADC345_CLK_ENABLED==0){
|
|
__HAL_RCC_ADC345_CLK_DISABLE();
|
|
}
|
|
|
|
/**ADC3 GPIO Configuration
|
|
PB1 ------> ADC3_IN1
|
|
*/
|
|
HAL_GPIO_DeInit(V_OUT_COMP_ADC3_GPIO_Port, V_OUT_COMP_ADC3_Pin);
|
|
|
|
/* ADC3 DMA DeInit */
|
|
HAL_DMA_DeInit(hadc->DMA_Handle);
|
|
/* USER CODE BEGIN ADC3_MspDeInit 1 */
|
|
|
|
/* USER CODE END ADC3_MspDeInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC4)
|
|
{
|
|
/* USER CODE BEGIN ADC4_MspDeInit 0 */
|
|
|
|
/* USER CODE END ADC4_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
HAL_RCC_ADC345_CLK_ENABLED--;
|
|
if(HAL_RCC_ADC345_CLK_ENABLED==0){
|
|
__HAL_RCC_ADC345_CLK_DISABLE();
|
|
}
|
|
|
|
/**ADC4 GPIO Configuration
|
|
PB12 ------> ADC4_IN3
|
|
*/
|
|
HAL_GPIO_DeInit(VBAT_ADC_GPIO_Port, VBAT_ADC_Pin);
|
|
|
|
/* ADC4 DMA DeInit */
|
|
HAL_DMA_DeInit(hadc->DMA_Handle);
|
|
/* USER CODE BEGIN ADC4_MspDeInit 1 */
|
|
|
|
/* USER CODE END ADC4_MspDeInit 1 */
|
|
}
|
|
else if(hadc->Instance==ADC5)
|
|
{
|
|
/* USER CODE BEGIN ADC5_MspDeInit 0 */
|
|
|
|
/* USER CODE END ADC5_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
HAL_RCC_ADC345_CLK_ENABLED--;
|
|
if(HAL_RCC_ADC345_CLK_ENABLED==0){
|
|
__HAL_RCC_ADC345_CLK_DISABLE();
|
|
}
|
|
|
|
/**ADC5 GPIO Configuration
|
|
PA9 ------> ADC5_IN2
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9);
|
|
|
|
/* ADC5 DMA DeInit */
|
|
HAL_DMA_DeInit(hadc->DMA_Handle);
|
|
/* USER CODE BEGIN ADC5_MspDeInit 1 */
|
|
|
|
/* USER CODE END ADC5_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief COMP MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hcomp: COMP handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_COMP_MspInit(COMP_HandleTypeDef* hcomp)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
if(hcomp->Instance==COMP1)
|
|
{
|
|
/* USER CODE BEGIN COMP1_MspInit 0 */
|
|
|
|
/* USER CODE END COMP1_MspInit 0 */
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**COMP1 GPIO Configuration
|
|
PB1 ------> COMP1_INP
|
|
*/
|
|
GPIO_InitStruct.Pin = V_OUT_COMP_ADC3_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(V_OUT_COMP_ADC3_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* COMP1 interrupt Init */
|
|
HAL_NVIC_SetPriority(COMP1_2_3_IRQn, 0, 0);
|
|
HAL_NVIC_EnableIRQ(COMP1_2_3_IRQn);
|
|
/* USER CODE BEGIN COMP1_MspInit 1 */
|
|
|
|
/* USER CODE END COMP1_MspInit 1 */
|
|
}
|
|
else if(hcomp->Instance==COMP3)
|
|
{
|
|
/* USER CODE BEGIN COMP3_MspInit 0 */
|
|
|
|
/* USER CODE END COMP3_MspInit 0 */
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
/**COMP3 GPIO Configuration
|
|
PC1 ------> COMP3_INP
|
|
*/
|
|
GPIO_InitStruct.Pin = I_IN_COMP_ADC_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(I_IN_COMP_ADC_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* COMP3 interrupt Init */
|
|
HAL_NVIC_SetPriority(COMP1_2_3_IRQn, 0, 0);
|
|
HAL_NVIC_EnableIRQ(COMP1_2_3_IRQn);
|
|
/* USER CODE BEGIN COMP3_MspInit 1 */
|
|
|
|
/* USER CODE END COMP3_MspInit 1 */
|
|
}
|
|
else if(hcomp->Instance==COMP4)
|
|
{
|
|
/* USER CODE BEGIN COMP4_MspInit 0 */
|
|
|
|
/* USER CODE END COMP4_MspInit 0 */
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**COMP4 GPIO Configuration
|
|
PB0 ------> COMP4_INP
|
|
*/
|
|
GPIO_InitStruct.Pin = I_LOAD_COMP_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(I_LOAD_COMP_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* COMP4 interrupt Init */
|
|
HAL_NVIC_SetPriority(COMP4_5_6_IRQn, 0, 0);
|
|
HAL_NVIC_EnableIRQ(COMP4_5_6_IRQn);
|
|
/* USER CODE BEGIN COMP4_MspInit 1 */
|
|
|
|
/* USER CODE END COMP4_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief COMP MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hcomp: COMP handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_COMP_MspDeInit(COMP_HandleTypeDef* hcomp)
|
|
{
|
|
if(hcomp->Instance==COMP1)
|
|
{
|
|
/* USER CODE BEGIN COMP1_MspDeInit 0 */
|
|
|
|
/* USER CODE END COMP1_MspDeInit 0 */
|
|
|
|
/**COMP1 GPIO Configuration
|
|
PB1 ------> COMP1_INP
|
|
*/
|
|
HAL_GPIO_DeInit(V_OUT_COMP_ADC3_GPIO_Port, V_OUT_COMP_ADC3_Pin);
|
|
|
|
/* COMP1 interrupt DeInit */
|
|
/* USER CODE BEGIN COMP1:COMP1_2_3_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "COMP1_2_3_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(COMP1_2_3_IRQn); */
|
|
/* USER CODE END COMP1:COMP1_2_3_IRQn disable */
|
|
|
|
/* USER CODE BEGIN COMP1_MspDeInit 1 */
|
|
|
|
/* USER CODE END COMP1_MspDeInit 1 */
|
|
}
|
|
else if(hcomp->Instance==COMP3)
|
|
{
|
|
/* USER CODE BEGIN COMP3_MspDeInit 0 */
|
|
|
|
/* USER CODE END COMP3_MspDeInit 0 */
|
|
|
|
/**COMP3 GPIO Configuration
|
|
PC1 ------> COMP3_INP
|
|
*/
|
|
HAL_GPIO_DeInit(I_IN_COMP_ADC_GPIO_Port, I_IN_COMP_ADC_Pin);
|
|
|
|
/* COMP3 interrupt DeInit */
|
|
/* USER CODE BEGIN COMP3:COMP1_2_3_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "COMP1_2_3_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(COMP1_2_3_IRQn); */
|
|
/* USER CODE END COMP3:COMP1_2_3_IRQn disable */
|
|
|
|
/* USER CODE BEGIN COMP3_MspDeInit 1 */
|
|
|
|
/* USER CODE END COMP3_MspDeInit 1 */
|
|
}
|
|
else if(hcomp->Instance==COMP4)
|
|
{
|
|
/* USER CODE BEGIN COMP4_MspDeInit 0 */
|
|
|
|
/* USER CODE END COMP4_MspDeInit 0 */
|
|
|
|
/**COMP4 GPIO Configuration
|
|
PB0 ------> COMP4_INP
|
|
*/
|
|
HAL_GPIO_DeInit(I_LOAD_COMP_GPIO_Port, I_LOAD_COMP_Pin);
|
|
|
|
/* COMP4 interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(COMP4_5_6_IRQn);
|
|
/* USER CODE BEGIN COMP4_MspDeInit 1 */
|
|
|
|
/* USER CODE END COMP4_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief DAC MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hdac: DAC handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_DAC_MspInit(DAC_HandleTypeDef* hdac)
|
|
{
|
|
if(hdac->Instance==DAC1)
|
|
{
|
|
/* USER CODE BEGIN DAC1_MspInit 0 */
|
|
|
|
/* USER CODE END DAC1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_DAC1_CLK_ENABLE();
|
|
/* DAC1 interrupt Init */
|
|
HAL_NVIC_SetPriority(TIM6_DAC_IRQn, 2, 0);
|
|
HAL_NVIC_EnableIRQ(TIM6_DAC_IRQn);
|
|
/* USER CODE BEGIN DAC1_MspInit 1 */
|
|
|
|
/* USER CODE END DAC1_MspInit 1 */
|
|
}
|
|
else if(hdac->Instance==DAC3)
|
|
{
|
|
/* USER CODE BEGIN DAC3_MspInit 0 */
|
|
|
|
/* USER CODE END DAC3_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_DAC3_CLK_ENABLE();
|
|
/* DAC3 interrupt Init */
|
|
HAL_NVIC_SetPriority(TIM6_DAC_IRQn, 2, 0);
|
|
HAL_NVIC_EnableIRQ(TIM6_DAC_IRQn);
|
|
/* USER CODE BEGIN DAC3_MspInit 1 */
|
|
|
|
/* USER CODE END DAC3_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief DAC MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hdac: DAC handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_DAC_MspDeInit(DAC_HandleTypeDef* hdac)
|
|
{
|
|
if(hdac->Instance==DAC1)
|
|
{
|
|
/* USER CODE BEGIN DAC1_MspDeInit 0 */
|
|
|
|
/* USER CODE END DAC1_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_DAC1_CLK_DISABLE();
|
|
|
|
/* DAC1 interrupt DeInit */
|
|
/* USER CODE BEGIN DAC1:TIM6_DAC_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "TIM6_DAC_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(TIM6_DAC_IRQn); */
|
|
/* USER CODE END DAC1:TIM6_DAC_IRQn disable */
|
|
|
|
/* USER CODE BEGIN DAC1_MspDeInit 1 */
|
|
|
|
/* USER CODE END DAC1_MspDeInit 1 */
|
|
}
|
|
else if(hdac->Instance==DAC3)
|
|
{
|
|
/* USER CODE BEGIN DAC3_MspDeInit 0 */
|
|
|
|
/* USER CODE END DAC3_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_DAC3_CLK_DISABLE();
|
|
|
|
/* DAC3 interrupt DeInit */
|
|
/* USER CODE BEGIN DAC3:TIM6_DAC_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "TIM6_DAC_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(TIM6_DAC_IRQn); */
|
|
/* USER CODE END DAC3:TIM6_DAC_IRQn disable */
|
|
|
|
/* USER CODE BEGIN DAC3_MspDeInit 1 */
|
|
|
|
/* USER CODE END DAC3_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief FDCAN MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hfdcan: FDCAN handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_FDCAN_MspInit(FDCAN_HandleTypeDef* hfdcan)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
|
if(hfdcan->Instance==FDCAN2)
|
|
{
|
|
/* USER CODE BEGIN FDCAN2_MspInit 0 */
|
|
|
|
/* USER CODE END FDCAN2_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_FDCAN;
|
|
PeriphClkInit.FdcanClockSelection = RCC_FDCANCLKSOURCE_PCLK1;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_FDCAN_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**FDCAN2 GPIO Configuration
|
|
PB5 ------> FDCAN2_RX
|
|
PB6 ------> FDCAN2_TX
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_5|GPIO_PIN_6;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
GPIO_InitStruct.Alternate = GPIO_AF9_FDCAN2;
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
/* FDCAN2 interrupt Init */
|
|
HAL_NVIC_SetPriority(FDCAN2_IT0_IRQn, 15, 0);
|
|
HAL_NVIC_EnableIRQ(FDCAN2_IT0_IRQn);
|
|
HAL_NVIC_SetPriority(FDCAN2_IT1_IRQn, 1, 0);
|
|
HAL_NVIC_EnableIRQ(FDCAN2_IT1_IRQn);
|
|
/* USER CODE BEGIN FDCAN2_MspInit 1 */
|
|
|
|
/* USER CODE END FDCAN2_MspInit 1 */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief FDCAN MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hfdcan: FDCAN handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_FDCAN_MspDeInit(FDCAN_HandleTypeDef* hfdcan)
|
|
{
|
|
if(hfdcan->Instance==FDCAN2)
|
|
{
|
|
/* USER CODE BEGIN FDCAN2_MspDeInit 0 */
|
|
|
|
/* USER CODE END FDCAN2_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_FDCAN_CLK_DISABLE();
|
|
|
|
/**FDCAN2 GPIO Configuration
|
|
PB5 ------> FDCAN2_RX
|
|
PB6 ------> FDCAN2_TX
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOB, GPIO_PIN_5|GPIO_PIN_6);
|
|
|
|
/* FDCAN2 interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(FDCAN2_IT0_IRQn);
|
|
HAL_NVIC_DisableIRQ(FDCAN2_IT1_IRQn);
|
|
/* USER CODE BEGIN FDCAN2_MspDeInit 1 */
|
|
|
|
/* USER CODE END FDCAN2_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief FMAC MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hfmac: FMAC handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_FMAC_MspInit(FMAC_HandleTypeDef* hfmac)
|
|
{
|
|
if(hfmac->Instance==FMAC)
|
|
{
|
|
/* USER CODE BEGIN FMAC_MspInit 0 */
|
|
|
|
/* USER CODE END FMAC_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_FMAC_CLK_ENABLE();
|
|
/* FMAC interrupt Init */
|
|
HAL_NVIC_SetPriority(FMAC_IRQn, 0, 0);
|
|
HAL_NVIC_EnableIRQ(FMAC_IRQn);
|
|
/* USER CODE BEGIN FMAC_MspInit 1 */
|
|
|
|
/* USER CODE END FMAC_MspInit 1 */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief FMAC MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hfmac: FMAC handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_FMAC_MspDeInit(FMAC_HandleTypeDef* hfmac)
|
|
{
|
|
if(hfmac->Instance==FMAC)
|
|
{
|
|
/* USER CODE BEGIN FMAC_MspDeInit 0 */
|
|
|
|
/* USER CODE END FMAC_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_FMAC_CLK_DISABLE();
|
|
|
|
/* FMAC interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(FMAC_IRQn);
|
|
/* USER CODE BEGIN FMAC_MspDeInit 1 */
|
|
|
|
/* USER CODE END FMAC_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief HRTIM MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hhrtim: HRTIM handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_HRTIM_MspInit(HRTIM_HandleTypeDef* hhrtim)
|
|
{
|
|
if(hhrtim->Instance==HRTIM1)
|
|
{
|
|
/* USER CODE BEGIN HRTIM1_MspInit 0 */
|
|
|
|
/* USER CODE END HRTIM1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_HRTIM1_CLK_ENABLE();
|
|
/* HRTIM1 interrupt Init */
|
|
HAL_NVIC_SetPriority(HRTIM1_FLT_IRQn, 1, 0);
|
|
HAL_NVIC_EnableIRQ(HRTIM1_FLT_IRQn);
|
|
/* USER CODE BEGIN HRTIM1_MspInit 1 */
|
|
|
|
/* USER CODE END HRTIM1_MspInit 1 */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_HRTIM_MspPostInit(HRTIM_HandleTypeDef* hhrtim)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
if(hhrtim->Instance==HRTIM1)
|
|
{
|
|
/* USER CODE BEGIN HRTIM1_MspPostInit 0 */
|
|
|
|
/* USER CODE END HRTIM1_MspPostInit 0 */
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
/**HRTIM1 GPIO Configuration
|
|
PC6 ------> HRTIM1_CHF1
|
|
PC7 ------> HRTIM1_CHF2
|
|
PC8 ------> HRTIM1_CHE1
|
|
PC9 ------> HRTIM1_CHE2
|
|
*/
|
|
GPIO_InitStruct.Pin = PWM4_Pin|PWM1_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF13_HRTIM1;
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = PWM3_Pin|PWM2_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF3_HRTIM1;
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN HRTIM1_MspPostInit 1 */
|
|
|
|
/* USER CODE END HRTIM1_MspPostInit 1 */
|
|
}
|
|
|
|
}
|
|
/**
|
|
* @brief HRTIM MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hhrtim: HRTIM handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_HRTIM_MspDeInit(HRTIM_HandleTypeDef* hhrtim)
|
|
{
|
|
if(hhrtim->Instance==HRTIM1)
|
|
{
|
|
/* USER CODE BEGIN HRTIM1_MspDeInit 0 */
|
|
|
|
/* USER CODE END HRTIM1_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_HRTIM1_CLK_DISABLE();
|
|
|
|
/* HRTIM1 interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(HRTIM1_FLT_IRQn);
|
|
/* USER CODE BEGIN HRTIM1_MspDeInit 1 */
|
|
|
|
/* USER CODE END HRTIM1_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief I2C MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hi2c: I2C handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_I2C_MspInit(I2C_HandleTypeDef* hi2c)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
|
if(hi2c->Instance==I2C1)
|
|
{
|
|
/* USER CODE BEGIN I2C1_MspInit 0 */
|
|
|
|
/* USER CODE END I2C1_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_I2C1;
|
|
PeriphClkInit.I2c1ClockSelection = RCC_I2C1CLKSOURCE_PCLK1;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**I2C1 GPIO Configuration
|
|
PB7 ------> I2C1_SDA
|
|
PB8-BOOT0 ------> I2C1_SCL
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_7|GPIO_PIN_8;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
GPIO_InitStruct.Alternate = GPIO_AF4_I2C1;
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_I2C1_CLK_ENABLE();
|
|
/* USER CODE BEGIN I2C1_MspInit 1 */
|
|
|
|
/* USER CODE END I2C1_MspInit 1 */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief I2C MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hi2c: I2C handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_I2C_MspDeInit(I2C_HandleTypeDef* hi2c)
|
|
{
|
|
if(hi2c->Instance==I2C1)
|
|
{
|
|
/* USER CODE BEGIN I2C1_MspDeInit 0 */
|
|
|
|
/* USER CODE END I2C1_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_I2C1_CLK_DISABLE();
|
|
|
|
/**I2C1 GPIO Configuration
|
|
PB7 ------> I2C1_SDA
|
|
PB8-BOOT0 ------> I2C1_SCL
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOB, GPIO_PIN_7);
|
|
|
|
HAL_GPIO_DeInit(GPIOB, GPIO_PIN_8);
|
|
|
|
/* USER CODE BEGIN I2C1_MspDeInit 1 */
|
|
|
|
/* USER CODE END I2C1_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief OPAMP MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param hopamp: OPAMP handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_OPAMP_MspInit(OPAMP_HandleTypeDef* hopamp)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
if(hopamp->Instance==OPAMP1)
|
|
{
|
|
/* USER CODE BEGIN OPAMP1_MspInit 0 */
|
|
|
|
/* USER CODE END OPAMP1_MspInit 0 */
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
/**OPAMP1 GPIO Configuration
|
|
PA1 ------> OPAMP1_VINP
|
|
PA2 ------> OPAMP1_VOUT
|
|
PA3 ------> OPAMP1_VINM
|
|
*/
|
|
GPIO_InitStruct.Pin = TEMP_OP__Pin|TEMP_OUT_ADC_Pin|TEMP_OP_A3_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN OPAMP1_MspInit 1 */
|
|
|
|
/* USER CODE END OPAMP1_MspInit 1 */
|
|
}
|
|
else if(hopamp->Instance==OPAMP2)
|
|
{
|
|
/* USER CODE BEGIN OPAMP2_MspInit 0 */
|
|
|
|
/* USER CODE END OPAMP2_MspInit 0 */
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
/**OPAMP2 GPIO Configuration
|
|
PA5 ------> OPAMP2_VINM
|
|
PA6 ------> OPAMP2_VOUT
|
|
PA7 ------> OPAMP2_VINP
|
|
*/
|
|
GPIO_InitStruct.Pin = VFLY_OP__Pin|VFLY_OUT_ADC_Pin|VFLY_OP_A7_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN OPAMP2_MspInit 1 */
|
|
|
|
/* USER CODE END OPAMP2_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief OPAMP MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param hopamp: OPAMP handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_OPAMP_MspDeInit(OPAMP_HandleTypeDef* hopamp)
|
|
{
|
|
if(hopamp->Instance==OPAMP1)
|
|
{
|
|
/* USER CODE BEGIN OPAMP1_MspDeInit 0 */
|
|
|
|
/* USER CODE END OPAMP1_MspDeInit 0 */
|
|
|
|
/**OPAMP1 GPIO Configuration
|
|
PA1 ------> OPAMP1_VINP
|
|
PA2 ------> OPAMP1_VOUT
|
|
PA3 ------> OPAMP1_VINM
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, TEMP_OP__Pin|TEMP_OUT_ADC_Pin|TEMP_OP_A3_Pin);
|
|
|
|
/* USER CODE BEGIN OPAMP1_MspDeInit 1 */
|
|
|
|
/* USER CODE END OPAMP1_MspDeInit 1 */
|
|
}
|
|
else if(hopamp->Instance==OPAMP2)
|
|
{
|
|
/* USER CODE BEGIN OPAMP2_MspDeInit 0 */
|
|
|
|
/* USER CODE END OPAMP2_MspDeInit 0 */
|
|
|
|
/**OPAMP2 GPIO Configuration
|
|
PA5 ------> OPAMP2_VINM
|
|
PA6 ------> OPAMP2_VOUT
|
|
PA7 ------> OPAMP2_VINP
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, VFLY_OP__Pin|VFLY_OUT_ADC_Pin|VFLY_OP_A7_Pin);
|
|
|
|
/* USER CODE BEGIN OPAMP2_MspDeInit 1 */
|
|
|
|
/* USER CODE END OPAMP2_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief TIM_Base MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param htim_base: TIM_Base handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base)
|
|
{
|
|
if(htim_base->Instance==TIM1)
|
|
{
|
|
/* USER CODE BEGIN TIM1_MspInit 0 */
|
|
|
|
/* USER CODE END TIM1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_TIM1_CLK_ENABLE();
|
|
/* TIM1 interrupt Init */
|
|
HAL_NVIC_SetPriority(TIM1_UP_TIM16_IRQn, 1, 0);
|
|
HAL_NVIC_EnableIRQ(TIM1_UP_TIM16_IRQn);
|
|
/* USER CODE BEGIN TIM1_MspInit 1 */
|
|
|
|
/* USER CODE END TIM1_MspInit 1 */
|
|
}
|
|
else if(htim_base->Instance==TIM6)
|
|
{
|
|
/* USER CODE BEGIN TIM6_MspInit 0 */
|
|
|
|
/* USER CODE END TIM6_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_TIM6_CLK_ENABLE();
|
|
/* TIM6 interrupt Init */
|
|
HAL_NVIC_SetPriority(TIM6_DAC_IRQn, 2, 0);
|
|
HAL_NVIC_EnableIRQ(TIM6_DAC_IRQn);
|
|
/* USER CODE BEGIN TIM6_MspInit 1 */
|
|
|
|
/* USER CODE END TIM6_MspInit 1 */
|
|
}
|
|
else if(htim_base->Instance==TIM7)
|
|
{
|
|
/* USER CODE BEGIN TIM7_MspInit 0 */
|
|
|
|
/* USER CODE END TIM7_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_TIM7_CLK_ENABLE();
|
|
/* TIM7 interrupt Init */
|
|
HAL_NVIC_SetPriority(TIM7_DAC_IRQn, 3, 0);
|
|
HAL_NVIC_EnableIRQ(TIM7_DAC_IRQn);
|
|
/* USER CODE BEGIN TIM7_MspInit 1 */
|
|
|
|
/* USER CODE END TIM7_MspInit 1 */
|
|
}
|
|
else if(htim_base->Instance==TIM16)
|
|
{
|
|
/* USER CODE BEGIN TIM16_MspInit 0 */
|
|
|
|
/* USER CODE END TIM16_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_TIM16_CLK_ENABLE();
|
|
/* TIM16 interrupt Init */
|
|
HAL_NVIC_SetPriority(TIM1_UP_TIM16_IRQn, 1, 0);
|
|
HAL_NVIC_EnableIRQ(TIM1_UP_TIM16_IRQn);
|
|
/* USER CODE BEGIN TIM16_MspInit 1 */
|
|
|
|
/* USER CODE END TIM16_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
if(htim->Instance==TIM1)
|
|
{
|
|
/* USER CODE BEGIN TIM1_MspPostInit 0 */
|
|
|
|
/* USER CODE END TIM1_MspPostInit 0 */
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
/**TIM1 GPIO Configuration
|
|
PC13 ------> TIM1_CH1N
|
|
*/
|
|
GPIO_InitStruct.Pin = ALARM_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
GPIO_InitStruct.Alternate = GPIO_AF4_TIM1;
|
|
HAL_GPIO_Init(ALARM_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN TIM1_MspPostInit 1 */
|
|
|
|
/* USER CODE END TIM1_MspPostInit 1 */
|
|
}
|
|
|
|
}
|
|
/**
|
|
* @brief TIM_Base MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param htim_base: TIM_Base handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* htim_base)
|
|
{
|
|
if(htim_base->Instance==TIM1)
|
|
{
|
|
/* USER CODE BEGIN TIM1_MspDeInit 0 */
|
|
|
|
/* USER CODE END TIM1_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_TIM1_CLK_DISABLE();
|
|
|
|
/* TIM1 interrupt DeInit */
|
|
/* USER CODE BEGIN TIM1:TIM1_UP_TIM16_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "TIM1_UP_TIM16_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(TIM1_UP_TIM16_IRQn); */
|
|
/* USER CODE END TIM1:TIM1_UP_TIM16_IRQn disable */
|
|
|
|
/* USER CODE BEGIN TIM1_MspDeInit 1 */
|
|
|
|
/* USER CODE END TIM1_MspDeInit 1 */
|
|
}
|
|
else if(htim_base->Instance==TIM6)
|
|
{
|
|
/* USER CODE BEGIN TIM6_MspDeInit 0 */
|
|
|
|
/* USER CODE END TIM6_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_TIM6_CLK_DISABLE();
|
|
|
|
/* TIM6 interrupt DeInit */
|
|
/* USER CODE BEGIN TIM6:TIM6_DAC_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "TIM6_DAC_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(TIM6_DAC_IRQn); */
|
|
/* USER CODE END TIM6:TIM6_DAC_IRQn disable */
|
|
|
|
/* USER CODE BEGIN TIM6_MspDeInit 1 */
|
|
|
|
/* USER CODE END TIM6_MspDeInit 1 */
|
|
}
|
|
else if(htim_base->Instance==TIM7)
|
|
{
|
|
/* USER CODE BEGIN TIM7_MspDeInit 0 */
|
|
|
|
/* USER CODE END TIM7_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_TIM7_CLK_DISABLE();
|
|
|
|
/* TIM7 interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(TIM7_DAC_IRQn);
|
|
/* USER CODE BEGIN TIM7_MspDeInit 1 */
|
|
|
|
/* USER CODE END TIM7_MspDeInit 1 */
|
|
}
|
|
else if(htim_base->Instance==TIM16)
|
|
{
|
|
/* USER CODE BEGIN TIM16_MspDeInit 0 */
|
|
|
|
/* USER CODE END TIM16_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_TIM16_CLK_DISABLE();
|
|
|
|
/* TIM16 interrupt DeInit */
|
|
/* USER CODE BEGIN TIM16:TIM1_UP_TIM16_IRQn disable */
|
|
/**
|
|
* Uncomment the line below to disable the "TIM1_UP_TIM16_IRQn" interrupt
|
|
* Be aware, disabling shared interrupt may affect other IPs
|
|
*/
|
|
/* HAL_NVIC_DisableIRQ(TIM1_UP_TIM16_IRQn); */
|
|
/* USER CODE END TIM16:TIM1_UP_TIM16_IRQn disable */
|
|
|
|
/* USER CODE BEGIN TIM16_MspDeInit 1 */
|
|
|
|
/* USER CODE END TIM16_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief UART MSP Initialization
|
|
* This function configures the hardware resources used in this example
|
|
* @param huart: UART handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_UART_MspInit(UART_HandleTypeDef* huart)
|
|
{
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
|
if(huart->Instance==UART4)
|
|
{
|
|
/* USER CODE BEGIN UART4_MspInit 0 */
|
|
|
|
/* USER CODE END UART4_MspInit 0 */
|
|
|
|
/** Initializes the peripherals clocks
|
|
*/
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_UART4;
|
|
PeriphClkInit.Uart4ClockSelection = RCC_UART4CLKSOURCE_PCLK1;
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_UART4_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
/**UART4 GPIO Configuration
|
|
PC10 ------> UART4_TX
|
|
PC11 ------> UART4_RX
|
|
*/
|
|
GPIO_InitStruct.Pin = VCP_TX_Pin|VCP_RX_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_UART4;
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
/* UART4 interrupt Init */
|
|
HAL_NVIC_SetPriority(UART4_IRQn, 3, 0);
|
|
HAL_NVIC_EnableIRQ(UART4_IRQn);
|
|
/* USER CODE BEGIN UART4_MspInit 1 */
|
|
|
|
/* USER CODE END UART4_MspInit 1 */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief UART MSP De-Initialization
|
|
* This function freeze the hardware resources used in this example
|
|
* @param huart: UART handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_UART_MspDeInit(UART_HandleTypeDef* huart)
|
|
{
|
|
if(huart->Instance==UART4)
|
|
{
|
|
/* USER CODE BEGIN UART4_MspDeInit 0 */
|
|
|
|
/* USER CODE END UART4_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_UART4_CLK_DISABLE();
|
|
|
|
/**UART4 GPIO Configuration
|
|
PC10 ------> UART4_TX
|
|
PC11 ------> UART4_RX
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOC, VCP_TX_Pin|VCP_RX_Pin);
|
|
|
|
/* UART4 interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(UART4_IRQn);
|
|
/* USER CODE BEGIN UART4_MspDeInit 1 */
|
|
|
|
/* USER CODE END UART4_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/* USER CODE BEGIN 1 */
|
|
|
|
/* USER CODE END 1 */
|