Skip to content

espressif/esp-iot-solution

Repository files navigation

Documentation Status

Try it with ESP Launchpad

Espressif IoT Solution Overview

ESP-IoT-Solution contains device drivers and code frameworks for the development of IoT systems, providing extra components that enhance the capabilities of ESP-IDF and greatly simplify the development process.

ESP-IoT-Solution contains the following contents:

  • Device drivers for sensors, display, audio, input, actuators, etc.
  • Framework and documentation for Low power, security, storage, etc.
  • Guide for espressif open source solutions from practical application point.

Documentation Center

Quick Reference

Development Board

You can choose any of the ESP series development boards to use ESP-IoT-Solution or choose one of the boards supported in boards component for a quick start.

Powered by 40nm technology, ESP series SoC provides a robust, highly integrated platform, which helps meet the continuous demands for efficient power usage, compact design, security, high performance, and reliability.

Setup Environment

Setup ESP-IDF Environment

ESP-IoT-Solution is developed based on ESP-IDF functions and tools, so ESP-IDF development environment must be set up first, you can refer Setting up Development Environment for the detailed steps.

Please note that different versions of ESP-IoT-Solution may depend on different versions of ESP-IDF, please refer to the below table to select the correct version:

ESP-IoT-Solution Dependent ESP-IDF Major Change User Guide Support State
master >= v5.3 New Chips Support Docs online New features
release/v2.0 <= v5.3, >= v4.4 Support component manager Docs online Bugfix only,until v5.3 EOL
release/v1.1 v4.0.1 IDF version update, remove no longer supported code v1.1 Overview archived
release/v1.0 v3.2.2 legacy version v1.0 Overview archived

Since the master branch uses the ESP Component Manager to manager components, each of them is a separate package, and each package may support a different version of the ESP-IDF, which will be declared in the component's idf_component.yml file

Get Components from ESP Component Registry

If you just want to use the components in ESP-IoT-Solution, we recommend you use it from the ESP Component Registry.

The registered components in ESP-IoT-Solution are listed below:

Component Version
aht20 Component Registry
apds9960 Component Registry
at581x Component Registry
avi_player Component Registry
ble_anp Component Registry
ble_conn_mgr Component Registry
ble_hci Component Registry
ble_hrp Component Registry
ble_htp Component Registry
ble_ota Component Registry
ble_services Component Registry
bme280 Component Registry
bootloader_support_plus Component Registry
button Component Registry
cmake_utilities Component Registry
drv10987 Component Registry
elf_loader Component Registry
esp_lcd_axs15231b Component Registry
esp_lcd_ek79007 Component Registry
esp_lcd_gc9b71 Component Registry
esp_lcd_hx8399 Component Registry
esp_lcd_jd9165 Component Registry
esp_lcd_jd9365 Component Registry
esp_lcd_nv3022b Component Registry
esp_lcd_panel_io_additions Component Registry
esp_lcd_sh8601 Component Registry
esp_lcd_spd2010 Component Registry
esp_lcd_st7701 Component Registry
esp_lcd_st7703 Component Registry
esp_lcd_st77903_qspi Component Registry
esp_lcd_st77903_rgb Component Registry
esp_lcd_st77916 Component Registry
esp_lcd_st77922 Component Registry
esp_lcd_touch_ili2118 Component Registry
esp_lcd_touch_spd2010 Component Registry
esp_lcd_touch_st7123 Component Registry
esp_lcd_usb_display Component Registry
esp_lv_decoder Component Registry
esp_lv_fs Component Registry
esp_mmap_assets Component Registry
esp_msc_ota Component Registry
esp_sensorless_bldc_control Component Registry
esp_simplefoc Component Registry
esp_tinyuf2 Component Registry
extended_vfs Component Registry
gprof Component Registry
hdc2010 Component Registry
i2c_bus Component Registry
ina236 Component Registry
iot_usbh Component Registry
iot_usbh_cdc Component Registry
iot_usbh_modem Component Registry
ir_learn Component Registry
keyboard_button Component Registry
knob Component Registry
led_indicator Component Registry
lightbulb_driver Component Registry
lis2dh12 Component Registry
max17048 Component Registry
mcp23017 Component Registry
mcp3201 Component Registry
mvh3004d Component Registry
ntc_driver Component Registry
openai Component Registry
power_measure Component Registry
pwm_audio Component Registry
sensor_hub Component Registry
servo Component Registry
sht3x Component Registry
spi_bus Component Registry
touch_proximity_sensor Component Registry
usb_device_uac Component Registry
usb_device_uvc Component Registry
usb_stream Component Registry
veml6040 Component Registry
veml6075 Component Registry
xz Component Registry
zero_detection Component Registry

You can directly add the components from the Component Registry to your project by using the idf.py add-dependency command under your project's root directory. eg run idf.py add-dependency "espressif/usb_stream" to add the usb_stream, the component will be downloaded automatically during the CMake step.

Please refer to IDF Component Manager for details.

Get ESP-IoT-Solution Repository

If you want to Contribute to the components in ESP-IoT-Solution or want to start from the examples in ESP-IoT-Solution, you can get the ESP-IoT-Solution repository by following the steps:

  • If select the master version, open the terminal, and run the following command:

    git clone --recursive https://github.com/espressif/esp-iot-solution
    
  • If select the release/v2.0 version, open the terminal, and run the following command:

    git clone -b release/v2.0 --recursive https://github.com/espressif/esp-iot-solution
    

Build and Flash Examples

We highly recommend you Build Your First Project to get familiar with ESP-IDF and make sure the environment is set up correctly.

There is no difference between building and flashing the examples in ESP-IoT-Solution and in ESP-IDF. In most cases, you can build and flash the examples in ESP-IoT-Solution by following the steps:

  1. Change the current directory to the example directory, eg cd examples/usb/host/usb_audio_player.
  2. Run idf.py set-target TARGET to set the target chip. eg idf.py set-target esp32s3 to set the target chip to ESP32-S3.
  3. Run idf.py build to build the example.
  4. Run idf.py -p PORT flash monitor to flash the example, and view the serial output. eg idf.py -p /dev/ttyUSB0 flash monitor to flash the example and view the serial output on /dev/ttyUSB0.

Some examples may need extra steps to setup the ESP-IoT-Solution environment, you can run export IOT_SOLUTION_PATH=~/esp/esp-iot-solution in Linux/MacOS or set IOT_SOLUTION_PATH=C:\esp\esp-iot-solution in Windows to setup the environment.

Resources