rp2040-i2s
All Classes Files Functions Variables Typedefs Modules Pages
audio_i2s.pio.h
1 // -------------------------------------------------- //
2 // This file is autogenerated by pioasm; do not edit! //
3 // -------------------------------------------------- //
4 
5 #if !PICO_NO_HARDWARE
6 #include "hardware/pio.h"
7 #endif
8 
9 // --------- //
10 // audio_i2s //
11 // --------- //
12 
13 #define audio_i2s_wrap_target 0
14 #define audio_i2s_wrap 7
15 
16 #define audio_i2s_offset_entry_point 7u
17 
18 static const uint16_t audio_i2s_program_instructions[] = {
19  // .wrap_target
20  0x7001, // 0: out pins, 1 side 2
21  0x1840, // 1: jmp x--, 0 side 3
22  0x6001, // 2: out pins, 1 side 0
23  0xe82e, // 3: set x, 14 side 1
24  0x6001, // 4: out pins, 1 side 0
25  0x0844, // 5: jmp x--, 4 side 1
26  0x7001, // 6: out pins, 1 side 2
27  0xf82e, // 7: set x, 14 side 3
28  // .wrap
29 };
30 
31 #if !PICO_NO_HARDWARE
32 static const struct pio_program audio_i2s_program = {
33  .instructions = audio_i2s_program_instructions,
34  .length = 8,
35  .origin = -1,
36 };
37 
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);
42  return c;
43 }
44 
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); // clear pins
54  pio_sm_exec(pio, sm, pio_encode_jmp(offset + audio_i2s_offset_entry_point));
55 }
56 
57 #endif
58