mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 10:28:29 -04:00
AP_GPS: fixed GPS to UART mapping
this allows for first GPS as UAVCAN and 2nd as UART. That is not possible currently unless you waste a uart
This commit is contained in:
parent
a5e79f4231
commit
b19ad689a6
@ -301,14 +301,33 @@ AP_GPS::AP_GPS()
|
|||||||
_singleton = this;
|
_singleton = this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// return true if a specific type of GPS uses a UART
|
||||||
|
bool AP_GPS::needs_uart(GPS_Type type) const
|
||||||
|
{
|
||||||
|
switch (type) {
|
||||||
|
case GPS_TYPE_NONE:
|
||||||
|
case GPS_TYPE_HIL:
|
||||||
|
case GPS_TYPE_UAVCAN:
|
||||||
|
case GPS_TYPE_MAV:
|
||||||
|
return false;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/// Startup initialisation.
|
/// Startup initialisation.
|
||||||
void AP_GPS::init(const AP_SerialManager& serial_manager)
|
void AP_GPS::init(const AP_SerialManager& serial_manager)
|
||||||
{
|
{
|
||||||
primary_instance = 0;
|
primary_instance = 0;
|
||||||
|
|
||||||
// search for serial ports with gps protocol
|
// search for serial ports with gps protocol
|
||||||
|
uint8_t uart_idx = 0;
|
||||||
for (uint8_t i=0; i<GPS_MAX_RECEIVERS; i++) {
|
for (uint8_t i=0; i<GPS_MAX_RECEIVERS; i++) {
|
||||||
_port[i] = serial_manager.find_serial(AP_SerialManager::SerialProtocol_GPS, i);
|
if (needs_uart((GPS_Type)_type[i].get())) {
|
||||||
|
_port[i] = serial_manager.find_serial(AP_SerialManager::SerialProtocol_GPS, uart_idx);
|
||||||
|
uart_idx++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
_last_instance_swap_ms = 0;
|
_last_instance_swap_ms = 0;
|
||||||
|
|
||||||
|
@ -566,6 +566,8 @@ private:
|
|||||||
|
|
||||||
bool should_log() const;
|
bool should_log() const;
|
||||||
|
|
||||||
|
bool needs_uart(GPS_Type type) const;
|
||||||
|
|
||||||
// Auto configure types
|
// Auto configure types
|
||||||
enum GPS_AUTO_CONFIG {
|
enum GPS_AUTO_CONFIG {
|
||||||
GPS_AUTO_CONFIG_DISABLE = 0,
|
GPS_AUTO_CONFIG_DISABLE = 0,
|
||||||
|
Loading…
Reference in New Issue
Block a user