Skip to content

Global Navigation Satellite Systems (GNSS)

A GNSS system is needed for missions, and some other automatic and manual/assisted modes. PX4 supports Global Navigation Satellite Systems (GNSS) such as GPS, GLONASS, Galileo, Beidou, QZSS and SBAS, etc. using receivers that communicate via the u-blox, MTK Ashtech or Emlid protocols, or via UAVCAN.

Up to two GPS modules can be connected using either a UART or the CAN bus:

GPS + Compass

INFO

PX4 also supports Real Time Kinematic (RTK) and Post-Processing Kinematic (PPK) GNSS Receivers, which extend GNSS systems to centimetre-level precision.

Supported GNSS

PX4 should work with any unit that communicates via the u-blox, MTK Ashtech or Emlid protocols, or via UAVCAN.

This table contains non-RTK GNSS units (most of which also have a compass). These have been tested by the PX4 dev team, or which are popular within the PX4 community.

DeviceGPSCompassCANBuzzer / SafeSw / LEDNotes
ARK GPSM9NICM42688p+ Baro, IMU
Avionics Anonymous UAVCAN GNSS/MagSAM-M8QMMC5983MA
CUAV NEO 3 GPSM9NIST8310
CUAV NEO 3 Pro GPSM9NRM3100+ Baro
CUAV NEO 3X GPSM9NRM3100✗✓✓+ Baro.
CubePilot Here2 GNSS GPS (M8N)M8NICM20948Superseded by HERE3
Emlid Reach M+Supports PPK. RTK expected.
Holybro DroneCAN M8N GPSM8NBMM150+ Baro
Holybro Micro M8N GPSM8NIST8310
Holybro Nano Ublox M8 5883 GPSUBX-M8030QMC5883
Holybro M8N GPSM8NIST8310
Holybro M9N GPSM9NIST8310
Holybro DroneCAN M9N GPSM9NBMM150
Hobbyking u-blox Neo-M8N GPS & CompassM8N
LOCOSYS Hawk A1 GNSS receiverMC-1612-V2boptional✗✗✓
LOCOSYS Hawk R1MC-1612-V2b✗✗✓
LOCOSYS Hawk R2MC-1612-V2bIST8310✗✗✓
mRo GPS u-blox Neo-M8N Dual CompassM8NLIS3MDL, IST8308
RaccoonLab L1 GNSS NEO-M8NNEO-M8NRM3100✗✗✓+ Baro
Sky-Drones SmartAP GPSM8NHMC5983, IST8310, LIS3MDL+ Baro
Zubax GNSS 2MAX-M8QLIS3MDL+ Baro

Notes:

  • ✓ 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).
  • The list may omit some discontinued hardware that is still supported (check earlier versions for info about discontinued modules). Removed items include:
    • Here GPS
    • Drotek DP0804

Mounting the GNSS/Compass

Most GNSS modules also contain a compass/magnetometer part (see link for calibration/setup information). Because of this the GNSS module should be mounted as far away from the motor/ESC power supply lines as possible - typically on a pedestal or wing (for fixed-wing).

Mounting the Compass explains how to mount a GNSS module that has a compass.

Hardware Setup

The hardware setup depends on the flight controller, the GNSS module, and the connection bus it supports - UART/I2C or CAN.

Pixhawk Standard Connectors

Connecting GNSS/Compass modules is easiest when using a flight controller that supports the Pixhawk connector standard. All flight controllers that follow this standard, including most Pixhawk Standard controllers (and many others) use the same port connectors and wiring for connecting GNSS modules. Because of this standardization, many popular GNSS/Compass modules plug directly into the flight controller "out of the box".

If you're using GNSS/Compass modules that connect via generic UARTs and serial protocols like I2C:

  • The primary GNSS/Compass module should be connected to the 10-pin port labelled GPS1, GPS&SAFETY, or GPS (this is port described as "Full GPS + Safety Switch Port" in the connector standard). The GPS should incorporate a buzzer, safety switch, and UI LED.
  • An (optional) secondary module can be connected to the 6-pin GPS2 port, if present (this is "Basic GPS Port" in the standard).
  • The ports are generally plug-n-play for u-blox modules (only).

INFO

