1.. zephyr:board:: esp32_devkitc_wroom 2 3Overview 4******** 5 6ESP32 is a series of low cost, low power system on a chip microcontrollers 7with integrated Wi-Fi & dual-mode Bluetooth. The ESP32 series employs a 8Tensilica Xtensa LX6 microprocessor in both dual-core and single-core 9variations. ESP32 is created and developed by Espressif Systems, a 10Shanghai-based Chinese company, and is manufactured by TSMC using their 40nm 11process. For more information, check `ESP32-DevKitC-WROOM`_. 12 13The features include the following: 14 15- Dual core Xtensa microprocessor (LX6), running at 160 or 240MHz 16- 520KB of SRAM 17- 802.11b/g/n/e/i 18- Bluetooth v4.2 BR/EDR and BLE 19- Various peripherals: 20 21 - 12-bit ADC with up to 18 channels 22 - 2x 8-bit DACs 23 - 10x touch sensors 24 - Temperature sensor 25 - 4x SPI 26 - 2x I2S 27 - 2x I2C 28 - 3x UART 29 - SD/SDIO/MMC host 30 - Slave (SDIO/SPI) 31 - Ethernet MAC 32 - CAN bus 2.0 33 - IR (RX/TX) 34 - Motor PWM 35 - LED PWM with up to 16 channels 36 - Hall effect sensor 37 38- Cryptographic hardware acceleration (RNG, ECC, RSA, SHA-2, AES) 39- 5uA deep sleep current 40 41For more information, check the datasheet at `ESP32 Datasheet`_ or the technical reference 42manual at `ESP32 Technical Reference Manual`_. 43 44Asymmetric Multiprocessing (AMP) 45******************************** 46 47ESP32-DevKitC-WROOM allows 2 different applications to be executed in ESP32 SoC. Due to its dual-core architecture, each core can be enabled to execute customized tasks in stand-alone mode 48and/or exchanging data over OpenAMP framework. See :zephyr:code-sample-category:`ipc` folder as code reference. 49 50Supported Features 51================== 52 53Current Zephyr's ESP32-DevKitC-WROOM board supports the following features: 54 55+------------+------------+-------------------------------------+ 56| Interface | Controller | Driver/Component | 57+============+============+=====================================+ 58| UART | on-chip | serial port | 59+------------+------------+-------------------------------------+ 60| GPIO | on-chip | gpio | 61+------------+------------+-------------------------------------+ 62| PINMUX | on-chip | pinmux | 63+------------+------------+-------------------------------------+ 64| USB-JTAG | on-chip | hardware interface | 65+------------+------------+-------------------------------------+ 66| SPI Master | on-chip | spi | 67+------------+------------+-------------------------------------+ 68| Timers | on-chip | counter | 69+------------+------------+-------------------------------------+ 70| Watchdog | on-chip | watchdog | 71+------------+------------+-------------------------------------+ 72| TRNG | on-chip | entropy | 73+------------+------------+-------------------------------------+ 74| LEDC | on-chip | pwm | 75+------------+------------+-------------------------------------+ 76| MCPWM | on-chip | pwm | 77+------------+------------+-------------------------------------+ 78| PCNT | on-chip | qdec | 79+------------+------------+-------------------------------------+ 80| SPI DMA | on-chip | spi | 81+------------+------------+-------------------------------------+ 82| TWAI | on-chip | can | 83+------------+------------+-------------------------------------+ 84| ADC | on-chip | adc | 85+------------+------------+-------------------------------------+ 86| DAC | on-chip | dac | 87+------------+------------+-------------------------------------+ 88| Wi-Fi | on-chip | | 89+------------+------------+-------------------------------------+ 90| Bluetooth | on-chip | | 91+------------+------------+-------------------------------------+ 92 93System requirements 94=================== 95 96Prerequisites 97------------- 98 99Espressif HAL requires WiFi and Bluetooth binary blobs in order work. Run the command 100below to retrieve those files. 101 102.. code-block:: console 103 104 west blobs fetch hal_espressif 105 106.. note:: 107 108 It is recommended running the command above after :file:`west update`. 109 110Building & Flashing 111******************* 112 113Simple boot 114=========== 115 116The board could be loaded using the single binary image, without 2nd stage bootloader. 117It is the default option when building the application without additional configuration. 118 119.. note:: 120 121 Simple boot does not provide any security features nor OTA updates. 122 123MCUboot bootloader 124================== 125 126User may choose to use MCUboot bootloader instead. In that case the bootloader 127must be built (and flashed) at least once. 128 129There are two options to be used when building an application: 130 1311. Sysbuild 1322. Manual build 133 134.. note:: 135 136 User can select the MCUboot bootloader by adding the following line 137 to the board default configuration file. 138 139 .. code:: cfg 140 141 CONFIG_BOOTLOADER_MCUBOOT=y 142 143Sysbuild 144======== 145 146The sysbuild makes possible to build and flash all necessary images needed to 147bootstrap the board with the ESP32 SoC. 148 149To build the sample application using sysbuild use the command: 150 151.. zephyr-app-commands:: 152 :tool: west 153 :zephyr-app: samples/hello_world 154 :board: esp_wrover_kit 155 :goals: build 156 :west-args: --sysbuild 157 :compact: 158 159By default, the ESP32 sysbuild creates bootloader (MCUboot) and application 160images. But it can be configured to create other kind of images. 161 162Build directory structure created by sysbuild is different from traditional 163Zephyr build. Output is structured by the domain subdirectories: 164 165.. code-block:: 166 167 build/ 168 ├── hello_world 169 │ └── zephyr 170 │ ├── zephyr.elf 171 │ └── zephyr.bin 172 ├── mcuboot 173 │ └── zephyr 174 │ ├── zephyr.elf 175 │ └── zephyr.bin 176 └── domains.yaml 177 178.. note:: 179 180 With ``--sysbuild`` option the bootloader will be re-build and re-flash 181 every time the pristine build is used. 182 183For more information about the system build please read the :ref:`sysbuild` documentation. 184 185Manual build 186============ 187 188During the development cycle, it is intended to build & flash as quickly possible. 189For that reason, images can be built one at a time using traditional build. 190 191The instructions following are relevant for both manual build and sysbuild. 192The only difference is the structure of the build directory. 193 194.. note:: 195 196 Remember that bootloader (MCUboot) needs to be flash at least once. 197 198Build and flash applications as usual (see :ref:`build_an_application` and 199:ref:`application_run` for more details). 200 201.. zephyr-app-commands:: 202 :zephyr-app: samples/hello_world 203 :board: esp32_devkitc_wroom/esp32/procpu 204 :goals: build 205 206The usual ``flash`` target will work with the ``esp32_devkitc_wroom`` board 207configuration. Here is an example for the :zephyr:code-sample:`hello_world` 208application. 209 210.. zephyr-app-commands:: 211 :zephyr-app: samples/hello_world 212 :board: esp32_devkitc_wroom/esp32/procpu 213 :goals: flash 214 215Open the serial monitor using the following command: 216 217.. code-block:: shell 218 219 west espressif monitor 220 221After the board has automatically reset and booted, you should see the following 222message in the monitor: 223 224.. code-block:: console 225 226 ***** Booting Zephyr OS vx.x.x-xxx-gxxxxxxxxxxxx ***** 227 Hello World! esp32_devkitc_wroom 228 229Debugging 230********* 231 232ESP32 support on OpenOCD is available at `OpenOCD ESP32`_. 233 234On the ESP32-DevKitC-WROOM board, the JTAG pins are not run to a 235standard connector (e.g. ARM 20-pin) and need to be manually connected 236to the external programmer (e.g. a Flyswatter2): 237 238+------------+-----------+ 239| ESP32 pin | JTAG pin | 240+============+===========+ 241| 3V3 | VTRef | 242+------------+-----------+ 243| EN | nTRST | 244+------------+-----------+ 245| IO14 | TMS | 246+------------+-----------+ 247| IO12 | TDI | 248+------------+-----------+ 249| GND | GND | 250+------------+-----------+ 251| IO13 | TCK | 252+------------+-----------+ 253| IO15 | TDO | 254+------------+-----------+ 255 256Further documentation can be obtained from the SoC vendor in `JTAG debugging for ESP32`_. 257 258Here is an example for building the :zephyr:code-sample:`hello_world` application. 259 260.. zephyr-app-commands:: 261 :zephyr-app: samples/hello_world 262 :board: esp32_devkitc_wroom/esp32/procpu 263 :goals: build flash 264 265You can debug an application in the usual way. Here is an example for the :zephyr:code-sample:`hello_world` application. 266 267.. zephyr-app-commands:: 268 :zephyr-app: samples/hello_world 269 :board: esp32_devkitc_wroom/esp32/procpu 270 :goals: debug 271 272Note on Debugging with GDB Stub 273=============================== 274 275GDB stub is enabled on ESP32. 276 277* When adding breakpoints, please use hardware breakpoints with command 278 ``hbreak``. Command ``break`` uses software breakpoints which requires 279 modifying memory content to insert break/trap instructions. 280 This does not work as the code is on flash which cannot be randomly 281 accessed for modification. 282 283References 284********** 285 286.. target-notes:: 287 288.. _`ESP32-DevKitC-WROOM`: https://docs.espressif.com/projects/esp-idf/en/stable/esp32/hw-reference/esp32/get-started-devkitc.html# 289.. _`ESP32 Datasheet`: https://www.espressif.com/sites/default/files/documentation/esp32_datasheet_en.pdf 290.. _`ESP32 Technical Reference Manual`: https://espressif.com/sites/default/files/documentation/esp32_technical_reference_manual_en.pdf 291.. _`JTAG debugging for ESP32`: https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-guides/jtag-debugging/index.html 292.. _`OpenOCD ESP32`: https://github.com/espressif/openocd-esp32/releases 293