nuttx/Documentation/platforms/xtensa/esp32/boards/esp32-lyrat/index.rst
2022-11-08 10:03:18 -03:00

445 lines
16 KiB
ReStructuredText

..
Ported from ESP-ADF documentation https://espressif-docs.readthedocs-hosted.com/projects/esp-adf/en/latest/design-guide/dev-boards/board-esp32-lyrat-v4.3.html
================
ESP32-LyraT V4.3
================
The ESP32-LyraT development board is a hardware platform designed for the
dual-core ESP32 audio applications, e.g., Wi-Fi or BT audio speakers,
speech-based remote controllers, smart-home appliances with audio
functionality(ies), etc. You can find the board schematic `here <https://dl.espressif.com/dl/schematics/ESP32-LYRAT_V4.3-20220119.pdf>`_.
.. figure:: esp32-lyrat-v4.3-layout-with-wrover-e-module.jpg
:alt: ESP32 LyraT V4.3 Board Layout
:figclass: align-center
ESP32-LyraT V4.3 Board Layout
The block diagram below presents main components of the ESP32-LyraT.
.. figure:: esp32-lyrat-v4.3-electrical-block-diagram-with-wrover-e-module.png
:alt: ESP32 LyraT V4.3 Electrical Block Diagram
:figclass: align-center
ESP32-LyraT V4.3 Electrical Block Diagram
Features
========
- ESP32-WROVER-E Module
- JTAG Interface
- MicroSD Slot
- Audio Codec Chip
- Battery Charger Chip
- Touch Pad Buttons
Serial Console
==============
UART0 is, by default, the serial console. It connects to the on-board
CP2102N bridge and is available on the USB connector.
It will show up as /dev/ttyUSB[n] where [n] will probably be 0.
Buttons and LEDs
================
Buttons
-------
Two key labeled *Rec* and *Mode*. They are routed to **ESP32-WROVER-E Module**
and intended for developing and testing a UI for audio applications using
dedicated API.
Four touch pads labeled *Play*, *Sel*, *Vol+* and *Vol-*.
They are routed to **ESP32-WROVER-E Module** and intended for development and
testing of a UI for audio applications using dedicated API. **They are currently
not supported as the driver is in development.**
There are two buttons labeled Boot and EN. The EN button pulls the chip enable
line that doubles as a reset line. The BOOT button is connected to IO0. On
reset it is used as a strapping pin to determine whether the chip boots
normally or into the serial bootloader.
Entering of the ESP32 into upload mode may be done in two ways:
* Manually by pressing both **Boot** and **RST** keys and then releasing first
**RST** and then **Boot** key.
* Automatically by software performing the upload. The software is using
**DTR** and **RTS** signals of the serial interface to control states of
**EN**, **IO0** and **IO2** pins of the ESP32. This functionality is enabled
by installing jumpers in three headers **JP23**, **JP24** and **JP25**.
Remove all jumpers after upload is complete.
LEDs
----
A general purpose green LED controlled by the **ESP32-WROVER-E Module** to
indicate certain operation states of the audio application using dedicated
API. It can also be used by the user for other purposes.
The **Standby** green LED indicates that power has been applied to the
**Micro USB Port**. The **Charging** red LED indicates that a battery
connected to the **Battery Socket** is being charged.
Audio Codec
===========
**This is currently unsupported. Drivers still in development.**
The Audio Codec Chip, `ES8388 <http://www.everest-semi.com/pdf/ES8388%20DS.pdf>`_,
is a low power stereo audio codec with a headphone amplifier. It consists
of 2-channel ADC, 2-channel DAC, microphone amplifier, headphone amplifier
, digital sound effects, analog mixing and gain functions. It is
interfaced with **ESP32-WROVER-E Module** over I2S and I2S buses to
provide audio processing in hardware independently from the audio
application.
It also provides:
- Onboard microphone connected to IN1 of the **Audio Codec Chip**.
- Auxiliary input socket connected to IN2 (left and right channel) of the
**Audio Codec Chip**. Use a 3.5 mm stereo jack to connect to this socket.
- Output socket to connect headphones with a 3.5 mm stereo jack.
.. note::
The socket may be used with mobile phone headsets and is compatible
with OMPT standard headsets only. It does work with CTIA headsets.
Please refer to `Phone connector (audio) <https://en.wikipedia.org/wiki/Phone_connector_(audio)#TRRS_standards>`_
on Wikipedia.
- Output socket to connect a speaker. The 4-ohm and 3-watt speaker is
recommended. The pins have a 2.00 mm / 0.08" pitch.
The development board uses two mono Class D amplifier ICs, model number NS4150
with maximum output power of 3W and operating voltage from 3.0V to 5.25V.
The audio input source is the digital-to-analog converter (DAC) output of the
ES8388. Audio output supports two external speakers.
An optional audio output is a pair of headphones feed from the same DACs as
the amplifier ICs.
To switch between using headphones and speakers, the board provides a digital
input signal to detect when a headphone jack is inserted and a digital output
signal to enable or disable the amplifier ICs. In other words selection
between speakers and headphones is under software control instead of using
mechanical contacts that would disconnect speakers once a headphone jack is
inserted.
.. note::
The codec implementation on the LyraT board was validated using 16-bit,
44.1kHz WAV files. Other configurations might not work as expected.
SD card
=======
The development board supports a MicroSD card in SPI/1-bit/4-bit modes,
and can store or play audio files in the MicroSD card. Note that **JTAG**
cannot be used and should be disconnected by setting **Function DIP
Switch** when **MicroSD Card** is in operation, because some of signals
are shared by both devices.
Enable MicroSD Card in 1-wire Mode
----------------------------------
Set **Function DIP Switch** to:
+---------+-----------------+
| DIP SW | Position |
+=========+=================+
| 1 | OFF |
+---------+-----------------+
| 2 | OFF |
+---------+-----------------+
| 3 | OFF |
+---------+-----------------+
| 4 | OFF |
+---------+-----------------+
| 5 | OFF |
+---------+-----------------+
| 6 | OFF |
+---------+-----------------+
| 7 | OFF :sup:`1` |
+---------+-----------------+
| 8 | n/a |
+---------+-----------------+
1. **AUX Input** detection may be enabled by toggling the DIP SW 7 *ON*.
Note that the **AUX Input** signal pin should not be be plugged in when the
system powers up. Otherwise the ESP32 may not be able to boot correctly.
In this mode:
* **JTAG** functionality is not available
* *Vol-* touch button is available for use with the API
Enable MicroSD Card in 4-wire Mode
----------------------------------
Set **Function DIP Switch** to:
+---------+-----------+
| DIP SW | Position |
+=========+===========+
| 1 | ON |
+---------+-----------+
| 2 | ON |
+---------+-----------+
| 3 | OFF |
+---------+-----------+
| 4 | OFF |
+---------+-----------+
| 5 | OFF |
+---------+-----------+
| 6 | OFF |
+---------+-----------+
| 7 | OFF |
+---------+-----------+
| 8 | n/a |
+---------+-----------+
In this mode:
* **JTAG** functionality is not available
* *Vol-* touch button is not available for use with the API
* **AUX Input** detection from the API is not available
JTAG
====
Provides access to the **JTAG** interface of **ESP32-WROVER-E Module**.
It may be used for debugging, application upload, as well as implementing
several other functions.
Enable JTAG
-----------
Set **Function DIP Switch** to:
+---------+-----------+
| DIP SW | Position |
+=========+===========+
| 1 | OFF |
+---------+-----------+
| 2 | OFF |
+---------+-----------+
| 3 | ON |
+---------+-----------+
| 4 | ON |
+---------+-----------+
| 5 | ON |
+---------+-----------+
| 6 | ON |
+---------+-----------+
| 7 | ON |
+---------+-----------+
| 8 | n/a |
+---------+-----------+
In this mode:
* **MicroSD Card** functionality is not available, remove the card from the slot
* *Vol-* touch button is not available for use with the API
* **AUX Input** detection from the API is not available
Battery
=======
The board has a constant current & constant voltage linear charger for single cell
lithium-ion batteries AP5056. Used for charging of a battery connected to
the **Battery Socket** over the **Micro USB Port**.
.. note::
Please verify if polarity on the battery plug matches polarity of the
socket as marked on the board's soldermask besides the socket.
.. note::
The **Power On Switch** does not affect/disconnect the Li-ion
battery charging.
Pin Mapping
===========
Several pins ESP32 module are allocated to the on board hardware. Some of
them, like GPIO0 or GPIO2, have multiple functions. Please refer to the table
below.
+-----------+------+-------------------------------------------------------+
| GPIO Pin | Type | Function Definition |
+===========+======+=======================================================+
| SENSOR_VP | I | Audio **Rec** (PB) |
+-----------+------+-------------------------------------------------------+
| SENSOR_VN | I | Audio **Mode** (PB) |
+-----------+------+-------------------------------------------------------+
| IO32 | I/O | Audio **Set** (TP) |
+-----------+------+-------------------------------------------------------+
| IO33 | I/O | Audio **Play** (TP) |
+-----------+------+-------------------------------------------------------+
| IO27 | I/O | Audio **Vol+** (TP) |
+-----------+------+-------------------------------------------------------+
| IO13 | I/O | JTAG **MTCK**, MicroSD **D3**, Audio **Vol-** (TP) |
+-----------+------+-------------------------------------------------------+
| IO14 | I/O | JTAG **MTMS**, MicroSD **CLK** |
+-----------+------+-------------------------------------------------------+
| IO12 | I/O | JTAG **MTDI**, MicroSD **D2**, Aux signal **detect** |
+-----------+------+-------------------------------------------------------+
| IO15 | I/O | JTAG **MTDO**, MicroSD **CMD** |
+-----------+------+-------------------------------------------------------+
| IO2 | I/O | Automatic Upload, MicroSD **D0** |
+-----------+------+-------------------------------------------------------+
| IO4 | I/O | MicroSD **D1** |
+-----------+------+-------------------------------------------------------+
| IO34 | I | MicroSD insert **detect** |
+-----------+------+-------------------------------------------------------+
| IO0 | I/O | Automatic Upload, I2S **MCLK** |
+-----------+------+-------------------------------------------------------+
| IO5 | I/O | I2S **SCLK** |
+-----------+------+-------------------------------------------------------+
| IO25 | I/O | I2S **LRCK** |
+-----------+------+-------------------------------------------------------+
| IO26 | I/O | I2S **DSDIN** |
+-----------+------+-------------------------------------------------------+
| IO35 | I | I2S **ASDOUT** |
+-----------+------+-------------------------------------------------------+
| IO19 | I/O | Headphone jack insert **detect** |
+-----------+------+-------------------------------------------------------+
| IO22 | I/O | Green LED indicator |
+-----------+------+-------------------------------------------------------+
| IO21 | I/O | PA Enable output |
+-----------+------+-------------------------------------------------------+
| IO18 | I/O | I2C **SDA** |
+-----------+------+-------------------------------------------------------+
| IO23 | I/O | I2C **SCL** |
+-----------+------+-------------------------------------------------------+
* (TP) - touch pad
* (PB) - push button
There are several pin headers available to connect external components, check
the state of particular signal bus or debug operation of ESP32. Note that some
signals are shared.
UART Header / JP2
-----------------
+---+-------------+
| | Header Pin |
+===+=============+
| 1 | 3.3V |
+---+-------------+
| 2 | TX |
+---+-------------+
| 3 | RX |
+---+-------------+
| 4 | GND |
+---+-------------+
I2S Header / JP4
----------------
+---+----------------+-------------+
| | I2C Header Pin | ESP32 Pin |
+===+================+=============+
| 1 | MCLK | GPIO0 |
+---+----------------+-------------+
| 2 | SCLK | GPIO5 |
+---+----------------+-------------+
| 1 | LRCK | GPIO25 |
+---+----------------+-------------+
| 2 | DSDIN | GPIO26 |
+---+----------------+-------------+
| 3 | ASDOUT | GPIO35 |
+---+----------------+-------------+
| 3 | GND | GND |
+---+----------------+-------------+
I2C Header / JP5
----------------
+---+----------------+-------------+
| | I2C Header Pin | ESP32 Pin |
+===+================+=============+
| 1 | SCL | GPIO23 |
+---+----------------+-------------+
| 2 | SDA | GPIO18 |
+---+----------------+-------------+
| 3 | GND | GND |
+---+----------------+-------------+
JTAG Header / JP7
-----------------
+---+---------------+-------------+
| | ESP32 Pin | JTAG Signal |
+===+===============+=============+
| 1 | MTDO / GPIO15 | TDO |
+---+---------------+-------------+
| 2 | MTCK / GPIO13 | TCK |
+---+---------------+-------------+
| 3 | MTDI / GPIO12 | TDI |
+---+---------------+-------------+
| 4 | MTMS / GPIO14 | TMS |
+---+---------------+-------------+
.. note::
**JTAG** cannot be used if **MicroSD Card** is enabled.
Configurations
==============
audio
-----
This configuration uses the I2S0 peripheral and the ES8388 audio codec
present on the LyraT board to play an audio file streamed over HTTP
while connected to a Wi-Fi network.
**Simple HTTP server**
Prepare a PCM-encoded (`.wav`) audio file with 16 bits/sample (sampled at
44.1kHz). This file must be placed into a folder in a computer that could
be accessed on the same Wi-Fi network the ESP32 will be connecting to.
Python provides a simple HTTP server. `cd` to the audio file folder on the
PC and run::
$ python3 -m http.server
Serving HTTP on 0.0.0.0 port 8000 (http://0.0.0.0:8000/)
Look for your PC IP address and test playing the prepared audio on your
browser:
.. figure:: esp32-lyrat-v4.3-audio-config-file.png
:align: center
After successfully built and flashed, connect the board to the Wi-Fi network::
$ nsh> wapi psk wlan0 mypasswd 1
$ nsh> wapi essid wlan0 myssid 1
$ nsh> renew wlan0
Once connected, open NuttX's player and play the file according to its file
name and the IP address of the HTTP server (For example `tones.wav` and
`192.168.1.239:8000`, respectively)::
$ nsh> nxplayer
$ nxplayer> play http://192.168.1.239:8000/tones.wav
.. note::
The codec implementation on the LyraT board was validated using 16-bit,
44.1kHz WAV files. Other configurations might not work as expected.
nsh
---
Basic NuttShell configuration (console enabled in UART0, exposed via
USB connection by means of the CP2102N bridge, at 115200 bps).
wapi
----
Enables Wi-Fi support.