The ports include a UART for the GNSS and an I2C port for connecting the Compass. The "Full GPS + Safety Switch Port" includes additional I2C connectors for LEDs, buzzer and safety switch. There is nothing to stop you from connecting the GPS pins to any other free UART as a GNSS port, and the compass or buzzer to an I2C port. However if you do this then you will need to configure the ports.

For DroneCAN GNSS/compass modules:

  • DroneCan GPS modules are connected to CAN-bus ports, which are 4-pin ports labeled CAN1 or CAN2.

Other Flight Controllers/GNSS Modules

If you're working with a flight controller and GNSS module combination that does not comply with the Pixhawk connector standard then you will need to pay particular attention to the connector pinouts on the flight controller and the module. You may need to rewire/solder the connectors.

WARNING

Some flight controllers use ports that are software-compatible but not connector compatible (even if they use the same connector!) because they use different pin orderings.

The pinouts for the connector standard are documented in the standard. Pinouts for other controllers and the GNSS modules should be included in their manufacturer documentation.

GNSS Configuration

The default configuration for GPS module connected via the GPS serial port is provided below. Additional device-specific configuration may be provided in PX4 or manufacturer device documentation (e.g. Trimble MB-Two > Configuration).

Primary GPS Configuration (UART)

Primary GPS configuration on Pixhawk is handled transparently for U-Blox GPS modules — simply connect the GPS module to the port labeled GPS1, GPS&SAFETY, or GPS (if there is only one GPS port), and everything should work.

The default Serial Port Configuration configures GPS1 as a GPS port using GPS_1_CONFIG, sets the protocol to u-blox with GPS_1_PROTOCOL, and a baud rate of 0: Auto with SER_GPS1_BAUD.

For GPS types like Trimble, Emlid, MTK, you will need to change the GPS_1_PROTOCOL appropriately. For Trimble MB-Two you will also need to modify SER_GPS1_BAUD to set the rate to 115200 baud.

Secondary GPS Configuration (UART)

To use a secondary GPS, you will generally attach it to the port named GPS2, if present, and otherwise attach it to any free UART port. The port may be pre-configured, but unlike the primary port, this is not guaranteed.

To ensure the port is set up correctly 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 GPS 2 port in QGroundControl:

  1. Find and set the parameter GPS_2_CONFIG to GPS 2.

    • Open QGroundControl and navigate to the Vehicle Setup > Parameters section.

    • Select the GPS tab, then open the GPS_2_CONFIG parameter and select GPS 2 from the dropdown list.

      QGC Serial Example

  2. Reboot the vehicle in order to make the other parameters visible.

  3. Select the Serial tab, and open the SER_GPS2_BAUD parameter (GPS 2 port baud rate): set it to Auto (or 115200 for the Trimble).

    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.

DroneCAN GNSS Configuration

DroneCAN GNSS configuration is covered in the linked document (and in the documentation for specific modules).

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. This is documented in RTK GPS > Configuring GPS as Yaw/Heading Source.

Compass Configuration

Compass calibration for an included compass part is covered in: Compass Configuration.

GNSS Data Overview

PX4 uses the subset of information that can be provided by most GNSS modules. This is written to the SensorGps uORB message and used by the estimator as an input to global position estimation. It is also streamed via MAVLink using messages such as GPS_RAW_INT and GPS2_RAW.

Some of GNSS terms that are useful for interpreting the data include:

  • DOP: Dilution of position (dimensionless). This is a measure of the geometric quality of satellite positions and their effect on the precision of the GPS receiver's calculations.
  • EPH: Standard deviation of horizontal position error (metres). This represents the the uncertainty in the GPS fix latitude and longitude.
  • EPV: Standard deviation of vertical position error (metres). This represents the the uncertainty in the GPS fix altitude.

DOP vs EPH/EPV

DOP is a measure of the potential for high accuracy based on satellite positions. EPH/EPV are more comprehensive: they are direct estimates of the GPS position error and consider both satellite geometry and other error sources like signal noise and atmospheric effects. It is possible to have low DOP (good satellite geometry) but still have high EPH/EPV if there is significant signal noise or atmospheric interference.

EPH/EPV values therefore provide a more immediate and practical estimate of the actual GPS accuracy you can expect under current conditions.

Developer Information