diff options
author | Damien George <damien.p.george@gmail.com> | 2020-03-20 13:40:01 +1100 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2020-03-20 13:40:01 +1100 |
commit | 8d34344dceb367844b651deccadff2b55f20c55c (patch) | |
tree | 7b6d3ccf585303374c248fae2c5d9e53067a0135 | |
parent | 19ea30bdd551fedab493f26d5d6c33a6b39bb49b (diff) |
esp8266/modmachine: Implement machine.soft_reset().
Fixes issue #5764.
-rw-r--r-- | ports/esp8266/modmachine.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/ports/esp8266/modmachine.c b/ports/esp8266/modmachine.c index e6be0c1af..bb7a780a3 100644 --- a/ports/esp8266/modmachine.c +++ b/ports/esp8266/modmachine.c @@ -30,6 +30,7 @@ #include "py/obj.h" #include "py/runtime.h" +#include "lib/utils/pyexec.h" // This needs to be set before we include the RTOS headers #define USE_US_TIMER 1 @@ -77,6 +78,12 @@ STATIC mp_obj_t machine_reset(void) { } STATIC MP_DEFINE_CONST_FUN_OBJ_0(machine_reset_obj, machine_reset); +STATIC mp_obj_t machine_soft_reset(void) { + pyexec_system_exit = PYEXEC_FORCED_EXIT; + mp_raise_type(&mp_type_SystemExit); +} +STATIC MP_DEFINE_CONST_FUN_OBJ_0(machine_soft_reset_obj, machine_soft_reset); + STATIC mp_obj_t machine_reset_cause(void) { return MP_OBJ_NEW_SMALL_INT(system_get_rst_info()->reason); } @@ -392,6 +399,7 @@ STATIC const mp_rom_map_elem_t machine_module_globals_table[] = { { MP_ROM_QSTR(MP_QSTR_freq), MP_ROM_PTR(&machine_freq_obj) }, { MP_ROM_QSTR(MP_QSTR_reset), MP_ROM_PTR(&machine_reset_obj) }, + { MP_ROM_QSTR(MP_QSTR_soft_reset), MP_ROM_PTR(&machine_soft_reset_obj) }, { MP_ROM_QSTR(MP_QSTR_reset_cause), MP_ROM_PTR(&machine_reset_cause_obj) }, { MP_ROM_QSTR(MP_QSTR_unique_id), MP_ROM_PTR(&machine_unique_id_obj) }, { MP_ROM_QSTR(MP_QSTR_idle), MP_ROM_PTR(&machine_idle_obj) }, |