Important changes to forums and questions
All forums and questions are now archived. To start a new conversation or read the latest updates go to forums.mbed.com.
8 years, 9 months ago.
Current consumption in sleep STOP mode
Hi,
I am implementing by myself the mDot in STOP sleep mode, because libmdot only has STANDBY mode implemented. Measured STANDBY current with libmdot is about 35uA. In STOP mode I am obtaining 150 uA current, but I expect about 45uA. Could you guide me with the pin settings and peripheral configuration for the lower current consumption? And could you tell me which are the pins used by mdot that have to be changed in sleep mode? Does the new LDO in last hardware version have to be controlled to decrease the power consumption?
Thank you and regards, Gilen
Question relating to:
1 Answer
8 years, 9 months ago.
Hi Gilen,
I'm actually quite curious to hear how you got stop mode down that low. Would you be willing to share your application with us?
Cheers,
Mike
Hi Mike, I don´t do it with mbed and libmdot. I have implemented a porting of mDot to Contiki OS working with the transceiver in FSK modulation. I have configured all unused pins as analog inputs. And deinit all other pins to their less current state. But I think some other configuration is needed to achieve the optimum consumption. Cheers, Gilen
posted by 17 Mar 2016I think I recall seeing it that low. I did this with the mDot mbed library, but my own sleep routines (that I'm guessing are hardly any different then those in the mDot library). Like Gilen, I set all unused pins to the analog state (including JTAG and the oscillator pins). The LoRa radio has to have been configured so that it drops into its low power state. I also figured out that the SPI flash must have pull-downs on the write-protect and hold lines, as current consumption drops when I stop driving those lines. I think the only pins that remained in a non-analog state were the SPI bus to the SPI flash, and the pins to the LoRa radio.
You'll know if there's anything floating if you can put your fingers on the mDot and it alters the power consumption significantly.
posted by 17 Mar 2016Hi Michael, I have configured all GPIOs like you. The only difference is the pull_down of HOLD and WP of flash, I had pull_up, and it could be a little less current with pull-down but is not appreciated much. Now mDot is consuming between 145-150uA. If STANDBY mode is 35uA, and the datasheet says that lowest STOP mode is between 10-14uA, I will expect between 43-47uA. Any other suggestion? Thanks, Gilen
posted by 17 Mar 2016The Flash memory has a pull up on the CS line and a pull down on the WP line. So those pins don't need pull ups or pull downs activated. One issue is that the NSS pin (processor pin PB_12) of the SX1272 does not have a pull up on it. If the NSS line drops low enough, the SPI interface of the SX1272 can become active and draw up to 100 uA of current.
posted by 17 Mar 2016Took me longer than I wanted to get it back to what I remembered, but my mDot is currently sipping 39uA @ 3.3V while toggling pin PA_0 once per second. I was getting about what you were (150 uA), until I enabled a pull-down on the HOLD pin of SPI flash. See if that helps...
posted by 17 Mar 2016The one other thing to check would be the state of the MISO lines. These lines float when no slave has chip select asserted. The default for mbed does not have a pull selected for MISO, and the current consumption from the floating pin is noticeable in low power modes. If this doesn't help, paste all the pin settings you have and I'll see if there's anything obviously different.
posted by 18 Mar 2016Hi Michael,
These are my pin settings in sleep STOP mode.
The JTAG pins are all ANALOGIC inputs.
GpioInit( &ioPin, PA_0, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_1, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_2, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_3, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_4, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_5, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_6, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_7, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_8, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_9, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); TX
GpioInit( &ioPin, PA_10, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); RX
GpioInit( &ioPin, PA_11, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PA_12, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PB_0, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PB_1, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PB_2, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_DOWN, 0 ); BOOT1
GpioInit( &ioPin, PC_1, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PC_4, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); to GND
GpioInit( &ioPin, PC_5, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); to GND
GpioInit( &ioPin, PC_6, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_UP, 1 ); Flash CS
GpioInit( &ioPin, PC_7, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_DOWN, 0 ); Flash HOLD
GpioInit( &ioPin, PC_8, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); Flash WP
GpioInit( &ioPin, PC_9, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PC_10, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); Flash SCK
GpioInit( &ioPin, PC_11, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_DOWN, 0 ); FLash MISO
GpioInit( &ioPin, PC_12, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); Flash MOSI
GpioInit( &ioPin, PC_13, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &ioPin, PD_2, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); to GND
Is there anything different compared to your configuration?
Thank you and regards,
Gilen
posted by 18 Mar 2016Hi again,
The SX1272 transceiver pins are here:
GpioInit( &SX1272.Spi.Nss, RADIO_NSS, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_UP, 1 );
GpioInit( &SX1272.Spi.Mosi, RADIO_MOSI, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.Spi.Miso, RADIO_MISO, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_DOWN, 0 );
GpioInit( &SX1272.Spi.Sclk, RADIO_SCLK, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.DIO0, RADIO_DIO_0, PIN_INPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.DIO1, RADIO_DIO_1, PIN_INPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.DIO2, RADIO_DIO_2, PIN_INPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.DIO3, RADIO_DIO_3, PIN_INPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.DIO4, RADIO_DIO_4, PIN_INPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
GpioInit( &SX1272.DIO5, RADIO_DIO_5, PIN_INPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 );
Any suggestion?
Thanks, Gilen
posted by 18 Mar 2016Nothing is obviously jumping out at me. One change that might have lowered my power consumption (I can't remember if it did) was that I'm using the internal RC OSC, rather than the external crystal. Maybe try that?
posted by 21 Mar 2016Hi Michael,
I think that the PLL, HSI and HSE RC oscillators are all disabled when the micro enters in STOP mode. The only one active is LSE or LSI. mDot has a 32.768 kHz low-speed external crystal and I have tried my software with LSE and with LSI, but the current is similar.
You mentioned that your consumption was 39uA @ 3.3V, but I suppose that this is in STANDBY mode. This is the same current that I get with the libmdot library in the sleep STANDBY mode.
I request libmdot Multitech developers that support me with this low power STOP mode, please. What minimum current consumption could I expect with mDot? Any other idea to reduce this current?
Thank you and regards,
Gilen
posted by 22 Mar 2016Here's the line of code I use to enter STOP:
HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI);
So, pretty sure I'm not entering STANDBY (also given that my GPIO toggles, it has to be STOP as the variable to set/toggle the value lives on the stack and would get reset when exiting STANDBY mode).
I might have some time today to run an experiment for you, to see if I can recall the steps I took. I spent about a week getting the mDot into low enough power consumption that I can use it in an energy harvesting scenario. One of those steps was switching from the external crystal to the internal RC, mainly because I had to keep run-time current below a threshold. I don't have enough time to completely help you, so I can only throw out what I remember. But, do check the state of pins PH_0 and PH_1. It might have been that those float when the oscillators are disabled, but I don't remember.
posted by 22 Mar 2016Hi Michael,
Yes, the issue is somewhere there in PH_0 and PH_1. I have noticed it when I put my finger near the 26MHz crystal pads, and the amperimeter shows 80uA. The main loop of my application is running with external crystal and LSE.
I am trying to configure PH_0 and PH_1 as analogic inputs when the program goes to sleep. This is my code before going to STOP mode.
/* Enable HSI */
RCC_HSICmd( ENABLE );
/* Wait till HSI is ready */
while (RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET) {}
/* now switch to this source */
RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);
RCC_HSEConfig( RCC_HSE_OFF );
GpioInit( &ioPin, OSC_HSE_IN, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 1 );
GpioInit( &ioPin, OSC_HSE_OUT, PIN_ANALOGIC, PIN_PUSH_PULL, PIN_NO_PULL, 1 );
But when the GpioInit function is executed, my program jumps to HardFault_Handler. Does the STM32F411RE have any limitation with PH_0 and PH_1 as GPIO? Or am I doing anything wrong in those steps?
Thank you for your time and best regards,
Gilen
posted by 22 Mar 2016Did you enable the IO port H clock in RCC_AHB1ENR? I do basically the same as you, though I never enable HSE:
pin_function(PH_0, STM_PIN_DATA(STM_MODE_ANALOG, GPIO_PULLDOWN, 0)); pin_function(PH_1, STM_PIN_DATA(STM_MODE_ANALOG, GPIO_PULLDOWN, 0));
The reference manual doesn't indicate any limitations, just that HSE takes priority over GPIO if HSE is enabled.
posted by 22 Mar 2016Hi,
I had a problem with the GPIO driver and PortH pins. I have resolved it and the current is now 80uA. Could you confirm me that your mDot consumption in STOP mode is 40uA? If this is true, this should be my goal and there is still room for improvement. Thank you for your invaluable help. And if you remember any other adjustments to reduce this current, please let me know.
Best regards, Gilen
posted by 22 Mar 2016Yes, 40uA is what I saw.
Did you configure flash and the regulators? Such as:
HAL_PWREx_EnableMainRegulatorLowVoltage(); HAL_PWREx_EnableFlashPowerDown(); HAL_PWREx_EnableLowRegulatorLowVoltage();
See section 5.3.4 Stop mode in the Power controller (PWR).
posted by 22 Mar 2016I Michael,
In table 17 Stop operating modes, I am activating the STOP LPLV, that I think is the less current consumer. (LPLVDS and LPDS bits). Electrical characteristis in datasheet say 10uA.
Your configuration seems to be STOP MRLV. (MRLVDS and LPLVDS bits) Electrical characteristis in datasheet say 14uA.
Anyway, I will try these other configurations. I suggest you try the mode STOP LPLV , to verify if you save 4uA.
posted by 23 Mar 2016Hi again,
I am meassuring 54uA @ 3.3V just now. Previously I was measuring the current when powering with a Varta battery of 3V. With a laboratory power supply, I noticed that with voltage below 3V the current is 80uA and with upper voltages the current is 54uA. I don't know which is the explanation.
However, they spare me 14 uA to reach the goal of 40uA.
Regards,
Gilen
posted by 23 Mar 2016How can I do that?
I only have configured the GPIOs connected to SPI Flash.
GpioInit( &ioPin, PC_6, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_UP, 1 ); Flash CS
GpioInit( &ioPin, PC_7, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_DOWN, 0 ); Flash HOLD
GpioInit( &ioPin, PC_8, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); Flash WP
GpioInit( &ioPin, PC_10, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); Flash SCK
GpioInit( &ioPin, PC_11, PIN_OUTPUT, PIN_PUSH_PULL, PIN_PULL_DOWN, 0 ); FLash MISO
GpioInit( &ioPin, PC_12, PIN_OUTPUT, PIN_PUSH_PULL, PIN_NO_PULL, 0 ); Flash MOSI
Does I have to send any command by SPI? Do you know the Flash SPI reference to study its datasheet?
posted by 23 Mar 2016I have downloaded the Micron's M25P20 2Mbit Flash datasheet. I see that the command 0xB9 is needed to put it in deep power down (1-5 uA), and not in the default standby mode (10-50 uA).
Thanks for the hint, I'm sure this is the final solution. I will try this next week.
Have a nice weekend and happy Easter!
Gilen
posted by 23 Mar 2016