# GPS & Compass

PX4 supports global navigation satellite systems (GNSS) (including GPS, GLONASS, Galileo, BeiDou, QZSS and SBAS) using receivers that communicate via the u-blox, MTK Ashtech or Emlid protocols, or via UAVCAN. It also supports Real Time Kinematic (RTK) GPS Receivers, which extend GPS systems to centimetre-level precision.

PX4 can be used with the following compass parts (magnetometers): Bosch BMM 150 MEMS (via I2C bus), HMC5883 / HMC5983 (I2C or SPI), IST8310 (I2C) and LIS3MDL (I2C or SPI). Up to 4 internal or external magnetometers can be connected, though only one will actually be used as a heading source.

The system automatically chooses the best available compass based on their priority (external magnetometers have a higher priority than internal magnetometers). If the primary compass fails in-flight, it will failover to the next one. If it fails before flight, arming will be denied.

GPS + Compass

TIP

When using Pixhawk-series flight controllers, we recommend using a combined GPS + Compass mounted as far away from the motor/ESC power supply lines as possible - typically on a pedestal or wing (for fixed-wing). The internal compass may be useful on larger vehicles (e.g. VTOL) where it is possible to reduce electromagnetic interference by mounting the Pixhawk a long way from power supply lines. On small vehicles an external compass is almost always required.

# Supported GNSS and/or Compass

PX4 should work with any unit that communicates via the u-blox, MTK Ashtech or Emlid protocols, or via UAVCAN. This list contains GNSS/Compass units that have been tested by the PX4 dev team, or which are popular within the PX4 community.

Device GPS Compass RTK GPS Yaw Output Dual FP9 GPS Heading
Avionics Anonymous UAVCAN GNSS/Mag (opens new window) SAM-M8Q MMC5983MA
Avionics Anonymous UAVCAN Magnetometer (opens new window)
CUAV C-RTK GPS M8P/M8N
CubePilot Here2 GNSS GPS (M8N) M8N ICM20948
CubePilot Here+ RTK GPS M8P HMC5983
CubePilot Here3 CAN GNSS GPS (M8N) (opens new window) M8N ICM20948
Drotek DP0804 (opens new window) (and other Drotek u-blox GPS/Compasses (opens new window)) M9N LIS3MDL
Drotek SIRIUS RTK GNSS ROVER (F9P) (opens new window) F9P RM3100
Drotek XL RTK GPS M8U LIS3MDL
Emlid Reach M+ (opens new window) - PX4 only supports "ordinary" GPS with this module. RTK support is expected in the near future.
Femtones MINI2 Receiver FB672, FB6A0
Freefly RTK GPS F9P IST8310
Holybro Micro M8N GPS Module (opens new window) M8N IST8310
Holybro Nano Ublox M8 5883 GPS Module (opens new window) UBX-M8030 QMC5883
Holybro Pix32 M8N GPS Module (opens new window) M8N IST8310
Holybro Pixhawk 4 GPS Module (10 pin) (opens new window) M8N IST8310
Holybro Pixhawk 4 2nd GPS Module (6 pin) (opens new window) M8N IST8310
Holybro H-RTK F9P GNSS F9P IST8310
Holybro H-RTK M8P GNSS M8P IST8310
Hobbyking u-blox Neo-M8N GPS with Compass (opens new window) M8N
mRo GPS u-blox Neo-M8N Dual Compass (opens new window) M8N LIS3MDL, IST8308
mRo u-blox ZED-F9 RTK L1/L2 GPS (opens new window) F9P
SparkFun GPS-RTK2 Board - ZED-F9P (opens new window) F9P
Trimble MB-Two F9P
Zubax GNSS 2 (opens new window) MAX-M8Q LIS3MDL

Note

  • ✓ or a specific part number indicate that a features is supported, while ✗ or empty show that the feature is not supported. "?" indicates "unknown".
  • Where possible and relevant the part name is used (i.e. ✓ in the GPS column indicates that a GPS module is present but the part is not known).
  • Avionics Anonymous UAVCAN Magnetometer (opens new window) is a compass (not a GPS).
  • Some RTK modules can only be used in a particular role (base or rover), while others can be used interchangeably.
  • The list may omit some discontinued hardware that is still supported. For example CubePilot Here+ RTK GPS is discontinued and may be removed from the list in a future release. The original Here has already been removed. Check earlier versions if a discontinued module is not mentioned here.

