![]()
![]()
#include <stdbool.h>
![]()
![]()
#include "hal/misc.h"
![]()
![]()
#include "soc/i2s_periph.h"
![]()
![]()
#include "soc/i2s_struct.h"
![]()
![]()
#include "soc/dport_reg.h"
![]()
![]()
#include "hal/i2s_types.h"
![]()
![]()
#include "hal/hal_utils.h"
![]()
![]()
#define I2S_LL_GET_HW
![]()
![]()
#define I2S_LL_AD_BCK_FACTOR
![]()
![]()
#define I2S_LL_PDM_BCK_FACTOR
![]()
![]()
#define I2S_LL_CLK_FRAC_DIV_N_MAX
![]()
![]()
#define I2S_LL_CLK_FRAC_DIV_AB_MAX
![]()
![]()
#define I2S_LL_BCK_MAX_PRESCALE
![]()
![]()
#define I2S_LL_EVENT_RX_EOF
![]()
![]()
#define I2S_LL_EVENT_TX_EOF
![]()
![]()
#define I2S_LL_EVENT_RX_DSCR_ERR
![]()
![]()
#define I2S_LL_EVENT_TX_DSCR_ERR
![]()
![]()
#define I2S_LL_EVENT_TX_TEOF
![]()
![]()
#define I2S_INTR_MAX
![]()
![]()
#define I2S_LL_TX_EVENT_MASK
![]()
![]()
#define I2S_LL_RX_EVENT_MASK
![]()
![]()
#define I2S_LL_PLL_F160M_CLK_FREQ
![]()
![]()
#define I2S_LL_DEFAULT_CLK_FREQ
![]()
![]()
i2s_ll_dma_enable_owner_check(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_dma_enable_auto_write_back(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_dma_enable_eof_on_fifo_empty(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_enable_bus_clock(int, bool)
![]()
![]()
if
(enable)
![]()
![]()
if
(i2s_id == 0)
![]()
![]()
else
![]()
![]()
else if
(i2s_id == 1)
![]()
![]()
if
(i2s_id == 0)
![]()
![]()
else
![]()
![]()
#define i2s_ll_enable_bus_clock
![]()
![]()
i2s_ll_reset_register(int)
![]()
![]()
if
(i2s_id == 0)
![]()
![]()
else if
(i2s_id == 1)
![]()
![]()
#define i2s_ll_reset_register
![]()
![]()
i2s_ll_enable_core_clock(i2s_dev_t *, bool)
![]()
![]()
if
(enable && !hw->clkm_conf.clk_en)
![]()
![]()
else if
(!enable && hw->clkm_conf.clk_en)
![]()
![]()
#define i2s_ll_enable_core_clock
![]()
![]()
i2s_ll_tx_enable_msb_right(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_rx_enable_msb_right(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_enable_right_first(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_rx_enable_right_first(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_force_enable_fifo_mod(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_rx_force_enable_fifo_mod(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_set_slave_mod(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_rx_set_slave_mod(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_reset(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_reset(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_reset_fifo(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_reset_fifo(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_clk_set_src(i2s_dev_t *, i2s_clock_src_t)
![]()
![]()
i2s_ll_rx_clk_set_src(i2s_dev_t *, i2s_clock_src_t)
![]()
![]()
i2s_ll_tx_set_bck_div_num(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_set_raw_mclk_div(i2s_dev_t *, uint32_t, uint32_t, uint32_t)
![]()
![]()
i2s_ll_tx_set_mclk(i2s_dev_t *, const hal_utils_clk_div_t *)
![]()
![]()
i2s_ll_rx_set_bck_div_num(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_rx_set_mclk(i2s_dev_t *, const hal_utils_clk_div_t *)
![]()
![]()
i2s_ll_enable_intr(i2s_dev_t *, uint32_t, bool)
![]()
![]()
if
(en)
![]()
![]()
else
![]()
![]()
i2s_ll_tx_enable_intr(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_disable_intr(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_enable_intr(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_disable_intr(i2s_dev_t *)
![]()
![]()
i2s_ll_get_intr_status_reg(i2s_dev_t *)
![]()
![]()
i2s_ll_get_intr_status(i2s_dev_t *)
![]()
![]()
i2s_ll_get_interrupt_status_reg(i2s_dev_t *)
![]()
![]()
i2s_ll_clear_intr_status(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_tx_reset_dma(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_reset_dma(i2s_dev_t *)
![]()
![]()
i2s_ll_start_out_link(i2s_dev_t *)
![]()
![]()
i2s_ll_set_out_link_addr(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_tx_start(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_start(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_start_link(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_rx_start_link(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_tx_stop(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_stop(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_stop_link(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_stop_link(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_get_eof_des_addr(i2s_dev_t *, uint32_t *)
![]()
![]()
i2s_ll_rx_get_eof_des_addr(i2s_dev_t *, uint32_t *)
![]()
![]()
i2s_ll_rx_set_eof_num(i2s_dev_t *, int)
![]()
![]()
i2s_ll_tx_set_bits_mod(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_tx_set_sample_bit(i2s_dev_t *, uint8_t, int)
![]()
![]()
i2s_ll_rx_set_sample_bit(i2s_dev_t *, uint8_t, int)
![]()
![]()
i2s_ll_tx_stop_on_fifo_empty(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_enable_dma(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_set_ws_width(i2s_dev_t *, int)
![]()
![]()
i2s_ll_rx_set_ws_width(i2s_dev_t *, int)
![]()
![]()
i2s_ll_tx_enable_msb_shift(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_rx_enable_msb_shift(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_select_pdm_slot(i2s_dev_t *, i2s_pdm_slot_mask_t, bool)
![]()
![]()
if
(is_mono)
![]()
![]()
switch
(slot_mask)
![]()
![]()
case
I2S_PDM_SLOT_RIGHT:
![]()
![]()
case
I2S_PDM_SLOT_LEFT:
![]()
![]()
case
I2S_PDM_SLOT_BOTH:
![]()
![]()
default
![]()
![]()
else
![]()
![]()
switch
(slot_mask)
![]()
![]()
case
I2S_PDM_SLOT_RIGHT:
![]()
![]()
case
I2S_PDM_SLOT_LEFT:
![]()
![]()
case
I2S_PDM_SLOT_BOTH:
![]()
![]()
default
![]()
![]()
i2s_ll_rx_select_pdm_slot(i2s_dev_t *, i2s_pdm_slot_mask_t)
![]()
![]()
switch
(slot_mask)
![]()
![]()
case
I2S_PDM_SLOT_RIGHT:
![]()
![]()
case
I2S_PDM_SLOT_LEFT:
![]()
![]()
case
I2S_PDM_SLOT_BOTH:
![]()
![]()
default
![]()
![]()
i2s_ll_tx_select_std_slot(i2s_dev_t *, i2s_std_slot_mask_t, bool)
![]()
![]()
if
(is_mono)
![]()
![]()
switch
(slot_mask)
![]()
![]()
case
I2S_STD_SLOT_RIGHT:
![]()
![]()
case
I2S_STD_SLOT_LEFT:
![]()
![]()
case
I2S_STD_SLOT_BOTH:
![]()
![]()
default
![]()
![]()
else
![]()
![]()
switch
(slot_mask)
![]()
![]()
case
I2S_STD_SLOT_RIGHT:
![]()
![]()
case
I2S_STD_SLOT_LEFT:
![]()
![]()
case
I2S_STD_SLOT_BOTH:
![]()
![]()
default
![]()
![]()
i2s_ll_rx_select_std_slot(i2s_dev_t *, i2s_std_slot_mask_t, bool)
![]()
![]()
switch
(slot_mask)
![]()
![]()
case
I2S_STD_SLOT_RIGHT:
![]()
![]()
case
I2S_STD_SLOT_LEFT:
![]()
![]()
case
I2S_STD_SLOT_BOTH:
![]()
![]()
default
![]()
![]()
i2s_ll_tx_enable_mono_mode(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_rx_enable_mono_mode(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_share_bck_ws(i2s_dev_t *, bool)
![]()
![]()
I2S PDM Configurations
![]()
![]()
i2s_ll_rx_set_pdm_dsr(i2s_dev_t *, i2s_pdm_dsr_t)
![]()
![]()
i2s_ll_rx_get_pdm_dsr(i2s_dev_t *, i2s_pdm_dsr_t *)
![]()
![]()
i2s_ll_tx_enable_std(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_enable_std(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_enable_pdm(i2s_dev_t *)
![]()
![]()
i2s_ll_rx_enable_pdm(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_set_pdm_prescale(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_tx_set_pdm_hp_scale(i2s_dev_t *, i2s_pdm_sig_scale_t)
![]()
![]()
i2s_ll_tx_set_pdm_lp_scale(i2s_dev_t *, i2s_pdm_sig_scale_t)
![]()
![]()
i2s_ll_tx_set_pdm_sinc_scale(i2s_dev_t *, i2s_pdm_sig_scale_t)
![]()
![]()
i2s_ll_tx_set_pdm_sd_scale(i2s_dev_t *, i2s_pdm_sig_scale_t)
![]()
![]()
i2s_ll_tx_set_pdm_over_sample_ratio(i2s_dev_t *, uint32_t)
![]()
![]()
i2s_ll_tx_set_pdm_fpfs(i2s_dev_t *, uint32_t, uint32_t)
![]()
![]()
i2s_ll_tx_get_pdm_fp(i2s_dev_t *)
![]()
![]()
i2s_ll_tx_get_pdm_fs(i2s_dev_t *)
![]()
![]()
I2S ADC/DAC Configurations
![]()
![]()
i2s_ll_enable_lcd(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_enable_camera(i2s_dev_t *, bool)
![]()
![]()
i2s_ll_enable_builtin_adc_dac(i2s_dev_t *, bool)