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

ICD-U64 Stopped Working as a debugger in PCW IDE

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



Joined: 16 Nov 2009
Posts: 14

View user's profile Send private message

ICD-U64 Stopped Working as a debugger in PCW IDE
PostPosted: Sun Jul 01, 2012 8:43 pm     Reply with quote

After opening and auditing the "Device Editor" for my MCU (PIC24HJ128GP306) I lost ICD debugging functionality. I believe I have inadvertently corrupted my device settings by saving the incorrect #fuses during the prompt. I enable debugging through the CCS IDE and the MCU loads the code, but at the bottom of the debugging window, it states "Not Ready" in red. If I disable the debugging function in the IDE, recompile, then load via ccsload app, the code loads but displays a verification error.

The verification error displayed is the following:
Configuration Fuses: 8H ACTUAL:0000 EXPECTED:00FF

The code runs but, I have lost ICD functionality and not through the IDE.

I am running a PIC24H development kit and IDE Version 4.134.

My ICD is an ICD-U64 at firmware 2.93 Rev 2

Code:
#build(stack = 256)
#device ICD=TRUE
#FUSES DEBUG                    //Debug mode for use with ICD
#fuses HS,NOWDT,PR
#use delay(crystal=20M, clock=40M)

#use rs232(UART2, PARITY=N, BITS=8, STOP=1, ERRORS)

#word U2BRG = 0x238
#bit  U2BRGH = 0x230.3

char T;

void main()
{
U2BRGH = 0;
U2BRG = 10; // sets 115200 Baud, -1.4%

 while(TRUE)
 {
      T = getchar();              // Puts Input BYTE from AP_IN UART Port and copies it to a variable
      putc(T);
 }     
}


I have read through the forum and read the Microchip guidelines but I didn't have any success for those suggestions.

Any insight is greatly appreciated!
Matt Que



Joined: 16 Nov 2009
Posts: 14

View user's profile Send private message

PostPosted: Mon Jul 02, 2012 9:24 pm     Reply with quote

Just an update...

I contacted CCS today and they emailed me the device database for 4.134 IDE just in case it was corrupted. I reloaded the compiler database and still do not have ICD functionality when compiling with debugging enabled.

Any insight? Should I try uninstalling the ICD drivers and reinstalling or is this a fuse configuration issue?

Thanks
temtronic



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

View user's profile Send private message

PostPosted: Tue Jul 03, 2012 3:02 pm     Reply with quote

Have you tried another PIC or at least 'wiping out' all the fuse information (resetting to all 0xFF) on the 'problem' PIC.

I don't use the ICD as I always test in the real world..but..resetting the all PICs fuses to default _might_ bring back ICD for you??

hth
jay
Matt Que



Joined: 16 Nov 2009
Posts: 14

View user's profile Send private message

PostPosted: Wed Jul 04, 2012 10:47 am     Reply with quote

Thanks temtronic for the suggestion. I am not aware of how to wipe out all the fuse information opposed to going into ccsload and selecting 'erase chip'.

I have learned a little bit more about the problem...

I backed up my PICC/PROJECT folder.

I uninstalled the IDE, CCSLOAD and CCS UPDATE. I didn't go back into the PICC installation folder and delete all the contents.

I re-installed via the CD then updated to the latest revision.

Problem still existed.

However...

If I open a PJT file that was previously compiled with an older version of the compiler (IDE 4.116, the version prior upgrading), the debugger runs and operates as expected in IDE 4.134. If I recompile that same exact code in the current version installed (IDE 4.134), the ICD shows not ready after the ICD loads to the target chip and the ICD doesn't function.

I don't know how to audit what the IDE is doing with the fuses once it compiles the code... is it buried in the .lst file? Are there any settings available in the CCS IDE that may be incorrect for the ICD?

Are there people out there successfully using an ICD-U64 with IDE 4.134? And a PIC24H?
Matt Que



Joined: 16 Nov 2009
Posts: 14

View user's profile Send private message

PostPosted: Wed Jul 04, 2012 11:24 am     Reply with quote

I tried rolling back my IDE version to 4.118 (the only other version I had) and I got ICD functionality back!!!!

