Log GPS data on pad after boost detect.
[fw/altos] / src / ao_gps_skytraq.c
index 0dd45c0c7f9a57659f88cf488393b4582545e1f7..ae8c7ef7cafb1980d5cb08ffd541eac66d2f596c 100644 (file)
@@ -28,9 +28,11 @@ static __xdata char ao_gps_char;
 static __xdata uint8_t ao_gps_cksum;
 static __xdata uint8_t ao_gps_error;
 
+__xdata uint16_t ao_gps_tick;
 __xdata struct ao_gps_data     ao_gps_data;
 __xdata struct ao_gps_tracking_data    ao_gps_tracking_data;
 
+static __xdata uint16_t                                ao_gps_next_tick;
 static __xdata struct ao_gps_data              ao_gps_next;
 static __xdata uint8_t                         ao_gps_date_flags;
 static __xdata struct ao_gps_tracking_data     ao_gps_tracking_next;
@@ -248,6 +250,7 @@ ao_gps(void) __reentrant
                         *         *66          checksum
                         */
 
+                       ao_gps_next_tick = ao_time();
                        ao_gps_next.flags = AO_GPS_RUNNING | ao_gps_date_flags;
                        ao_gps_next.hour = ao_gps_decimal(2);
                        ao_gps_next.minute = ao_gps_decimal(2);
@@ -297,6 +300,7 @@ ao_gps(void) __reentrant
                                ao_gps_error = 1;
                        if (!ao_gps_error) {
                                ao_mutex_get(&ao_gps_mutex);
+                               ao_gps_tick = ao_gps_next_tick;
                                memcpy(&ao_gps_data, &ao_gps_next, sizeof (struct ao_gps_data));
                                ao_mutex_put(&ao_gps_mutex);
                                ao_wakeup(&ao_gps_data);