machine.lightsleep makes time.sleep_ms takes more time on every call
Port, board and/or hardware
rp2040
MicroPython version
MicroPython v1.23.0 on 2024-06-02; Raspberry Pi Pico with RP2040
Reproduction
while True:
# omitted code to turn led on and off
time.sleep_ms(500)
machine.lightsleep(4000)
Expected behaviour
every call to time.sleep_ms(500) should take the same time
Observed behaviour
the led take more and more time to turn on and off after the same sleep_ms()
Additional Information
No, I've provided everything above.
Code of Conduct
Yes, I agree
RP2350 the watchdog timer does not count down while lightsleep is running
Port, board and/or hardware
Raspberry Pi Pico2
MicroPython version
MicroPython v1.25.0 on 2025-04-15; Raspberry Pi Pico2 with RP2350
Reproduction
Copy the following into wdt_lightsleep_2350.py.
from machine import lightsleep, WDT
from time import sleep_ms
wdt = WDT(timeout=5000)
lightsleep(3000)
sleep_ms(3000)
print('Should not print')
sleep_ms(3000)
Do 'mpremote run wdt_lightsleep_2350.py'.
Expected behaviour
Expect the same behavior seen when the lightsleep is replaced with sleep_ms.
File wdt_sleep_ms_2350.py
from machine import lightsleep, WDT
from time import sleep_ms
wdt = WDT(timeout=5000)
sleep_ms(3000)
sleep_ms(3000)
print('Should not print')
sleep_ms(3000)
>> mpremote run wdt_sleep_ms_2350.py
Traceback (most recent call last):
File "/home/picompute/.local/bin/mpremote", line 8, in <module>
sys.exit(main())
Note: most of traceback removed.
This time the print did not execute because the watchdog timer triggered during the second sleep_ms(3000).
Observed behaviour
The print statement does execute and the watchdog timer triggers during the last sleep_ms(3000).
>> mpremote run wdt_lightsleep_2350.py
Should not print
Traceback (most recent call last):
File "/home/picompute/.local/bin/mpremote", line 8, in <module>
sys.exit(main())
Note: most of traceback removed.
Additional Information
I have changes to lightsleep in modmachine.c which fix this problem.
I will prepare a pull request with this fix.
The root cause is the watchdog timer does not count down while lightsleep() is running.
This problem is RP2350 specific and is not seen on RP2040.
Code of Conduct
Yes, I agree