/* USER CODE BEGIN Header */ /** ****************************************************************************** * File Name : stm32h7xx_hal_msp.c * Description : This file provides code for the MSP Initialization * and de-Initialization codes. ****************************************************************************** * @attention * *

© Copyright (c) 2020 STMicroelectronics. * All rights reserved.

* * This software component is licensed by ST under Ultimate Liberty license * SLA0044, the "License"; You may not use this file except in compliance with * the License. You may obtain a copy of the License at: * www.st.com/SLA0044 * ****************************************************************************** */ /* USER CODE END Header */ /* Includes ------------------------------------------------------------------*/ #include "main.h" /* USER CODE BEGIN Includes */ /* USER CODE END Includes */ /* 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 */ /** * Initializes the Global MSP. */ void HAL_MspInit(void) { /* USER CODE BEGIN MspInit 0 */ /* USER CODE END MspInit 0 */ __HAL_RCC_SYSCFG_CLK_ENABLE(); /* System interrupt init*/ /* USER CODE BEGIN MspInit 1 */ /* USER CODE END MspInit 1 */ } static uint32_t DFSDM1_Init = 0; /** * @brief DFSDM_Channel MSP Initialization * This function configures the hardware resources used in this example * @param hdfsdm_channel: DFSDM_Channel handle pointer * @retval None */ void HAL_DFSDM_ChannelMspInit(DFSDM_Channel_HandleTypeDef* hdfsdm_channel) { if(DFSDM1_Init == 0) { /* USER CODE BEGIN DFSDM1_MspInit 0 */ /* USER CODE END DFSDM1_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_DFSDM1_CLK_ENABLE(); /* USER CODE BEGIN DFSDM1_MspInit 1 */ /* USER CODE END DFSDM1_MspInit 1 */ } } /** * @brief DFSDM_Channel MSP De-Initialization * This function freeze the hardware resources used in this example * @param hdfsdm_channel: DFSDM_Channel handle pointer * @retval None */ void HAL_DFSDM_ChannelMspDeInit(DFSDM_Channel_HandleTypeDef* hdfsdm_channel) { DFSDM1_Init-- ; if(DFSDM1_Init == 0) { /* USER CODE BEGIN DFSDM1_MspDeInit 0 */ /* USER CODE END DFSDM1_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_DFSDM1_CLK_DISABLE(); /* USER CODE BEGIN DFSDM1_MspDeInit 1 */ /* USER CODE END DFSDM1_MspDeInit 1 */ } } /** * @brief DSI MSP Initialization * This function configures the hardware resources used in this example * @param hdsi: DSI handle pointer * @retval None */ void HAL_DSI_MspInit(DSI_HandleTypeDef* hdsi) { GPIO_InitTypeDef GPIO_InitStruct = {0}; if(hdsi->Instance==DSI) { /* USER CODE BEGIN DSI_MspInit 0 */ /* USER CODE END DSI_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_DSI_CLK_ENABLE(); __HAL_RCC_GPIOA_CLK_ENABLE(); /**DSIHOST GPIO Configuration PA15 (JTDI) ------> DSIHOST_TE DSI_D1P ------> DSIHOST_D1P DSI_D1N ------> DSIHOST_D1N DSI_CKP ------> DSIHOST_CKP DSI_CKN ------> DSIHOST_CKN DSI_D0P ------> DSIHOST_D0P DSI_D0N ------> DSIHOST_D0N */ GPIO_InitStruct.Pin = GPIO_PIN_15; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF13_DSI; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); /* USER CODE BEGIN DSI_MspInit 1 */ /* USER CODE END DSI_MspInit 1 */ } } /** * @brief DSI MSP De-Initialization * This function freeze the hardware resources used in this example * @param hdsi: DSI handle pointer * @retval None */ void HAL_DSI_MspDeInit(DSI_HandleTypeDef* hdsi) { if(hdsi->Instance==DSI) { /* USER CODE BEGIN DSI_MspDeInit 0 */ /* USER CODE END DSI_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_DSI_CLK_DISABLE(); /**DSIHOST GPIO Configuration PA15 (JTDI) ------> DSIHOST_TE DSI_D1P ------> DSIHOST_D1P DSI_D1N ------> DSIHOST_D1N DSI_CKP ------> DSIHOST_CKP DSI_CKN ------> DSIHOST_CKN DSI_D0P ------> DSIHOST_D0P DSI_D0N ------> DSIHOST_D0N */ HAL_GPIO_DeInit(GPIOA, GPIO_PIN_15); /* USER CODE BEGIN DSI_MspDeInit 1 */ /* USER CODE END DSI_MspDeInit 1 */ } } /** * @brief ETH MSP Initialization * This function configures the hardware resources used in this example * @param heth: ETH handle pointer * @retval None */ void HAL_ETH_MspInit(ETH_HandleTypeDef* heth) { if(heth->Instance==ETH) { /* USER CODE BEGIN ETH_MspInit 0 */ /* USER CODE END ETH_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_ETH1MAC_CLK_ENABLE(); __HAL_RCC_ETH1TX_CLK_ENABLE(); __HAL_RCC_ETH1RX_CLK_ENABLE(); /* USER CODE BEGIN ETH_MspInit 1 */ /* USER CODE END ETH_MspInit 1 */ } } /** * @brief ETH MSP De-Initialization * This function freeze the hardware resources used in this example * @param heth: ETH handle pointer * @retval None */ void HAL_ETH_MspDeInit(ETH_HandleTypeDef* heth) { if(heth->Instance==ETH) { /* USER CODE BEGIN ETH_MspDeInit 0 */ /* USER CODE END ETH_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_ETH1MAC_CLK_DISABLE(); __HAL_RCC_ETH1TX_CLK_DISABLE(); __HAL_RCC_ETH1RX_CLK_DISABLE(); /* USER CODE BEGIN ETH_MspDeInit 1 */ /* USER CODE END ETH_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}; if(hi2c->Instance==I2C1) { /* USER CODE BEGIN I2C1_MspInit 0 */ /* USER CODE END I2C1_MspInit 0 */ __HAL_RCC_GPIOB_CLK_ENABLE(); /**I2C1 GPIO Configuration PB6 ------> I2C1_SCL PB7 ------> I2C1_SDA */ GPIO_InitStruct.Pin = I2C1_SCL_Pin|I2C1_SDA_Pin; 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 PB6 ------> I2C1_SCL PB7 ------> I2C1_SDA */ HAL_GPIO_DeInit(I2C1_SCL_GPIO_Port, I2C1_SCL_Pin); HAL_GPIO_DeInit(I2C1_SDA_GPIO_Port, I2C1_SDA_Pin); /* USER CODE BEGIN I2C1_MspDeInit 1 */ /* USER CODE END I2C1_MspDeInit 1 */ } } /** * @brief LTDC MSP Initialization * This function configures the hardware resources used in this example * @param hltdc: LTDC handle pointer * @retval None */ void HAL_LTDC_MspInit(LTDC_HandleTypeDef* hltdc) { if(hltdc->Instance==LTDC) { /* USER CODE BEGIN LTDC_MspInit 0 */ /* USER CODE END LTDC_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_LTDC_CLK_ENABLE(); /* USER CODE BEGIN LTDC_MspInit 1 */ /* USER CODE END LTDC_MspInit 1 */ } } /** * @brief LTDC MSP De-Initialization * This function freeze the hardware resources used in this example * @param hltdc: LTDC handle pointer * @retval None */ void HAL_LTDC_MspDeInit(LTDC_HandleTypeDef* hltdc) { if(hltdc->Instance==LTDC) { /* USER CODE BEGIN LTDC_MspDeInit 0 */ /* USER CODE END LTDC_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_LTDC_CLK_DISABLE(); /* USER CODE BEGIN LTDC_MspDeInit 1 */ /* USER CODE END LTDC_MspDeInit 1 */ } } /** * @brief QSPI MSP Initialization * This function configures the hardware resources used in this example * @param hqspi: QSPI handle pointer * @retval None */ void HAL_QSPI_MspInit(QSPI_HandleTypeDef* hqspi) { GPIO_InitTypeDef GPIO_InitStruct = {0}; if(hqspi->Instance==QUADSPI) { /* USER CODE BEGIN QUADSPI_MspInit 0 */ /* USER CODE END QUADSPI_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_QSPI_CLK_ENABLE(); __HAL_RCC_GPIOG_CLK_ENABLE(); __HAL_RCC_GPIOF_CLK_ENABLE(); __HAL_RCC_GPIOH_CLK_ENABLE(); __HAL_RCC_GPIOB_CLK_ENABLE(); /**QUADSPI GPIO Configuration PG9 ------> QUADSPI_BK2_IO2 PG14 ------> QUADSPI_BK2_IO3 PG6 ------> QUADSPI_BK1_NCS PF6 ------> QUADSPI_BK1_IO3 PF7 ------> QUADSPI_BK1_IO2 PF8 ------> QUADSPI_BK1_IO0 PF9 ------> QUADSPI_BK1_IO1 PH2 ------> QUADSPI_BK2_IO0 PH3 ------> QUADSPI_BK2_IO1 PB2 ------> QUADSPI_CLK */ GPIO_InitStruct.Pin = QSPI_BK2_IO2_Pin|QSPI_BK2_IO3_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI; HAL_GPIO_Init(GPIOG, &GPIO_InitStruct); GPIO_InitStruct.Pin = QSPI_BK1_NCS_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF10_QUADSPI; HAL_GPIO_Init(QSPI_BK1_NCS_GPIO_Port, &GPIO_InitStruct); GPIO_InitStruct.Pin = QSPI_BK1_IO3_Pin|QSPI_BK1_IO2_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI; HAL_GPIO_Init(GPIOF, &GPIO_InitStruct); GPIO_InitStruct.Pin = QSPI_BK1_IO0_Pin|QSPI_BK1_IO1_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF10_QUADSPI; HAL_GPIO_Init(GPIOF, &GPIO_InitStruct); GPIO_InitStruct.Pin = QSPI_BK2_IO0_Pin|QSPI_BK2_IO1_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI; HAL_GPIO_Init(GPIOH, &GPIO_InitStruct); GPIO_InitStruct.Pin = QSPI_CLK_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF9_QUADSPI; HAL_GPIO_Init(QSPI_CLK_GPIO_Port, &GPIO_InitStruct); /* USER CODE BEGIN QUADSPI_MspInit 1 */ /* USER CODE END QUADSPI_MspInit 1 */ } } /** * @brief QSPI MSP De-Initialization * This function freeze the hardware resources used in this example * @param hqspi: QSPI handle pointer * @retval None */ void HAL_QSPI_MspDeInit(QSPI_HandleTypeDef* hqspi) { if(hqspi->Instance==QUADSPI) { /* USER CODE BEGIN QUADSPI_MspDeInit 0 */ /* USER CODE END QUADSPI_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_QSPI_CLK_DISABLE(); /**QUADSPI GPIO Configuration PG9 ------> QUADSPI_BK2_IO2 PG14 ------> QUADSPI_BK2_IO3 PG6 ------> QUADSPI_BK1_NCS PF6 ------> QUADSPI_BK1_IO3 PF7 ------> QUADSPI_BK1_IO2 PF8 ------> QUADSPI_BK1_IO0 PF9 ------> QUADSPI_BK1_IO1 PH2 ------> QUADSPI_BK2_IO0 PH3 ------> QUADSPI_BK2_IO1 PB2 ------> QUADSPI_CLK */ HAL_GPIO_DeInit(GPIOG, QSPI_BK2_IO2_Pin|QSPI_BK2_IO3_Pin|QSPI_BK1_NCS_Pin); HAL_GPIO_DeInit(GPIOF, QSPI_BK1_IO3_Pin|QSPI_BK1_IO2_Pin|QSPI_BK1_IO0_Pin|QSPI_BK1_IO1_Pin); HAL_GPIO_DeInit(GPIOH, QSPI_BK2_IO0_Pin|QSPI_BK2_IO1_Pin); HAL_GPIO_DeInit(QSPI_CLK_GPIO_Port, QSPI_CLK_Pin); /* USER CODE BEGIN QUADSPI_MspDeInit 1 */ /* USER CODE END QUADSPI_MspDeInit 1 */ } } /** * @brief SD MSP Initialization * This function configures the hardware resources used in this example * @param hsd: SD handle pointer * @retval None */ void HAL_SD_MspInit(SD_HandleTypeDef* hsd) { GPIO_InitTypeDef GPIO_InitStruct = {0}; if(hsd->Instance==SDMMC1) { /* USER CODE BEGIN SDMMC1_MspInit 0 */ /* USER CODE END SDMMC1_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_SDMMC1_CLK_ENABLE(); __HAL_RCC_GPIOC_CLK_ENABLE(); __HAL_RCC_GPIOB_CLK_ENABLE(); __HAL_RCC_GPIOD_CLK_ENABLE(); /**SDMMC1 GPIO Configuration PC10 ------> SDMMC1_D2 PC11 ------> SDMMC1_D3 PC12 ------> SDMMC1_CK PB9 ------> SDMMC1_CDIR PB8 ------> SDMMC1_CKIN PD2 ------> SDMMC1_CMD PC8 ------> SDMMC1_D0 PC9 ------> SDMMC1_D1 PC7 ------> SDMMC1_D123DIR PC6 ------> SDMMC1_D0DIR */ GPIO_InitStruct.Pin = SDIO1_D2_Pin|SDIO1_D3_Pin|SDIO1_CLK_Pin|SDIO1_D0_Pin |SDIO1_D1_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_AF12_SDIO1; HAL_GPIO_Init(GPIOC, &GPIO_InitStruct); GPIO_InitStruct.Pin = SDIO1_CDIR_Pin|SDIO1_CKIN_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_SDIO1; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); GPIO_InitStruct.Pin = SDIO1_CMD_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_AF12_SDIO1; HAL_GPIO_Init(SDIO1_CMD_GPIO_Port, &GPIO_InitStruct); GPIO_InitStruct.Pin = SDIO1_D123DIR_Pin|SDIO1_D0DIR_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_AF8_SDIO1; HAL_GPIO_Init(GPIOC, &GPIO_InitStruct); /* USER CODE BEGIN SDMMC1_MspInit 1 */ /* USER CODE END SDMMC1_MspInit 1 */ } } /** * @brief SD MSP De-Initialization * This function freeze the hardware resources used in this example * @param hsd: SD handle pointer * @retval None */ void HAL_SD_MspDeInit(SD_HandleTypeDef* hsd) { if(hsd->Instance==SDMMC1) { /* USER CODE BEGIN SDMMC1_MspDeInit 0 */ /* USER CODE END SDMMC1_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_SDMMC1_CLK_DISABLE(); /**SDMMC1 GPIO Configuration PC10 ------> SDMMC1_D2 PC11 ------> SDMMC1_D3 PC12 ------> SDMMC1_CK PB9 ------> SDMMC1_CDIR PB8 ------> SDMMC1_CKIN PD2 ------> SDMMC1_CMD PC8 ------> SDMMC1_D0 PC9 ------> SDMMC1_D1 PC7 ------> SDMMC1_D123DIR PC6 ------> SDMMC1_D0DIR */ HAL_GPIO_DeInit(GPIOC, SDIO1_D2_Pin|SDIO1_D3_Pin|SDIO1_CLK_Pin|SDIO1_D0_Pin |SDIO1_D1_Pin|SDIO1_D123DIR_Pin|SDIO1_D0DIR_Pin); HAL_GPIO_DeInit(GPIOB, SDIO1_CDIR_Pin|SDIO1_CKIN_Pin); HAL_GPIO_DeInit(SDIO1_CMD_GPIO_Port, SDIO1_CMD_Pin); /* USER CODE BEGIN SDMMC1_MspDeInit 1 */ /* USER CODE END SDMMC1_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}; if(huart->Instance==USART1) { /* USER CODE BEGIN USART1_MspInit 0 */ /* USER CODE END USART1_MspInit 0 */ /* Peripheral clock enable */ __HAL_RCC_USART1_CLK_ENABLE(); __HAL_RCC_GPIOB_CLK_ENABLE(); /**USART1 GPIO Configuration PB15 ------> USART1_RX PB14 ------> USART1_TX */ GPIO_InitStruct.Pin = RS_232RX_Pin|RS232_TX_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_USART1; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); /* USER CODE BEGIN USART1_MspInit 1 */ /* USER CODE END USART1_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==USART1) { /* USER CODE BEGIN USART1_MspDeInit 0 */ /* USER CODE END USART1_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_USART1_CLK_DISABLE(); /**USART1 GPIO Configuration PB15 ------> USART1_RX PB14 ------> USART1_TX */ HAL_GPIO_DeInit(GPIOB, RS_232RX_Pin|RS232_TX_Pin); /* USER CODE BEGIN USART1_MspDeInit 1 */ /* USER CODE END USART1_MspDeInit 1 */ } } /** * @brief PCD MSP Initialization * This function configures the hardware resources used in this example * @param hpcd: PCD handle pointer * @retval None */ void HAL_PCD_MspInit(PCD_HandleTypeDef* hpcd) { GPIO_InitTypeDef GPIO_InitStruct = {0}; if(hpcd->Instance==USB_OTG_FS) { /* USER CODE BEGIN USB_OTG_FS_MspInit 0 */ /* USER CODE END USB_OTG_FS_MspInit 0 */ __HAL_RCC_GPIOA_CLK_ENABLE(); /**USB_OTG_FS GPIO Configuration PA9 ------> USB_OTG_FS_VBUS PA12 ------> USB_OTG_FS_DP PA11 ------> USB_OTG_FS_DM */ GPIO_InitStruct.Pin = USB_FS1_VBUS_Pin; GPIO_InitStruct.Mode = GPIO_MODE_INPUT; GPIO_InitStruct.Pull = GPIO_NOPULL; HAL_GPIO_Init(USB_FS1_VBUS_GPIO_Port, &GPIO_InitStruct); GPIO_InitStruct.Pin = USB_FS1_DP_Pin|USB_FS1_DM_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF10_OTG1_FS; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); /* Peripheral clock enable */ __HAL_RCC_USB_OTG_FS_CLK_ENABLE(); /* USER CODE BEGIN USB_OTG_FS_MspInit 1 */ /* USER CODE END USB_OTG_FS_MspInit 1 */ } else if(hpcd->Instance==USB_OTG_HS) { /* USER CODE BEGIN USB_OTG_HS_MspInit 0 */ /* USER CODE END USB_OTG_HS_MspInit 0 */ __HAL_RCC_GPIOB_CLK_ENABLE(); __HAL_RCC_GPIOI_CLK_ENABLE(); __HAL_RCC_GPIOC_CLK_ENABLE(); __HAL_RCC_GPIOH_CLK_ENABLE(); __HAL_RCC_GPIOA_CLK_ENABLE(); /**USB_OTG_HS GPIO Configuration PB5 ------> USB_OTG_HS_ULPI_D7 PI11 ------> USB_OTG_HS_ULPI_DIR PC0 ------> USB_OTG_HS_ULPI_STP PH4 ------> USB_OTG_HS_ULPI_NXT PB10 ------> USB_OTG_HS_ULPI_D3 PB11 ------> USB_OTG_HS_ULPI_D4 PA5 ------> USB_OTG_HS_ULPI_CK PB1 ------> USB_OTG_HS_ULPI_D2 PB12 ------> USB_OTG_HS_ULPI_D5 PA3 ------> USB_OTG_HS_ULPI_D0 PB0 ------> USB_OTG_HS_ULPI_D1 PB13 ------> USB_OTG_HS_ULPI_D6 */ GPIO_InitStruct.Pin = ULPI_D7_Pin|ULPI_D3_Pin|ULPI_D4_Pin|ULPI_D2_Pin |ULPI_D5_Pin|ULPI_D1_Pin|ULPI_D6_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); GPIO_InitStruct.Pin = ULPI_DIR_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS; HAL_GPIO_Init(ULPI_DIR_GPIO_Port, &GPIO_InitStruct); GPIO_InitStruct.Pin = ULPI_STP_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS; HAL_GPIO_Init(ULPI_STP_GPIO_Port, &GPIO_InitStruct); GPIO_InitStruct.Pin = ULPI_NXT_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS; HAL_GPIO_Init(ULPI_NXT_GPIO_Port, &GPIO_InitStruct); GPIO_InitStruct.Pin = ULPI_CK_Pin|ULPI_D0_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF10_OTG2_HS; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); /* Peripheral clock enable */ __HAL_RCC_USB_OTG_HS_CLK_ENABLE(); __HAL_RCC_USB_OTG_HS_ULPI_CLK_ENABLE(); /* USER CODE BEGIN USB_OTG_HS_MspInit 1 */ /* USER CODE END USB_OTG_HS_MspInit 1 */ } } /** * @brief PCD MSP De-Initialization * This function freeze the hardware resources used in this example * @param hpcd: PCD handle pointer * @retval None */ void HAL_PCD_MspDeInit(PCD_HandleTypeDef* hpcd) { if(hpcd->Instance==USB_OTG_FS) { /* USER CODE BEGIN USB_OTG_FS_MspDeInit 0 */ /* USER CODE END USB_OTG_FS_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_USB_OTG_FS_CLK_DISABLE(); /**USB_OTG_FS GPIO Configuration PA9 ------> USB_OTG_FS_VBUS PA12 ------> USB_OTG_FS_DP PA11 ------> USB_OTG_FS_DM */ HAL_GPIO_DeInit(GPIOA, USB_FS1_VBUS_Pin|USB_FS1_DP_Pin|USB_FS1_DM_Pin); /* USER CODE BEGIN USB_OTG_FS_MspDeInit 1 */ /* USER CODE END USB_OTG_FS_MspDeInit 1 */ } else if(hpcd->Instance==USB_OTG_HS) { /* USER CODE BEGIN USB_OTG_HS_MspDeInit 0 */ /* USER CODE END USB_OTG_HS_MspDeInit 0 */ /* Peripheral clock disable */ __HAL_RCC_USB_OTG_HS_CLK_DISABLE(); __HAL_RCC_USB_OTG_HS_ULPI_CLK_DISABLE(); /**USB_OTG_HS GPIO Configuration PB5 ------> USB_OTG_HS_ULPI_D7 PI11 ------> USB_OTG_HS_ULPI_DIR PC0 ------> USB_OTG_HS_ULPI_STP PH4 ------> USB_OTG_HS_ULPI_NXT PB10 ------> USB_OTG_HS_ULPI_D3 PB11 ------> USB_OTG_HS_ULPI_D4 PA5 ------> USB_OTG_HS_ULPI_CK PB1 ------> USB_OTG_HS_ULPI_D2 PB12 ------> USB_OTG_HS_ULPI_D5 PA3 ------> USB_OTG_HS_ULPI_D0 PB0 ------> USB_OTG_HS_ULPI_D1 PB13 ------> USB_OTG_HS_ULPI_D6 */ HAL_GPIO_DeInit(GPIOB, ULPI_D7_Pin|ULPI_D3_Pin|ULPI_D4_Pin|ULPI_D2_Pin |ULPI_D5_Pin|ULPI_D1_Pin|ULPI_D6_Pin); HAL_GPIO_DeInit(ULPI_DIR_GPIO_Port, ULPI_DIR_Pin); HAL_GPIO_DeInit(ULPI_STP_GPIO_Port, ULPI_STP_Pin); HAL_GPIO_DeInit(ULPI_NXT_GPIO_Port, ULPI_NXT_Pin); HAL_GPIO_DeInit(GPIOA, ULPI_CK_Pin|ULPI_D0_Pin); /* USER CODE BEGIN USB_OTG_HS_MspDeInit 1 */ /* USER CODE END USB_OTG_HS_MspDeInit 1 */ } } static uint32_t FMC_Initialized = 0; static void HAL_FMC_MspInit(void){ /* USER CODE BEGIN FMC_MspInit 0 */ /* USER CODE END FMC_MspInit 0 */ GPIO_InitTypeDef GPIO_InitStruct ={0}; if (FMC_Initialized) { return; } FMC_Initialized = 1; /* Peripheral clock enable */ __HAL_RCC_FMC_CLK_ENABLE(); /** FMC GPIO Configuration PI6 ------> FMC_D28 PI5 ------> FMC_NBL3 PI4 ------> FMC_NBL2 PG10 ------> FMC_NE3 PD5 ------> FMC_NWE PD4 ------> FMC_NOE PI1 ------> FMC_D25 PI0 ------> FMC_D24 PI7 ------> FMC_D29 PE1 ------> FMC_NBL1 PD6 ------> FMC_NWAIT PI2 ------> FMC_D26 PH15 ------> FMC_D23 PH14 ------> FMC_D22 PE0 ------> FMC_NBL0 PD7 ------> FMC_NE1 PI3 ------> FMC_D27 PG15 ------> FMC_SDNCAS PD0 ------> FMC_D2 PH13 ------> FMC_D21 PI9 ------> FMC_D30 PD1 ------> FMC_D3 PI10 ------> FMC_D31 PG8 ------> FMC_SDCLK PF2 ------> FMC_A2 PF1 ------> FMC_A1 PF0 ------> FMC_A0 PG5 ------> FMC_A15 PG5 ------> FMC_BA1 PF3 ------> FMC_A3 PG4 ------> FMC_A14 PG4 ------> FMC_BA0 PG3 ------> FMC_A13 PG2 ------> FMC_A12 PF5 ------> FMC_A5 PF4 ------> FMC_A4 PE10 ------> FMC_D7 PH5 ------> FMC_SDNWE PF13 ------> FMC_A7 PF14 ------> FMC_A8 PE9 ------> FMC_D6 PE11 ------> FMC_D8 PH10 ------> FMC_D18 PH11 ------> FMC_D19 PD15 ------> FMC_D1 PD14 ------> FMC_D0 PF12 ------> FMC_A6 PF15 ------> FMC_A9 PE12 ------> FMC_D9 PE15 ------> FMC_D12 PH9 ------> FMC_D17 PH12 ------> FMC_D20 PD11 ------> FMC_A16 PD12 ------> FMC_A17 PD13 ------> FMC_A18 PF11 ------> FMC_SDNRAS PG0 ------> FMC_A10 PE8 ------> FMC_D5 PE13 ------> FMC_D10 PH6 ------> FMC_SDNE1 PH8 ------> FMC_D16 PD10 ------> FMC_D15 PD9 ------> FMC_D14 PG1 ------> FMC_A11 PE7 ------> FMC_D4 PE14 ------> FMC_D11 PH7 ------> FMC_SDCKE1 PD8 ------> FMC_D13 */ GPIO_InitStruct.Pin = D28_Pin|FMC_NBL3_Pin|FMC_NBL2_Pin|D25_Pin |D24_Pin|D29_Pin|D26_Pin|D27__IS42S32800G_DQ27_Pin |D30_Pin|D31_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_AF12_FMC; HAL_GPIO_Init(GPIOI, &GPIO_InitStruct); GPIO_InitStruct.Pin = FMC_NE3_Pin|SDNCAS_Pin|SDCLK_Pin|GPIO_PIN_5 |GPIO_PIN_4|A13_Pin|A12_Pin|A10_Pin |A11_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_AF12_FMC; HAL_GPIO_Init(GPIOG, &GPIO_InitStruct); GPIO_InitStruct.Pin = FMC_NWE_Pin|FMC_NOE_Pin|FMC_NWAIT_Pin|FMC_NE1_Pin |D2_Pin|D3_Pin|D1_Pin|D0_Pin |A16_Pin|A17_Pin|A18_Pin|D15_Pin |D14_Pin|D13_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_AF12_FMC; HAL_GPIO_Init(GPIOD, &GPIO_InitStruct); GPIO_InitStruct.Pin = FMC_NBL1_Pin|FMC_NBL0_Pin|D7_Pin|D6_Pin |D8_Pin|D9_Pin|D12_Pin|D5_Pin |D10_Pin|D4_Pin|D11_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_AF12_FMC; HAL_GPIO_Init(GPIOE, &GPIO_InitStruct); GPIO_InitStruct.Pin = D23_Pin|D22_Pin|D21_Pin|SDNWE_Pin |D18_Pin|D19_Pin|D17_Pin|D20_Pin |SDNE1_Pin|D16_Pin|SDCKE1_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_AF12_FMC; HAL_GPIO_Init(GPIOH, &GPIO_InitStruct); GPIO_InitStruct.Pin = A2_Pin|A1_Pin|A0_Pin|A3_Pin |A5_Pin|A4_Pin|A7_Pin|A8_Pin |A6_Pin|A9_Pin|SNDRAS_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_AF12_FMC; HAL_GPIO_Init(GPIOF, &GPIO_InitStruct); /* USER CODE BEGIN FMC_MspInit 1 */ /* USER CODE END FMC_MspInit 1 */ } void HAL_NOR_MspInit(NOR_HandleTypeDef* hnor){ /* USER CODE BEGIN NOR_MspInit 0 */ /* USER CODE END NOR_MspInit 0 */ HAL_FMC_MspInit(); /* USER CODE BEGIN NOR_MspInit 1 */ /* USER CODE END NOR_MspInit 1 */ } void HAL_SRAM_MspInit(SRAM_HandleTypeDef* hsram){ /* USER CODE BEGIN SRAM_MspInit 0 */ /* USER CODE END SRAM_MspInit 0 */ HAL_FMC_MspInit(); /* USER CODE BEGIN SRAM_MspInit 1 */ /* USER CODE END SRAM_MspInit 1 */ } void HAL_SDRAM_MspInit(SDRAM_HandleTypeDef* hsdram){ /* USER CODE BEGIN SDRAM_MspInit 0 */ /* USER CODE END SDRAM_MspInit 0 */ HAL_FMC_MspInit(); /* USER CODE BEGIN SDRAM_MspInit 1 */ /* USER CODE END SDRAM_MspInit 1 */ } static uint32_t FMC_DeInitialized = 0; static void HAL_FMC_MspDeInit(void){ /* USER CODE BEGIN FMC_MspDeInit 0 */ /* USER CODE END FMC_MspDeInit 0 */ if (FMC_DeInitialized) { return; } FMC_DeInitialized = 1; /* Peripheral clock enable */ __HAL_RCC_FMC_CLK_DISABLE(); /** FMC GPIO Configuration PI6 ------> FMC_D28 PI5 ------> FMC_NBL3 PI4 ------> FMC_NBL2 PG10 ------> FMC_NE3 PD5 ------> FMC_NWE PD4 ------> FMC_NOE PI1 ------> FMC_D25 PI0 ------> FMC_D24 PI7 ------> FMC_D29 PE1 ------> FMC_NBL1 PD6 ------> FMC_NWAIT PI2 ------> FMC_D26 PH15 ------> FMC_D23 PH14 ------> FMC_D22 PE0 ------> FMC_NBL0 PD7 ------> FMC_NE1 PI3 ------> FMC_D27 PG15 ------> FMC_SDNCAS PD0 ------> FMC_D2 PH13 ------> FMC_D21 PI9 ------> FMC_D30 PD1 ------> FMC_D3 PI10 ------> FMC_D31 PG8 ------> FMC_SDCLK PF2 ------> FMC_A2 PF1 ------> FMC_A1 PF0 ------> FMC_A0 PG5 ------> FMC_A15 PG5 ------> FMC_BA1 PF3 ------> FMC_A3 PG4 ------> FMC_A14 PG4 ------> FMC_BA0 PG3 ------> FMC_A13 PG2 ------> FMC_A12 PF5 ------> FMC_A5 PF4 ------> FMC_A4 PE10 ------> FMC_D7 PH5 ------> FMC_SDNWE PF13 ------> FMC_A7 PF14 ------> FMC_A8 PE9 ------> FMC_D6 PE11 ------> FMC_D8 PH10 ------> FMC_D18 PH11 ------> FMC_D19 PD15 ------> FMC_D1 PD14 ------> FMC_D0 PF12 ------> FMC_A6 PF15 ------> FMC_A9 PE12 ------> FMC_D9 PE15 ------> FMC_D12 PH9 ------> FMC_D17 PH12 ------> FMC_D20 PD11 ------> FMC_A16 PD12 ------> FMC_A17 PD13 ------> FMC_A18 PF11 ------> FMC_SDNRAS PG0 ------> FMC_A10 PE8 ------> FMC_D5 PE13 ------> FMC_D10 PH6 ------> FMC_SDNE1 PH8 ------> FMC_D16 PD10 ------> FMC_D15 PD9 ------> FMC_D14 PG1 ------> FMC_A11 PE7 ------> FMC_D4 PE14 ------> FMC_D11 PH7 ------> FMC_SDCKE1 PD8 ------> FMC_D13 */ HAL_GPIO_DeInit(GPIOI, D28_Pin|FMC_NBL3_Pin|FMC_NBL2_Pin|D25_Pin |D24_Pin|D29_Pin|D26_Pin|D27__IS42S32800G_DQ27_Pin |D30_Pin|D31_Pin); HAL_GPIO_DeInit(GPIOG, FMC_NE3_Pin|SDNCAS_Pin|SDCLK_Pin|GPIO_PIN_5 |GPIO_PIN_4|A13_Pin|A12_Pin|A10_Pin |A11_Pin); HAL_GPIO_DeInit(GPIOD, FMC_NWE_Pin|FMC_NOE_Pin|FMC_NWAIT_Pin|FMC_NE1_Pin |D2_Pin|D3_Pin|D1_Pin|D0_Pin |A16_Pin|A17_Pin|A18_Pin|D15_Pin |D14_Pin|D13_Pin); HAL_GPIO_DeInit(GPIOE, FMC_NBL1_Pin|FMC_NBL0_Pin|D7_Pin|D6_Pin |D8_Pin|D9_Pin|D12_Pin|D5_Pin |D10_Pin|D4_Pin|D11_Pin); HAL_GPIO_DeInit(GPIOH, D23_Pin|D22_Pin|D21_Pin|SDNWE_Pin |D18_Pin|D19_Pin|D17_Pin|D20_Pin |SDNE1_Pin|D16_Pin|SDCKE1_Pin); HAL_GPIO_DeInit(GPIOF, A2_Pin|A1_Pin|A0_Pin|A3_Pin |A5_Pin|A4_Pin|A7_Pin|A8_Pin |A6_Pin|A9_Pin|SNDRAS_Pin); /* USER CODE BEGIN FMC_MspDeInit 1 */ /* USER CODE END FMC_MspDeInit 1 */ } void HAL_NOR_MspDeInit(NOR_HandleTypeDef* hnor){ /* USER CODE BEGIN NOR_MspDeInit 0 */ /* USER CODE END NOR_MspDeInit 0 */ HAL_FMC_MspDeInit(); /* USER CODE BEGIN NOR_MspDeInit 1 */ /* USER CODE END NOR_MspDeInit 1 */ } void HAL_SRAM_MspDeInit(SRAM_HandleTypeDef* hsram){ /* USER CODE BEGIN SRAM_MspDeInit 0 */ /* USER CODE END SRAM_MspDeInit 0 */ HAL_FMC_MspDeInit(); /* USER CODE BEGIN SRAM_MspDeInit 1 */ /* USER CODE END SRAM_MspDeInit 1 */ } void HAL_SDRAM_MspDeInit(SDRAM_HandleTypeDef* hsdram){ /* USER CODE BEGIN SDRAM_MspDeInit 0 */ /* USER CODE END SDRAM_MspDeInit 0 */ HAL_FMC_MspDeInit(); /* USER CODE BEGIN SDRAM_MspDeInit 1 */ /* USER CODE END SDRAM_MspDeInit 1 */ } static uint32_t SAI1_client =0; void HAL_SAI_MspInit(SAI_HandleTypeDef* hsai) { GPIO_InitTypeDef GPIO_InitStruct; /* SAI1 */ if(hsai->Instance==SAI1_Block_A) { /* Peripheral clock enable */ if (SAI1_client == 0) { __HAL_RCC_SAI1_CLK_ENABLE(); } SAI1_client ++; /**SAI1_A_Block_A GPIO Configuration PE5 ------> SAI1_SCK_A PE4 ------> SAI1_FS_A PE6 ------> SAI1_SD_A PG7 ------> SAI1_MCLK_A */ GPIO_InitStruct.Pin = SAI1_SCKA_Pin|SAI1_FSA_Pin|SAI1_SDA_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF6_SAI1; HAL_GPIO_Init(GPIOE, &GPIO_InitStruct); GPIO_InitStruct.Pin = SAI1_MCLKA_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF6_SAI1; HAL_GPIO_Init(SAI1_MCLKA_GPIO_Port, &GPIO_InitStruct); } if(hsai->Instance==SAI1_Block_B) { /* Peripheral clock enable */ if (SAI1_client == 0) { __HAL_RCC_SAI1_CLK_ENABLE(); } SAI1_client ++; /**SAI1_B_Block_B GPIO Configuration PE3 ------> SAI1_SD_B */ GPIO_InitStruct.Pin = SAI1_SDB_Pin; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.Alternate = GPIO_AF6_SAI1; HAL_GPIO_Init(SAI1_SDB_GPIO_Port, &GPIO_InitStruct); } } void HAL_SAI_MspDeInit(SAI_HandleTypeDef* hsai) { /* SAI1 */ if(hsai->Instance==SAI1_Block_A) { SAI1_client --; if (SAI1_client == 0) { /* Peripheral clock disable */ __HAL_RCC_SAI1_CLK_DISABLE(); } /**SAI1_A_Block_A GPIO Configuration PE5 ------> SAI1_SCK_A PE4 ------> SAI1_FS_A PE6 ------> SAI1_SD_A PG7 ------> SAI1_MCLK_A */ HAL_GPIO_DeInit(GPIOE, SAI1_SCKA_Pin|SAI1_FSA_Pin|SAI1_SDA_Pin); HAL_GPIO_DeInit(SAI1_MCLKA_GPIO_Port, SAI1_MCLKA_Pin); } if(hsai->Instance==SAI1_Block_B) { SAI1_client --; if (SAI1_client == 0) { /* Peripheral clock disable */ __HAL_RCC_SAI1_CLK_DISABLE(); } /**SAI1_B_Block_B GPIO Configuration PE3 ------> SAI1_SD_B */ HAL_GPIO_DeInit(SAI1_SDB_GPIO_Port, SAI1_SDB_Pin); } } /* USER CODE BEGIN 1 */ /* USER CODE END 1 */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/