1.. zephyr:board:: esp32c3_devkitm
2
3Overview
4********
5
6ESP32-C3-DevKitM is an entry-level development board based on ESP32-C3-MINI-1,
7a module named for its small size. This board integrates complete Wi-Fi and Bluetooth® Low Energy functions.
8For more information, check `ESP32-C3-DevKitM`_.
9
10Hardware
11********
12
13ESP32-C3 is a single-core Wi-Fi and Bluetooth 5 (LE) microcontroller SoC,
14based on the open-source RISC-V architecture. It strikes the right balance of power,
15I/O capabilities and security, thus offering the optimal cost-effective
16solution for connected devices.
17The availability of Wi-Fi and Bluetooth 5 (LE) connectivity not only makes the device configuration easy,
18but it also facilitates a variety of use-cases based on dual connectivity.
19
20The features include the following:
21
22- 32-bit core RISC-V microcontroller with a maximum clock speed of 160 MHz
23- 400 KB of internal RAM
24- 802.11b/g/n/e/i
25- A Bluetooth LE subsystem that supports features of Bluetooth 5 and Bluetooth Mesh
26- Various peripherals:
27
28  - 12-bit ADC with up to 6 channels
29  - TWAI compatible with CAN bus 2.0
30  - Temperature sensor
31  - 3x SPI
32  - 1x I2S
33  - 1x I2C
34  - 2x UART
35  - LED PWM with up to 6 channels
36
37- Cryptographic hardware acceleration (RNG, ECC, RSA, SHA-2, AES)
38
39For more information, check the datasheet at `ESP32-C3 Datasheet`_ or the technical reference
40manual at `ESP32-C3 Technical Reference Manual`_.
41
42Supported Features
43==================
44
45Current Zephyr's ESP32-C3-Devkitm board supports the following features:
46
47+------------+------------+-------------------------------------+
48| Interface  | Controller | Driver/Component                    |
49+============+============+=====================================+
50| UART       | on-chip    | serial port                         |
51+------------+------------+-------------------------------------+
52| GPIO       | on-chip    | gpio                                |
53+------------+------------+-------------------------------------+
54| PINMUX     | on-chip    | pinmux                              |
55+------------+------------+-------------------------------------+
56| USB-JTAG   | on-chip    | hardware interface                  |
57+------------+------------+-------------------------------------+
58| SPI Master | on-chip    | spi                                 |
59+------------+------------+-------------------------------------+
60| Timers     | on-chip    | counter                             |
61+------------+------------+-------------------------------------+
62| Watchdog   | on-chip    | watchdog                            |
63+------------+------------+-------------------------------------+
64| TRNG       | on-chip    | entropy                             |
65+------------+------------+-------------------------------------+
66| LEDC       | on-chip    | pwm                                 |
67+------------+------------+-------------------------------------+
68| SPI DMA    | on-chip    | spi                                 |
69+------------+------------+-------------------------------------+
70| TWAI       | on-chip    | can                                 |
71+------------+------------+-------------------------------------+
72| USB-CDC    | on-chip    | serial                              |
73+------------+------------+-------------------------------------+
74| ADC        | on-chip    | adc                                 |
75+------------+------------+-------------------------------------+
76| Wi-Fi      | on-chip    |                                     |
77+------------+------------+-------------------------------------+
78| Bluetooth  | on-chip    |                                     |
79+------------+------------+-------------------------------------+
80
81System requirements
82*******************
83
84Prerequisites
85=============
86
87Espressif HAL requires WiFi and Bluetooth binary blobs in order work. Run the command
88below to retrieve those files.
89
90.. code-block:: console
91
92   west blobs fetch hal_espressif
93
94.. note::
95
96   It is recommended running the command above after :file:`west update`.
97
98Building & Flashing
99*******************
100
101Simple boot
102===========
103
104The board could be loaded using the single binary image, without 2nd stage bootloader.
105It is the default option when building the application without additional configuration.
106
107.. note::
108
109   Simple boot does not provide any security features nor OTA updates.
110
111MCUboot bootloader
112==================
113
114User may choose to use MCUboot bootloader instead. In that case the bootloader
115must be built (and flashed) at least once.
116
117There are two options to be used when building an application:
118
1191. Sysbuild
1202. Manual build
121
122.. note::
123
124   User can select the MCUboot bootloader by adding the following line
125   to the board default configuration file.
126
127   .. code:: cfg
128
129      CONFIG_BOOTLOADER_MCUBOOT=y
130
131Sysbuild
132========
133
134The sysbuild makes possible to build and flash all necessary images needed to
135bootstrap the board with the ESP32 SoC.
136
137To build the sample application using sysbuild use the command:
138
139.. zephyr-app-commands::
140   :tool: west
141   :zephyr-app: samples/hello_world
142   :board: esp32c3_devkitm
143   :goals: build
144   :west-args: --sysbuild
145   :compact:
146
147By default, the ESP32 sysbuild creates bootloader (MCUboot) and application
148images. But it can be configured to create other kind of images.
149
150Build directory structure created by sysbuild is different from traditional
151Zephyr build. Output is structured by the domain subdirectories:
152
153.. code-block::
154
155  build/
156  ├── hello_world
157  │   └── zephyr
158  │       ├── zephyr.elf
159  │       └── zephyr.bin
160  ├── mcuboot
161  │    └── zephyr
162  │       ├── zephyr.elf
163  │       └── zephyr.bin
164  └── domains.yaml
165
166.. note::
167
168   With ``--sysbuild`` option the bootloader will be re-build and re-flash
169   every time the pristine build is used.
170
171For more information about the system build please read the :ref:`sysbuild` documentation.
172
173Manual build
174============
175
176During the development cycle, it is intended to build & flash as quickly possible.
177For that reason, images can be built one at a time using traditional build.
178
179The instructions following are relevant for both manual build and sysbuild.
180The only difference is the structure of the build directory.
181
182.. note::
183
184   Remember that bootloader (MCUboot) needs to be flash at least once.
185
186Build and flash applications as usual (see :ref:`build_an_application` and
187:ref:`application_run` for more details).
188
189.. zephyr-app-commands::
190   :zephyr-app: samples/hello_world
191   :board: esp32c3_devkitm
192   :goals: build
193
194The usual ``flash`` target will work with the ``esp32c3_devkitm`` board
195configuration. Here is an example for the :zephyr:code-sample:`hello_world`
196application.
197
198.. zephyr-app-commands::
199   :zephyr-app: samples/hello_world
200   :board: esp32c3_devkitm
201   :goals: flash
202
203Open the serial monitor using the following command:
204
205.. code-block:: shell
206
207   west espressif monitor
208
209After the board has automatically reset and booted, you should see the following
210message in the monitor:
211
212.. code-block:: console
213
214   ***** Booting Zephyr OS vx.x.x-xxx-gxxxxxxxxxxxx *****
215   Hello World! esp32c3_devkitm
216
217Debugging
218*********
219
220As with much custom hardware, the ESP32-C3 modules require patches to
221OpenOCD that are not upstreamed yet. Espressif maintains their own fork of
222the project. The custom OpenOCD can be obtained at `OpenOCD ESP32`_.
223
224The Zephyr SDK uses a bundled version of OpenOCD by default. You can overwrite that behavior by adding the
225``-DOPENOCD=<path/to/bin/openocd> -DOPENOCD_DEFAULT_PATH=<path/to/openocd/share/openocd/scripts>``
226parameter when building.
227
228Here is an example for building the :zephyr:code-sample:`hello_world` application.
229
230.. zephyr-app-commands::
231   :zephyr-app: samples/hello_world
232   :board: esp32c3_devkitm
233   :goals: build flash
234   :gen-args: -DOPENOCD=<path/to/bin/openocd> -DOPENOCD_DEFAULT_PATH=<path/to/openocd/share/openocd/scripts>
235
236You can debug an application in the usual way. Here is an example for the :zephyr:code-sample:`hello_world` application.
237
238.. zephyr-app-commands::
239   :zephyr-app: samples/hello_world
240   :board: esp32c3_devkitm
241   :goals: debug
242
243References
244**********
245
246.. target-notes::
247
248.. _`ESP32-C3-DevKitM`: https://docs.espressif.com/projects/esp-idf/en/latest/esp32c3/hw-reference/esp32c3/user-guide-devkitm-1.html
249.. _`ESP32-C3 Datasheet`: https://www.espressif.com/sites/default/files/documentation/esp32-c3_datasheet_en.pdf
250.. _`ESP32-C3 Technical Reference Manual`: https://espressif.com/sites/default/files/documentation/esp32-c3_technical_reference_manual_en.pdf
251.. _`OpenOCD ESP32`: https://github.com/espressif/openocd-esp32/releases
252