mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-17 13:25:30 +03:00
Add support for MSP2_SENSOR_GPS message from RemoteID module (#13062)
This commit is contained in:
parent
5cd2ab50e4
commit
a72ad8b2b6
3 changed files with 63 additions and 11 deletions
|
@ -1355,10 +1355,29 @@ void gpsUpdate(timeUs_t currentTimeUs)
|
||||||
isFast = false;
|
isFast = false;
|
||||||
rescheduleTask(TASK_SELF, TASK_PERIOD_HZ(TASK_GPS_RATE));
|
rescheduleTask(TASK_SELF, TASK_PERIOD_HZ(TASK_GPS_RATE));
|
||||||
}
|
}
|
||||||
} else if (GPS_update & GPS_MSP_UPDATE) { // GPS data received via MSP
|
} else if (gpsConfig()->provider == GPS_MSP) {
|
||||||
gpsSetState(GPS_STATE_RECEIVING_DATA);
|
if (GPS_update & GPS_MSP_UPDATE) { // GPS data received via MSP
|
||||||
onGpsNewData();
|
if (gpsData.state == GPS_STATE_INITIALIZED) {
|
||||||
GPS_update &= ~GPS_MSP_UPDATE;
|
gpsSetState(GPS_STATE_RECEIVING_DATA);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Data is available
|
||||||
|
DEBUG_SET(DEBUG_GPS_CONNECTION, 3, gpsData.now - gpsData.lastNavMessage); // interval since last Nav data was received
|
||||||
|
gpsData.lastNavMessage = gpsData.now;
|
||||||
|
sensorsSet(SENSOR_GPS);
|
||||||
|
|
||||||
|
GPS_update ^= GPS_DIRECT_TICK;
|
||||||
|
|
||||||
|
onGpsNewData();
|
||||||
|
|
||||||
|
GPS_update &= ~GPS_MSP_UPDATE;
|
||||||
|
} else {
|
||||||
|
DEBUG_SET(DEBUG_GPS_CONNECTION, 2, gpsData.now - gpsData.lastNavMessage); // time since last Nav data, updated each GPS task interval
|
||||||
|
// check for no data/gps timeout/cable disconnection etc
|
||||||
|
if (cmp32(gpsData.now, gpsData.lastNavMessage) > GPS_TIMEOUT_MS) {
|
||||||
|
gpsSetState(GPS_STATE_LOST_COMMUNICATION);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (gpsData.state) {
|
switch (gpsData.state) {
|
||||||
|
@ -1382,11 +1401,13 @@ void gpsUpdate(timeUs_t currentTimeUs)
|
||||||
|
|
||||||
case GPS_STATE_RECEIVING_DATA:
|
case GPS_STATE_RECEIVING_DATA:
|
||||||
#ifdef USE_GPS_UBLOX
|
#ifdef USE_GPS_UBLOX
|
||||||
if (gpsConfig()->autoConfig == GPS_AUTOCONFIG_ON) {
|
if (gpsConfig()->provider != GPS_MSP) {
|
||||||
// when we are connected up, and get a 3D fix, enable the 'flight' fix model
|
if (gpsConfig()->autoConfig == GPS_AUTOCONFIG_ON) {
|
||||||
if (!gpsData.ubloxUsingFlightModel && STATE(GPS_FIX)) {
|
// when we are connected up, and get a 3D fix, enable the 'flight' fix model
|
||||||
gpsData.ubloxUsingFlightModel = true;
|
if (!gpsData.ubloxUsingFlightModel && STATE(GPS_FIX)) {
|
||||||
ubloxSendNAV5Message(gpsConfig()->gps_ublox_flight_model);
|
gpsData.ubloxUsingFlightModel = true;
|
||||||
|
ubloxSendNAV5Message(gpsConfig()->gps_ublox_flight_model);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -1434,14 +1455,14 @@ void gpsUpdate(timeUs_t currentTimeUs)
|
||||||
schedulerSetNextStateTime(gpsStateDurationFractionUs[gpsCurrentState] >> GPS_TASK_DECAY_SHIFT);
|
schedulerSetNextStateTime(gpsStateDurationFractionUs[gpsCurrentState] >> GPS_TASK_DECAY_SHIFT);
|
||||||
|
|
||||||
DEBUG_SET(DEBUG_GPS_CONNECTION, 5, executeTimeUs);
|
DEBUG_SET(DEBUG_GPS_CONNECTION, 5, executeTimeUs);
|
||||||
// keeping temporarily, to be used when debugging the sheduler stuff
|
// keeping temporarily, to be used when debugging the scheduler stuff
|
||||||
// DEBUG_SET(DEBUG_GPS_CONNECTION, 6, (gpsStateDurationFractionUs[gpsCurrentState] >> GPS_TASK_DECAY_SHIFT));
|
// DEBUG_SET(DEBUG_GPS_CONNECTION, 6, (gpsStateDurationFractionUs[gpsCurrentState] >> GPS_TASK_DECAY_SHIFT));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gpsNewData(uint16_t c)
|
static void gpsNewData(uint16_t c)
|
||||||
{
|
{
|
||||||
DEBUG_SET(DEBUG_GPS_CONNECTION, 1, gpsSol.navIntervalMs);
|
DEBUG_SET(DEBUG_GPS_CONNECTION, 1, gpsSol.navIntervalMs);
|
||||||
if (!gpsNewFrame(c)) {
|
if (!gpsNewFrame(c)) {
|
||||||
// no new nav solution data
|
// no new nav solution data
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3604,6 +3604,34 @@ static mspResult_e mspProcessInCommand(mspDescriptor_t srcDesc, int16_t cmdMSP,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_GPS
|
#ifdef USE_GPS
|
||||||
|
case MSP2_SENSOR_GPS:
|
||||||
|
(void)sbufReadU8(src); // instance
|
||||||
|
(void)sbufReadU16(src); // gps_week
|
||||||
|
gpsSol.time = sbufReadU32(src); // ms_tow
|
||||||
|
gpsSetFixState(sbufReadU8(src) != 0); // fix_type
|
||||||
|
gpsSol.numSat = sbufReadU8(src); // satellites_in_view
|
||||||
|
gpsSol.acc.hAcc = sbufReadU16(src) * 10; // horizontal_pos_accuracy - convert cm to mm
|
||||||
|
gpsSol.acc.vAcc = sbufReadU16(src) * 10; // vertical_pos_accuracy - convert cm to mm
|
||||||
|
gpsSol.acc.sAcc = sbufReadU16(src) * 10; // horizontal_vel_accuracy - convert cm to mm
|
||||||
|
gpsSol.dop.hdop = sbufReadU16(src); // hdop
|
||||||
|
gpsSol.llh.lon = sbufReadU32(src);
|
||||||
|
gpsSol.llh.lat = sbufReadU32(src);
|
||||||
|
gpsSol.llh.altCm = sbufReadU32(src); // alt
|
||||||
|
int32_t ned_vel_north = (int32_t)sbufReadU32(src); // ned_vel_north
|
||||||
|
int32_t ned_vel_east = (int32_t)sbufReadU32(src); // ned_vel_east
|
||||||
|
gpsSol.groundSpeed = (uint16_t)sqrtf((ned_vel_north * ned_vel_north) + (ned_vel_east * ned_vel_east));
|
||||||
|
(void)sbufReadU32(src); // ned_vel_down
|
||||||
|
gpsSol.groundCourse = ((uint16_t)sbufReadU16(src) % 360); // ground_course
|
||||||
|
(void)sbufReadU16(src); // true_yaw
|
||||||
|
(void)sbufReadU16(src); // year
|
||||||
|
(void)sbufReadU8(src); // month
|
||||||
|
(void)sbufReadU8(src); // day
|
||||||
|
(void)sbufReadU8(src); // hour
|
||||||
|
(void)sbufReadU8(src); // min
|
||||||
|
(void)sbufReadU8(src); // sec
|
||||||
|
GPS_update |= GPS_MSP_UPDATE; // MSP data signalisation to GPS functions
|
||||||
|
break;
|
||||||
|
|
||||||
case MSP_SET_RAW_GPS:
|
case MSP_SET_RAW_GPS:
|
||||||
gpsSetFixState(sbufReadU8(src));
|
gpsSetFixState(sbufReadU8(src));
|
||||||
gpsSol.numSat = sbufReadU8(src);
|
gpsSol.numSat = sbufReadU8(src);
|
||||||
|
|
|
@ -20,3 +20,6 @@
|
||||||
|
|
||||||
#define MSP2_COMMON_SERIAL_CONFIG 0x1009
|
#define MSP2_COMMON_SERIAL_CONFIG 0x1009
|
||||||
#define MSP2_COMMON_SET_SERIAL_CONFIG 0x100A
|
#define MSP2_COMMON_SET_SERIAL_CONFIG 0x100A
|
||||||
|
|
||||||
|
// Sensors
|
||||||
|
#define MSP2_SENSOR_GPS 0x1F03
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue