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