View previous topic :: View next topic |
Author |
Message |
ipq
Joined: 20 Aug 2015 Posts: 17
|
pic24fj128ga310 + CCS 5.051 = DEEP SLEEP mode not working! |
Posted: Fri Aug 26, 2016 8:35 am |
|
|
Hello,
I know this is a very frequent question but I tried to solve it by searching on the forum and I failed...
This is my source code:
main.h
Code: |
#include <24FJ128GA310.h>
#device ICSP=1
#use delay(internal=8000000)
#FUSES NOWDT //No Watch Dog Timer
#FUSES LVR //Low Voltage Regulator Enabled, Controlled in Software
#FUSES PROTECT //Code protected from reads
#FUSES NOJTAG //JTAG disabled
//#FUSES NOCKSNOFSM //Clock Switching is disabled, fail Safe clock monitor is disabled
#FUSES WPCFG //Configuration Words page is erase/write-protected
#FUSES NODSWDT //Deep Sleep Watchdog Timer disabled
|
main.c
Code: |
#include <main.h>
void main()
{
//Example blinking LED program
while(true)
{
setup_adc_ports(NO_ANALOGS);
setup_vref(VREF_DISABLED);
output_a(0);
output_b(0);
output_c(0);
output_d(0);
output_e(0);
output_f(0);
output_g(0);
//output_high(PIN_D4 | PIN_D5);
output_high(PIN_D4);
output_high(PIN_D5);
output_high(PIN_F6);
output_high(PIN_G2);
output_low(PIN_D11);
output_low(PIN_E4);
output_low(PIN_D0);
output_low(PIN_D1);
output_low(PIN_D2);
output_low(PIN_D3);
disable_interrupts(INTR_GLOBAL);
sleep(SLEEP_FULL);
}
}
|
I'm running this source code is a very simple board with the mcu a couple of leds and a buzzer.
It is strange but I cannot decrease the consumption under 9mA.
The content of the *.lst
Code: |
00000: GOTO 200
.................... #include <main.h>
.................... #include <24FJ128GA310.h>
.................... //////////// Standard Header file for the PIC24FJ128GA310 device ////////////////
.................... ///////////////////////////////////////////////////////////////////////////
.................... //// (C) Copyright 1996, 2014 Custom Computer Services ////
.................... //// This source code may only be used by licensed users of the CCS C ////
.................... //// compiler. This source code may only be distributed to other ////
.................... //// licensed users of the CCS C compiler. No other use, reproduction ////
.................... //// or distribution is permitted without written permission. ////
.................... //// Derivative programs created using this software in object code ////
.................... //// form are not restricted in any way. ////
.................... ///////////////////////////////////////////////////////////////////////////
.................... #device PIC24FJ128GA310
....................
.................... #list
....................
.................... #device ICSP=1
.................... #use delay(internal=8000000)
....................
.................... #FUSES NOWDT //No Watch Dog Timer
.................... #FUSES LVR //Low Voltage Regulator Enabled, Controlled in Software
.................... #FUSES PROTECT //Code protected from reads
.................... #FUSES NOJTAG //JTAG disabled
.................... //#FUSES NOCKSNOFSM //Clock Switching is disabled, fail Safe clock monitor is disabled
.................... #FUSES WPCFG //Configuration Words page is erase/write-protected
.................... #FUSES NODSWDT //Deep Sleep Watchdog Timer disabled
....................
....................
....................
.................... #define LED PIN_E9
.................... #define DELAY 250
....................
.................... //#bit DSEN = DSCONH.7
....................
....................
....................
.................... void main()
*
00200: MOV #2780,W15
00202: MOV #27FF,W0
00204: MOV W0,20
00206: NOP
00208: BSET.B 81.7
0020A: MOV #0,W0
0020C: MOV W0,384
0020E: MOV #FFFF,W0
00210: MOV W0,386
00212: CLR 744
00214: MOV.B #5,W0L
00216: MOV.B W0L,588
00218: CLR 4E0
0021A: CLR 4E2
0021C: CLR 4E4
0021E: CLR 4E6
00220: CLR 4E8
00222: CLR 4EC
.................... {
....................
.................... //Example blinking LED program
.................... while(true)
.................... {
....................
.................... setup_adc_ports(NO_ANALOGS);
00224: CLR 4E0
00226: CLR 4E2
00228: CLR 4E4
0022A: CLR 4E6
0022C: CLR 4E8
0022E: CLR 4EA
00230: CLR 4EC
00232: MOV #0,W0
.................... setup_vref(VREF_DISABLED);
00234: CLR 632
....................
.................... output_a(0);
00236: CLR 2C0
00238: CLR 2C4
.................... output_b(0);
0023A: CLR 2C8
0023C: CLR 2CC
.................... output_c(0);
0023E: CLR 2D0
00240: CLR 2D4
.................... output_d(0);
00242: CLR 2D8
00244: CLR 2DC
.................... output_e(0);
00246: CLR 2E0
00248: CLR 2E4
.................... output_f(0);
0024A: CLR 2E8
0024C: CLR 2EC
.................... output_g(0);
0024E: CLR 2F0
00250: CLR 2F4
....................
.................... //output_high(PIN_D4 | PIN_D5);
.................... output_high(PIN_D4);
00252: BCLR.B 2D8.4
00254: BSET.B 2DC.4
.................... output_high(PIN_D5);
00256: BCLR.B 2D8.5
00258: BSET.B 2DC.5
....................
.................... output_high(PIN_F6);
0025A: BCLR.B 2E8.6
0025C: BSET.B 2EC.6
.................... output_high(PIN_G2);
0025E: BCLR.B 2F0.2
00260: BSET.B 2F4.2
....................
.................... output_low(PIN_D11);
00262: BCLR.B 2D9.3
00264: BCLR.B 2DD.3
.................... output_low(PIN_E4);
00266: BCLR.B 2E0.4
00268: BCLR.B 2E4.4
....................
.................... output_low(PIN_D0);
0026A: BCLR.B 2D8.0
0026C: BCLR.B 2DC.0
.................... output_low(PIN_D1);
0026E: BCLR.B 2D8.1
00270: BCLR.B 2DC.1
.................... output_low(PIN_D2);
00272: BCLR.B 2D8.2
00274: BCLR.B 2DC.2
.................... output_low(PIN_D3);
00276: BCLR.B 2D8.3
00278: BCLR.B 2DC.3
....................
....................
.................... disable_interrupts(INTR_GLOBAL);
0027A: BCLR.B 81.7
0027C: MOV #E0,W4
0027E: MOV W4,42
00280: BSET.B 81.7
....................
.................... sleep(SLEEP_FULL);
00282: PWRSAV #0
00284: GOTO 224
.................... }
....................
.................... }
00288: PWRSAV #0
|
Configuration Fuses:
Code: |
Word 1L: 1B9F WPOSTS16 WDT128 NOWDT WINDIS ICSP1 LVR NODEBUG NOWRT PROTECT NOJTAG
H: 0000
Word 2L: FFFF NOPR IOL1WAY NOOSCIO FRC_PS VREFNORM_CVREFNORM IESO
H: 0000
Word 3L: BEFF WPFP VBATBOR SOSC_DIG WDTWIN_25% BROWNOUT WPDIS WPCFG WPEND
H: 0000
Word 4L: FF7F DSWDTCK_LPRC DSBOR NODSWDT DS_SW
H: 0000
|
Any word of wisdom???
Thank you in advance!!! |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Fri Aug 26, 2016 9:56 am |
|
|
Post your schematic.
How to post an image on the CCS forum:
Go to this website: http://postimage.org/
Upload your image. Select family safe. Then click the first button for
"Hotlink to Forum" to get a link to the image.
Then go to the CCS forum and type Ctrl-V to paste the link into a post.
If postimage.org doesn't work in your country, then use Google to find
another free image hosting site for forums. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19552
|
|
Posted: Fri Aug 26, 2016 1:18 pm |
|
|
One suggestion. Try setting Port C.14 as an input.
Not sure what the default SOSC configuration is, and you are not explicitly setting this in the fuses. Wondering about Note 2 on table 29-3. |
|
|
ipq
Joined: 20 Aug 2015 Posts: 17
|
Schematic |
Posted: Mon Aug 29, 2016 3:25 am |
|
|
Hello,
See schematic on: http://tinyurl.com/deepsleep-pic24
This is the complete schematic of the pcb in which we want to decrease the consumption. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9246 Location: Greensville,Ontario
|
|
Posted: Mon Aug 29, 2016 7:07 am |
|
|
just a couple of comments from a 'dinosaur'..
1) the schematic would be a lot easier to read if all +5V terminations were 'pointing up' and all grounds were pointing 'down'. yeah I'm old but was taught that way. Same holds true for the 32KHz xtal layout
2) the Vbat PIC pin goes to 3volts, seems to be fed from the regulator. if so why bother with deep sleep as it appears the PIC is 'line' powered.
3) looks like that PIC has onboard USB, so be sure you can configure those D+, D- pins for alternate use. Some PICs can't.
Jay |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19552
|
|
Posted: Mon Aug 29, 2016 7:23 am |
|
|
Look at figure 2-2 in the data sheet.
Read this paragraph:
"During programming and debugging, the resistance
and capacitance that can be added to the pin must
be considered. Device programmers and debuggers
drive the MCLR pin. Consequently, specific voltage
levels (VIH and VIL) and fast signal transitions must
not be adversely affected. Therefore, specific values
of R1 and C1 will need to be adjusted based on the
application and PCB requirements. For example, it is
recommended that the capacitor, C1, be isolated
from the MCLR pin during programming and
debugging operations by using a jumper (Figure 2-2).
The jumper is replaced for normal run-time
operations."
Leaving the 0.1uF on MCLR when trying to use the ICD, is a recipe for it to not be reliable.....
Are you sure your capacitor on the Vcap pins meets the ESR requirements?.
Is it as close as required to the pin?. Section 2.4 in the data sheet. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Mon Aug 29, 2016 8:22 am |
|
|
Where are you measuring the current ? At the board's input power
terminals ? If so, you have a LD1117S33TR regulator as U1. This
regulator has a quiescent current of 5 to 10 ma. That's probably
your whole problem. See Table 6. Electrical characteristics of LD1117#33
on page 12 of the data sheet:
http://www.st.com/resource/en/datasheet/ld1117.pdf
Code: | Id Quiescent current Vin ≤ 15V 5 to 10 mA |
|
|
|
ipq
Joined: 20 Aug 2015 Posts: 17
|
|
Posted: Mon Aug 29, 2016 8:24 am |
|
|
temtronic wrote: | just a couple of comments from a 'dinosaur'..
1) the schematic would be a lot easier to read if all +5V terminations were 'pointing up' and all grounds were pointing 'down'. yeah I'm old but was taught that way. Same holds true for the 32KHz xtal layout
2) the Vbat PIC pin goes to 3volts, seems to be fed from the regulator. if so why bother with deep sleep as it appears the PIC is 'line' powered.
3) looks like that PIC has onboard USB, so be sure you can configure those D+, D- pins for alternate use. Some PICs can't.
Jay |
Hello,
Thank you for your feedback. It is appreciated. The reason why I am not using arrows pointing up is because in Altium it is faster to use standard symbols. However, I'll take your suggestion into account:)
The device is batt powered, so vbat has no effect here.
Regarding the USB, this MCU does not have this peripheral.
Thank you for your appreciated help |
|
|
ipq
Joined: 20 Aug 2015 Posts: 17
|
|
Posted: Mon Aug 29, 2016 8:27 am |
|
|
Ttelmah wrote: | Look at figure 2-2 in the data sheet.
Read this paragraph:
"During programming and debugging, the resistance
and capacitance that can be added to the pin must
be considered. Device programmers and debuggers
drive the MCLR pin. Consequently, specific voltage
levels (VIH and VIL) and fast signal transitions must
not be adversely affected. Therefore, specific values
of R1 and C1 will need to be adjusted based on the
application and PCB requirements. For example, it is
recommended that the capacitor, C1, be isolated
from the MCLR pin during programming and
debugging operations by using a jumper (Figure 2-2).
The jumper is replaced for normal run-time
operations."
Leaving the 0.1uF on MCLR when trying to use the ICD, is a recipe for it to not be reliable.....
Are you sure your capacitor on the Vcap pins meets the ESR requirements?.
Is it as close as required to the pin?. Section 2.4 in the data sheet. |
Yes, all components are placed according datasheet and the capacitor is like suggested (ESR is OK).
The reason why I did not place the jumper in the MCLR line is because I never faced any problem during programming, so I decided not to put it...
However I'll take your words into account for future modifications.
Thanks! |
|
|
ipq
Joined: 20 Aug 2015 Posts: 17
|
|
Posted: Mon Aug 29, 2016 8:36 am |
|
|
PCM programmer wrote: | Where are you measuring the current ? At the board's input power
terminals ? If so, you have a LD1117S33TR regulator as U1. This
regulator has a quiescent current of 5 to 10 ma. That's probably
your whole problem. See Table 6. Electrical characteristics of LD1117#33
on page 12 of the data sheet:
http://www.st.com/resource/en/datasheet/ld1117.pdf
Code: | Id Quiescent current Vin ≤ 15V 5 to 10 mA |
|
That was my first conclusion but then I removed the regulator, powered the board directly at 3.0 volts and the consumption still remains above the 3mA
I know it is complicated decrease the consumption and make it lower tha 1mA, but I've tried removing all components on the PCB and it is already higher than 3mA...
Strange thing...
Any idea? |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19552
|
|
Posted: Mon Aug 29, 2016 9:23 am |
|
|
The MCLR rise time requirements for ICD, are many times lower than those for programming. When doing normal programming it can take mSec to reach the Vpp. Using the ICD is has to get to the same level in a few uSec.
This is why the ICD 'sheet' from Microchip (this is the one for ICD3, but the same applies to all the ICD units):
<http://ww1.microchip.com/downloads/en/DeviceDoc/DS-51765C.pdf>
has as it's second warning down in the 'additional precautions' box 'do not use capacitors on MCLR'.
Your power is 'odd'. I was thinking of things possibly oscillating (the regulator can do this).
Are you sure you are turning off the LCD peripheral fully?. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Mon Aug 29, 2016 9:54 am |
|
|
Quote: |
That was my first conclusion but then I removed the regulator, powered
the board directly at 3.0 volts and the consumption still remains above the 3mA |
That's a 1K load, or maybe three 3.3K loads. What do you have plugged
into the various connectors, RFCONN, Keypad, and IOS ? |
|
|
jgschmidt
Joined: 03 Dec 2008 Posts: 184 Location: Gresham, OR USA
|
|
|
ipq
Joined: 20 Aug 2015 Posts: 17
|
|
Posted: Tue Aug 30, 2016 12:40 am |
|
|
PCM programmer wrote: | Quote: |
That was my first conclusion but then I removed the regulator, powered
the board directly at 3.0 volts and the consumption still remains above the 3mA |
That's a 1K load, or maybe three 3.3K loads. What do you have plugged
into the various connectors, RFCONN, Keypad, and IOS ? |
There is nothing. Those IOs right now are connected to different connectors to expand system capabilities. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Tue Aug 30, 2016 12:43 am |
|
|
What instrument are you using to measure the current ? Have you
checked the instrument with, say 3v running through a 1 MegOhm resistor ? |
|
|
|