summaryrefslogtreecommitdiff
path: root/ports/esp8266/modmachine.c
diff options
context:
space:
mode:
Diffstat (limited to 'ports/esp8266/modmachine.c')
-rw-r--r--ports/esp8266/modmachine.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/ports/esp8266/modmachine.c b/ports/esp8266/modmachine.c
index ccde1e5ed..e20e8cb75 100644
--- a/ports/esp8266/modmachine.c
+++ b/ports/esp8266/modmachine.c
@@ -355,6 +355,35 @@ STATIC mp_obj_t machine_enable_irq(mp_obj_t state_in) {
}
MP_DEFINE_CONST_FUN_OBJ_1(machine_enable_irq_obj, machine_enable_irq);
+// Custom version of this function that feeds system WDT if necessary
+mp_uint_t machine_time_pulse_us(mp_hal_pin_obj_t pin, int pulse_level, mp_uint_t timeout_us) {
+ int nchanges = 2;
+ uint32_t start = system_get_time(); // in microseconds
+ for (;;) {
+ uint32_t dt = system_get_time() - start;
+
+ // Check if pin changed to wanted value
+ if (mp_hal_pin_read(pin) == pulse_level) {
+ if (--nchanges == 0) {
+ return dt;
+ }
+ pulse_level = 1 - pulse_level;
+ start = system_get_time();
+ continue;
+ }
+
+ // Check for timeout
+ if (dt >= timeout_us) {
+ return (mp_uint_t)-nchanges;
+ }
+
+ // Only feed WDT every now and then, to make sure edge timing is accurate
+ if ((dt & 0xffff) == 0xffff && !ets_loop_dont_feed_sw_wdt) {
+ system_soft_wdt_feed();
+ }
+ }
+}
+
STATIC const mp_rom_map_elem_t machine_module_globals_table[] = {
{ MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_umachine) },
{ MP_ROM_QSTR(MP_QSTR_mem8), MP_ROM_PTR(&machine_mem8_obj) },