6 #include "hardware/pio.h"
13 #define audio_i2s_wrap_target 0
14 #define audio_i2s_wrap 7
16 #define audio_i2s_offset_entry_point 7u
18 static const uint16_t audio_i2s_program_instructions[] = {
32 static const struct pio_program audio_i2s_program = {
33 .instructions = audio_i2s_program_instructions,
38 static inline pio_sm_config audio_i2s_program_get_default_config(uint offset) {
39 pio_sm_config c = pio_get_default_sm_config();
40 sm_config_set_wrap(&c, offset + audio_i2s_wrap_target, offset + audio_i2s_wrap);
41 sm_config_set_sideset(&c, 2,
false,
false);
45 static inline void audio_i2s_program_init(PIO pio, uint sm, uint offset, uint data_pin, uint clock_pin_base) {
46 pio_sm_config sm_config = audio_i2s_program_get_default_config(offset);
47 sm_config_set_out_pins(&sm_config, data_pin, 1);
48 sm_config_set_sideset_pins(&sm_config, clock_pin_base);
49 sm_config_set_out_shift(&sm_config,
false,
true, 32);
50 pio_sm_init(pio, sm, offset, &sm_config);
51 uint pin_mask = (1u << data_pin) | (3u << clock_pin_base);
52 pio_sm_set_pindirs_with_mask(pio, sm, pin_mask, pin_mask);
53 pio_sm_set_pins(pio, sm, 0);
54 pio_sm_exec(pio, sm, pio_encode_jmp(offset + audio_i2s_offset_entry_point));