Fixed osal_timer_diff bug (#106)
This commit is contained in:
parent
fb975cbc70
commit
e78bb66327
|
@ -49,11 +49,13 @@ ec_timet osal_current_time(void)
|
||||||
|
|
||||||
void osal_time_diff(ec_timet *start, ec_timet *end, ec_timet *diff)
|
void osal_time_diff(ec_timet *start, ec_timet *end, ec_timet *diff)
|
||||||
{
|
{
|
||||||
diff->sec = end->sec - start->sec;
|
if (end->usec < start->usec) {
|
||||||
diff->usec = end->usec - start->usec;
|
diff->sec = end->sec - start->sec - 1;
|
||||||
if (diff->usec < 0) {
|
diff->usec = end->usec + 1000000 - start->usec;
|
||||||
--diff->sec;
|
}
|
||||||
diff->usec += 1000000;
|
else {
|
||||||
|
diff->sec = end->sec - start->sec;
|
||||||
|
diff->usec = end->usec - start->usec;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -92,12 +92,14 @@ ec_timet osal_current_time(void)
|
||||||
|
|
||||||
void osal_time_diff(ec_timet *start, ec_timet *end, ec_timet *diff)
|
void osal_time_diff(ec_timet *start, ec_timet *end, ec_timet *diff)
|
||||||
{
|
{
|
||||||
diff->sec = end->sec - start->sec;
|
if (end->usec < start->usec) {
|
||||||
diff->usec = end->usec - start->usec;
|
diff->sec = end->sec - start->sec - 1;
|
||||||
if (diff->usec < 0) {
|
diff->usec = end->usec + 1000000 - start->usec;
|
||||||
--diff->sec;
|
}
|
||||||
diff->usec += 1000000;
|
else {
|
||||||
}
|
diff->sec = end->sec - start->sec;
|
||||||
|
diff->usec = end->usec - start->usec;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void osal_timer_start(osal_timert * self, uint32 timeout_usec)
|
void osal_timer_start(osal_timert * self, uint32 timeout_usec)
|
||||||
|
|
|
@ -42,11 +42,13 @@ ec_timet osal_current_time (void)
|
||||||
|
|
||||||
void osal_time_diff(ec_timet *start, ec_timet *end, ec_timet *diff)
|
void osal_time_diff(ec_timet *start, ec_timet *end, ec_timet *diff)
|
||||||
{
|
{
|
||||||
diff->sec = end->sec - start->sec;
|
if (end->usec < start->usec) {
|
||||||
diff->usec = end->usec - start->usec;
|
diff->sec = end->sec - start->sec - 1;
|
||||||
if (diff->usec < 0) {
|
diff->usec = end->usec + 1000000 - start->usec;
|
||||||
--diff->sec;
|
}
|
||||||
diff->usec += 1000000;
|
else {
|
||||||
|
diff->sec = end->sec - start->sec;
|
||||||
|
diff->usec = end->usec - start->usec;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue