/* 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 */