CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Timer1 during sleep high consumption

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

Timer1 during sleep high consumption
PostPosted: Sat Jun 28, 2014 3:04 pm     Reply with quote

Hi all, I'm working in a simple idea: any time I press a button, MCU has to wake up and write current timer in the memory.
Device will be in sleep mode 99% of the time, maybe only press the button 4 or 5 times in a day.

I'm using PIC16LF1459 with a button cell, and my problem is power consumption during sleep.

I don't need real time, just a counter, when I start up the device it starts counting from zero, I don't need an accurate counter.

I checked sleep mode, power consumption is only 0.1uA or less, and it can interrupt when I press the button.

The problem is to calculate time during sleep. I'm using timer1 during sleep with an external 32khz crystal.

But the device wake-up on an overflow and this consumes a lot of power, I checked power during sleep in this case, one second 0.1uA, one second 700uA, changing continuously. Is this normal ?

Please I need help with these questions:

1. Can I use timer1 during sleep, without using interrupt on overflow ? I only want my device to wake up when I press the button.

2. If device must wake-up on an overflow to keep timer1 counting, what power consumption is good ? I think 700uA is very high.

3. I'm thinking about another option: Not to use sleep mode. Then I will try to disable all peripherals, and leave timer1 running. Can I use LFINTOSC in this case ? Or is it better to use LP mode with external crystal ?What power consumption can I expect in this case ?

Data sheet, page 1: Timer1 Oscillator: 600 nA @ 32 kHz, typical. Is it possible to disable everything, and leave only Timer1 running with less than 1uA ?. This is much better than sleep mode for me.

Any help would be appreciated

Thanks
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sat Jun 28, 2014 4:08 pm     Reply with quote

Quote:
I checked power during sleep in this case, one second 0.1uA, one second
700uA, changing continuously.

It shouldn't run 700ua for one second. Post your test program. Make it short but complete (compilable, with #fuses, etc.).
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

PostPosted: Sat Jun 28, 2014 4:44 pm     Reply with quote

Ok, I will post my code on monday (not at home now)
I'm reading power consumption using a multimeter, it is hard to read because it changes. But before I enable timer1 power consumption was always 0.1uA.
Is it normal that power changes due to timer1 interrupt ? What should I expect ?
I will be very happy if I can get a continuous 5uA during sleep
Ttelmah



Joined: 11 Mar 2010
Posts: 19615

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 1:00 am     Reply with quote

Even 0.1uA is rather high....

Critical thing with 'sleep' is to make _sure_ you set everything to reduce power. Things that are often missed are that (for example), a pin left floating as an 'input', will draw more power, than the same pin set as an output!. A floating pin, if it floats into the 'transition region' (where the internal gate is switching levels), results in a spike of power every time it switches. The output FET set to drive, provided there is no load, draws almost nothing.
However you do say 'or less', so things probably are OK.

The 700uA though is silly. It suggests something is happening like a pin being driven in your 'I'm awake' code. Key is that your sequence should be to just handle incrementing the timer overflow register, if this is the cause of waking, and then go straight back to sleep. It possibly sounds as if the code is going straight into the 'do something' part of your code, assuming the button was the reason for waking, and only after a lot of time, 'realising' this wasn't the case. If handled correctly, the extra power will be under a couple of uA, for just a handful of uSec every couple of seconds.

You want the overflow, or the timer can't give you a 'time' beyond a couple of seconds, or a 'count' beyond 65535.

Best Wishes
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 4:53 am     Reply with quote

Thanks for your reply.

Sometimes I get 0.1uA, and sometimes 0.0uA, my multimeter cannot read less than 0.1uA.

What you said give me a lot of hope, that means power should be 0.1uA during 2 seconds, and 2uA during 1u second.

I'm very new to microchip, and I'm not sure of my results.
During wake-up, if PIC16 HFINTOSC run at 4Mhz, that means power should be only 100uA ? Datasheet page 1: Operating Current: 25 uA/MHz @ 1.8V, typical.
I got around 2mA, but Im using 3.6v battery.

By the way, I have 2 load caps with the external crystal, but I see some designs using only crystal, without caps.
How can that be done ? If I use a crystal with only 4pF load cap, can it work without caps ?
For example this one:
www.abracon.com/Resonators/ABS06-107-32.768kHz-T.pdf

Edit: Thoses design are with TI mcu or Atmel mcu, maybe those mcu have built-in load capacitors. Anybody tried with PIC ?
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 2:32 am     Reply with quote

Compiler 5.015

Code:

MCU used : PIC16LF1459

Clock : 2MHz while sleep
Compile used : CCS

// Fuse settings fCCS compiler

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES NOBROWNOUT               //No brownout reset
#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
 #fuses MCLR
   #fuses PUT
   #fuses NOWDT


Void timer1_interrupt()
{

second++;
time_sleep++;

if(second>59)
{
second=0;
minute++;

}

if(minute>59)
{
minute=0;
hour++;
}

if(hour>23)
{
hour=0;
day++;
}

}


