-
Notifications
You must be signed in to change notification settings - Fork 13.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Bug] PX4 doesn't have a default compiler anymore #23963
Comments
What I would like to do going forward is have the official/supported compiler version that we use for CI and to produce QGC flashable builds is to follow the current Ubuntu LTS. Unofficially I would like to keep things working back to the previous LTS version. With newer CI resources we can now afford to do a few builds across a larger matrix of distros + versions. However if/when someone hits an issue we need to point them at the supported (current LTS) environment. |
Wouldn't it just be easier to select a compiler that everyone should use? Reason I'm bringing this up because on a clean Ubuntu 24.04 it will use GCC 13.2 which fails to compile on various targets. Also do we really want to go into runtime errors caused by different compiler versions? |
We're still choosing a version that CI and production builds will use and what I will strongly recommend people use. The difference is we won't make a mess of your system trying to force an exact version of something. Another piece to be aware of is that it's more than just a specific GCC version. There are different edge cases with cmake versions, python pain, and then other random tools. The point of this is to try and be more tolerant of a wider array of setups. There have always been many people using Ubuntu versions in between an LTS, or Fedora, RHEL, Arch, etc, etc. They hit super minor things like compiler warnings or other annoyances, some of them get frustrated and waste a lot of time, others end up hacking these fixes in private and power through. Let's try to minimize the barrier to entry for PX4 development, because whether we like it or not people are doing it regardless.
It didn't happen the way I would have preferred, but things are in flux at the moment and will soon be reconciled with everything on 24.04 with packaged GCC (clean simple setup script, default px4-dev container, CI and QGC builds). On the side we'll have a minimal set of builds across all Ubuntu versions (and ideally other distros next). |
Okay that sounds reasonable to me, it's just that at the moment it's quite vague hence this issue whereas before we were fixed on GCC 9.3.1. |
Let's try to get it wrapped up this week. Do you have any specific issues to share while we're here? With the current setup script and in tree Dockerfile we're now working through validating builds and updating everything in CI. |
Some compilation errors with GCC 13.2 triggering on werror i.e.
|
Regardless of the specific version, for the compiler we recommend and use in the CI, I would like to see the official ARM compiler used. That ensures that on different host platforms ({Windows, Linux, Darwin} x {Intel, ARM}), the exact same compiler version is used with the exact same patches. |
Just a quick note. I have been using GCC 13 since months as I did not want to use the old GCC 9. GCC 13 also has the advantage of using less FLASH for the same build. |
|
@dagar can we pick a new number/version of GCC going forward? It seems that V6X-RT has some weird startup issues with the newer GCC compilers (10.3, 13.2) whereas GCC 9.3.1 works fine. I want to look into this issue, however I don't want to debug all potential compiler versions, would be nice to bump the version of GCC and match CI/Releases with that. |
Agreed, we will be picking a default compiler as a minimum version once things settle on our end with CI. |
Just wanted to quickly add a few more comparisons between the GCC9 used by the CI and a local GCC13.3.1 (from ARM). FLASH (v5x)
FLASH (v6x)
CPU LOAD (v5x)
The results are very similar here, indicating that the FLASH savings are not gained by a space-time tradeoff. |
Describe the bug
#23869 removes the installation of GCC 9.3.1
Instead install OS provided GCC.
Now we're all using different compilers
https://launchpad.net/ubuntu/+source/gcc-arm-none-eabi
To Reproduce
No response
Expected behavior
No response
Screenshot / Media
No response
Flight Log
No response
Software Version
No response
Flight controller
No response
Vehicle type
None
How are the different components wired up (including port information)
No response
Additional context
No response
The text was updated successfully, but these errors were encountered: