|
|
View previous topic :: View next topic |
Author |
Message |
Plater
Joined: 21 Feb 2013 Posts: 8
|
12LF1822 POWER TEST |
Posted: Fri Feb 22, 2013 8:35 am |
|
|
I am trying to put my 12LF1822 to sleep in a manner which uses the least amount of power.
I am using the 8pin package.
My compiler version is 4.140
I made this sample program to put it to sleep so I could measure current draw.
Code: |
#include <12LF1822.h>
#FUSES INTRC_IO //Internal RC Osc, no CLKOUT
#FUSES WDT_SW //No Watch Dog Timer, enabled in Software
#FUSES PUT //Power up Timer
#FUSES PLL_SW //4X HW PLL disabled, enabled in Software
#FUSES NOLVP //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#use delay(clock=31000)
#define LED_LIGHT_PIPE PIN_A4
void main()
{
setup_oscillator(OSC_31KHZ |OSC_INTRC | OSC_PLL_OFF);
port_a_pullups(0x00);//no pullups?
setup_wdt(WDT_OFF);
output_low(LED_LIGHT_PIPE);//turn LED OFF
sleep();//For this purpose just go to sleep forever
//you should never get here, but just for sanity:
output_high(LED_LIGHT_PIPE);//turn LED on
for(;;) { delay_ms(1000); }
}
|
The power source is about 3.50 volts from a lithium battery. It is regulated to 2.75 volts for the pic.
The measured current is about 84microAmps. I believe it should be closer to 20micros.
Is there anything more I should be doing with the code to cut power? |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9229 Location: Greensville,Ontario
|
|
Posted: Fri Feb 22, 2013 8:59 am |
|
|
While I do not use that PIC a 'general' comment.
You'll need to read the datasheet and disable any and all internal peripherals you are not using.SPI,ADC,PLL all consume power and PICs typically default the ADC 'on'..
Check the 'fuses' options too,some default values may consume more power.
Buried in the datasheets are the details..and I KNOW reading 400-500 pages can be ,well, boring..but in there is the stuff you need to know if you want ultra low power.
I gave up on the quest for super low power decades ago.Adding a second battery was a lot cheaper ,more reliable solution in getting products off the R&D bench and into the field.
hth
jay |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19520
|
|
Posted: Fri Feb 22, 2013 9:06 am |
|
|
Also, the other 'classic' with sleep is that _all_ the pins must not be left floating.
Pins must either be driven by external circuits, that pull them 'to' a rail (even just resistors), or must be driven by the internal drivers, to a state that draws the least power. The latter draws a fraction more power than driving the pins externally (but it is pA).
Currently, all the pins except A4, if they are not connected externally, are floating. If they float into the gate transition region, power consumption will shoot up.....
Best Wishes |
|
|
Plater
Joined: 21 Feb 2013 Posts: 8
|
|
Posted: Fri Feb 22, 2013 9:12 am |
|
|
Ahh yes, I had heard not to float pins but wasnt sure which way to pull them.
In another thread someone stated that peripherals default to off, and that sometimes using the setup commands (like setup_SPI(ss_disabled)) will actually turn them on when you don't want to.
I try to read the spec sheets but there seems to be nothing in common between pics so everytime I switch, i have to figure out what everything is called all over again. Ugh. I will try that out. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19520
|
|
Posted: Fri Feb 22, 2013 9:24 am |
|
|
A lot of clocked peripherals do stop, but remain turned on internally.
However the key problem in the line you post, is that setup_SPI(ss_disabled), _will_ turn on the SPI, since it is an incorrect command.....
The command to turn off the SPI, is setup_spi(FALSE); ss_disabled, says 'turn off slave select', but turn _on_ everything else. It is a faulty command from the 'wizard', and should never be used.
Best Wishes |
|
|
Plater
Joined: 21 Feb 2013 Posts: 8
|
|
Posted: Fri Feb 22, 2013 2:27 pm |
|
|
Ttelmah wrote: | A lot of clocked peripherals do stop, but remain turned on internally.
However the key problem in the line you post, is that setup_SPI(ss_disabled), _will_ turn on the SPI, since it is an incorrect command.....
The command to turn off the SPI, is setup_spi(FALSE); ss_disabled, says 'turn off slave select', but turn _on_ everything else. It is a faulty command from the 'wizard', and should never be used.
Best Wishes |
The reason why I question it is because FALSE is defined as 0 and SPI_DISABLED is also defined as 0. So I figured there had to be more to it.
Turning off all the devices(I suspect just the A2D was on) saved me another 20microamps. Putting me down to 60micros in sleep.
I will have to talk to the hardware guy when he gets back. |
|
|
ckielstra
Joined: 18 Mar 2004 Posts: 3680 Location: The Netherlands
|
|
Posted: Fri Feb 22, 2013 4:16 pm |
|
|
Plater wrote: | The reason why I question it is because FALSE is defined as 0 and SPI_DISABLED is also defined as 0. So I figured there had to be more to it. | You referred to SS_DISABLED, this one isn't zero and should only be used in the slave. Using SS_DISABLED on it's own actually enables SPI. This wrong configuration can be found in many code samples on this forum as the early CCS v4 Code Wizards did it wrong.
For the low power issue, search this forum. The topic has been discussed several times before with many useful tips.
A few threads that I found in two minutes Googling and will be helpful to you:
here they found out that disabling the fail-safe clock (enabled by default) safes a few dozens of uA. Code: |
#FUSES NOFCMEN //Fail-safe clock monitor disabled |
Already mentioned above is that floating inputs can create current consumption caused by oscillation. A nice variation on this theme that I never heard of before is this recent thread where a LED connected to the Open Collector input A4 caused extra current flow. Driving the output high (to switch the LED off) actually created a floating input because the push FET is missing. Easily solved with a 100k resistor over the LED. |
|
|
Plater
Joined: 21 Feb 2013 Posts: 8
|
|
Posted: Mon Feb 25, 2013 9:00 am |
|
|
Ah ha! Ok I see the difference between SPI_DISABLED and SPI_SS_DISABLED disabled now. That was my typo.
I only searched for my specific PIC chip when looking for power savings, wasnt sure how much translated between pics.
Unfortuantely I found no difference in power consumption with and without the NOCFM line.
Your comment on the LED pin went over my head. But my led pin goes to a 100k resister then into the LED then to ground. I don't know if that follow the pattern you described or not.
My revised code so far
Code: |
#include <12LF1822.h>
#FUSES INTRC_IO //Internal RC Osc, no CLKOUT
#FUSES NOWDT //No Watch Dog Timer
#FUSES PUT //Power up Timer
#FUSES PLL_SW //4X HW PLL disabled, enabled in Software
#FUSES NOLVP //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES NOBROWNOUT //No brownout reset
#FUSES NOFCMEN //Fail-safe clock monitor disabled
#use delay(clock=31000)
#define P_DATA_IN PIN_A0
#define P_CLOCK_IN PIN_A1
#define BAT_VOLTAGE PIN_A2
#define MCLR PIN_A3
#define LED_LIGHT_PIPE PIN_A4
#define EPA_CONNECTED PIN_A5
void main()
{
setup_oscillator(OSC_31KHZ |OSC_INTRC | OSC_PLL_OFF);
port_a_pullups(0x00);//no pullups?
//setup_wdt(WDT_OFF);//turned off with a fuse
//setup_timer_0(T0_DISABLED);there is no disable?
setup_timer_1(T1_DISABLED);
setup_timer_2(T2_DISABLED,1,1);
SETUP_CCP1(CCP_OFF);
setup_comparator(NC_NC);
setup_vref(VREF_OFF);
SETUP_DAC(DAC_OFF);
setup_adc_ports(NO_ANALOGS);
setup_adc(ADC_OFF);
setup_spi(FALSE);//
output_low(P_DATA_IN);//
output_low(P_CLOCK_IN);
input(BAT_VOLTAGE);
output_low(MCLR);
output_low(LED_LIGHT_PIPE);//turn LED OFF
//EPA_CONNECTED is driven elsewhere by a physical jumper
//output_high(BAT_SENSE_ENABLE);//This pin will be an A2D pin later
sleep();//For this purpose just go to sleep forever
//you should never get here, but just for sanity:
output_high(LED_LIGHT_PIPE);//turn LED on
for(;;) { delay_ms(1000); }
}
|
|
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|