99 lines
2.2 KiB
C
Raw Normal View History

2021-05-12 19:15:17 +08:00
/**************************************************************************//**
*
* @copyright (C) 2020 Nuvoton Technology Corp. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2020-12-12 Wayne First version
*
******************************************************************************/
#ifndef __DRV_I2S_H__
#define __DRV_I2S_H__
#include <rtthread.h>
#include <drv_sys.h>
#include "NuMicro.h"
#if !defined(NU_I2S_DMA_FIFO_SIZE)
#define NU_I2S_DMA_FIFO_SIZE (2048)
#endif
#if !defined(NU_I2S_DMA_BUF_BLOCK_NUMBER)
#define NU_I2S_DMA_BUF_BLOCK_NUMBER (2)
#endif
#if ( (NU_I2S_DMA_FIFO_SIZE % NU_I2S_DMA_BUF_BLOCK_NUMBER) != 0 )
#error "Please give an aligned definition"
#endif
#if ( NU_I2S_DMA_FIFO_SIZE < 2048 )
#warning "DMA FIFO too small, miss voice?"
#endif
#define NU_I2S_DMA_BUF_BLOCK_SIZE (NU_I2S_DMA_FIFO_SIZE/NU_I2S_DMA_BUF_BLOCK_NUMBER)
#if ( NU_I2S_DMA_BUF_BLOCK_SIZE > RT_AUDIO_RECORD_PIPE_SIZE )
#error "Specified I2S DMA buffer size is small than PIPE size in RT driver."
#error "You should enlarge RT_AUDIO_RECORD_PIPE_SIZE. "
#endif
typedef enum
{
NU_I2S_DAI_PLAYBACK,
NU_I2S_DAI_CAPTURE,
NU_I2S_DAI_CNT
} E_NU_I2S_DAI;
typedef enum
{
NU_ACODEC_ROLE_MASTER,
NU_ACODEC_ROLE_SLAVE,
} E_NU_ACODEC_ROLE;
typedef struct
{
char *name;
E_NU_ACODEC_ROLE role;
struct rt_audio_configure config;
rt_err_t (*nu_acodec_init)(void);
rt_err_t (*nu_acodec_reset)(void);
rt_err_t (*nu_acodec_dsp_control)(struct rt_audio_configure *config);
rt_err_t (*nu_acodec_mixer_control)(rt_uint32_t ui32Item, rt_uint32_t ui32Value);
rt_err_t (*nu_acodec_mixer_query)(rt_uint32_t ui32Item, rt_uint32_t *ui32Value);
} nu_acodec_ops;
typedef nu_acodec_ops *nu_acodec_ops_t;
struct nu_i2s_dai
{
rt_uint8_t *fifo;
};
typedef struct nu_i2s_dai *nu_i2s_dai_t;
struct nu_i2s
{
struct rt_audio_device audio;
struct rt_audio_configure config;
char *name;
IRQn_Type irqn;
E_SYS_IPRST rstidx;
E_SYS_IPCLK clkidx;
struct nu_i2s_dai i2s_dais[NU_I2S_DAI_CNT];
nu_acodec_ops_t AcodecOps;
};
typedef struct nu_i2s *nu_i2s_t;
#endif // __DRV_I2S_H___