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

PIC18F4520 doing strange things

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



Joined: 15 Sep 2003
Posts: 226

View user's profile Send private message

PIC18F4520 doing strange things
PostPosted: Tue Oct 25, 2005 8:23 pm     Reply with quote

I hate new chips... !

This design uses the PIC18F4520 with H4 oscillator setting and a 7.372MHz crystal.

#FUSES NOWDT //No Watch Dog Timer
#FUSES WDT128 //Watch Dog Timer uses 1:128 Postscale
#FUSES H4 //High speed osc with HW enabled 4X PLL
#FUSES NOPROTECT //Code not protected from reading
#FUSES NOBROWNOUT //No brownout reset
#FUSES BORV25 //Brownout reset at 2.5V
#FUSES PUT //Power Up Timer
#FUSES NOCPD //No EE protection
#FUSES STVREN //Stack full/underflow will cause reset
#FUSES NODEBUG //No Debug mode for ICD
#FUSES NOLVP //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES NOWRT //Program memory not write protected
#FUSES NOWRTD //Data EEPROM not write protected
#FUSES IESO //Internal External Switch Over mode enabled
#FUSES FCMEN //Fail-safe clock monitor enabled
#FUSES PBADEN //PORTB pins are configured as analog input channels on RESET
#FUSES NOWRTC //configuration not registers write protected
#FUSES NOWRTB //Boot block not write protected
#FUSES NOEBTR //Memory not protected from table reads
#FUSES NOEBTRB //Boot block not protected from table reads
#FUSES NOCPB //No Boot Block code protection
#FUSES RESERVED //Reserved
#FUSES MCLR //Master Clear pin enabled
#FUSES XINST //Extended set extension and Indexed Addressing mode enabled

#use delay(clock=29491200)
#use rs232(baud=230400,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8)

There is a 22K resistor from MCLR to VDD.

If the chip boots up correctly MCLR pin is very sensitive and touching it with a 10M Ohm voltmeter probe will cause a reset.

Sometimes it boots up and bypasses some code that shoudl be impossible to bypass.. I should see a total of ten flashes of an LED and it's about 50/50 chance I do.

Then sometimes the LED is just ON ! as if code has been bypassed !

void main()
{
FlashLED5Times(); // must flash 5 times
SetupPortEtc();
FlashLED5Times(); // must flash 5 times

LED_ON;

rest of code....

}

If I connect the debugger (ICDU-40) there is never a problem.

Has anyone else that strange happenings with this chip ?

Does it need a real reset generator on the MCLR ?
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Tue Oct 25, 2005 8:36 pm     Reply with quote

Quote:
Sometimes it boots up and bypasses some code that should be impossible to bypass

Read this thread. It discusses two issues that might cause your problem:
A #fuses issue, and a compiler installation issue.
http://www.ccsinfo.com/forum/viewtopic.php?t=24669

On 2nd thought, I didn't see the part about it working OK with ICDU-40.
Still, change the fuse to NOXINST.


Last edited by PCM programmer on Tue Oct 25, 2005 8:38 pm; edited 1 time in total
asmallri



Joined: 12 Aug 2004
Posts: 1635
Location: Perth, Australia

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

PostPosted: Tue Oct 25, 2005 8:36 pm     Reply with quote

I suggest checking the resistance from the MCLR pin to VDD when the power is off to ensure the 22K resistor is not open circuit. 22K is high if you do not also have a small capacitor (<=10nF) to ground on the MCLR pin.
_________________
Regards, Andrew

http://www.brushelectronics.com/software
Home of Ethernet, SD card and Encrypted Serial Bootloaders for PICs!!
Hans Wedemeyer



Joined: 15 Sep 2003
Posts: 226

View user's profile Send private message

I did this....
PostPosted: Wed Oct 26, 2005 8:34 am     Reply with quote

PCM Programmer:
Nothing in the link that indicated a problem similar to this.
I changed to NOXINST and the lst files are intentical. The code is not doing anything fancy so I doubt it is using any of the "new" stuff anyway.

The reason I question "Does this thing need a reset generator" is if I pull the reset line low with a jumper it starts correctly every time.

asmallri:
Yes it is the classic symptom of a open circuit or broken resistor. I have already checked that! It's 22K .

Last night a wired in the recommended (data sheet) reset circuit for slow power ramp up issues and that seems to be working. This is similar to your suggestion of adding a 10nF, except the values need to be such that it creates at least 150mS delay.
I appreciate your suggetion of the 10nF was to "decouple" the pin and make it less sesitive. In fact that may work.
I have to build another board today, and I'm curious to see if the MCLR is as sensitive. If it is I'll try a 10nF first.

Why the slow ramp reset circuit fixes this issue is strange because the power ramps up very quickly. Perhaps this new generation of PIC's are more sensitive than the earlier version.

BTW I also tried NOMCLR that did not fix the issue.

Thanks for the help.
asmallri



Joined: 12 Aug 2004
Posts: 1635
Location: Perth, Australia

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

PostPosted: Wed Oct 26, 2005 8:52 am     Reply with quote

You have the BOR reset value set low. I assume your are running this at 3.3 volts. If the chip an F or an LF part?
_________________
Regards, Andrew

http://www.brushelectronics.com/software
Home of Ethernet, SD card and Encrypted Serial Bootloaders for PICs!!
Guest








PostPosted: Wed Oct 26, 2005 5:12 pm     Reply with quote

asmallri wrote:
You have the BOR reset value set low. I assume your are running this at 3.3 volts. If the chip an F or an LF part?


The NOBROWNOUT overides the BOR value.
Bart



Joined: 12 Jul 2005
Posts: 49

View user's profile Send private message

PostPosted: Thu Oct 27, 2005 1:02 pm     Reply with quote

I had a simular problem with a change from 16F877 to 18F4550.
Finaly it was due to the MAX232 ic witch was used for the rs232 communications. The uncoupling condensator/capasitor of 100n was to less to remove the noise generated by the switching circuit from the max232. I placed some uF (10 or 22) in parallel and problem was solved.
_________________
I like Skype (www.skype.com), my username is BplotM
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