# Hardware Setup

Instructions for connecting the GPS (and compass, if present) are usually provided by the manufacturer (at least for more common Autopilot Hardware).

Pixhawk Series controllers typically have a clearly labeled port for connecting the GPS, and the compass is connected to either the I2C or SPI port/bus (depending on the device).

The Zubax GNSS 2 (opens new window), CubePilot Here3 CAN GNSS GPS (M8N) (opens new window), and Avionics Anonymous GNSS/Mag (opens new window) can also be connected via UAVCAN.

WARNING

Pay attention to pinout when connecting the GPS module. While these are all software-compatible, there are several different pin orderings.

# GNSS Configuration

The "standard" GPS configuration is provided below. Additional device-specific configuration may be provided in PX4 or manufacturer device documentation (e.g. Trimble MB-Two > Configuration).

WARNING

The GPS protocol expected by PX4 defaults to u-blox (by default other GPS types like Trimble, Emlid, MTK, will not be detected) The protocol can be configured with GPS_x_PROTOCOL.

# Configuring the Primary GPS

GPS configuration on Pixhawk is handled transparently for the user - simply connect the GPS module to the port labeled GPS and everything should work.

Note

The default Serial Port Configuration works for most devices. If you are using the Trimble MB-Two you will need to modify the configuration to explicitly set the rate to 115200 baud.

# Configuring a Secondary GPS (Dual GPS System)

To use a secondary GPS, attach it to any free port, and then perform a Serial Port Configuration to assign GPS_2_CONFIG to the selected port.

The following steps show how to configure a secondary GPS on the TELEM 2 port in QGroundControl:

  1. Find and set the parameter GPS_2_CONFIG to TELEM 2.
    • Open QGroundControl and navigate to the Vehicle Setup > Parameters section.
    • Select the GPS tab (1), then open the GPS_2_CONFIG parameter (2) and select TELEM 2 from the dropdown list (3). QGC Serial Example
  2. Reboot the vehicle in order to make the other parameters visible.
  3. Select the Serial tab, and open the SER_TEL2_BAUD parameter (TELEM 2 port baud rate): set it to Auto. QGC Serial Baudrate Example

After setting up the second GPS port:

  1. Configure the ECL/EKF2 estimator to blend data from both GPS systems. For detailed instructions see: Using the ECL EKF > Dual Receivers.

# Configuring GPS as Yaw/Heading Source

GPS can be used as a source for yaw fusion when using modules where yaw output is supported by the device (e.g. Trimble MB-Two) or when using some RTK GPS Setups with Dual u-blox F9P.

When using GPS for yaw fusion you will need to configure the following parameters:

Parameter Setting
GPS_YAW_OFFSET The angle made by the baseline (the line between the two GPS antennas) relative to the vehicle x-axis (front/back axis, as shown here).
EKF2_AID_MASK Set bit position 7 "GPS yaw fusion" to 1 (i.e. add 128 to the parameter value).

TIP

If using this feature, all other configuration should be setup up as normal (e.g. RTK Positioning).

# Compass Configuration

Compass calibration is covered in: Compass Configuration. The process is straightforward and will autodetect, calibrate and prioritise all connected magnetometers.

Further compass configuration should generally not be required.

Note

All external compasses are given the same priority by default, which is higher than the prority shared by all internal compasses.

# Disable a Compass

As stated above, generally no further configuration should be required.

That said, developers can disable internal compasses if desired using the compass parameters. These are prefixed with CAL_MAGx_ (where x=0-3).

To disable an internal compass:

  • Use CAL_MAGn_ROT to determine which compasses are internal. A compass is internal if CAL_MAGn_ROT==1.
  • Then use CAL_MAGx_PRIO to disable the compass. This can also be used to change the relative priority of a compass.

# Developer Information