Official Espruino boards come with one of two different types of processor:
nRF52 devices are used in newer Espruino products. On these, Espruino is able to enter low power sleep modes automatically. Out of the box, power consumption is around 20uA (0.02mA) or over a year on a CR2032 battery.
Mode | nRF52 devices | Notes |
---|---|---|
Run | 4-8mA | Processing JavaScript |
Sleep with HSE on | ~1mA | USART/Serial or high speed timer in use |
Sleep with Bluetooth advertising | 0.02mA - 0.08mA | The default when not executing code |
Sleep | 0.003mA | With bluetooth advertising disabled |
Power usage varies slightly with the board used (based on voltage regulators and peripherals), so for detailed power usage stats see:
Espruino on STM32 can run in one of 3 different modes.
Mode | nRF52 devices (see below) | Original Espruino 1v4 | Pico/WiFi | Notes |
---|---|---|---|---|
Run | ~5mA | ~35mA | 32mA | Espruino is executing code and running at full speed |
Sleep | - | ~12mA | ~11mA | Espruino has stopped the clock to the CPU, but all peripherals are still running and can wake it up |
Stop | 0.003mA | ~0.03mA | 0.02mA | Espruino has stopped the clock to everything except the real-time clock (RTC). It can wake up on setInterval/setTimeout or setWatch |
Note: Standby mode is available on the STM32 chip (very low power, but all data is lost from RAM). It is not currently used in Espruino.
This is the normal low-power mode for Espruino on STM32. You don't have to do anything to enter this at all, Espruino will enter this mode whenever it isn't doing anything.
This is the best low-power mode in Espruino on STM32, which involves turning off the main clock (which stops all peripherals) and waking only when an external pin changes state or after a set amount of time. It is only enabled when you run setDeepSleep(1)
(you can turn it off with setDeepSleep(0)
). It's not enabled by default because:
setDeepSleep(0)
has been called).For deep sleep to work, you must:
setDeepSleep(1)
digitalPulse(...)
command that is yet to finishNote: Espruino won't enter deep sleep as soon as you execute setDeepSleep(1)
. It'll wait until all the bullet points above are satisfied, and then it'll enter it. For example you can type setDeepSleep(1)
while you're connected to your PC via USB, and Espruino will only enter deep sleep mode once you unplug from USB.
setDeepSleep(...)
sets a flag internally - so you only need to call it once (not each time you want to go to sleep).
You can wake after a set amount of time - for example to flash an LED every 60 seconds:
setInterval(function() {
digitalWrite(LED1, 1);
setTimeout(function () {
digitalWrite(LED1, 0);
}, 20);
}, 60000);
setDeepSleep(1);
or you can wake when an external pin changes state - for instance to flash an LED when pressing the button:
setWatch(function() {
digitalWrite(LED1, 1);
setTimeout(function () {
digitalWrite(LED1, 0);
}, 20);
}, BTN, true);
setDeepSleep(1);
You can call functions to help with debugging:
setSleepIndicator(LED1)
will light LED1 whenever the device is not sleeping, allowing you to make sure it is sleeping as much as possible.setBusyIndicator(LED2)
will light LED2 when Espruino is not sleeping and is busy executing JavaScriptThere is currently no way to see when Espruino has entered Deep Sleep.
Note that Espruino won't go to sleep when it is connected via USB, as it knows it has ample power available.
If you don't have a dedicated Power Usage meter, the best way to measure power draw is to connect a multimeter in series with a battery and power Espruino from that. You'll then get a good idea of exactly how much power is being used.
If Espruino is not sleeping, check that you haven't called setInterval
with a small timeout. For instance you may have been controlling model aircraft servos or something similar, but if they are already in the correct position you can call clearInterval(...)
to ensure that Espruino is not having to wake up as often.
Bear in mind that lighting just one LED light can use more power than the entire CPU. Don't turn on LEDs when sleeping, and be sure that Espruino isn't powering anything externally. If you've used outputs, you may be able to set them to 'float' either by reading the value with digitalRead
or by using pinMode(pin, "input")
to change the state of the pin to input.
This page is auto-generated from GitHub. If you see any mistakes or have suggestions, please let us know.