mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 02:18:29 -04:00
GPS: Corrections to Media Tek GPS Driver. Change to 5Hz and SBAS
This commit is contained in:
parent
85e8ba7993
commit
661d1500d2
@ -28,8 +28,14 @@ AP_GPS_MTK::init(enum GPS_Engine_Setting nav_setting)
|
|||||||
// XXX should assume binary, let GPS_AUTO handle dynamic config?
|
// XXX should assume binary, let GPS_AUTO handle dynamic config?
|
||||||
_port->print(MTK_SET_BINARY);
|
_port->print(MTK_SET_BINARY);
|
||||||
|
|
||||||
// set 4Hz update rate
|
// set 5Hz update rate
|
||||||
_port->print(MTK_OUTPUT_4HZ);
|
_port->print(MTK_OUTPUT_5HZ);
|
||||||
|
|
||||||
|
// set SBAS on
|
||||||
|
_port->print(SBAS_ON);
|
||||||
|
|
||||||
|
// set WAAS on
|
||||||
|
_port->print(WAAS_ON);
|
||||||
|
|
||||||
// set initial epoch code
|
// set initial epoch code
|
||||||
_epoch = TIME_OF_DAY;
|
_epoch = TIME_OF_DAY;
|
||||||
@ -129,7 +135,7 @@ restart:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
fix = (_buffer.msg.fix_type == FIX_3D);
|
fix = ((_buffer.msg.fix_type == FIX_3D) || (_buffer.msg.fix_type == FIX_3D_SBAS);
|
||||||
latitude = _swapl(&_buffer.msg.latitude) * 10;
|
latitude = _swapl(&_buffer.msg.latitude) * 10;
|
||||||
longitude = _swapl(&_buffer.msg.longitude) * 10;
|
longitude = _swapl(&_buffer.msg.longitude) * 10;
|
||||||
altitude = _swapl(&_buffer.msg.altitude);
|
altitude = _swapl(&_buffer.msg.altitude);
|
||||||
|
@ -40,7 +40,9 @@ private:
|
|||||||
enum diyd_mtk_fix_type {
|
enum diyd_mtk_fix_type {
|
||||||
FIX_NONE = 1,
|
FIX_NONE = 1,
|
||||||
FIX_2D = 2,
|
FIX_2D = 2,
|
||||||
FIX_3D = 3
|
FIX_3D = 3,
|
||||||
|
FIX_3D_SBAS = 6,
|
||||||
|
FIX_3D_SBAS =7
|
||||||
};
|
};
|
||||||
|
|
||||||
enum diyd_mtk_protocol_bytes {
|
enum diyd_mtk_protocol_bytes {
|
||||||
|
@ -34,9 +34,15 @@ AP_GPS_MTK16::init(enum GPS_Engine_Setting nav_setting)
|
|||||||
// XXX should assume binary, let GPS_AUTO handle dynamic config?
|
// XXX should assume binary, let GPS_AUTO handle dynamic config?
|
||||||
_port->print(MTK_SET_BINARY);
|
_port->print(MTK_SET_BINARY);
|
||||||
|
|
||||||
// set 4Hz update rate
|
// set 5Hz update rate
|
||||||
_port->print(MTK_OUTPUT_4HZ);
|
_port->print(MTK_OUTPUT_5HZ);
|
||||||
|
|
||||||
|
// set SBAS on
|
||||||
|
_port->print(SBAS_ON);
|
||||||
|
|
||||||
|
// set WAAS on
|
||||||
|
_port->print(WAAS_ON);
|
||||||
|
|
||||||
// set initial epoch code
|
// set initial epoch code
|
||||||
_epoch = TIME_OF_DAY;
|
_epoch = TIME_OF_DAY;
|
||||||
_time_offset = 0;
|
_time_offset = 0;
|
||||||
@ -125,7 +131,7 @@ restart:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
fix = _buffer.msg.fix_type == FIX_3D;
|
fix = ((_buffer.msg.fix_type == FIX_3D) || (_buffer.msg.fix_type == FIX_3D_SBAS);
|
||||||
latitude = _buffer.msg.latitude * 10; // XXX doc says *10e7 but device says otherwise
|
latitude = _buffer.msg.latitude * 10; // XXX doc says *10e7 but device says otherwise
|
||||||
longitude = _buffer.msg.longitude * 10; // XXX doc says *10e7 but device says otherwise
|
longitude = _buffer.msg.longitude * 10; // XXX doc says *10e7 but device says otherwise
|
||||||
altitude = _buffer.msg.altitude;
|
altitude = _buffer.msg.altitude;
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
#define MTK_OUTPUT_1HZ "$PMTK220,1000*1F\r\n"
|
#define MTK_OUTPUT_1HZ "$PMTK220,1000*1F\r\n"
|
||||||
#define MTK_OUTPUT_2HZ "$PMTK220,500*2B\r\n"
|
#define MTK_OUTPUT_2HZ "$PMTK220,500*2B\r\n"
|
||||||
#define MTK_OUTPUT_4HZ "$PMTK220,250*29\r\n"
|
#define MTK_OUTPUT_4HZ "$PMTK220,250*29\r\n"
|
||||||
#define MTK_OTUPUT_5HZ "$PMTK220,200*2C\r\n"
|
#define MTK_OUTPUT_5HZ "$PMTK220,200*2C\r\n"
|
||||||
#define MTK_OUTPUT_10HZ "$PMTK220,100*2F\r\n"
|
#define MTK_OUTPUT_10HZ "$PMTK220,100*2F\r\n"
|
||||||
|
|
||||||
#define MTK_BAUD_RATE_38400 "$PMTK251,38400*27\r\n"
|
#define MTK_BAUD_RATE_38400 "$PMTK251,38400*27\r\n"
|
||||||
|
Loading…
Reference in New Issue
Block a user