|
|
View previous topic :: View next topic |
Author |
Message |
Emmo
Joined: 02 Feb 2017 Posts: 14
|
pic24fj512gb606 not resetting on cpu_reset() and wdt reset |
Posted: Thu Jul 13, 2017 8:14 am |
|
|
Hello guys,
I once more need your help :-( I'm working with a pic24fj512gb606 and ccs compiler v5.073. I made a very very very simple program after I figure out, my pic is not resetting when I call reset_cpu(). Same behavior when watchdog is hitting. It seems, the device stays in an unknown state. Nothing is working anymore. I already checked the forum about same issues. I found out, that debug mode can be the problem. So I add #fuses nodebug and removed #device icd=3. My project is set in release and not debug, too. But the problem is still there. Here is my code:
Code: |
#include <24FJ512GB606.h>
#device ADC=12 //return 12bit adc value
//#device icd=3 //uses PGC3/PGD3 pins
//#FUSES BROWNOUT_NOSL //brownout reset
#FUSES NOIESO //Internal External Switch Over mode disabled
#FUSES NOWDT
#FUSES NODEBUG
//#FUSES WDT_SW //No Watch Dog Timer, enabled in Software
//#FUSES WPOSTS12 //Watchdog postscaler 2,048 sec
//#FUSES WDTCLK_SYS //WDT uses system clock as clock source
//#FUSES PROTECT //turn on code protect - blocks reading of the MCU program
//#FUSES SOSC_SEL //SOSC circuit selected
#FUSES SOSC_DIG //Digital mode, I/O port functionality of SOSCI and SOSCO pins
#FUSES NOCKSNOFSM //Clock Switching is disabled, fail Safe clock monitor is disabled
#FUSES NOBSS //No boot segment
#FUSES NOWRT //Program memory not write protected
//#FUSES WINDIS //Watch Dog Timer in non-Window mode
#FUSES NOJTAG //JTAG disabled
//#FUSES FRC_PLL //Internal Fast RC oscillator with PLL
//#FUSES LVR //Low Voltage Regulator Enabled, Controlled in Software
#FUSES NOBTSWP //BOOTSWP Instruction Disabled
#FUSES NOIOL1WAY //Allows multiple reconfigurations of peripheral pins
#use delay(internal=32MHz,restart_wdt) //run at 32MHz
//#use delay(internal=32MHz,USB_FULL,restart_wdt,ACT=USB)
#include <usb_cdc.h>
//#zero_ram
void main(void)
{
delay_ms(72);
output_high(PIN_E0);
delay_ms(2000);
output_low(PIN_E0);
delay_ms(2000);
while(1)
{
reset_cpu();
/*#asm
RESET
#endasm*/
output_high(PIN_E0);
}
}
|
I connected a LED to pin E0 and look if it is flashing. With the code above it is on for 2sec and then go out forever. Only a power reset helps. The funny thing is, when I'm using this: #use delay(internal=32MHz,USB_FULL,restart_wdt,ACT=USB), the device is resetting as it should do and the LED is blinking. I dont know why I have to use usb for a proper reset. And when I set #use delay(internal=8MHz,restart_wdt) it is working, too. Make no sense to me. What is wrong? If someone got an idea, let me know please! Thanks! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19544
|
|
Posted: Thu Jul 13, 2017 9:04 am |
|
|
Though this shouldn't apply:
Code: |
7. Module: Reset
If a lower priority address error trap occurs while
a higher priority oscillator failure trap is being
processed, the TRAPR bit (RCON<15>) is not
set. A Trap Conflict Reset does not occur as
expected and the device may stop executing
code.
Work around
None. However, a MCLR/POR Reset will
recover the device.
|
Is interesting, since it talks about the chip getting into a state where it stops executing code.
What environment are you using to compile this from?. If MPLAB, remember you need to re-compile in release mode, and setup the programming device as a 'programmer', not as a 'debugger'. If you program with the device set as a debugger, it tends to switch back to debug... |
|
|
Emmo
Joined: 02 Feb 2017 Posts: 14
|
|
Posted: Fri Jul 14, 2017 12:37 am |
|
|
Ttelmah wrote: | Though this shouldn't apply:
Code: |
7. Module: Reset
If a lower priority address error trap occurs while
a higher priority oscillator failure trap is being
processed, the TRAPR bit (RCON<15>) is not
set. A Trap Conflict Reset does not occur as
expected and the device may stop executing
code.
Work around
None. However, a MCLR/POR Reset will
recover the device.
|
Is interesting, since it talks about the chip getting into a state where it stops executing code.
What environment are you using to compile this from?. If MPLAB, remember you need to re-compile in release mode, and setup the programming device as a 'programmer', not as a 'debugger'. If you program with the device set as a debugger, it tends to switch back to debug... |
I tested MCLR Reset and it is not recovering the device. I pull MCLR Pin to GND and nothing happened. Only power reset is recovering.
I'm using MPLAB X v3.65. I have CCS IDE v5.07, too. Tested with both and no one is working. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19544
|
|
Posted: Fri Jul 14, 2017 5:06 am |
|
|
Check MCLR is enabled. It may be defaulting to off.
The only thing that requires a power down and MCLR can't recover from is a FET getting into the locked state by an ESD event. |
|
|
Ben1172
Joined: 22 Aug 2017 Posts: 7
|
|
Posted: Thu Aug 24, 2017 10:19 am |
|
|
This is an old thread, but for others info, I too had this problem
It seems some 24FJ pic have a problem clock switching in software to PLL enabled internal osc.
But setting up the oscillator using configuration bits can solves this.
After your delay statement add #FUSE FRC_PLL
This overrides the CCS code to configure the oscillator thru software.
CCS tech support mentioned they will put an exception in their next build (5.075?) for this family to not configure the oscillator thru software, so this issue should go away soon. |
|
|
|
|
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
|