aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLorenz Meier <lorenz@px4.io>2015-01-07 13:02:50 +0100
committerLorenz Meier <lorenz@px4.io>2015-01-07 13:02:50 +0100
commit6ed2f77ca5c713e537c8fd4a9aacd7adc7887f53 (patch)
treeb8d4421ed539fddde1d14ffe4a097638397d5dd9
parentc6722fce0be914e2c678437eee6531e087e5d89a (diff)
parent78cde98ea89dfab02e27c4e36536dc1e827dfce5 (diff)
downloadpx4-firmware-6ed2f77ca5c713e537c8fd4a9aacd7adc7887f53.tar.gz
px4-firmware-6ed2f77ca5c713e537c8fd4a9aacd7adc7887f53.tar.bz2
px4-firmware-6ed2f77ca5c713e537c8fd4a9aacd7adc7887f53.zip
Merge pull request #1599 from PX4/mtk_time
GPS driver: Add missing wall clock setup for MTK GPS modules
-rw-r--r--src/drivers/gps/mtk.cpp22
1 files changed, 19 insertions, 3 deletions
diff --git a/src/drivers/gps/mtk.cpp b/src/drivers/gps/mtk.cpp
index c0c47073b..c112f65a8 100644
--- a/src/drivers/gps/mtk.cpp
+++ b/src/drivers/gps/mtk.cpp
@@ -264,7 +264,7 @@ MTK::handle_message(gps_mtk_packet_t &packet)
_gps_position->satellites_used = packet.satellites;
/* convert time and date information to unix timestamp */
- struct tm timeinfo; //TODO: test this conversion
+ struct tm timeinfo;
uint32_t timeinfo_conversion_temp;
timeinfo.tm_mday = packet.date * 1e-4;
@@ -280,8 +280,24 @@ MTK::handle_message(gps_mtk_packet_t &packet)
timeinfo_conversion_temp -= timeinfo.tm_sec * 1e3;
time_t epoch = mktime(&timeinfo);
- _gps_position->time_utc_usec = epoch * 1e6; //TODO: test this
- _gps_position->time_utc_usec += timeinfo_conversion_temp * 1e3;
+ if (epoch > GPS_EPOCH_SECS) {
+ // FMUv2+ boards have a hardware RTC, but GPS helps us to configure it
+ // and control its drift. Since we rely on the HRT for our monotonic
+ // clock, updating it from time to time is safe.
+
+ timespec ts;
+ ts.tv_sec = epoch;
+ ts.tv_nsec = timeinfo_conversion_temp * 1000000ULL;
+ if (clock_settime(CLOCK_REALTIME, &ts)) {
+ warn("failed setting clock");
+ }
+
+ _gps_position->time_utc_usec = static_cast<uint64_t>(epoch) * 1000000ULL;
+ _gps_position->time_utc_usec += timeinfo_conversion_temp * 1000ULL;
+ } else {
+ _gps_position->time_utc_usec = 0;
+ }
+
_gps_position->timestamp_position = _gps_position->timestamp_time = hrt_absolute_time();
// Position and velocity update always at the same time