This repository contains all components necessary to create a minimal working example of communication between an STM32F767ZI using embeddedRTPS and a Linux system using FastRTPS. This repository contains two projects:
- The first project in the
stm32
folder is a STM32CubeIDE project which uses EmbeddedRTPS and is deployed to the STM32Nucleo-F767ZI. - The second project in the
linux
folder is a C++ project that uses eProsima FastRTPS for the Linux system.
When both of these projects are executed, the Linux system will send RTPS messages with test data to the STM32F407, to which the STM32F767ZI will then respond. This simple communication test is executed 10 times.
The main embeddedRTPS repository is located here.
To compile the project for the STM32, install the following Software:
- STM32CubeIDE
- st-stlink-server.1.2.0-5.1 (Provided with the IDE)
To compile the project for Linux, install the following Software:
Packages to install using apt-get:
sudo apt-get -y update && apt-get -y upgrade
sudo apt-get install -y \
software-properties-common \
libboost-all-dev \
libssl-dev \
build-essential \
cmake \
After installing the required dependencies, both projects can first cloned and compiled using the following instructions:
git clone --recursive https://github.com/embedded-software-laboratory/embeddedRTPS-STM32
To compile and deploy the STM32 project, first open the STM32CubeIDE.
File -> Open projects from File System -> Directory -> Select the stm32 Folder
Then press finish to import the project into your local workspace.
Now select the project in the project explorer:
Project Explorer -> embedded_rtps_stm32
After selecting the process, right click the hammer button in the navigation bar. This opens the menu to select the build configuration:
- debug: The debug configuration compiles the code with debug symbols and lowers optimization for debugging.
- release: This configuration disables debug symbols and increases optimizations to maximum.
The selected configuration is then compiled by STM32CubeIDE.
The STM32 should now be connected to the linux computer using a micro-USB cable. The cable should be plugged into a USB socket on your computer and into the debugger side of the STM32 Nucleo board.
The compiled configuration can then be flashed on to the STM32 in the following steps:
Navigation bar -> Run -> Debug
It might now be necessary to select the target, in which case "STM32 Application" should be selected. The IDE will then flash the STM32 with your selected configuration.
- The IDE may prompt you to update the firmware of the onboard ST-Link debugger, this is normal and you can follow the process to update the firmware to the newest version.
- The IDE may also ask you to switch to the Run/Debug display after flashing a configuration to the STM32, this is the debug screen of the IDE and thus usefull to see the current callstack and more.
To compile the Linux project navigate to the linux folder. Then compile the CMakeLists project using the following commands:
cd stm32 \
mkdir build \
cd build \
cmake -DTHIRDPARTY=ON .. \
make
The resulting executable can then be found in the build directory and is called embedded_rtps_test
.
After compiling both projects the communication between both devices can be tested. To conduct this test follow these steps:
- Connect the STM32 to your computer using a ethernet cable.
- Ensure all firewalls are disable. (probably an OSX issue)
- Manually assign an IP address (and subnet mask) to the STM32.
(for example: IP:192.168.0.1, subnet: 255.255.255.0) - (It may be necessary to disable other network connections, like wifi, if the chosen IP address is in your local network, necessary with the example adresses provided here.)
- Flash a configuration to the STM32 and run it.
- The debugger will halt on the first line of the main method, press either F8 or the Resume button.
- The STM32 should now wait for a subscriber match (to verify this flash the debug configuration and execute steps one and two, then halt the debugger after a couple of seconds after clicking resume in step 2, the debugger should halt on line 495).
- Execute the
embedded_rtps_test
executable in the linux/build folder. - The executable will then send test data to the STM32 and the STM32 should respond to by returning other test data of the following form:
Received message from STM32 with len:10
0 : 10
1 : 10
2 : 10
3 : 10
4 : 10
5 : 10
6 : 10
7 : 10
8 : 10
9 : 10
The first component is the byte index while the second component is the value. As the test code sets all values in the test array to 10, this is the expected output.