kopia lustrzana https://github.com/mobilinkd/NucleoTNC
740 wiersze
20 KiB
C
740 wiersze
20 KiB
C
/**
|
|
******************************************************************************
|
|
* File Name : stm32l4xx_hal_msp.c
|
|
* Description : This file provides code for the MSP Initialization
|
|
* and de-Initialization codes.
|
|
******************************************************************************
|
|
* This notice applies to any and all portions of this file
|
|
* that are not between comment pairs USER CODE BEGIN and
|
|
* USER CODE END. Other portions of this file, whether
|
|
* inserted by the user or by software development tools
|
|
* are owned by their respective copyright owners.
|
|
*
|
|
* Copyright (c) 2021 STMicroelectronics International N.V.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted, provided that the following conditions are met:
|
|
*
|
|
* 1. Redistribution of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
* 3. Neither the name of STMicroelectronics nor the names of other
|
|
* contributors to this software may be used to endorse or promote products
|
|
* derived from this software without specific written permission.
|
|
* 4. This software, including modifications and/or derivative works of this
|
|
* software, must execute solely and exclusively on microcontroller or
|
|
* microprocessor devices manufactured by or for STMicroelectronics.
|
|
* 5. Redistribution and use of this software other than as permitted under
|
|
* this license is void and will automatically terminate your rights under
|
|
* this license.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY STMICROELECTRONICS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS, IMPLIED OR STATUTORY WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
|
* PARTICULAR PURPOSE AND NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY
|
|
* RIGHTS ARE DISCLAIMED TO THE FULLEST EXTENT PERMITTED BY LAW. IN NO EVENT
|
|
* SHALL STMICROELECTRONICS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
|
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
/* Includes ------------------------------------------------------------------*/
|
|
#include "stm32l4xx_hal.h"
|
|
extern DMA_HandleTypeDef hdma_adc1;
|
|
|
|
extern DMA_HandleTypeDef hdma_dac_ch1;
|
|
|
|
extern DMA_HandleTypeDef hdma_i2c3_rx;
|
|
|
|
extern DMA_HandleTypeDef hdma_i2c3_tx;
|
|
|
|
extern DMA_HandleTypeDef hdma_usart2_rx;
|
|
|
|
extern DMA_HandleTypeDef hdma_usart2_tx;
|
|
|
|
extern void _Error_Handler(char *, int);
|
|
/* USER CODE BEGIN 0 */
|
|
|
|
/* USER CODE END 0 */
|
|
|
|
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();
|
|
|
|
HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITYGROUP_4);
|
|
|
|
/* System interrupt init*/
|
|
/* MemoryManagement_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(MemoryManagement_IRQn, 0, 0);
|
|
/* BusFault_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(BusFault_IRQn, 0, 0);
|
|
/* UsageFault_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(UsageFault_IRQn, 0, 0);
|
|
/* SVCall_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(SVCall_IRQn, 0, 0);
|
|
/* DebugMonitor_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(DebugMonitor_IRQn, 0, 0);
|
|
/* PendSV_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(PendSV_IRQn, 15, 0);
|
|
/* SysTick_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(SysTick_IRQn, 15, 0);
|
|
|
|
/* USER CODE BEGIN MspInit 1 */
|
|
|
|
/* USER CODE END MspInit 1 */
|
|
}
|
|
|
|
void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
if(hadc->Instance==ADC1)
|
|
{
|
|
/* USER CODE BEGIN ADC1_MspInit 0 */
|
|
|
|
/* USER CODE END ADC1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_ADC_CLK_ENABLE();
|
|
|
|
/**ADC1 GPIO Configuration
|
|
PA3 ------> ADC1_IN8
|
|
*/
|
|
GPIO_InitStruct.Pin = AUDIO_IN_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG_ADC_CONTROL;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(AUDIO_IN_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* ADC1 DMA Init */
|
|
/* ADC1 Init */
|
|
hdma_adc1.Instance = DMA1_Channel1;
|
|
hdma_adc1.Init.Request = DMA_REQUEST_0;
|
|
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_LOW;
|
|
if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
|
|
{
|
|
_Error_Handler(__FILE__, __LINE__);
|
|
}
|
|
|
|
__HAL_LINKDMA(hadc,DMA_Handle,hdma_adc1);
|
|
|
|
/* USER CODE BEGIN ADC1_MspInit 1 */
|
|
|
|
/* USER CODE END ADC1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
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_ADC_CLK_DISABLE();
|
|
|
|
/**ADC1 GPIO Configuration
|
|
PA3 ------> ADC1_IN8
|
|
*/
|
|
HAL_GPIO_DeInit(AUDIO_IN_GPIO_Port, AUDIO_IN_Pin);
|
|
|
|
/* ADC1 DMA DeInit */
|
|
HAL_DMA_DeInit(hadc->DMA_Handle);
|
|
/* USER CODE BEGIN ADC1_MspDeInit 1 */
|
|
|
|
/* USER CODE END ADC1_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_CRC_MspInit(CRC_HandleTypeDef* hcrc)
|
|
{
|
|
|
|
if(hcrc->Instance==CRC)
|
|
{
|
|
/* USER CODE BEGIN CRC_MspInit 0 */
|
|
|
|
/* USER CODE END CRC_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_CRC_CLK_ENABLE();
|
|
/* USER CODE BEGIN CRC_MspInit 1 */
|
|
|
|
/* USER CODE END CRC_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_CRC_MspDeInit(CRC_HandleTypeDef* hcrc)
|
|
{
|
|
|
|
if(hcrc->Instance==CRC)
|
|
{
|
|
/* USER CODE BEGIN CRC_MspDeInit 0 */
|
|
|
|
/* USER CODE END CRC_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_CRC_CLK_DISABLE();
|
|
/* USER CODE BEGIN CRC_MspDeInit 1 */
|
|
|
|
/* USER CODE END CRC_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_DAC_MspInit(DAC_HandleTypeDef* hdac)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
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 GPIO Configuration
|
|
PA4 ------> DAC1_OUT1
|
|
PA5 ------> DAC1_OUT2
|
|
*/
|
|
GPIO_InitStruct.Pin = AUDIO_OUT_DAC_Pin|AUDIO_IN_VREF_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
/* DAC1 DMA Init */
|
|
/* DAC_CH1 Init */
|
|
hdma_dac_ch1.Instance = DMA2_Channel4;
|
|
hdma_dac_ch1.Init.Request = DMA_REQUEST_3;
|
|
hdma_dac_ch1.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
|
hdma_dac_ch1.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_dac_ch1.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_dac_ch1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_dac_ch1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_dac_ch1.Init.Mode = DMA_CIRCULAR;
|
|
hdma_dac_ch1.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_dac_ch1) != HAL_OK)
|
|
{
|
|
_Error_Handler(__FILE__, __LINE__);
|
|
}
|
|
|
|
__HAL_LINKDMA(hdac,DMA_Handle1,hdma_dac_ch1);
|
|
|
|
/* USER CODE BEGIN DAC1_MspInit 1 */
|
|
|
|
/* USER CODE END DAC1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
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 GPIO Configuration
|
|
PA4 ------> DAC1_OUT1
|
|
PA5 ------> DAC1_OUT2
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, AUDIO_OUT_DAC_Pin|AUDIO_IN_VREF_Pin);
|
|
|
|
/* DAC1 DMA DeInit */
|
|
HAL_DMA_DeInit(hdac->DMA_Handle1);
|
|
/* USER CODE BEGIN DAC1_MspDeInit 1 */
|
|
|
|
/* USER CODE END DAC1_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_I2C_MspInit(I2C_HandleTypeDef* hi2c)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
if(hi2c->Instance==I2C3)
|
|
{
|
|
/* USER CODE BEGIN I2C3_MspInit 0 */
|
|
|
|
/* USER CODE END I2C3_MspInit 0 */
|
|
|
|
/**I2C3 GPIO Configuration
|
|
PA7 ------> I2C3_SCL
|
|
PB4 (NJTRST) ------> I2C3_SDA
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_7;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF4_I2C3;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_4;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF4_I2C3;
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_I2C3_CLK_ENABLE();
|
|
|
|
/* I2C3 DMA Init */
|
|
/* I2C3_RX Init */
|
|
hdma_i2c3_rx.Instance = DMA1_Channel3;
|
|
hdma_i2c3_rx.Init.Request = DMA_REQUEST_3;
|
|
hdma_i2c3_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_i2c3_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_i2c3_rx.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_i2c3_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
|
hdma_i2c3_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
|
hdma_i2c3_rx.Init.Mode = DMA_NORMAL;
|
|
hdma_i2c3_rx.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_i2c3_rx) != HAL_OK)
|
|
{
|
|
_Error_Handler(__FILE__, __LINE__);
|
|
}
|
|
|
|
__HAL_LINKDMA(hi2c,hdmarx,hdma_i2c3_rx);
|
|
|
|
/* I2C3_TX Init */
|
|
hdma_i2c3_tx.Instance = DMA1_Channel2;
|
|
hdma_i2c3_tx.Init.Request = DMA_REQUEST_3;
|
|
hdma_i2c3_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
|
hdma_i2c3_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_i2c3_tx.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_i2c3_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
|
hdma_i2c3_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
|
hdma_i2c3_tx.Init.Mode = DMA_NORMAL;
|
|
hdma_i2c3_tx.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_i2c3_tx) != HAL_OK)
|
|
{
|
|
_Error_Handler(__FILE__, __LINE__);
|
|
}
|
|
|
|
__HAL_LINKDMA(hi2c,hdmatx,hdma_i2c3_tx);
|
|
|
|
/* USER CODE BEGIN I2C3_MspInit 1 */
|
|
|
|
/* USER CODE END I2C3_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_I2C_MspDeInit(I2C_HandleTypeDef* hi2c)
|
|
{
|
|
|
|
if(hi2c->Instance==I2C3)
|
|
{
|
|
/* USER CODE BEGIN I2C3_MspDeInit 0 */
|
|
|
|
/* USER CODE END I2C3_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_I2C3_CLK_DISABLE();
|
|
|
|
/**I2C3 GPIO Configuration
|
|
PA7 ------> I2C3_SCL
|
|
PB4 (NJTRST) ------> I2C3_SDA
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_7);
|
|
|
|
HAL_GPIO_DeInit(GPIOB, GPIO_PIN_4);
|
|
|
|
/* I2C3 DMA DeInit */
|
|
HAL_DMA_DeInit(hi2c->hdmarx);
|
|
HAL_DMA_DeInit(hi2c->hdmatx);
|
|
/* USER CODE BEGIN I2C3_MspDeInit 1 */
|
|
|
|
/* USER CODE END I2C3_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_OPAMP_MspInit(OPAMP_HandleTypeDef* hopamp)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
if(hopamp->Instance==OPAMP1)
|
|
{
|
|
/* USER CODE BEGIN OPAMP1_MspInit 0 */
|
|
|
|
/* USER CODE END OPAMP1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_OPAMP_CLK_ENABLE();
|
|
|
|
/**OPAMP1 GPIO Configuration
|
|
PA0 ------> OPAMP1_VINP
|
|
PA1 ------> OPAMP1_VINM
|
|
PA3 ------> OPAMP1_VOUT
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = AUDIO_IN_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG_ADC_CONTROL;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(AUDIO_IN_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN OPAMP1_MspInit 1 */
|
|
|
|
/* USER CODE END OPAMP1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_OPAMP_MspDeInit(OPAMP_HandleTypeDef* hopamp)
|
|
{
|
|
|
|
if(hopamp->Instance==OPAMP1)
|
|
{
|
|
/* USER CODE BEGIN OPAMP1_MspDeInit 0 */
|
|
|
|
/* USER CODE END OPAMP1_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_OPAMP_CLK_DISABLE();
|
|
|
|
/**OPAMP1 GPIO Configuration
|
|
PA0 ------> OPAMP1_VINP
|
|
PA1 ------> OPAMP1_VINM
|
|
PA3 ------> OPAMP1_VOUT
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, GPIO_PIN_0|GPIO_PIN_1|AUDIO_IN_Pin);
|
|
|
|
/* USER CODE BEGIN OPAMP1_MspDeInit 1 */
|
|
|
|
/* USER CODE END OPAMP1_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_RNG_MspInit(RNG_HandleTypeDef* hrng)
|
|
{
|
|
|
|
if(hrng->Instance==RNG)
|
|
{
|
|
/* USER CODE BEGIN RNG_MspInit 0 */
|
|
|
|
/* USER CODE END RNG_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_RNG_CLK_ENABLE();
|
|
/* USER CODE BEGIN RNG_MspInit 1 */
|
|
|
|
/* USER CODE END RNG_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_RNG_MspDeInit(RNG_HandleTypeDef* hrng)
|
|
{
|
|
|
|
if(hrng->Instance==RNG)
|
|
{
|
|
/* USER CODE BEGIN RNG_MspDeInit 0 */
|
|
|
|
/* USER CODE END RNG_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_RNG_CLK_DISABLE();
|
|
/* USER CODE BEGIN RNG_MspDeInit 1 */
|
|
|
|
/* USER CODE END RNG_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_RTC_MspInit(RTC_HandleTypeDef* hrtc)
|
|
{
|
|
|
|
if(hrtc->Instance==RTC)
|
|
{
|
|
/* USER CODE BEGIN RTC_MspInit 0 */
|
|
|
|
/* USER CODE END RTC_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_RTC_ENABLE();
|
|
/* USER CODE BEGIN RTC_MspInit 1 */
|
|
|
|
/* USER CODE END RTC_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_RTC_MspDeInit(RTC_HandleTypeDef* hrtc)
|
|
{
|
|
|
|
if(hrtc->Instance==RTC)
|
|
{
|
|
/* USER CODE BEGIN RTC_MspDeInit 0 */
|
|
|
|
/* USER CODE END RTC_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_RTC_DISABLE();
|
|
/* USER CODE BEGIN RTC_MspDeInit 1 */
|
|
|
|
/* USER CODE END RTC_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
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, 5, 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();
|
|
/* 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();
|
|
/* USER CODE BEGIN TIM7_MspInit 1 */
|
|
|
|
/* USER CODE END TIM7_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
if(htim->Instance==TIM1)
|
|
{
|
|
/* USER CODE BEGIN TIM1_MspPostInit 0 */
|
|
|
|
/* USER CODE END TIM1_MspPostInit 0 */
|
|
|
|
/**TIM1 GPIO Configuration
|
|
PA8 ------> TIM1_CH1
|
|
PA9 ------> TIM1_CH2
|
|
PA10 ------> TIM1_CH3
|
|
*/
|
|
GPIO_InitStruct.Pin = LED_RED_Pin|LED_GREEN_Pin|LED_YELLOW_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN TIM1_MspPostInit 1 */
|
|
|
|
/* USER CODE END TIM1_MspPostInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
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 */
|
|
HAL_NVIC_DisableIRQ(TIM1_UP_TIM16_IRQn);
|
|
/* 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();
|
|
/* 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();
|
|
/* USER CODE BEGIN TIM7_MspDeInit 1 */
|
|
|
|
/* USER CODE END TIM7_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_UART_MspInit(UART_HandleTypeDef* huart)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct;
|
|
if(huart->Instance==USART2)
|
|
{
|
|
/* USER CODE BEGIN USART2_MspInit 0 */
|
|
|
|
/* USER CODE END USART2_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_USART2_CLK_ENABLE();
|
|
|
|
/**USART2 GPIO Configuration
|
|
PA2 ------> USART2_TX
|
|
PA15 (JTDI) ------> USART2_RX
|
|
*/
|
|
GPIO_InitStruct.Pin = VCP_TX_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_AF7_USART2;
|
|
HAL_GPIO_Init(VCP_TX_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = VCP_RX_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_USART2;
|
|
HAL_GPIO_Init(VCP_RX_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
/* USART2 DMA Init */
|
|
/* USART2_RX Init */
|
|
hdma_usart2_rx.Instance = DMA1_Channel6;
|
|
hdma_usart2_rx.Init.Request = DMA_REQUEST_2;
|
|
hdma_usart2_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_usart2_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_usart2_rx.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_usart2_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
|
hdma_usart2_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
|
hdma_usart2_rx.Init.Mode = DMA_NORMAL;
|
|
hdma_usart2_rx.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_usart2_rx) != HAL_OK)
|
|
{
|
|
_Error_Handler(__FILE__, __LINE__);
|
|
}
|
|
|
|
__HAL_LINKDMA(huart,hdmarx,hdma_usart2_rx);
|
|
|
|
/* USART2_TX Init */
|
|
hdma_usart2_tx.Instance = DMA1_Channel7;
|
|
hdma_usart2_tx.Init.Request = DMA_REQUEST_2;
|
|
hdma_usart2_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
|
hdma_usart2_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_usart2_tx.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_usart2_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
|
hdma_usart2_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
|
hdma_usart2_tx.Init.Mode = DMA_NORMAL;
|
|
hdma_usart2_tx.Init.Priority = DMA_PRIORITY_LOW;
|
|
if (HAL_DMA_Init(&hdma_usart2_tx) != HAL_OK)
|
|
{
|
|
_Error_Handler(__FILE__, __LINE__);
|
|
}
|
|
|
|
__HAL_LINKDMA(huart,hdmatx,hdma_usart2_tx);
|
|
|
|
/* USART2 interrupt Init */
|
|
HAL_NVIC_SetPriority(USART2_IRQn, 6, 0);
|
|
HAL_NVIC_EnableIRQ(USART2_IRQn);
|
|
/* USER CODE BEGIN USART2_MspInit 1 */
|
|
|
|
/* USER CODE END USART2_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
void HAL_UART_MspDeInit(UART_HandleTypeDef* huart)
|
|
{
|
|
|
|
if(huart->Instance==USART2)
|
|
{
|
|
/* USER CODE BEGIN USART2_MspDeInit 0 */
|
|
|
|
/* USER CODE END USART2_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_USART2_CLK_DISABLE();
|
|
|
|
/**USART2 GPIO Configuration
|
|
PA2 ------> USART2_TX
|
|
PA15 (JTDI) ------> USART2_RX
|
|
*/
|
|
HAL_GPIO_DeInit(GPIOA, VCP_TX_Pin|VCP_RX_Pin);
|
|
|
|
/* USART2 DMA DeInit */
|
|
HAL_DMA_DeInit(huart->hdmarx);
|
|
HAL_DMA_DeInit(huart->hdmatx);
|
|
|
|
/* USART2 interrupt DeInit */
|
|
HAL_NVIC_DisableIRQ(USART2_IRQn);
|
|
/* USER CODE BEGIN USART2_MspDeInit 1 */
|
|
|
|
/* USER CODE END USART2_MspDeInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
/* USER CODE BEGIN 1 */
|
|
|
|
/* USER CODE END 1 */
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|