This component has been tested in ESP-IDF v5.2 with ESP32, ESP32-S2, ESP32-S3, ESP32-C3 and ESP32-C6.
Note: ESP-IDF v4.4 is supported only in ROS 2 Humble and Jazzy due to Python version incompatibilities.
Dependencies
This component needs colcon and other Python 3 packages inside the IDF virtual environment in order to build micro-ROS packages:
. $IDF_PATH/export.sh pip3 install catkin_pkg lark-parser colcon-common-extensions
Middlewares available
This package support the usage of micro-ROS on top of two different middlewares:
- eProsima Micro XRCE-DDS: the default micro-ROS middleware.
- embeddedRTPS: an experimental implementation of a RTPS middleware compatible with ROS 2.
In order to select it, use idf.py menuconfig and go to micro-ROS Settings > micro-ROS middleware
Usage
You can clone this repo directly in the components folder of your project.
If you encounter issues during the build process, ensure that you are running in a clean shell environment without the ROS 2 setup script sourced.
Example
In order to test a int32_publisher example:
. $IDF_PATH/export.sh cd examples/int32_publisher # Set target board [esp32|esp32s2|esp32s3|esp32c3] idf.py set-target esp32 idf.py menuconfig # Set your micro-ROS configuration and WiFi credentials under micro-ROS Settings idf.py build idf.py flash idf.py monitor
To clean and rebuild all the micro-ROS library:
Is possible to use a micro-ROS Agent just with this docker command:
# UDPv4 micro-ROS Agent
docker run -it --rm --net=host microros/micro-ros-agent:kilted udp4 --port 8888 -v6Build with docker container
It's possible to build this example application using the official Espressif docker images, following the same steps:
docker pull espressif/idf:release-v5.2 # Run ESP-IDF container docker run --name micro-ros-espidf-component-test -it espressif/idf:release-v5.2 bash git clone https://github.com/micro-ROS/micro_ros_espidf_component.git cd micro_ros_espidf_component/ # Install dependencies pip3 install catkin_pkg lark-parser colcon-common-extensions $IDF_PATH/export.sh cd examples/int32_publisher # Set target board [esp32|esp32s2|esp32s3|esp32c3] idf.py set-target esp32 idf.py menuconfig # Set your micro-ROS configuration and WiFi credentials under micro-ROS Settings idf.py build idf.py flash idf.py monitor
Using serial transport
By default, micro-ROS component uses UDP transport, but is possible to enable UART transport or any other custom transport setting the colcon.meta like:
... "rmw_microxrcedds": { "cmake-args": [ ... "-DRMW_UXRCE_TRANSPORT=custom", ... ] }, ...
An example on how to implement this external transports is available in examples/int32_publisher_custom_transport.
Available ports are 0, 1 and 2 corresponding UART_NUM_0, UART_NUM_1 and UART_NUM_2.
Is possible to use a micro-ROS Agent just with this docker command:
# Serial micro-ROS Agent
docker run -it --rm -v /dev:/dev --privileged --net=host microros/micro-ros-agent:kilted serial --dev [YOUR BOARD PORT] -v6Purpose of the Project
This software is not ready for production use. It has neither been developed nor tested for a specific use case. However, the license conditions of the applicable Open Source licenses allow you to adapt the software to your needs. Before using it in a safety relevant setting, make sure that the software fulfills your requirements and adjust it according to any applicable safety standards, e.g., ISO 26262.
License
This repository is open-sourced under the Apache-2.0 license. See the LICENSE file for details.
For a list of other open-source components included in ROS 2 system_modes, see the file 3rd-party-licenses.txt.
Known Issues/Limitations
There are no known limitations.

