1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

tests/pkg/minmea: fixing RMC timestamp

This commit is contained in:
Jan Mohr 2023-10-26 10:40:43 +02:00
parent 7da2817d4c
commit 0f27efb98d
2 changed files with 6 additions and 8 deletions

View File

@ -106,12 +106,6 @@ int _parse_nmea_msg(const char* nmea_msg)
if (minmea_parse_rmc(&frame, nmea_msg) && frame.valid) { if (minmea_parse_rmc(&frame, nmea_msg) && frame.valid) {
puts("check_nmea: RMC recorded"); puts("check_nmea: RMC recorded");
/* parse timestamp */
struct tm tm;
time_t timestamp;
minmea_getdatetime(&tm, &frame.date, &frame.time);
timestamp = mktime(&tm);
/* print values */ /* print values */
print_str("\tlat: "); print_str("\tlat: ");
print_float(minmea_tocoord(&frame.latitude), 6); print_float(minmea_tocoord(&frame.latitude), 6);
@ -119,7 +113,10 @@ int _parse_nmea_msg(const char* nmea_msg)
print_str("\tlon: "); print_str("\tlon: ");
print_float(minmea_tocoord(&frame.longitude), 6); print_float(minmea_tocoord(&frame.longitude), 6);
printf("\n"); printf("\n");
printf("\ttime: %"PRIu32"\n", (uint32_t)timestamp); /* NMEA RMC is providing UTC time */
printf("\tdate: %d.%d.%d\n", frame.date.day, frame.date.month, frame.date.year);
printf("\ttime: %dh %dm %ds, %dms\n", frame.time.hours, frame.time.minutes,
frame.time.seconds, frame.time.microseconds/1000);
} }
else { else {
puts("check_nmea: invalid RMC record"); puts("check_nmea: invalid RMC record");

View File

@ -32,7 +32,8 @@ def testfunc(child):
child.expect_exact('check_nmea: RMC recorded\r\n') child.expect_exact('check_nmea: RMC recorded\r\n')
child.expect_exact('\tlat: 52.450366\r\n') child.expect_exact('\tlat: 52.450366\r\n')
child.expect_exact('\tlon: 13.298649\r\n') child.expect_exact('\tlon: 13.298649\r\n')
child.expect_exact('\ttime: 1697808102\r\n') child.expect_exact('\tdate: 20.10.23\r\n')
child.expect_exact('\ttime: 14h 21m 42s, 227ms\r\n')
child.expect_exact('SUCCESS\r\n') child.expect_exact('SUCCESS\r\n')