编译 PX4 软件
PX4 firmware can be built from source code on the console or in an IDE, for both simulated and hardware targets.
You need to build PX4 in order to use simulators, or if you want to modify PX4 and create a custom build. If you just want to try out PX4 on real hardware then load the prebuilt binaries using QGroundControl (there is no need to follow these instructions).
Before following these instructions you must first install the Developer Toolchain for your host operating system and target hardware. If you have any problems after following these steps see the Troubleshooting section below. 若要在您的计算机上获得最新的版本,请在终端中输入以下命令:
下载 PX4 源代码
The PX4 source code is stored on Github in the PX4/PX4-Autopilot repository.
To get the very latest ("main") version onto your computer, enter the following command into a terminal:
sh
git clone https://github.com/PX4/PX4-Autopilot.git --recursive
This is all you need to do just to build the latest code. If needed you can also get the source code specific to a particular release. GIT Examples provides a lot more information working with releases and contributing to PX4. 这使我们能够在进入真正的硬件和 IDE 之前验证系统设置。
初次编译(使用 jMAVSim 模拟器)
首先我们要用控制台(小黑窗)来构建一个模拟模拟目标 This allows us to validate the system setup before moving on to real hardware and an IDE.
Navigate into the PX4-Autopilot directory and start jMAVSim using the following command:
sh
make px4_sitl jmavsim
This will bring up the PX4 console below:
You may need to start QGroundControl before proceeding, as the default PX4 configuration requires a ground control connection before takeoff. This can be downloaded from here.
The drone can be flown by typing:
sh
pxh> commander takeoff
The drone can be landed by typing commander land
and the whole simulation can be stopped by doing CTRL+C (or by entering shutdown
).
Flying the simulation with the ground control station is closer to the real operation of the vehicle. Click on a location in the map while the vehicle is flying (takeoff flight mode) and enable the slider. This will reposition the vehicle.
PX4 can be used with a number of other Simulators, including Gazebo, Gazebo Classic and AirSim. These are also started with make - e.g.
sh
make px4_sitl gazebo-classic
基于NuttX / Pixhawk 的飞控板
获取特定发行版本
下面的列表是常见飞控板的生成命令:
For example, to build for Pixhawk 4 hardware you could use the following command:
sh
cd PX4-Autopilot
make px4_fmu-v5_default
A successful run will end with similar output to:
sh
-- Build files have been written to: /home/youruser/src/PX4-Autopilot/build/px4_fmu-v4_default
[954/954] Creating /home/youruser/src/PX4-Autopilot/build/px4_fmu-v4_default/px4_fmu-v4_default.px4
The first part of the build target px4_fmu-v4
indicates the target flight controller hardware for the firmware. The suffix, in this case _default
, indicates a firmware configuration, such as supporting or omitting particular features.
The _default
suffix is optional. For example, make px4_fmu-v5
and px4_fmu-v5_default
result in the same firmware. 运行成功后将输出类似结束:
The following list shows the build commands for the Pixhawk standard boards:
- Holybro Pixhawk 6X-RT (FMUv6X):
make px4_fmu-v6xrt_default
- Holybro Pixhawk 6X (FMUv6X):
make px4_fmu-v6x_default
- Holybro Pixhawk 6C (FMUv6C):
make px4_fmu-v6c_default
- Holybro Pixhawk 6C Mini (FMUv6C):
make px4_fmu-v6c_default
- Holybro Pix32 v6 (FMUv6C):
make px4_fmu-v6c_default
- Holybro Pixhawk 5X (FMUv5X):
make px4_fmu-v5x_default
- Pixhawk 4 (FMUv5):
make px4_fmu-v5_default
- Pixhawk 4 Mini (FMUv5):
make px4_fmu-v5_default
- CUAV V5+ (FMUv5):
make px4_fmu-v5_default
- CUAV V5 nano (FMUv5):
make px4_fmu-v5_default
- Pixracer (FMUv4):
make px4_fmu-v4_default
- Pixhawk 3 Pro:
make px4_fmu-v4pro_default
- Pixhawk Mini:
make px4_fmu-v3_default
- Pixhawk 2 (Cube Black) (FMUv3):
make px4_fmu-v3_default
- mRo Pixhawk (FMUv3):
make px4_fmu-v3_default
(supports 2MB Flash) - Holybro pix32 (FMUv2):
make px4_fmu-v2_default
- Pixfalcon (FMUv2):
make px4_fmu-v2_default
- Dropix (FMUv2):
make px4_fmu-v2_default
- Pixhawk 1 (FMUv2):
make px4_fmu-v2_default
WARNING
You must use a supported version of GCC to build this board (e.g. the same as used by CI/docker) or remove modules from the build. Building with an unsupported GCC may fail, as PX4 is close to the board's 1MB flash limit. 若要在您的计算机上获得最新的版本,请在终端中输入以下命令:
- Pixhawk 1 with 2 MB flash:
make px4_fmu-v3_default
Build commands for non-Pixhawk NuttX fight controllers (and for all other-boards) are provided in the documentation for the individual flight controller boards.
将固件烧录到飞控板
Append upload
to the make commands to upload the compiled binary to the autopilot hardware via USB. For example
sh
make px4_fmu-v4_default upload
并上传:
sh
Erase : [====================] 100.0%
Program: [====================] 100.0%
Verify : [====================] 100.0%
Rebooting.
[100%] Built target upload
其他飞控板
Build commands for other boards are given the board-specific flight controller pages (usually under a heading Building Firmware).
You can also list all configuration targets using the command:
sh
make list_config_targets
用图形界面 IDE 编译
VSCode is the officially supported (and recommended) IDE for PX4 development. It is easy to set up and can be used to compile PX4 for both simulation and hardware environments.
Qt Creator 功能
将固件烧录到飞控板
Many build problems are caused by either mismatching submodules or an incompletely cleaned-up build environment. Updating the submodules and doing a distclean
can fix these kinds of errors:
sh
sudo ./bin/px4 -s px4.config
OcPoC-Zynq Mini
The region 'flash' overflowed by XXXX bytes
error indicates that the firmware is too large for the target hardware platform. This is common for make px4_fmu-v2_default
builds, where the flash size is limited to 1MB.
If you're building the vanilla master branch, the most likely cause is using an unsupported version of GCC. In this case, install the version specified in the Developer Toolchain instructions.
If building your own branch, it is possibly you have increased the firmware size over the 1MB limit. In this case you will need to remove any drivers/modules that you don't need from the build.
Parrot Bebop
MacOS allows a default maximum of 256 open files in all running processes. The PX4 build system opens a large number of files, so you may exceed this number.
The build toolchain will then report Too many open files
for many files, as shown below:
sh
cd Firmware
make emlid_navio2_native # for native build
The solution is to increase the maximum allowed number of open files (e.g. to 300). You can do this in the macOS Terminal for each session:
Run this script Tools/mac_set_ulimit.sh, or
Enter this command:
shulimit -S -n 300
Qt creator 提供符号跳转、自动补全和编译固件的功能。
As of macOS Catalina 10.15.1 there may be problems when trying to build the simulator with cmake. If you have build problems on this platform then try run the following command in your terminal:
sh
xcode-select --install
sudo ln -s /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/* /usr/local/include/
基于 QuRT / Snapdragon 的飞控板
Build issues related to arm_none_eabi_gcc
may be due to a broken g++ toolchain installation. You can verify that this is the case by checking for missing dependencies using:
sh
<br />______ __ __ ___
| ___ \ \ \ / / / |
| |_/ / \ V / / /| |
| __/ / \ / /_| |
| | / /^\ \ \___ |
\_| \/ \/ |_/
px4 starting.
pxh>
Example of bash output with missing dependencies:
sh
arm-none-eabi-gdb --version
arm-none-eabi-gdb: command not found
This can be resolved by removing and reinstalling the compiler.
Ubuntu 18.04: Visual Studio Code is unable to watch for file changes in this large workspace
See Visual Studio Code IDE (VSCode) > Troubleshooting.
Failed to import Python packages
"Failed to import" errors when running the make px4_sitl jmavsim
command indicates that some Python packages are not installed (where expected).
sh
Failed to import jinja2: No module named 'jinja2'
You may need to install it using:
pip3 install --user jinja2
If you have already installed these dependencies this may be because there is more than one Python version on the computer (e.g. Python 2.7.16 Python 3.8.3), and the module is not present in the version used by the build toolchain.
You should be able to fix this by explicitly installing the dependencies as shown:
sh
pip3 install --user pyserial empty toml numpy pandas jinja2 pyyaml pyros-genmsg packaging
PX4 创建生成目标
The previous sections showed how you can call make to build a number of different targets, start simulators, use IDEs etc. This section shows how make options are constructed and how to find the available choices.
The full syntax to call make with a particular configuration and initialization file is:
sh
make [VENDOR_][MODEL][_VARIANT] [VIEWER_MODEL_DEBUGGER_WORLD]
VENDOR_MODEL_VARIANT: (also known as CONFIGURATION_TARGET
)
- VENDOR: The manufacturer of the board:
px4
,aerotenna
,airmind
,atlflight
,auav
,beaglebone
,intel
,nxp
, etc. The vendor name for Pixhawk series boards ispx4
. - MODEL: The board model "model":
sitl
,fmu-v2
,fmu-v3
,fmu-v4
,fmu-v5
,navio2
, etc. - VARIANT: Indicates particular configurations: e.g.
bootloader
,cyphal
, which contain components that are not present in thedefault
configuration. Most commonly this isdefault
, and may be omitted.
TIP
You can get a list of all available CONFIGURATION_TARGET
options using the command below:
sh
make list_config_targets
若要在您的计算机上获得最新的版本,请在终端中输入以下命令:
VIEWER_MODEL_DEBUGGER_WORLD:
- VIEWER: This is the simulator ("viewer") to launch and connect:
gz
,gazebo
,jmavsim
,none
TIP
none
can be used if you want to launch PX4 and wait for a simulator (jmavsim, Gazebo, Gazebo Classic, or some other simulator). For example, make px4_sitl none_iris
launches PX4 without a simulator (but with the iris airframe).
- MODEL: The vehicle model to use (e.g.
iris
(default),rover
,tailsitter
, etc), which will be loaded by the simulator. 环境变量PX4_SIM_MODEL
将设置为所选模型。 然后在 启动脚本 中使用该模型来选择适当的参数。 - DEBUGGER: Debugger to use:
none
(default),ide
,gdb
,lldb
,ddd
,valgrind
,callgrind
. 有关详细信息,请参阅 < 0>Simulation 调试 </0>。 - WORLD: (Gazebo Classic only). Set the world (PX4-Autopilot/Tools/simulation/gazebo-classic/sitl_gazebo-classic/worlds) that is loaded. Default is empty.world. For more information see Gazebo Classic > Loading a Specific World.
TIP
You can get a list of all available VIEWER_MODEL_DEBUGGER_WORLD
options using the command below:
sh
make px4_sitl list_vmd_make_targets
::: infos:
- Most of the values in the
CONFIGURATION_TARGET
andVIEWER_MODEL_DEBUGGER
have defaults, and are hence optional. For example,gazebo-classic
is equivalent togazebo-classic_iris
orgazebo-classic_iris_none
. - You can use three underscores if you want to specify a default value between two other settings. For example,
gazebo-classic___gdb
is equivalent togazebo-classic_iris_gdb
. - You can use a
none
value forVIEWER_MODEL_DEBUGGER
to start PX4 and wait for a simulator. For example start PX4 usingmake px4_sitl_default none
and jMAVSim using./Tools/simulation/jmavsim/jmavsim_run.sh -l
.
The VENDOR_MODEL_VARIANT
options map to particular px4board configuration files in the PX4 source tree under the /boards directory. Specifically VENDOR_MODEL_VARIANT
maps to a configuration file boards/VENDOR/MODEL/VARIANT.px4board (e.g. px4_fmu-v5_default
corresponds to boards/px4/fmu-v5/default.px4board).
Additional make targets are discussed in relevant sections:
bloaty_compare_master
: Binary Size Profiling- ...
列出所有发行版本(标签) sh git tag -l
The PX4 Firmware Version and Custom Firmware Version are published using the MAVLink AUTOPILOT_VERSION message, and displayed in the QGroundControl Setup > Summary airframe panel:
These are extracted at build time from the active git tag for your repo tree. The git tag should be formatted as <PX4-version>-<vendor-version>
(e.g. the tag in the image above was set to v1.8.1-2.22.1
).
WARNING
If you use a different git tag format, versions information may not be displayed properly. 若要在您的计算机上获得最新的版本,请在终端中输入以下命令: