mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-09 20:46:07 +01:00
593 lines
20 KiB
C
593 lines
20 KiB
C
/**
|
|
******************************************************************************
|
|
* @addtogroup OpenPilotModules OpenPilot Modules
|
|
* @{
|
|
* @addtogroup GSPModule GPS Module
|
|
* @brief Process GPS information
|
|
* @{
|
|
*
|
|
* @file GPS.c
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
* @brief GPS module, handles GPS and NMEA stream
|
|
* @see The GNU Public License (GPL) Version 3
|
|
*
|
|
*****************************************************************************/
|
|
/*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
// ****************
|
|
|
|
#include <openpilot.h>
|
|
|
|
#include "gpspositionsensor.h"
|
|
#include "homelocation.h"
|
|
#include "gpstime.h"
|
|
#include "gpssatellites.h"
|
|
#include "gpsvelocitysensor.h"
|
|
#include "gpssettings.h"
|
|
#include "taskinfo.h"
|
|
#include "hwsettings.h"
|
|
#include "auxmagsensor.h"
|
|
#include "WorldMagModel.h"
|
|
#include "CoordinateConversions.h"
|
|
#include <pios_com.h>
|
|
|
|
#include "GPS.h"
|
|
#include "NMEA.h"
|
|
#include "UBX.h"
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL)
|
|
#include "inc/ubx_autoconfig.h"
|
|
#endif
|
|
|
|
#include <pios_instrumentation_helper.h>
|
|
PERF_DEFINE_COUNTER(counterBytesIn);
|
|
PERF_DEFINE_COUNTER(counterRate);
|
|
PERF_DEFINE_COUNTER(counterParse);
|
|
// ****************
|
|
// Private functions
|
|
|
|
static void gpsTask(void *parameters);
|
|
static void updateHwSettings();
|
|
|
|
#ifdef PIOS_GPS_SETS_HOMELOCATION
|
|
static void setHomeLocation(GPSPositionSensorData *gpsData);
|
|
static float GravityAccel(float latitude, float longitude, float altitude);
|
|
#endif
|
|
|
|
#ifdef PIOS_INCLUDE_GPS_UBX_PARSER
|
|
void AuxMagSettingsUpdatedCb(UAVObjEvent *ev);
|
|
#ifndef PIOS_GPS_MINIMAL
|
|
void updateGpsSettings(UAVObjEvent *ev);
|
|
#endif
|
|
#endif
|
|
|
|
// ****************
|
|
// Private constants
|
|
|
|
#define GPS_TIMEOUT_MS 500
|
|
// delay from detecting HomeLocation.Set == False before setting new homelocation
|
|
// this prevent that a save with homelocation.Set = false triggered by gps ends saving
|
|
// the new location with Set = true.
|
|
#define GPS_HOMELOCATION_SET_DELAY 5000
|
|
|
|
#define GPS_LOOP_DELAY_MS 6
|
|
|
|
#ifdef PIOS_GPS_SETS_HOMELOCATION
|
|
// Unfortunately need a good size stack for the WMM calculation
|
|
#define STACK_SIZE_BYTES 1024
|
|
#else
|
|
#if defined(PIOS_GPS_MINIMAL)
|
|
#define GPS_READ_BUFFER 32
|
|
|
|
#ifdef PIOS_INCLUDE_GPS_NMEA_PARSER
|
|
#define STACK_SIZE_BYTES 580 // NMEA
|
|
#else
|
|
#define STACK_SIZE_BYTES 440 // UBX
|
|
#endif // PIOS_INCLUDE_GPS_NMEA_PARSER
|
|
#else
|
|
#define STACK_SIZE_BYTES 650
|
|
#endif // PIOS_GPS_MINIMAL
|
|
#endif // PIOS_GPS_SETS_HOMELOCATION
|
|
|
|
#ifndef GPS_READ_BUFFER
|
|
#define GPS_READ_BUFFER 128
|
|
#endif
|
|
|
|
#define TASK_PRIORITY (tskIDLE_PRIORITY + 1)
|
|
|
|
// ****************
|
|
// Private variables
|
|
|
|
static uint32_t gpsPort;
|
|
static bool gpsEnabled = false;
|
|
|
|
static xTaskHandle gpsTaskHandle;
|
|
|
|
static char *gps_rx_buffer;
|
|
|
|
static uint32_t timeOfLastCommandMs;
|
|
static uint32_t timeOfLastUpdateMs;
|
|
|
|
#if defined(PIOS_INCLUDE_GPS_NMEA_PARSER) || defined(PIOS_INCLUDE_GPS_UBX_PARSER)
|
|
static struct GPS_RX_STATS gpsRxStats;
|
|
#endif
|
|
|
|
// ****************
|
|
/**
|
|
* Initialise the gps module
|
|
* \return -1 if initialisation failed
|
|
* \return 0 on success
|
|
*/
|
|
|
|
int32_t GPSStart(void)
|
|
{
|
|
if (gpsEnabled) {
|
|
if (gpsPort) {
|
|
// Start gps task
|
|
xTaskCreate(gpsTask, "GPS", STACK_SIZE_BYTES / 4, NULL, TASK_PRIORITY, &gpsTaskHandle);
|
|
PIOS_TASK_MONITOR_RegisterTask(TASKINFO_RUNNING_GPS, gpsTaskHandle);
|
|
return 0;
|
|
}
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
/**
|
|
* Initialise the gps module
|
|
* \return -1 if initialisation failed
|
|
* \return 0 on success
|
|
*/
|
|
int32_t GPSInitialize(void)
|
|
{
|
|
gpsPort = PIOS_COM_GPS;
|
|
GPSSettingsDataProtocolOptions gpsProtocol;
|
|
|
|
#ifdef MODULE_GPS_BUILTIN
|
|
gpsEnabled = true;
|
|
#else
|
|
HwSettingsInitialize();
|
|
HwSettingsOptionalModulesData optionalModules;
|
|
|
|
HwSettingsOptionalModulesGet(&optionalModules);
|
|
|
|
if (optionalModules.GPS == HWSETTINGS_OPTIONALMODULES_ENABLED) {
|
|
gpsEnabled = true;
|
|
} else {
|
|
gpsEnabled = false;
|
|
}
|
|
#endif
|
|
|
|
#if defined(REVOLUTION)
|
|
// These objects MUST be initialized for Revolution
|
|
// because the rest of the system expects to just
|
|
// attach to their queues
|
|
GPSPositionSensorInitialize();
|
|
GPSVelocitySensorInitialize();
|
|
GPSTimeInitialize();
|
|
GPSSatellitesInitialize();
|
|
HomeLocationInitialize();
|
|
#ifdef PIOS_INCLUDE_GPS_UBX_PARSER
|
|
AuxMagSensorInitialize();
|
|
AuxMagSettingsInitialize();
|
|
GPSExtendedStatusInitialize();
|
|
|
|
// Initialize mag parameters
|
|
AuxMagSettingsUpdatedCb(NULL);
|
|
AuxMagSettingsConnectCallback(AuxMagSettingsUpdatedCb);
|
|
#endif
|
|
updateHwSettings();
|
|
#else
|
|
if (gpsPort && gpsEnabled) {
|
|
GPSPositionSensorInitialize();
|
|
GPSVelocitySensorInitialize();
|
|
#if !defined(PIOS_GPS_MINIMAL)
|
|
GPSTimeInitialize();
|
|
GPSSatellitesInitialize();
|
|
#endif
|
|
#if defined(PIOS_GPS_SETS_HOMELOCATION)
|
|
HomeLocationInitialize();
|
|
#endif
|
|
updateHwSettings();
|
|
}
|
|
#endif /* if defined(REVOLUTION) */
|
|
|
|
if (gpsPort && gpsEnabled) {
|
|
GPSSettingsInitialize();
|
|
GPSSettingsDataProtocolGet(&gpsProtocol);
|
|
switch (gpsProtocol) {
|
|
#if defined(PIOS_INCLUDE_GPS_NMEA_PARSER)
|
|
case GPSSETTINGS_DATAPROTOCOL_NMEA:
|
|
gps_rx_buffer = pios_malloc(NMEA_MAX_PACKET_LENGTH);
|
|
break;
|
|
#endif
|
|
case GPSSETTINGS_DATAPROTOCOL_UBX:
|
|
gps_rx_buffer = pios_malloc(sizeof(struct UBXPacket));
|
|
break;
|
|
default:
|
|
gps_rx_buffer = NULL;
|
|
}
|
|
PIOS_Assert(gps_rx_buffer);
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL)
|
|
GPSSettingsConnectCallback(updateGpsSettings);
|
|
#endif
|
|
return 0;
|
|
}
|
|
|
|
return -1;
|
|
}
|
|
|
|
MODULE_INITCALL(GPSInitialize, GPSStart);
|
|
|
|
// ****************
|
|
/**
|
|
* Main gps task. It does not return.
|
|
*/
|
|
|
|
static void gpsTask(__attribute__((unused)) void *parameters)
|
|
{
|
|
portTickType xDelay = 100 / portTICK_RATE_MS;
|
|
uint32_t timeNowMs = xTaskGetTickCount() * portTICK_RATE_MS;
|
|
|
|
#ifdef PIOS_GPS_SETS_HOMELOCATION
|
|
portTickType homelocationSetDelay = 0;
|
|
#endif
|
|
GPSPositionSensorData gpspositionsensor;
|
|
GPSSettingsData gpsSettings;
|
|
|
|
GPSSettingsGet(&gpsSettings);
|
|
|
|
timeOfLastUpdateMs = timeNowMs;
|
|
timeOfLastCommandMs = timeNowMs;
|
|
|
|
GPSPositionSensorGet(&gpspositionsensor);
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL)
|
|
updateGpsSettings(0);
|
|
#endif
|
|
|
|
TickType_t xLastWakeTime;
|
|
xLastWakeTime = xTaskGetTickCount();
|
|
PERF_INIT_COUNTER(counterBytesIn, 0x97510001);
|
|
PERF_INIT_COUNTER(counterRate, 0x97510002);
|
|
PERF_INIT_COUNTER(counterParse, 0x97510003);
|
|
uint8_t c[GPS_READ_BUFFER];
|
|
|
|
// Loop forever
|
|
while (1) {
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL)
|
|
if (gpsSettings.DataProtocol == GPSSETTINGS_DATAPROTOCOL_UBX) {
|
|
char *buffer = 0;
|
|
uint16_t count = 0;
|
|
uint8_t status;
|
|
GPSPositionSensorStatusGet(&status);
|
|
ubx_autoconfig_run(&buffer, &count, status != GPSPOSITIONSENSOR_STATUS_NOGPS);
|
|
// Something to send?
|
|
if (count) {
|
|
// clear ack/nak
|
|
ubxLastAck.clsID = 0x00;
|
|
ubxLastAck.msgID = 0x00;
|
|
ubxLastNak.clsID = 0x00;
|
|
ubxLastNak.msgID = 0x00;
|
|
|
|
PIOS_COM_SendBuffer(gpsPort, (uint8_t *)buffer, count);
|
|
}
|
|
}
|
|
#endif
|
|
// This blocks the task until there is something on the buffer
|
|
uint16_t cnt;
|
|
while ((cnt = PIOS_COM_ReceiveBuffer(gpsPort, c, GPS_READ_BUFFER, xDelay)) > 0) {
|
|
PERF_TIMED_SECTION_START(counterParse);
|
|
PERF_TRACK_VALUE(counterBytesIn, cnt);
|
|
PERF_MEASURE_PERIOD(counterRate);
|
|
int res;
|
|
switch (gpsSettings.DataProtocol) {
|
|
#if defined(PIOS_INCLUDE_GPS_NMEA_PARSER)
|
|
case GPSSETTINGS_DATAPROTOCOL_NMEA:
|
|
res = parse_nmea_stream(c, cnt, gps_rx_buffer, &gpspositionsensor, &gpsRxStats);
|
|
break;
|
|
#endif
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER)
|
|
case GPSSETTINGS_DATAPROTOCOL_UBX:
|
|
{
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL)
|
|
int32_t ac_status = ubx_autoconfig_get_status();
|
|
static uint8_t lastStatus = 0;
|
|
|
|
gpspositionsensor.AutoConfigStatus =
|
|
ac_status == UBX_AUTOCONFIG_STATUS_DISABLED ? GPSPOSITIONSENSOR_AUTOCONFIGSTATUS_DISABLED :
|
|
ac_status == UBX_AUTOCONFIG_STATUS_DONE ? GPSPOSITIONSENSOR_AUTOCONFIGSTATUS_DONE :
|
|
ac_status == UBX_AUTOCONFIG_STATUS_ERROR ? GPSPOSITIONSENSOR_AUTOCONFIGSTATUS_ERROR :
|
|
GPSPOSITIONSENSOR_AUTOCONFIGSTATUS_RUNNING;
|
|
if (gpspositionsensor.AutoConfigStatus != lastStatus) {
|
|
GPSPositionSensorAutoConfigStatusSet(&gpspositionsensor.AutoConfigStatus);
|
|
lastStatus = gpspositionsensor.AutoConfigStatus;
|
|
}
|
|
#endif
|
|
res = parse_ubx_stream(c, cnt, gps_rx_buffer, &gpspositionsensor, &gpsRxStats);
|
|
}
|
|
break;
|
|
#endif
|
|
default:
|
|
res = NO_PARSER; // this should not happen
|
|
break;
|
|
}
|
|
|
|
PERF_TIMED_SECTION_END(counterParse);
|
|
if (res == PARSER_COMPLETE) {
|
|
timeNowMs = xTaskGetTickCount() * portTICK_RATE_MS;
|
|
timeOfLastUpdateMs = timeNowMs;
|
|
timeOfLastCommandMs = timeNowMs;
|
|
}
|
|
}
|
|
|
|
// Check for GPS timeout
|
|
timeNowMs = xTaskGetTickCount() * portTICK_RATE_MS;
|
|
if ((timeNowMs - timeOfLastUpdateMs) >= GPS_TIMEOUT_MS ||
|
|
(gpsSettings.DataProtocol == GPSSETTINGS_DATAPROTOCOL_UBX && gpspositionsensor.AutoConfigStatus == GPSPOSITIONSENSOR_AUTOCONFIGSTATUS_ERROR)) {
|
|
// we have not received any valid GPS sentences for a while.
|
|
// either the GPS is not plugged in or a hardware problem or the GPS has locked up.
|
|
GPSPositionSensorStatusOptions status = GPSPOSITIONSENSOR_STATUS_NOGPS;
|
|
GPSPositionSensorStatusSet(&status);
|
|
AlarmsSet(SYSTEMALARMS_ALARM_GPS, SYSTEMALARMS_ALARM_ERROR);
|
|
} else {
|
|
// we appear to be receiving GPS sentences OK, we've had an update
|
|
// criteria for GPS-OK taken from this post...
|
|
// http://forums.openpilot.org/topic/1523-professors-insgps-in-svn/page__view__findpost__p__5220
|
|
if ((gpspositionsensor.PDOP < gpsSettings.MaxPDOP) && (gpspositionsensor.Satellites >= gpsSettings.MinSatellites) &&
|
|
(gpspositionsensor.Status == GPSPOSITIONSENSOR_STATUS_FIX3D) &&
|
|
(gpspositionsensor.Latitude != 0 || gpspositionsensor.Longitude != 0)) {
|
|
AlarmsClear(SYSTEMALARMS_ALARM_GPS);
|
|
#ifdef PIOS_GPS_SETS_HOMELOCATION
|
|
HomeLocationData home;
|
|
HomeLocationGet(&home);
|
|
|
|
if (home.Set == HOMELOCATION_SET_FALSE) {
|
|
if (homelocationSetDelay == 0) {
|
|
homelocationSetDelay = xTaskGetTickCount();
|
|
}
|
|
if (xTaskGetTickCount() - homelocationSetDelay > GPS_HOMELOCATION_SET_DELAY) {
|
|
setHomeLocation(&gpspositionsensor);
|
|
homelocationSetDelay = 0;
|
|
}
|
|
} else {
|
|
homelocationSetDelay = 0;
|
|
}
|
|
#endif
|
|
} else if ((gpspositionsensor.Status == GPSPOSITIONSENSOR_STATUS_FIX3D) &&
|
|
(gpspositionsensor.Latitude != 0 || gpspositionsensor.Longitude != 0)) {
|
|
AlarmsSet(SYSTEMALARMS_ALARM_GPS, SYSTEMALARMS_ALARM_WARNING);
|
|
} else {
|
|
AlarmsSet(SYSTEMALARMS_ALARM_GPS, SYSTEMALARMS_ALARM_CRITICAL);
|
|
}
|
|
}
|
|
vTaskDelayUntil(&xLastWakeTime, GPS_LOOP_DELAY_MS / portTICK_RATE_MS);
|
|
}
|
|
}
|
|
|
|
#ifdef PIOS_GPS_SETS_HOMELOCATION
|
|
/*
|
|
* Estimate the acceleration due to gravity for a particular location in LLA
|
|
*/
|
|
static float GravityAccel(float latitude, __attribute__((unused)) float longitude, float altitude)
|
|
{
|
|
/* WGS84 gravity model. The effect of gravity over latitude is strong
|
|
* enough to change the estimated accelerometer bias in those apps. */
|
|
float sinsq = sinf(latitude);
|
|
|
|
sinsq *= sinsq;
|
|
/* Likewise, over the altitude range of a high-altitude balloon, the effect
|
|
* due to change in altitude can also affect the model. */
|
|
return 9.7803267714f * (1.0f + 0.00193185138639f * sinsq) / sqrtf(1.0f - 0.00669437999013f * sinsq)
|
|
- 3.086e-6f * altitude;
|
|
}
|
|
|
|
// ****************
|
|
|
|
static void setHomeLocation(GPSPositionSensorData *gpsData)
|
|
{
|
|
HomeLocationData home;
|
|
|
|
HomeLocationGet(&home);
|
|
GPSTimeData gps;
|
|
GPSTimeGet(&gps);
|
|
|
|
if (gps.Year >= 2000) {
|
|
/* Store LLA */
|
|
home.Latitude = gpsData->Latitude;
|
|
home.Longitude = gpsData->Longitude;
|
|
home.Altitude = gpsData->Altitude + gpsData->GeoidSeparation;
|
|
|
|
/* Compute home ECEF coordinates and the rotation matrix into NED
|
|
* Note that floats are used here - they should give enough precision
|
|
* for this application.*/
|
|
|
|
float LLA[3] = { (home.Latitude) / 10e6f, (home.Longitude) / 10e6f, (home.Altitude) };
|
|
|
|
/* Compute magnetic flux direction at home location */
|
|
if (WMM_GetMagVector(LLA[0], LLA[1], LLA[2], gps.Month, gps.Day, gps.Year, &home.Be[0]) == 0) {
|
|
/*Compute local acceleration due to gravity. Vehicles that span a very large
|
|
* range of altitude (say, weather balloons) may need to update this during the
|
|
* flight. */
|
|
home.g_e = GravityAccel(LLA[0], LLA[1], LLA[2]);
|
|
home.Set = HOMELOCATION_SET_TRUE;
|
|
HomeLocationSet(&home);
|
|
}
|
|
}
|
|
}
|
|
#endif /* ifdef PIOS_GPS_SETS_HOMELOCATION */
|
|
|
|
/**
|
|
* Update the GPS settings, called on startup.
|
|
* FIXME: This should be in the GPSSettings object. But objects have
|
|
* too much overhead yet. Also the GPS has no any specific settings
|
|
* like protocol, etc. Thus the HwSettings object which contains the
|
|
* GPS port speed is used for now.
|
|
*/
|
|
static void updateHwSettings()
|
|
{
|
|
if (gpsPort) {
|
|
// Retrieve settings
|
|
HwSettingsGPSSpeedOptions speed;
|
|
HwSettingsGPSSpeedGet(&speed);
|
|
|
|
// Set port speed
|
|
switch (speed) {
|
|
case HWSETTINGS_GPSSPEED_2400:
|
|
PIOS_COM_ChangeBaud(gpsPort, 2400);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_4800:
|
|
PIOS_COM_ChangeBaud(gpsPort, 4800);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_9600:
|
|
PIOS_COM_ChangeBaud(gpsPort, 9600);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_19200:
|
|
PIOS_COM_ChangeBaud(gpsPort, 19200);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_38400:
|
|
PIOS_COM_ChangeBaud(gpsPort, 38400);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_57600:
|
|
PIOS_COM_ChangeBaud(gpsPort, 57600);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_115200:
|
|
PIOS_COM_ChangeBaud(gpsPort, 115200);
|
|
break;
|
|
case HWSETTINGS_GPSSPEED_230400:
|
|
PIOS_COM_ChangeBaud(gpsPort, 230400);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
#if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL)
|
|
void AuxMagSettingsUpdatedCb(__attribute__((unused)) UAVObjEvent *ev)
|
|
{
|
|
load_mag_settings();
|
|
}
|
|
|
|
void updateGpsSettings(__attribute__((unused)) UAVObjEvent *ev)
|
|
{
|
|
uint8_t ubxAutoConfig;
|
|
uint8_t ubxDynamicModel;
|
|
uint8_t ubxSbasMode;
|
|
ubx_autoconfig_settings_t newconfig;
|
|
uint8_t ubxSbasSats;
|
|
uint8_t ubxGnssMode;
|
|
|
|
GPSSettingsUbxRateGet(&newconfig.navRate);
|
|
|
|
GPSSettingsUbxAutoConfigGet(&ubxAutoConfig);
|
|
newconfig.autoconfigEnabled = ubxAutoConfig == GPSSETTINGS_UBXAUTOCONFIG_DISABLED ? false : true;
|
|
newconfig.storeSettings = ubxAutoConfig == GPSSETTINGS_UBXAUTOCONFIG_CONFIGUREANDSTORE;
|
|
|
|
GPSSettingsUbxDynamicModelGet(&ubxDynamicModel);
|
|
newconfig.dynamicModel = ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_PORTABLE ? UBX_DYNMODEL_PORTABLE :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_STATIONARY ? UBX_DYNMODEL_STATIONARY :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_PEDESTRIAN ? UBX_DYNMODEL_PEDESTRIAN :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_AUTOMOTIVE ? UBX_DYNMODEL_AUTOMOTIVE :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_SEA ? UBX_DYNMODEL_SEA :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_AIRBORNE1G ? UBX_DYNMODEL_AIRBORNE1G :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_AIRBORNE2G ? UBX_DYNMODEL_AIRBORNE2G :
|
|
ubxDynamicModel == GPSSETTINGS_UBXDYNAMICMODEL_AIRBORNE4G ? UBX_DYNMODEL_AIRBORNE4G :
|
|
UBX_DYNMODEL_AIRBORNE1G;
|
|
|
|
GPSSettingsUbxSBASModeGet(&ubxSbasMode);
|
|
switch ((GPSSettingsUbxSBASModeOptions)ubxSbasMode) {
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGCORRECTION:
|
|
case GPSSETTINGS_UBXSBASMODE_CORRECTION:
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGCORRECTIONINTEGRITY:
|
|
case GPSSETTINGS_UBXSBASMODE_CORRECTIONINTEGRITY:
|
|
newconfig.SBASCorrection = true;
|
|
break;
|
|
default:
|
|
newconfig.SBASCorrection = false;
|
|
}
|
|
|
|
switch ((GPSSettingsUbxSBASModeOptions)ubxSbasMode) {
|
|
case GPSSETTINGS_UBXSBASMODE_RANGING:
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGCORRECTION:
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGINTEGRITY:
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGCORRECTIONINTEGRITY:
|
|
newconfig.SBASRanging = true;
|
|
break;
|
|
default:
|
|
newconfig.SBASRanging = false;
|
|
}
|
|
|
|
switch ((GPSSettingsUbxSBASModeOptions)ubxSbasMode) {
|
|
case GPSSETTINGS_UBXSBASMODE_INTEGRITY:
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGINTEGRITY:
|
|
case GPSSETTINGS_UBXSBASMODE_RANGINGCORRECTIONINTEGRITY:
|
|
case GPSSETTINGS_UBXSBASMODE_CORRECTIONINTEGRITY:
|
|
newconfig.SBASIntegrity = true;
|
|
break;
|
|
default:
|
|
newconfig.SBASIntegrity = false;
|
|
}
|
|
|
|
GPSSettingsUbxSBASChannelsUsedGet(&newconfig.SBASChannelsUsed);
|
|
|
|
GPSSettingsUbxSBASSatsGet(&ubxSbasSats);
|
|
|
|
newconfig.SBASSats = ubxSbasSats == GPSSETTINGS_UBXSBASSATS_WAAS ? UBX_SBAS_SATS_WAAS :
|
|
ubxSbasSats == GPSSETTINGS_UBXSBASSATS_EGNOS ? UBX_SBAS_SATS_EGNOS :
|
|
ubxSbasSats == GPSSETTINGS_UBXSBASSATS_MSAS ? UBX_SBAS_SATS_MSAS :
|
|
ubxSbasSats == GPSSETTINGS_UBXSBASSATS_GAGAN ? UBX_SBAS_SATS_GAGAN :
|
|
ubxSbasSats == GPSSETTINGS_UBXSBASSATS_SDCM ? UBX_SBAS_SATS_SDCM : UBX_SBAS_SATS_AUTOSCAN;
|
|
|
|
GPSSettingsUbxGNSSModeGet(&ubxGnssMode);
|
|
|
|
switch (ubxGnssMode) {
|
|
case GPSSETTINGS_UBXGNSSMODE_GPSGLONASS:
|
|
newconfig.enableGPS = true;
|
|
newconfig.enableGLONASS = true;
|
|
newconfig.enableBeiDou = false;
|
|
break;
|
|
case GPSSETTINGS_UBXGNSSMODE_GLONASS:
|
|
newconfig.enableGPS = false;
|
|
newconfig.enableGLONASS = true;
|
|
newconfig.enableBeiDou = false;
|
|
break;
|
|
case GPSSETTINGS_UBXGNSSMODE_GPS:
|
|
newconfig.enableGPS = true;
|
|
newconfig.enableGLONASS = false;
|
|
newconfig.enableBeiDou = false;
|
|
break;
|
|
case GPSSETTINGS_UBXGNSSMODE_GPSBEIDOU:
|
|
newconfig.enableGPS = true;
|
|
newconfig.enableGLONASS = false;
|
|
newconfig.enableBeiDou = true;
|
|
break;
|
|
case GPSSETTINGS_UBXGNSSMODE_GLONASSBEIDOU:
|
|
newconfig.enableGPS = false;
|
|
newconfig.enableGLONASS = true;
|
|
newconfig.enableBeiDou = true;
|
|
break;
|
|
default:
|
|
newconfig.enableGPS = false;
|
|
newconfig.enableGLONASS = false;
|
|
newconfig.enableBeiDou = false;
|
|
break;
|
|
}
|
|
|
|
ubx_autoconfig_set(newconfig);
|
|
}
|
|
#endif /* if defined(PIOS_INCLUDE_GPS_UBX_PARSER) && !defined(PIOS_GPS_MINIMAL) */
|
|
/**
|
|
* @}
|
|
* @}
|
|
*/
|