2024-12-09 08:02 AM
Scenario: I am using STM32CubeMX (v6.13.0) to generate the necessary project files for a default STM32U5A9J-DK project with ThreadX enabled. The project files are copied into a docker container and built with cmake. Building and debugging in the container works until I attempt to add the ThreadX middleware. Outside of the container building and debugging with STM32CubeIde is not an issue.
Problem: The STM32CubeMX generated project files are not sufficient to compile a ThreadX program. Undefined reference problems flood the output.
Debug:
1) I have tried combinations of the settings in STM32CubeMX including: "Generate Under Root," "Enable multi-threaded support," and "copy all used libraries into the project folder" to no avail. My cmake program recursively adds all .h, .c, and .s/.S files as sources or include paths as appropriate in the project folder, so all generated files are always used.
2) I attempted to resolve the undefined issues by manually adding the source files missing from the firmware package STM32Cube_FW_U5_V1.7.0. I pull down the repository from git during my container setup. First, I included all files in the package. This was unsuccessful and resulted in errors. Next, I included only necessary files and directories, viewed the remaining dependencies, and repeated the process. This was a painful and undesirable tactic, and did not solve the problem either. A file that did not exist in the firmware package was referenced. Because ThreadX functions outside of the container referencing the same firmware package, I do not understand how to reference all the required files and why the option to "copy all used libraries into the project folder" fails for this middleware.
Please send support on resolving this issue. I am hoping I am unaware of the proper way to access the needed files. I can send more information on specific errors as desired.
Note: FreeRTOS was previously used in a similar fashion with a STM32H7 uC in a docker container without issue due to all necessary files being generated. However with the STM32U5 I must use LevelX and USB operations, so ThreadX is the natural choice and I do not want to run into the same missing files issues when I add the LevelX and USB middlewares to the project. Thanks!
2024-12-11 05:53 AM
Hello @nlippitt ,
Can you send the output message and the include paths for the failing project.
Also, can you specify the exact way you pulled the repository from GitHub as missing the --recursive option can lead to missing middleware files as they are not part of the same repository.
Regards
2024-12-11 05:56 AM
@STea wrote:specify the exact way you pulled the repository from GitHub as missing the --recursive option can lead to missing middleware files
@nlippitt see: https://community.st.com/t5/stm32-mcus/downloading-stm32cube-packages-from-github-correctly/ta-p/725288
2024-12-23 08:14 AM
Without cloning the repository and using only the generated files, I get the following errors:
When I clone the repository using:
"git clone --recursive "https://github.com/STMicroelectronics/STM32CubeU5.git" "
"git pull"
"git submodule update --init --recursive"
I get the errors: (Cropped for visibility)
My CMakeLists.txt uses lists of include directories and source files generated from a Python script that recursively starts from a base directory and adds all directories with .h files as include directories and all .c .s and .S files as source files where .s and .S files have property appended for "assembler-with-cpp" This setup works without any errors without cloning the STM32CubeU5 repository when ThreadX is not used and I am able to run and debug firmware within VSCode. I need this functionality to continue working when middlewares are added.
In the first scenario only the temp_fw/stm32_dev_fw base directory is used. In the second scenario both temp_fw/stm32_dev_fw and the git cloned STM32CubeU5 base directories are used. For example, in the second scenario these are the include paths. (Cropped for visibility)
2024-12-23 08:26 AM
It's better to post the messages as text - not screenshots:
2024-12-30 06:47 AM
Hello @nlippitt ,
did you manage to solve this compiling issue. are you sure you are getting the complete Cubefirmware package from GitHub some components or files might be missing if you don't use the option -- recursive in the git clone command.
Regards
2024-12-30 07:03 AM
Yes I am still having the same problem. And yes I am using the recursive option. Please see my previous message for more details.
2025-01-21 11:44 PM - edited 2025-01-21 11:54 PM
I am no docker expert but I just generated an STM32U575 project for CMake (NOT STM32CubeIDE) with threadx and the container project built just fine.
You mentioned " debugging with STM32CubeIde is not an issue."
Can you try to NOT use the CubdeIDE project in docker, instead, for testing purposes build a simple STM32U5 project with threadX but make the toolchain be CMake. See if that works. If it does then the CubeIDE project might be using some external dependency from the IDE or IDE might be caching something in its own env im not sure, I could be just talking nonsense, like I said never used docker before but did get it to work just now on Ubuntu (See logs in attached file and docker file below)
# Use a lightweight Ubuntu base image
FROM ubuntu:latest
# Install dependencies
RUN apt-get update && apt-get install -y \
build-essential \
gcc-arm-none-eabi \
openocd \
cmake \
git \
python3 \
python3-pip \
&& apt-get clean
# Copy the STM32 project into the container
COPY u5-test /workspace/u5-test
# Set up the working directory
WORKDIR /workspace/u5-test
# Default command to run a shell
CMD ["/bin/bash"]
2025-01-27 09:29 AM
One problem seems to be in the code generation for my specific evaluation board. I can replicate generating a project with cmake for a generic STM32U575 microcontroller. However, when I attempt to generate a project from CubeMX for STM32U5A9J-DK evaluation board with the same settings (cmake, ThreadX, cortex m33 support, and all library files included) I get error notifications from CubeMX that "CMakeproject generation have a problem." My cmake project files unsurprisingly fail. I have checked that there are no updates in CubeMX for the U5 firmware and I am using the latest version of CubeMX.
2025-01-27 07:16 PM
So to clarify, generating as Cmake project based off the MCU works with your container, but generating based off the dev kit does not work?
This sounds like perhaps some BSP related modules are not being imported or something. I will try making a project based off your devkit.