This repository contains a set of scripts and patches intended to simplify the building of a Zephyr image with a Micro-ROS application. It currently has the ability to build applications that use UDP over WiFi for transport on the following microcontroller boards: Raspberry Pi Pico W, ESP32, and ESP32c3. Other transport methods and board types should be possible with minor modifications.
app defaults to ping_pong
board defaults to rpi_pico_w (other options that have been tested are: esp32_devkitc_wroom, esp32c3_devkitm).
The setup script calls install_microros.sh which clones the necessary repositories and applies local patches to them.
The setup script then clones the ping_pong app from the repo.
The setup script then builds the chosen application and also creates and builds mircro_ros_agent. The agent is a ROS2 application that runs on your build machine and acts as a gateway between the microcontroller devices running Micro-ROS applications and larger devices running ROS2 applications.
To use in the root of your target directory run
setup.sh -a <app> -b <board>
The procedure described in "Option 1" should work in a clean Ubuntu 22.04 install, but may not work in other variants of Linux or in an Ubuntu 22.04 that has been modified such that it's environment is not compatible. This docker build should solve most of those problems, and will probably even allow you to build in an OS other than Linux with minor changes (it is known to work in Mac OS, for example, provided that the environment variable HOME is changed from "/home/{username}" to "/Users/{username}"). The docker container can also be used to run the micro-ROS agent, but docker run will need to be run with a -p 8888:8888 argument in order for the agent's UDP port to be visible outside of the container.
To build in a docker container, run this script and follow the instructions in its output:
./docker_setup.sh
Once the initial setup and build has been completed, ros2 commands can be used to rebuild the applicaton and image. The procedure is the same regardless of whether you're building within Docker. To modify and rebuild the app make sure that you source these two files:
source /opt/ros/\$ROS_DISTRO/setup.bash
source install/local_setup.bash
You can then build your app with the command:
ros2 run micro_ros_setup build_firmware.sh