Files
99_7018_lmx/cpu/br28/audio_link.h

133 lines
4.3 KiB
C
Raw Normal View History

2025-10-29 13:10:02 +08:00
#ifndef _AUDIO_LINK_H_
#define _AUDIO_LINK_H_
#define ALNK_BUF_POINTS_NUM 256
#define ALINK_CLK_OUPUT_DISABLE 0xFF
typedef enum {
ALINK0 = 0u, //BR28只有一个ALNK模块
} ALINK_PORT;
//ch_num
typedef enum {
ALINK_CH0 = 0u,
ALINK_CH1,
ALINK_CH2,
ALINK_CH3,
} ALINK_CH;
//ch_dir
typedef enum {
ALINK_DIR_TX = 0u,
ALINK_DIR_RX ,
} ALINK_DIR;
typedef enum {
ALINK_LEN_16BIT = 0u,
ALINK_LEN_24BIT , //ALINK_FRAME_MODE需要选择: ALINK_FRAME_64SCLK
} ALINK_DATA_WIDTH;
//ch_mode
typedef enum {
ALINK_MD_NONE = 0u,
ALINK_MD_IIS ,
ALINK_MD_IIS_LALIGN ,
ALINK_MD_IIS_RALIGN ,
ALINK_MD_DSP0 ,
ALINK_MD_DSP1 ,
} ALINK_MODE;
//ch_mode
typedef enum {
ALINK_ROLE_MASTER, //主机
ALINK_ROLE_SLAVE, //从机
} ALINK_ROLE;
typedef enum {
ALINK_CLK_FALL_UPDATE_RAISE_SAMPLE, //下降沿更新数据, 上升沿采样数据
ALINK_CLK_RAISE_UPDATE_FALL_SAMPLE, //上降沿更新数据, 下升沿采样数据
} ALINK_CLK_MODE;
typedef enum {
ALINK_FRAME_64SCLK, //64 sclk/frame
ALINK_FRAME_32SCLK, //32 sclk/frame
} ALINK_FRAME_MODE;
//SDK默认PLL是192M,仅支持44100,22050,11025采样率,如需其他采样率,需设置PLL为240M,可支持所有采样率
typedef enum {
ALINK_SR_48000 = 48000,
ALINK_SR_44100 = 44100,
ALINK_SR_32000 = 32000,
ALINK_SR_24000 = 24000,
ALINK_SR_22050 = 22050,
ALINK_SR_16000 = 16000,
ALINK_SR_12000 = 12000,
ALINK_SR_11025 = 11025,
ALINK_SR_8000 = 8000,
} ALINK_SR;
typedef enum {
ALINK_BUF_DUAL, //乒乓BUF
ALINK_BUF_CIRCLE, //循环BUF
} ALINK_BUF_MODE;
struct alnk_hw_ch {
ALINK_PORT module;
ALINK_CH ch_idx;
u8 data_io; //data IO配置
ALINK_DIR dir; //通道传输数据方向: Tx, Rx
void *buf; //dma buf地址
void (*isr_cb)(void *priv, void *addr, int len); //中断回调
void *private_data; //音频私有数据
};
//===================================//
//多个通道使用需要注意:
//1.数据位宽需要保持一致
//2.buf长度相同
//===================================//
typedef struct _ALINK_PARM {
ALINK_PORT module;
u8 mclk_io; //mclk IO输出配置: ALINK_CLK_OUPUT_DISABLE不输出该时钟
u8 sclk_io; //sclk IO输出配置: ALINK_CLK_OUPUT_DISABLE不输出该时钟
u8 lrclk_io; //lrclk IO输出配置: ALINK_CLK_OUPUT_DISABLE不输出该时钟
struct alnk_hw_ch ch_cfg[4]; //通道内部配置
ALINK_MODE mode; //IIS, left, right, dsp0, dsp1
ALINK_ROLE role; //主机/从机
ALINK_CLK_MODE clk_mode; //更新和采样边沿
ALINK_DATA_WIDTH bitwide; //数据位宽16/32bit
ALINK_FRAME_MODE sclk_per_frame; //32/64 sclk/frame
u16 dma_len; //buf长度: byte
u16 iperiod; //输入中断的周期点数
ALINK_SR sample_rate; //采样
ALINK_BUF_MODE buf_mode; //乒乓buf or 循环buf率
} ALINK_PARM;
//iis 模块相关
void *alink_init(void *hw_alink); //iis 初始化
int alink_start(void *hw_alink); //iis 开启
int alink_set_sr(void *hw_alink, u32 sr); //iis 设置采样率
int alink_get_sr(void *hw_alink); //iis 获取采样率
u32 alink_get_dma_len(void *hw_alink); //iis 获取DMA_LEN
void alink_set_rx_pns(void *hw_alink, u32 len); //iis 设置接收PNS
void alink_set_tx_pns(void *hw_alink, u32 len); //iis 设置发送PNS
void alink_uninit(void *hw_alink); //iis 退出
int alink_get_tx_pns(void *hw_alink);
//iis 通道相关
void *alink_channel_init(void *hw_alink, ALINK_CH ch_idx, u8 dir, void *priv, void (*handle)(void *priv, void *addr, int len)); //iis通道初始化返回句柄
void alink_channel_close(void *hw_channel); //iis通道关闭
u32 alink_get_addr(void *hw_channel); //iis获取通道DMA地址
u32 alink_get_shn(void *hw_channel); //iis获取通道SHN
void alink_set_shn(void *hw_channel, u32 len); //iis设置通道SHN
u32 alink_get_swptr(void *hw_channel); //iis获取通道swptr
void alink_set_swptr(void *hw_channel, u32 value); //iis设置通道swptr
u32 alink_get_hwptr(void *hw_channel); //iis获取通道hwptr
void alink_set_hwptr(void *hw_channel, u32 value); //iis设置通道hwptr
void alink_set_ch_ie(void *hw_channel, u32 value); //iis设置通道ie
void alink_clr_ch_pnd(void *hw_channel); //iis清除通道pnd
u32 audio_iis_hw_rates_match(u32 sr);
#endif