summaryrefslogtreecommitdiff
path: root/fw/fe310/eos/soc/i2s.h
blob: c5e92b73085410cb2a846170d74f54bbf73436da (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <stdint.h>

#include "i2s_def.h"

typedef struct EOSABuf {
    uint16_t idx_r;
    uint16_t idx_w;
    uint16_t size;
    uint8_t *array;
} EOSABuf;

typedef void (*eos_i2s_handler_t) (unsigned char);

int eos_i2s_init(uint8_t wakeup_cause);
void eos_i2s_init_mux(void);
void eos_i2s_start(uint32_t sample_rate);
void eos_i2s_stop(void);
int eos_i2s_running(void);
void eos_i2s_set_fmt(unsigned char fmt);
void eos_i2s_set_mode(unsigned char mode);

void eos_i2s_mic_set_handler(eos_i2s_handler_t handler, uint16_t wm);
void eos_i2s_mic_set_buf(uint8_t *mic_arr, uint16_t mic_arr_size);
uint8_t *eos_i2s_mic_get_buf(void);
uint16_t eos_i2s_mic_len(void);
uint16_t eos_i2s_mic_read(uint8_t *sample, uint16_t ssize);
int eos_i2s_mic_pop8(uint8_t *sample);
int eos_i2s_mic_pop16(uint16_t *sample);
int eos_i2s_mic_get_vol(void);
void eos_i2s_mic_set_vol(int vol);

void eos_i2s_spk_set_handler(eos_i2s_handler_t handler, uint16_t wm);
void eos_i2s_spk_set_buf(uint8_t *spk_arr, uint16_t spk_arr_size);
uint8_t *eos_i2s_spk_get_buf(void);
uint16_t eos_i2s_spk_len(void);
uint16_t eos_i2s_spk_write(uint8_t *sample, uint16_t ssize, uint8_t transform);
int eos_i2s_spk_push8(uint8_t sample);
int eos_i2s_spk_push16(uint16_t sample);
int eos_i2s_spk_get_vol(void);
void eos_i2s_spk_set_vol(int vol);