There have been a ton of bug fixes between 4.118 to 4.134. Does CCS have a directory you can get to that allows you to roll back to a previous version or do I need to contact them?
temtronic



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

View user's profile Send private message

PostPosted: Wed Jul 04, 2012 12:11 pm     Reply with quote

I've learned from past 'experience' to install each version of the compiler in it's own folder(PCM4100,PCM4101,PCM4102,etc) not just 'upgrade' into the default location. Yes, it can be a pain, but then it allows you to go back to what was working....Yes, you'll end up with a zillion files but heck harddrives are HUGE nowadays.

I'm pretty sure if you contact CCS and have a current account, they'll allow you to download past versions of the compiler. Heck, never hurts to ask ! They've been very nice to me over the past 15+ years.

As a general rule, I do not upgrade any software unless I really have to.If it's working for you WHY upgrade?
Matt Que



Joined: 16 Nov 2009
Posts: 14

View user's profile Send private message

PostPosted: Thu Jul 05, 2012 3:23 pm     Reply with quote

Digging deeper... I found when I compile the same .c code in V4.118 versus V4.134, the fuses are different.

It appears V4.134 is compiling the ICD debug as FFFF while V4.118 is
compiling it as 0000...

NON-WORKING.... V4.134

Code:
020C8:  BRA     20C8

Configuration Fuses:
   Word  1L: 00CF   NOWRTB NOBSS NORBS
          H: FF00
   Word  2L: 00CF   NOWRTSS NOSSS NORSS
          H: FF00
   Word  3L: 0007   NOWRT NOPROTECT
          H: FF00
   Word  4L: 0082   PR IESO
          H: FF00
   Word  5L: 00C6   HS NOOSCIO
          H: FF00
   Word  6L: 005F   WPOSTS16 WPRES128 WINDIS NOWDT
          H: FF00
   Word  7L: 00E0   NOPUT
          H: FF00
   Word  8L: 0043   ICSP1 NOJTAG DEBUG
          H: FFFF

   Some fuses have been forced to be compatible with the ICD debugger.


*************************************************************************************************************************
WORKING V4.118

Code:

Configuration Fuses:
   Word  1L: 00CF   NOWRTB NORBS
          H: 0000
   Word  2L: 00CF   NOWRTSS NORSS
          H: 0000
   Word  3L: 0007   NOWRT NOPROTECT
          H: 0000
   Word  4L: 0082   PR IESO
          H: 0000
   Word  5L: 00C6   HS NOOSCIO
          H: 0000
   Word  6L: 005F   WPOSTS16 WPRES128 WINDIS NOWDT
          H: 0000
   Word  7L: 00E0   NOPUT
          H: 0000
   Word  8L: 0043   ICSP1 NOJTAG DEBUG
          H: 0000

   Some fuses have been forced to be compatible with the ICD debugger.


So how do I make 4.134 compile and output the correct fuses from the c file? I am kinda concerned that none of the fuses match...

How do I decode the fuses? Are they listed in the Microchip datasheet? Sorry for the newbie questions but stuck here.

Thanks
temtronic



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

View user's profile Send private message

PostPosted: Thu Jul 05, 2012 5:25 pm     Reply with quote

yes, all the 'fuses' info is in the datasheet..I think under 'config'...been awhile since I actually had to read up on them..

If you're using MPLAB, you can configure the fuses from a menu/submenu and have _that_ configuration override the compiler's config.

Sorry for the lack of proper wording, I'm an old teletype/assembler guy
NOT a Windows IDE guru !
Matt Que



Joined: 16 Nov 2009
Posts: 14

View user's profile Send private message

Using ICD-64U with HS & PR_PLL fuses
PostPosted: Sun Mar 24, 2013 2:23 pm     Reply with quote

I am still having some issues with using the ICD-64U in a debugger role still. I can get the code to run as expected on the target chip when programmed but when I recompile with DEBUG mode enabled, the code doesn't perform in the same manner.

I wrote a very basic program that flashes an LED at 1hz which it does if code loaded via the CCSLOAD Utility:

Code:

#include <24HJ128GP306.h>
//#device ICD=TRUE

