Skip to main content

Blink LED on ESP32 with RTOS NuttX

·4 mins·
NuttX ESP32
Table of Contents

Introduction
#

This article is part of the “First Steps with ESP32 and NuttX” series. A series whose objective is to present an overview of the NuttX Operating System and to provide instructions for using NuttX on ESP32.

The first part of the series showed how to prepare the environment, compile and build the Operating System (NuttX) until uploading the firmware to the SoC (ESP32).

This is the second part and will demonstrate how to run the famous “Hello World” from the Embedded Systems world, i.e., an application that blinks a LED. The evaluation board used here is a DevKit v1 and the built-in LED will be used for convenience. If your DevKit does not come with a built-in LED, just connect an LED to pin 2 in series with a resistor as it will be briefly discussed in the execution section.

Including LED
#

From the nuttx directory, clean your current configuration and pre-existing binaries, load the configuration for ESP32 DevKit board with nsh (NuttX shell) and finally enter the configuration menu using the following commands:

cd ~/nuttxspace/nuttx
make distclean
./tools/configure.sh esp32-devkitc:nsh
make menuconfig

To add the driver for the LED, navigate to* Device Drivers-> LED Support and select LED Driver and Generic Lower Half LED Driver* (Click y). In this step you are adding the driver for the LED.

Return to the home menu via ‘Exit’. Just use the side arrows and ‘Enter’. Finally, to add the example, navigate to Application Configuration-> Examples and select Led Driver Example.

Exit the menu via “Exit” and save the configuration.

✓As a shortcut, you may load the leds config instead of nsh. If you do so, you don’t need to enter the configuration menu. This config has everything included for you. It’s nice to try both to realize how configs may be used to try functionalities faster but it’s also nice to get familiar with the menuconfig options.

Building and Flashing
#

If you did not add the paths for the cross compiler binaries and for the esptool to PATH permanently as suggested in the Getting Started, run the following commands to load these paths.

export PATH=$PATH:/opt/xtensa/xtensa-esp32-elf/bin
export PATH=$PATH:/home/<user>/.local/bin

NOTE: Replace with your user name.

Finally, clean up any previously generated binaries, connect your DevKit to your computer and perform the build process and flash using the following commands:

make clean
make download ESPTOOL_PORT=/dev/ttyUSB0

NOTE: adjust the USB port according to your configuration. In case this is the first time you are downloading the binaries to ESP32, pass the bootloader and the partition table directory as an argument in the second comand as instructed in the previous article from this series.

Example Execution
#

Access the serial terminal and execute the command leds. This command will run the selected example!

sudo picocom /dev/ttyUSB0 -b 115200

Congratulations! From now on you should be seeing the LED blinking! If you want to return to the terminal, reset the ESP32 by pressing the DevKit EN button. If you do not have a built-in led, connect an LED to pin 2 and associate a resistor in series (between 100 Ω to 1 k Ω).

Tip:

Run “help” or “?” to check the built-in apps like exposed in Figure 3.

Current Support Status
#

At the moment this article is written the following peripherals/features are supported:

  • Symmetric Multi-Processing (SMP)

It’s already possible to use the 2 ESP32 cores. The default configuration only uses 1 core. If you want to use both cores, access the following path in menuconfig:

-> RTOS Features -> Tasks and Scheduling

and enable the SMP option.

  • SPI
  • I2C
  • SPI Flash
  • Ethernet
  • WiFi
  • PSRAM
  • 4 Generic Timers
  • Watchdog Timers
  • Hardware Random Number Generator (RNG)
  • Low Power support (PM)

You can keep yourself updated through the following link:

https://github.com/apache/incubator-nuttx/tree/master/boards/xtensa/esp32/esp32-devkitc

Currently, the support for debugging with OpenOCD and eFUSE are in development! Sooner, they will also be available!

So, stay tuned!

Where to find support?
#

To participate in the Nuttx mail list, you can send an email to dev-subscribe@nuttx.apache.org.

For help, doubts, bugs reports, and discussion regarding NuttX, you can send an email to dev@nuttx.apache.org.

Related

ESP32 Programmers’ Memory Model
·8 mins
Esp32 Programming ESP32
Debugging Targets of idf.py
·3 mins
JTAG Idf.py ESP32 Debugger IoT
ESP32 Memory Analysis — Case Study
·11 mins
ESP32 ESP-IDF IoT Embedded Systems Memory Optimization