Sleep command settings used


// Timer1 settings
enable_interrupts(INT_TIMER1);
   enable_interrupts(GLOBAL);

// t1con reg settings
TMR1CS0=0;
T1CKPS1=0;
T1CKPS0=0;
T1OSCEN=1;  //1
T1SYNC=1;
TMR1ON=1;

// End timer1 settings

 USBEN=0; // USB disable
SDO_TRIS=0;  // SPI SDO
SCK_TRIS=0;  // SPI_SCK
//SDI_TRIS=0;
SPI_DO = 0;
SPI_SCK = 0;

output_bit(PIN_B4,0); // clear pins unused
output_bit(PIN_B6,0);
output_c(0x00);   
output_bit(CS,1);
IOCBN=0x00;
IOCB7=1;     // wake up interrupt
INTCONRABIE=1;
INTCONRABIF=0;
SLEEP();
Ttelmah



Joined: 11 Mar 2010
Posts: 19615

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 3:07 am     Reply with quote

First, start to use CCS!....

For example, the timer setup, is one line, using the 'setup_timer_1' command in CCS.

Then 'rethink' slightly.

Basically, get rid of the global interrupt enable. Then work like:
Code:

   output_low(PIN_B4); // clear pins unused
   output_low(PIN_B6);
   output_c(0x00);   
   output_high(CS);
   disable_interrupt(GLOBAL);
   enable_interrupt(INT_TIMER1);
   enable_interrupt(INT_RB7);
   //Now chip will wake on a change of RB7, or on the timer
   do
   {
       sleep();
       delay_cycles(1); //the instruction after a sleep should always be
       //a 'NOP'. This instruction is 'prefetched' when you sleep, and can
       //give unexpected results.
       if (INTERRUPT_ACTIVE(INT_RB))
       {
           //Handle your RB7 changed interrupt here
           // - remember must read the port and should clear the changed
           //latch as well as clearing the interrupt.

       }
       if (interrupt_active(INT_TIMER1))
       {
           timer1_interrupt(); //call the handler for the timer
           clear_interrupt(INT_TIMER1);
           //and go back to sleep ASAP
       }
    } while (TRUE); //unless you want to exit the loop


The point is that you don't want to waste time actually calling an interrupt handler. Two interrupts are enabled, and can therefore wake the chip. All you do, is test which one (or both) have triggered, handle their jobs, and as soon as you have done this, go back to sleep.
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 3:54 am     Reply with quote

Worked! thanks so much.

With SPI flash connected, without timer I got 6.6uA.
Now, with SPI flash, and timer working during sleep, I got 7.9uA.

Do you think it is a good result ?
Ttelmah



Joined: 11 Mar 2010
Posts: 19615

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 4:42 am     Reply with quote

The flash is obviously the big 'drinker' here. Question perhaps whether there is a lower power version/equivalent, or whether you can fully disable this (FET to turn off it's supply!...)?. However the 1.3uA sounds a much more sensible figure from the PIC. Smile

6.6uA, from something like a 240mAHr coin cell, would potentially give over 4 years operation....

Best Wishes
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 5:40 am     Reply with quote

Ttelmah, I really appreciate your great support, thanks again :-)

By the way, do you know anything about this:

Quote:
I have 2 load caps with the external crystal, but I see some designs using only crystal, without caps.
How can that be done ? If I use a crystal with only 4pF load cap, can it work without caps ?
For example this one:
www.abracon.com/Resonators/ABS06-107-32.768kHz-T.pdf
Ttelmah



Joined: 11 Mar 2010
Posts: 19615

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 7:40 am     Reply with quote

There are chips specifically designed to do this. For instance the DS1307 RTC. It has slightly higher than normal pin capacitances on the oscillator pins, and specifies a crystal load capacitance (12.5pF).

Now, you have to think carefully, since the capacitance seen by the crystal, is not the pin capacitance. It is the capacitance _between_ the pins that is seen as the crystal load. With just the pins, and PCB, these two capacitances paralleled together, in series with each other. This is why (for instance), you will typically see something like 30pF capacitors being used on crystals with 20pF specified capacitance. It sees the 30pF, paralleled by the track capacitance (perhaps 5pF), and the pin capacitance (another 4 to 5pF), all paralleled together (40pF), in series with the same capacitances on the other pin, giving 20pF across the crystal.

Most crystals will happily oscillate without the correct capacitance, just be slightly more 'in error', than they are specified to be. With a crystal designed for a low capacitance like 4pF, provided your pad layout is reasonably careful (so only gives perhaps 4 to 5pF of capacitance), you will be very close indeed to the correct value. The unit is designed for exactly this reason.
gabirelms



Joined: 28 Jun 2014
Posts: 38

View user's profile Send private message

PostPosted: Mon Jun 30, 2014 7:52 am     Reply with quote

I'm already placing my order in digi-key. Thanks Smile
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
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