mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-03-27 23:37:25 +00:00
260 lines
7.5 KiB
C
260 lines
7.5 KiB
C
/* USER CODE BEGIN Header */
|
|
/**
|
|
******************************************************************************
|
|
* @file i2s.c
|
|
* @brief This file provides code for the configuration
|
|
* of the I2S instances.
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* Copyright (c) 2024 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 "i2s.h"
|
|
|
|
/* USER CODE BEGIN 0 */
|
|
|
|
/* USER CODE END 0 */
|
|
|
|
I2S_HandleTypeDef hi2s2;
|
|
I2S_HandleTypeDef hi2s3;
|
|
DMA_HandleTypeDef hdma_spi2_rx;
|
|
DMA_HandleTypeDef hdma_spi3_tx;
|
|
|
|
/* I2S2 init function */
|
|
void MX_I2S2_Init(void)
|
|
{
|
|
|
|
/* USER CODE BEGIN I2S2_Init 0 */
|
|
|
|
/* USER CODE END I2S2_Init 0 */
|
|
|
|
/* USER CODE BEGIN I2S2_Init 1 */
|
|
|
|
/* USER CODE END I2S2_Init 1 */
|
|
hi2s2.Instance = SPI2;
|
|
hi2s2.Init.Mode = I2S_MODE_MASTER_RX;
|
|
hi2s2.Init.Standard = I2S_STANDARD_PHILIPS;
|
|
hi2s2.Init.DataFormat = I2S_DATAFORMAT_16B;
|
|
hi2s2.Init.MCLKOutput = I2S_MCLKOUTPUT_DISABLE;
|
|
hi2s2.Init.AudioFreq = 44100;
|
|
hi2s2.Init.CPOL = I2S_CPOL_LOW;
|
|
hi2s2.Init.ClockSource = I2S_CLOCK_PLL;
|
|
hi2s2.Init.FullDuplexMode = I2S_FULLDUPLEXMODE_DISABLE;
|
|
if (HAL_I2S_Init(&hi2s2) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
/* USER CODE BEGIN I2S2_Init 2 */
|
|
|
|
/* USER CODE END I2S2_Init 2 */
|
|
|
|
}
|
|
/* I2S3 init function */
|
|
void MX_I2S3_Init(void)
|
|
{
|
|
|
|
/* USER CODE BEGIN I2S3_Init 0 */
|
|
|
|
/* USER CODE END I2S3_Init 0 */
|
|
|
|
/* USER CODE BEGIN I2S3_Init 1 */
|
|
|
|
/* USER CODE END I2S3_Init 1 */
|
|
hi2s3.Instance = SPI3;
|
|
hi2s3.Init.Mode = I2S_MODE_MASTER_TX;
|
|
hi2s3.Init.Standard = I2S_STANDARD_PHILIPS;
|
|
hi2s3.Init.DataFormat = I2S_DATAFORMAT_16B;
|
|
hi2s3.Init.MCLKOutput = I2S_MCLKOUTPUT_ENABLE;
|
|
hi2s3.Init.AudioFreq = 44100;
|
|
hi2s3.Init.CPOL = I2S_CPOL_LOW;
|
|
hi2s3.Init.ClockSource = I2S_CLOCK_PLL;
|
|
hi2s3.Init.FullDuplexMode = I2S_FULLDUPLEXMODE_DISABLE;
|
|
if (HAL_I2S_Init(&hi2s3) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
/* USER CODE BEGIN I2S3_Init 2 */
|
|
|
|
/* USER CODE END I2S3_Init 2 */
|
|
|
|
}
|
|
|
|
void HAL_I2S_MspInit(I2S_HandleTypeDef* i2sHandle)
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
if(i2sHandle->Instance==SPI2)
|
|
{
|
|
/* USER CODE BEGIN SPI2_MspInit 0 */
|
|
|
|
/* USER CODE END SPI2_MspInit 0 */
|
|
/* I2S2 clock enable */
|
|
__HAL_RCC_SPI2_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**I2S2 GPIO Configuration
|
|
PC3 ------> I2S2_SD
|
|
PB10 ------> I2S2_CK
|
|
PB12 ------> I2S2_WS
|
|
*/
|
|
GPIO_InitStruct.Pin = PDM_OUT_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_SPI2;
|
|
HAL_GPIO_Init(PDM_OUT_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = CLK_IN_Pin|GPIO_PIN_12;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_SPI2;
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
/* I2S2 DMA Init */
|
|
/* SPI2_RX Init */
|
|
hdma_spi2_rx.Instance = DMA1_Stream3;
|
|
hdma_spi2_rx.Init.Channel = DMA_CHANNEL_0;
|
|
hdma_spi2_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma_spi2_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_spi2_rx.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_spi2_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_spi2_rx.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_spi2_rx.Init.Mode = DMA_CIRCULAR;
|
|
hdma_spi2_rx.Init.Priority = DMA_PRIORITY_HIGH;
|
|
hdma_spi2_rx.Init.FIFOMode = DMA_FIFOMODE_DISABLE;
|
|
if (HAL_DMA_Init(&hdma_spi2_rx) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(i2sHandle,hdmarx,hdma_spi2_rx);
|
|
|
|
/* USER CODE BEGIN SPI2_MspInit 1 */
|
|
|
|
/* USER CODE END SPI2_MspInit 1 */
|
|
}
|
|
else if(i2sHandle->Instance==SPI3)
|
|
{
|
|
/* USER CODE BEGIN SPI3_MspInit 0 */
|
|
|
|
/* USER CODE END SPI3_MspInit 0 */
|
|
/* I2S3 clock enable */
|
|
__HAL_RCC_SPI3_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
/**I2S3 GPIO Configuration
|
|
PA4 ------> I2S3_WS
|
|
PC7 ------> I2S3_MCK
|
|
PC10 ------> I2S3_CK
|
|
PC12 ------> I2S3_SD
|
|
*/
|
|
GPIO_InitStruct.Pin = I2S3_WS_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF6_SPI3;
|
|
HAL_GPIO_Init(I2S3_WS_GPIO_Port, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = I2S3_MCK_Pin|I2S3_SCK_Pin|I2S3_SD_Pin;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF6_SPI3;
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
/* I2S3 DMA Init */
|
|
/* SPI3_TX Init */
|
|
hdma_spi3_tx.Instance = DMA1_Stream7;
|
|
hdma_spi3_tx.Init.Channel = DMA_CHANNEL_0;
|
|
hdma_spi3_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
|
hdma_spi3_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma_spi3_tx.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma_spi3_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma_spi3_tx.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma_spi3_tx.Init.Mode = DMA_CIRCULAR;
|
|
hdma_spi3_tx.Init.Priority = DMA_PRIORITY_HIGH;
|
|
hdma_spi3_tx.Init.FIFOMode = DMA_FIFOMODE_ENABLE;
|
|
hdma_spi3_tx.Init.FIFOThreshold = DMA_FIFO_THRESHOLD_FULL;
|
|
hdma_spi3_tx.Init.MemBurst = DMA_MBURST_SINGLE;
|
|
hdma_spi3_tx.Init.PeriphBurst = DMA_PBURST_SINGLE;
|
|
if (HAL_DMA_Init(&hdma_spi3_tx) != HAL_OK)
|
|
{
|
|
Error_Handler();
|
|
}
|
|
|
|
__HAL_LINKDMA(i2sHandle,hdmatx,hdma_spi3_tx);
|
|
|
|
/* USER CODE BEGIN SPI3_MspInit 1 */
|
|
|
|
/* USER CODE END SPI3_MspInit 1 */
|
|
}
|
|
}
|
|
|
|
void HAL_I2S_MspDeInit(I2S_HandleTypeDef* i2sHandle)
|
|
{
|
|
|
|
if(i2sHandle->Instance==SPI2)
|
|
{
|
|
/* USER CODE BEGIN SPI2_MspDeInit 0 */
|
|
|
|
/* USER CODE END SPI2_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_SPI2_CLK_DISABLE();
|
|
|
|
/**I2S2 GPIO Configuration
|
|
PC3 ------> I2S2_SD
|
|
PB10 ------> I2S2_CK
|
|
PB12 ------> I2S2_WS
|
|
*/
|
|
HAL_GPIO_DeInit(PDM_OUT_GPIO_Port, PDM_OUT_Pin);
|
|
|
|
HAL_GPIO_DeInit(GPIOB, CLK_IN_Pin|GPIO_PIN_12);
|
|
|
|
/* I2S2 DMA DeInit */
|
|
HAL_DMA_DeInit(i2sHandle->hdmarx);
|
|
/* USER CODE BEGIN SPI2_MspDeInit 1 */
|
|
|
|
/* USER CODE END SPI2_MspDeInit 1 */
|
|
}
|
|
else if(i2sHandle->Instance==SPI3)
|
|
{
|
|
/* USER CODE BEGIN SPI3_MspDeInit 0 */
|
|
|
|
/* USER CODE END SPI3_MspDeInit 0 */
|
|
/* Peripheral clock disable */
|
|
__HAL_RCC_SPI3_CLK_DISABLE();
|
|
|
|
/**I2S3 GPIO Configuration
|
|
PA4 ------> I2S3_WS
|
|
PC7 ------> I2S3_MCK
|
|
PC10 ------> I2S3_CK
|
|
PC12 ------> I2S3_SD
|
|
*/
|
|
HAL_GPIO_DeInit(I2S3_WS_GPIO_Port, I2S3_WS_Pin);
|
|
|
|
HAL_GPIO_DeInit(GPIOC, I2S3_MCK_Pin|I2S3_SCK_Pin|I2S3_SD_Pin);
|
|
|
|
/* I2S3 DMA DeInit */
|
|
HAL_DMA_DeInit(i2sHandle->hdmatx);
|
|
/* USER CODE BEGIN SPI3_MspDeInit 1 */
|
|
|
|
/* USER CODE END SPI3_MspDeInit 1 */
|
|
}
|
|
}
|
|
|
|
/* USER CODE BEGIN 1 */
|
|
|
|
/* USER CODE END 1 */
|