Commit 10bde693 authored by Paul Sokolovsky's avatar Paul Sokolovsky

extmod/utime_mphal: ticks_diff(): Optimize to avoid if conditions.

parent 5fae9143
...@@ -89,12 +89,10 @@ STATIC mp_obj_t time_ticks_diff(mp_obj_t end_in, mp_obj_t start_in) { ...@@ -89,12 +89,10 @@ STATIC mp_obj_t time_ticks_diff(mp_obj_t end_in, mp_obj_t start_in) {
// we assume that the arguments come from ticks_xx so are small ints // we assume that the arguments come from ticks_xx so are small ints
uint32_t start = MP_OBJ_SMALL_INT_VALUE(start_in); uint32_t start = MP_OBJ_SMALL_INT_VALUE(start_in);
uint32_t end = MP_OBJ_SMALL_INT_VALUE(end_in); uint32_t end = MP_OBJ_SMALL_INT_VALUE(end_in);
int32_t diff = end - start; // Optimized formula avoiding if conditions. We adjust difference "forward",
if (diff < (signed)-(MICROPY_PY_UTIME_TICKS_PERIOD / 2)) { // wrap it around and adjust back.
diff += MICROPY_PY_UTIME_TICKS_PERIOD; int32_t diff = ((end - start + MICROPY_PY_UTIME_TICKS_PERIOD / 2) & (MICROPY_PY_UTIME_TICKS_PERIOD - 1))
} else if (diff >= (signed)(MICROPY_PY_UTIME_TICKS_PERIOD / 2)) { - MICROPY_PY_UTIME_TICKS_PERIOD / 2;
diff -= MICROPY_PY_UTIME_TICKS_PERIOD;
}
return MP_OBJ_NEW_SMALL_INT(diff); return MP_OBJ_NEW_SMALL_INT(diff);
} }
MP_DEFINE_CONST_FUN_OBJ_2(mp_utime_ticks_diff_obj, time_ticks_diff); MP_DEFINE_CONST_FUN_OBJ_2(mp_utime_ticks_diff_obj, time_ticks_diff);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment