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

PIC18F4620 support problems? Anyone?

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



Joined: 13 May 2004
Posts: 90
Location: Nashville, TN

View user's profile Send private message Send e-mail Visit poster's website

PIC18F4620 support problems? Anyone?
PostPosted: Tue Dec 14, 2004 11:32 am     Reply with quote

Before we upgrade from our PIC18F452 to a PIC18F4620, I wanted to poll the community about whether anyone's had good/bad experiences. CCS lists this part as "in beta test," but we've had good experiences with the 2620, which is listed the same way.

Anyone out there have any gripes about PIC18F4620 + CCS PCH & ICD?

--
Jeff S.
Guest








452 to 4620
PostPosted: Tue Dec 14, 2004 8:18 pm     Reply with quote

To get my 4620 working with old 452 code, I made the following change for the CCS compiler:

1. Tools --> Device Editor --> 4620 --> UART --> ESCI --> FALSE (PCWH 3.212) or ESCI --> Standard (? for PCWH 3.214)

i.e. set it back to the UART mode of 452

2. comment out #zero_ram and do it myself

Otherwise CCS's 4620 code have problem with RS232 and LCD.

BTW, 4620's hardware ADC seems to be slightly different from 452, check it out if necessary.

Best wishes
Ken Macfarlane



Joined: 04 Oct 2004
Posts: 12
Location: Glasgow, Scotland

View user's profile Send private message

I Agree
PostPosted: Thu Dec 30, 2004 8:33 am     Reply with quote

I haven't been able to get a simple LCD app to port from 452 to 4620, and my ICD doesn’t work properly: a program that works on an 18f452, won’t reset on an 18f4620 in the same pcb. The ICD complains that it "can’t reset the target", and instructs to check mclr & the clk. From a scope, the clock was non-existant, but surely, if they were good enough for the 452, the clock osc. should have run for a 4620 in the same pcb.

p.s. when you say you #zeroed ram yourself, do you mean explicitly seeting every local to zero, or do you mean an assembler level set ram to 0 for "every register that might be used to hold variables" as it says in the manual i.e. which registers?
Ken Macfarlane



Joined: 04 Oct 2004
Posts: 12
Location: Glasgow, Scotland

View user's profile Send private message

Ignore this
PostPosted: Thu Dec 30, 2004 9:31 am     Reply with quote

this is just because I forgot to set the notify when a reply is posted flag
Tom-H-PIC



Joined: 08 Sep 2003
Posts: 105
Location: New Castle, DE

View user's profile Send private message

Some Info on the 4620.
PostPosted: Fri Dec 31, 2004 9:25 am     Reply with quote

First off you need to have ICD firmware V 1.30 or higher if you are going to have a chance at all to get the ICD to work with the 4620.
I don’t know what compiler V you are using but ICD firmware V1.33 was supplied with compiler V3.213.
Second it does sound like that you main osc is not running. PIC are finicky at best when it comes to the oscillator drive. From my experience most all PIC chips are shipped with the OSC fuse set for LP. Some times this is not enough drive to get a fast crystal started. I have run in to this using ceramic resonator on the 16F series chips the most.
For example the target PCB will have a 20Mhz resonator on it and an ICD port. Put a new PIC16F8XX in it and it will not start to even get the first program loaded.
Remove the chip and put it on a test PCB with a slow crystal and program the chip with an OSC fuse setting of HS. Move the chip back to the target PCB and all is normal, the chip will program and run just fine from that point on in that PCB with the resonator.

Ok back to your issues.
First think that I would do is setup my program to run with out the ICD that is remove “#device ICD=TRUE”. Also there are one or two other thing that need to be removed from you program if you are using them. The two big ones are “#ZERO_RAM” and “#device WRITE_EEPROM=ASYNC”. The zero ram you can go back and working on write your own code for that when you get your program up and running if you have to have it. I have remove zero ram from all of my 2620 and 4620 programs and have not had an issues. The write eeprom async I have not been able to get to work on any PIC from the time CCS introduced it. Compile that program to a HEX file.

Run the stand alone ICD software and go to advanced and under read device click on Configuration this will read the fuse setting of the PIC. Note what the OSC setting are.
Now program the chip with your hex file and recheck the fuse setting and see if they have changed.
If the OSC setting did not change two things you can try are.
One rearrange the fuses in the program line i.e. move the OSC fuse to the end of the line and recompile and program test. This has worked one or two times for me in the pasted. I know it makes no sense but some times it works.
Two set the 4620 to use the internal oscillator block. You can do this by changing the OSC fuse to “INTRC_IO”. The 4620 will run slow but once you have it running you can change to the OSC fuse that you need for your crystal and reprogram for that crystal.

I hope this helps!
PS I have a number of 2620 and 4620 running in my projects.
They will run almost any code that the 452 will run.
Tom
jcjneudo



Joined: 21 Feb 2005
Posts: 4

View user's profile Send private message

18F4620 gotchas
PostPosted: Wed Feb 23, 2005 8:06 am     Reply with quote

There are a few gotchas with the 18F4620 that have slowed me down a bit.
1. The "XINST" flag is set by default on certain compiler versions. When I used v3.212, I lost several days because of this. Fixed in 3.219. Code like below can go into never-never land if the new instructions are enabled. The culperate seems to be things like line 0054, where the accumulator is moved to "06" (which is now indexed with the FSR2 register). I assume that the extra instructions just aren't supported at all.
2. 32MHz internal rc operation requires hand-tweaking of the OSCTUNE port.
3. Using CCS' ICD code (with Microchip ICD1) allows downloads but not debugging (the oscillator does not seem to be fully supported). Although perhaps given the previous post I should upgrade the ICD firmware again and retry.

Code:

....................   while(1) {
....................     for(i=55 ; i; i++) {
0052:  MOVLW  37
0054:  MOVWF  06
0056:  MOVF   06,F
0058:  BZ    0070
....................       LATD ^= 0x80;
005A:  MOVLW  80
005C:  XORWF  F8C,F
....................       delay_us(500);
005E:  MOVLW  02
0060:  MOVWF  07
0062:  MOVLW  FA
0064:  MOVWF  08
0066:  BRA    0004
0068:  DECFSZ 07,F
006A:  BRA    0062
....................     }
006C:  INCF   06,F
006E:  BRA    0056
....................     LATB ^= 0x01;
0070:  MOVLW  01
0072:  XORWF  F8A,F
....................   }
0074:  BRA    0052
.................... }
....................
0076:  SLEEP

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