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

WDT Tracking down

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



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

WDT Tracking down
PostPosted: Tue Jan 19, 2016 9:14 am     Reply with quote

I'm using CCS C Compiler 5.048, PIC18F67J50.

My fuses
Code:

#fuses HSPLL,PLL2,NOCPUDIV,NOIESO,NOFCMEN,STVREN,CCP2E7,WDT,WDT4096,PROTECT


I was debugging with ICD3 and get a WDT Timeout.

Now I want to know where the code get stucks, I make a little research on Internet and find that some chips have a WDT interrupt debug vector.

Quote:
In MPLABX Debugger
Debug>NewBreakpoint->Breakpoint Type->Event->Break when watchdog timer has expired


I'm using MPLAB IDE v8.92 and found the same at Event Breakpoints , but is greyed, like disabled feature.
This µC doesn't have that feature, do I need another debugger or is MPLAB unavailable feature and need to use MPLABX?
_________________
Electric Blue
temtronic



Joined: 01 Jul 2010
Posts: 9271
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Jan 19, 2016 11:49 am     Reply with quote

hmm... This µC doesn't have that feature

You've answered your own question.. you need a differenet PIC if you want a WDT interrupt debug vector.

NO new development programs or hardware will help, you need a different PIC.

Kinda like a car NOT having a trailer hitch. Trading in your boat trailer for a dump trailer doesn't work, neight hookup to the car, you need a new car( one with a hitch !).

Jay
E_Blue



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

PostPosted: Wed Jan 20, 2016 7:56 am     Reply with quote

I don´t know how to know which µC have and which haven´t that feature. Sad
_________________
Electric Blue
temtronic



Joined: 01 Jul 2010
Posts: 9271
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Jan 20, 2016 8:00 am     Reply with quote

You _should_ be able to go to Microchips 'select a PIC' website and choose that as an option ? maybe ??

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Wed Jan 20, 2016 8:27 am     Reply with quote

The primary 'point' of the watchdog, is to recover the chip if it has for some reason fundamentally stopped doing as it should, and so the watchdog will always normally reset the chip.
The exception to this is chips that have the PTG module. On this the module can accept as one of it's triggers the PTGSWT input (a separate watchdog), and use this as a trigger. This is a programmable state machine that can accept a number of trigger inputs, so you can program it to do particular jobs when certain events occur. One of these events can be it's own dedicated watchdog. So it can (for instance) reset a particular output if no activity occurs in a particular time. The PTG WDT, can trigger an interrupt.
This is independant of the main watchdog.

The "Break when watchdog timer has expired" option is dependant on the debugger used. Only some devices like 'RealICE" support this.

The way to find what is happening, is use a breadcrumb.
Have a global variable. Initialise it to 0, and then throughout your code have it being changed to values reflecting where you have got to. Add a breakpoint at the reset, and when this is reached, look at what the last value was.
temtronic



Joined: 01 Jul 2010
Posts: 9271
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Jan 20, 2016 8:42 am     Reply with quote

hmm 'breadcrumb'. Neat terminology !! Reminds me of the POST codes on a PC decades ago... The POST card would display a number for each test,when it 'hung' you knew which test failed.

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Wed Jan 20, 2016 9:46 am     Reply with quote

Intel motherboards still do it.
They have literally hundreds of codes on some (server boards), with a combination of a hex display, and about 15 LED's reflecting the status of several peripherals.
Some of the non server boards get 'silly', with a surface mount LED 'skull' in the motherboard, which flashes various parts according to what is going on...
E_Blue



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

PostPosted: Tue Jan 26, 2016 7:14 am     Reply with quote

Thanks, for answering, the device didn't reset by WDT again since that time but I will take the "breadcrumb" method in account.
_________________
Electric Blue
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Tue Jan 26, 2016 9:14 am     Reply with quote

One thing I'd look at is temperature....

There are two obvious possibilities:
1) The code did get stuck, and the watchdog was 'genuine'.
2) The watchdog just was not refreshed quickly enough.

Now your chip has a relatively accurate watchdog (nominal period of 3.4 to 4.6uSec), however this is still a nearly +/-20% change. The timing depends on supply voltage and temperature. If at any point your timing might be a bit 'close' on reaching the refresh, then it might simply be that you stepped over the margin at the particular temperature/supply voltage you were using.

However I'm also puzzled by your comment about using ICD3. When the ICD is in use, the watchdog by default will always be off. The compiler will do this automatically. In the debugger limitations from Microchip, you have the note for the ICD3:
Quote:

Debugger Limitations

The Watchdog Timer (WDT) cannot be used when debugging.


Problem is that the watchdog timer is independant of the CPU itself, and will not stop if the debugger stops the code, or if the debugger delays the code. So if enabled, it will timeout when debugging.
E_Blue



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

PostPosted: Tue Jan 26, 2016 1:28 pm     Reply with quote

That is strange, I been debugging with the WDT enabled until last week, the only warning that I get is about disable the code protection bit.

Now I disabled WDT in CONFIG and activate the WDT by using SWDTEN bit by software.

On MPLAB IDE Help says

The Watchdog Timer (WDT) cannot be used when debugging unless the device is set to “Break on Watchdog Timer” (Debugger>Breakpoints, Event Breakpoints) .

And I even using SLEEP instruction while in the same help states.

The SLEEP instruction cannot be used when debugging unless the device is set to “Break on SLEEP Instruction” (Debugger>Breakpoints, Event Break­points).

I confused now. Confused
_________________
Electric Blue
temtronic



Joined: 01 Jul 2010
Posts: 9271
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Jan 26, 2016 2:36 pm     Reply with quote

some points....

rule #1 you cannot use WDT if in 'debug ' mode

rule #2 MPLAB default for 'build configuration' is 'debug'

rule #3 You MUST set 'build configuration' to 'release' and recompile(build) BEFORE blasting PIC with your code.

Now you can set the MPLAB default to 'release' so you don't run into this in the future.


Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Wed Jan 27, 2016 2:51 am     Reply with quote

There is another thing here.

The 'IDE' help, is generic for the IDE. Separately there are limitations for the individual ICD devices involved.

The one being quoted from the IDE:
Quote:

The Watchdog Timer (WDT) cannot be used when debugging unless the device is set to “Break on Watchdog Timer” (Debugger>Breakpoints, Event Breakpoints) .


Is the overall limitation for the IDE.

The one I quote:
Quote:

Debugger Limitations

The Watchdog Timer (WDT) cannot be used when debugging.


Is for the ICD3.

So for the ICD3, the watchdog cannot be used at all. Some ICD devices (RealICE for example), allow you to have 'Break on watchdog', and for these the watchdog can be used if this is enabled.
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