#FUSES WPRES32                  //Watch Dog Timer PreScalar 1:32
#FUSES WPOSTS1                  //Watch Dog Timer PostScalar 1:1
#FUSES PROTECT_HIGH             //General Segment Code Protect High Security
#FUSES HS                       //High speed Osc (> 4mhz for PCM/PCH) (>10mhz for PCD)
#fuses PR_PLL
#FUSES CKSFSM                   //Clock Switching is enabled, fail Safe clock monitor is enabled
#FUSES NOWINDIS                 //Watch Dog Timer in Window mode
//#FUSES DEBUG                    //Debug mode for use with ICD

#use delay(crystal=20M,clock=80M)


void main()
{
   setup_spi( FALSE );
setup_spi2( FALSE );
set_tris_B(0b1111111111001011);


   setup_timer1(TMR_DISABLED|TMR_DIV_BY_1);

While(true)
   {
   
      output_high(pin_B2);
     
      delay_ms(1000);
     
      output_low(pin_B2);
     
      delay_ms(1000);
   }
   
}


When I try to run the code via the CCS IDE in DEBUG mode, the code loads and says "Ready MCU at 7.47 MHz"... not the 80MHz as intended. When I start the code via the debugger interface, it says it is running but doesn't execute the flashing LED.

Here are the fuses as compiled with DEBUG Mode Enabled:



Code:


Configuration Fuses:
   Word  1L: 00CF   NOWRTB NOBSS NORBS
          H: FF00 
   Word  2L: 00CF   NOWRTSS NOSSS NORSS
          H: FF00 
   Word  3L: 0007   NOWRT NOPROTECT
          H: FF00 
   Word  4L: 0080   FRC IESO
          H: FF00 
   Word  5L: 0006   HS NOOSCIO CKSFSM
          H: FF00 
   Word  6L: 0000   WPOSTS1 WPRES32 NOWINDIS NOWDT
          H: FF00 
   Word  7L: 00E0   NOPUT
          H: FF00 
   Word  8L: 0043   ICSP1 NOJTAG DEBUG
          H: FF00 

   Some fuses have been forced to be compatible with the ICD debugger.



Here are the fuses as compiled with DEBUG Disabled.

Code:

Configuration Fuses:
   Word  1L: 00CF   NOWRTB NOBSS NORBS
          H: FF00 
   Word  2L: 00CF   NOWRTSS NOSSS NORSS
          H: FF00 
   Word  3L: 0003   NOWRT PROTECT_HIGH
          H: FF00 
   Word  4L: 0080   FRC IESO
          H: FF00 
   Word  5L: 0006   HS NOOSCIO CKSFSM
          H: FF00 
   Word  6L: 0000   WPOSTS1 WPRES32 NOWINDIS NOWDT
          H: FF00 
   Word  7L: 00E7   PUT128
          H: FF00 
   Word  8L: 00C3   ICSP1 NOJTAG NODEBUG
          H: FF00 




Any insight on how to get DEBUGGER / ICD functionality would be greatly appreciated as I am losted.('Crying or Very sad')

I am using compiler:

CCS PCD C Compiler, Version 4.141, 3127

ICD-64U with software 4.040 / FW:2.95 and Hardware version 2.

The hardware is the CCS PIC24H Protoboard.

Thanks All
dyeatman



Joined: 06 Sep 2003
Posts: 1941
Location: Norman, OK

View user's profile Send private message

PostPosted: Sun Mar 24, 2013 4:45 pm     Reply with quote

I have seen the same issue with mine but confirmed the oscillator was
running at full speed and I have had no outward problems.
_________________
Google and Forum Search are some of your best tools!!!!
Douglas Kennedy



Joined: 07 Sep 2003
Posts: 755
Location: Florida

View user's profile Send private message AIM Address

PostPosted: Mon Mar 25, 2013 10:21 am     Reply with quote

I have a similar problem with the 24EP512GU810 and the ICD U64. The code will run on the target without the debugger support. I'd guess the ICD U64 debugger firmware can't start the oscillator in debug mode. These chips require careful handling to get them oscillating in the best of circumstances.
I'm hoping a CCS firmware upgrade to the ICD U64 will correct the issue.
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