AP_RTC: return 0 from get_utc_usec if rtc not set

This commit is contained in:
Peter Barker 2018-06-14 13:27:30 +10:00 committed by Andrew Tridgell
parent f83e65e04e
commit 312ac7dc73
2 changed files with 10 additions and 4 deletions

View File

@ -79,11 +79,13 @@ bool AP_RTC::get_utc_usec(uint64_t &usec) const
return true; return true;
} }
void AP_RTC::get_system_clock_utc(int32_t &hour, int32_t &min, int32_t &sec, int32_t &ms) bool AP_RTC::get_system_clock_utc(int32_t &hour, int32_t &min, int32_t &sec, int32_t &ms)
{ {
// get time of day in ms // get time of day in ms
uint64_t time_ms = 0; uint64_t time_ms = 0;
get_utc_usec(time_ms); // may fail, leaving time_ms at 0 if (!get_utc_usec(time_ms)) {
return false;
}
time_ms /= 1000U; time_ms /= 1000U;
// separate time into ms, sec, min, hour and days but all expressed in milliseconds // separate time into ms, sec, min, hour and days but all expressed in milliseconds
@ -96,6 +98,8 @@ void AP_RTC::get_system_clock_utc(int32_t &hour, int32_t &min, int32_t &sec, int
sec = sec_ms / 1000; sec = sec_ms / 1000;
min = min_ms / (60 * 1000); min = min_ms / (60 * 1000);
hour = hour_ms / (60 * 60 * 1000); hour = hour_ms / (60 * 60 * 1000);
return true;
} }
// get milliseconds from now to a target time of day expressed as hour, min, sec, ms // get milliseconds from now to a target time of day expressed as hour, min, sec, ms
@ -119,7 +123,9 @@ uint32_t AP_RTC::get_time_utc(int32_t hour, int32_t min, int32_t sec, int32_t ms
// get start_time_ms as h, m, s, ms // get start_time_ms as h, m, s, ms
int32_t curr_hour, curr_min, curr_sec, curr_ms; int32_t curr_hour, curr_min, curr_sec, curr_ms;
get_system_clock_utc(curr_hour, curr_min, curr_sec, curr_ms); if (!get_system_clock_utc(curr_hour, curr_min, curr_sec, curr_ms)) {
return 0;
}
int32_t total_delay_ms = 0; int32_t total_delay_ms = 0;
// calculate ms to target // calculate ms to target

View File

@ -37,7 +37,7 @@ public:
/* /*
get time in UTC hours, minutes, seconds and milliseconds get time in UTC hours, minutes, seconds and milliseconds
*/ */
void get_system_clock_utc(int32_t &hour, int32_t &min, int32_t &sec, int32_t &ms); bool get_system_clock_utc(int32_t &hour, int32_t &min, int32_t &sec, int32_t &ms);
uint32_t get_time_utc(int32_t hour, int32_t min, int32_t sec, int32_t ms); uint32_t get_time_utc(int32_t hour, int32_t min, int32_t sec, int32_t ms);