I2S ADC for Line-In
If you want the best experience, then Line-In using I2S will give the best quality. As you are getting a clean audio feed the squelch value should be set to 1 to start with, and a gain of 1 is also likely a good starting point. Automatic Gain Control (AGC) set to "Normal" is still recommended, but not strictly required.
Looking to add line-in with I2S support? You might want to try I2S ADC boards that use one of these chips:
- CirrusLogic WM8782
- CirrusLogic CS5343
- AKM AK5720 (datasheet)
- Ti PCM1808 or Ti PCM1802
- ES8388 and AC101
- WM8978
- ES8311 (mic is the common config)
Many I2S ADC line-in boards expect an additional MCLK signal ("Main Clock" aka "System Clock" aka "Master Clock" aka "Memory Clock"). MCLK is sometimes labelled SCLK for "system clock". For these boards with 4 data pins, use the AudioReactive Generic I2S with MCLK
input option, and connect MCLK pin to GPIO pin 0 on the original ESP32.
*NOTE: Technically GPIO 1 and 3 will work on the original ESP32 for MCLK, but these are most often in use for the serial console. If you're using an MCLK-required line-in board on an ESP32-S3 (and possibly other ESP32-XX boards) then the MCLK can be any free GPIO pin. WLED will generally show you which pins are allowed for MCLK on your board.
Pmod I2S2
- Jumper: Set to "Slave"
WM8782
Buy: AliExpress
- Remove jumper from MLCK
- DIP switch - SLAVE
- DIP switch - 24 bit
- Type - Generic I2S with Mclk
TI PCM1808
Buy: Amazon or AliExpress
Top side: Right audio input, Audio Ground, Left audio input.
Right side: The I2S connections -
- BCK = I2S SCK
- OUT = I2S SD
- LRC = I2S WS
- SCK = I2S MCLK (master clock)
- Ground = ground
- 3.3v input = 3.3v
Left side: Feature settings and 5v input:
- Format = Currently recommended set to 3.3v (see below) or Not Connected.
- Mode selector 0 = Not connected
- Mode selector 1 = Not connected
- Ground = alternate ground, you only need one
- 3.3v input = alternate 3.3v input, you only need one
- 5v input = 5v input for audio circuits. Connect to 5v
In WLED AudioReactive settings you will need to use Generic I2S with MCLK
. You have 3 choices of what MCLK pin you can use - 0, 1, and 3. Pin 0 highly recommended as 1 as 3 will likely be in use on the original ESP32 for the serial console.
5v seems to NEED to be connected. You can connect it to 3.3v but it will glitch randomly. Put that pin on 5v for best function.
3.3v and ground are connected to the same pins on the right side - just need to connect one of each, on either side.
MD1 and MD0 set master/slave modes. It defaults to slave (both pins are internally set to low), which is what you want for WLED. Don't connect these to anything.
FMY (format, FMT in the spec sheet - I assume the "Y" is a typo on the silkscreen) is a bit more interesting. By default it's pulled low internally, which the docs claim to be "I2S, 24-bit" - which will work fine as a default.
...however, pulling FMY "high" (connected to 3.3v) seems to make everything better in WLED. According to the spec sheet, this moves the entire 24 bit sequence one pulse earlier ("left justified") and the responsiveness seems to be better overall in WLED. The GEQ visual output is more "balanced" with the highs being better represented. The format of the 24 bits is unchanged - both are MSB first - but it seems to be better in WLED when the pin is pulled high. This may also depend on if you're using an IDF v3 build (the default) or IDF v4 (the requirement for ESP32-S3 and other more modern boards, optionally for the original ESP32).
ES8388 and AC101
Because of some confusion with these chips being used on various boards interchangably:
- The ES8388 chip is used in Espressif ESP32 LyraT boards and newer Ai-Thinker ESP AudioKit boards
- The AC101 chip is used in older Ai-Thinker ESP AudioKit boards
These audio chips reqires I2C commands to initialize properly. "Line-in mode" has been hard-coded into the initialization and will be used when "ES8388" or "AC101" is selected. (While the chips were sometimes used interchangably for the same basic function, the initialization is not the same!)
The on-board microphones are not currently supported by default - line-in is much better regardless.
Note: the underside of ESP32 overhang shows ESP32-A1S 2974. This version uses the ES8388 chip.
Line-in is internally routed to line-out, allowing these boards to be used in the middle of a line-level signal path.
Pin Config
The LyraT v4.3 and some AiThinker v2.2 boards use the following pin config:
- Type: ES8388
- IS2 SD = 35
- I2S WS = 25
- I2S SCK = 5
- I2S MCLK = 0
- I2C SDA = 18
- I2C SCL = 23
If the above doesn't work for AiThinker v2.2 boards use a chip with the following pins, use if you see errors about I2C:
Note: the underside of ESP32 overhang shows ESP32-A1S B221 and B238 on two boards with this config - the "B" or "B2" may be hints as to revision.
- Type: ES8388
- IS2 SD = 35
- I2S WS = 25
- I2S SCK = 27
- I2S MCLK = 0
- I2C SDA = 33
- I2C SCL = 32
Older Ai-Thinker AudioKit A1S boards use the AC101 chip. The board sample we have is marked "v2.2 2957". There is no stamp on the bottom of the ESP32 antenna overhang. Assume anything lower than that version is an AC101.
Config for the AC101 is:
- Type: AC101
- IS2 SD = 35
- I2S WS = 26
- I2S SCK = 27
- I2S MCLK = 0
- I2C SDA = 33
- I2C SCL = 32
...although who knows what other revisions may be floating around?!
WM8978
This audio chip reqires I2C commands to initialize properly. "Line-in mode" has been hard-coded into the initialization and will be used when "WM8978" is selected.
The on-board microphones are not currently supported - line-in is much better regardless.
Support for the WM8978 chipset is derived from the Puca DSP board:
Curently the Puca DSP on-board microphones may leak some sound in extremely loud environments, but the line-in will overpower this signal when presented. This has been minimized with settings. It technically shouldn't be using any mic signal, but there may be a small voltage leak in the analog signal path.
Line-in should be internally routed to line-out, allowing this board to be used in the middle of a line-level signal path.
Pin Config
The Puca DSP board pins are as follows:
- Type: WM8978
- I2S SD = 27
- I2S WS = 25
- I2S SCK = 23
- I2S MCLK = 0
- I2C SDA = 19 (set in global)
- I2C SCL = 18 (set in global)
ES8311 (mic, not line-in!)
This audio chip reqires I2C commands to initialize properly so including it here as it's a codec chip.
Many current (Jan 2025) ESP32-P4 dev boards use this chip, and those have one microphone on the board - as such this is a mic input and not a line-in, but could be supported in that configuration if someone released hardware.
If you need line-in on the ESP32-P4, you can use any of the other boards above on the P4, using different I2S pins from the on-board I2S codec chip.
Support for the ES8311 chipset is derived from the Espressif ESP32-P4 EV dev board:
This has also been confirmed on the Waveshare ESP32-P4 Nano boards as well, which use the same pins:
Pin Config
The Espressif EV and Waveshare Nano ESP32-P4 board pins are as follows:
- Type: ES8311
- I2S SD = 11
- I2S WS = 10
- I2S SCK = 12
- I2S MCLK = 13
- I2C SDA = 7 (set in global)
- I2C SCL = 8 (set in global)