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

PIC18F67K22 won't run on power up [SOLVED]

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



Joined: 01 Jul 2012
Posts: 12

View user's profile Send private message

PIC18F67K22 won't run on power up [SOLVED]
PostPosted: Tue Oct 14, 2014 7:10 pm     Reply with quote

I've used the 18F6722 before without any issues, but I'm having a silly problem with the 18F67K22 where it will only run following the loading of the program below with the ICD, but it won't run on power up. It seems to crash at the first delay_ms(100) statement. I am sure it has something to do with my fuse settings (as they pertain to the oscillator set up perhaps), but I can't seem to figure out what.

Any suggestions are much appreciated.

During programming I see the LED flashing at a much faster rate almost as though it starts to run the program with the wrong oscillator setting (although I'd expect to see the LED turned off during programming) and once it locks up I can get it to start up by unplugging the ICD from a USB port on the PC (which typically puts the PIC in reset - or it used to on older versions of the ICD). What's strange about that is I have a fuse that should cause the MCLR pin to be ignored, so I am not sure how the unplugged ICD is managing to reset the PIC.

The PIC will also start running if I touch PIN 7 with the multimeter probe, but according to my fuse settings it's supposed to be ignoring the MCLR pin altogether.

This PIC is running on a 5V board with an external 40MHz powered oscillator (CB3-3C-40M0000). I am using PCH v4.137 with an ICD-U64.

Pin 7 (nMCLR/G5) is tied to Pin 1 on the ICD connector through a 100Ohm resistor. Pin 1 on the ICD connector also goes to 5VD through a 47K resistor and to GND through a 0.1uF capacitor (which is not populated on the board). I am measuring 3.967V at the Pin 1 of the ICD and at the Pin 7 of the PIC.

The power up is clean and glitch free (Pin 7 voltage rises from 0.7V to 5V over 3ms in a steady and monotonic fashion which is the same as the PICs VDD rail given that the 0.1uF cap has been removed from Pin 1 of the ICD connector), but I'm still using a Power-Up-Timer and a 3.0V brownout - just to be safe. The PIC locks up with or without these fuses enabled.

Here is my code

Code:

#include <18F67K22.h>
#device adc=12

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES ECH_IO                   //External clock
#FUSES NOPLLEN                  //4X HW PLL disabled, 4X PLL enabled in software
#FUSES NOFCMEN                  //Fail-safe clock monitor disabled
#FUSES NOIESO                   //Internal External Switch Over mode disabled
#FUSES PUT                      //Power Up Timer
#FUSES BROWNOUT
#FUSES BORV30                   //Brownout reset at 3.0V
#FUSES NOMCLR                   //Master Clear pin used for I/O
#FUSES NOSTVREN                 //Stack full/underflow will not cause reset
#FUSES NODEBUG
#FUSES NOPROTECT
#FUSES NOCPB
#FUSES NOCPD
#FUSES NOWRT
#FUSES NOWRTC
#FUSES NOWRTB
#FUSES NOWRTD
#FUSES NOEBTRB

#use delay(clock=40000000)

#use rs232(baud=2400,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8,stream=RS232_UART,errors)
#use rs232(baud=9600,parity=N,xmit=PIN_G1,rcv=PIN_G2,bits=8,stream=RS485_UART,errors)

// Pin Defines
#define STATUS_LED   PIN_B4

int TIMER1_TICKS = 0;

// FUNCTION PROTOTYPES
void micro_init();


// INTERRUPTS
#int_TIMER0
void  TIMER0_isr(void)
{
   
}

#int_TIMER1
void  TIMER1_isr(void)
{
   if(TIMER1_TICKS == 255) TIMER1_TICKS = 0;
   TIMER1_TICKS++;
}

#int_TIMER2
void  TIMER2_isr(void)
{
   
}

#int_RDA
void  RDA_isr(void)
{
   
}
/*
#int_TBE
void  TBE_isr(void)
{

}*/

#int_RDA2
void  RDA2_isr(void)
{
   
}
/*
#int_TBE2
void  TBE2_isr(void)
{

}*/


void main()
{
   micro_init();
   
   while(TRUE)
   {
     
      output_high(STATUS_LED);
      delay_ms(100);
      output_low(STATUS_LED);
      delay_ms(100); 
     
   }
   while(1);

}

void micro_init()
{
   setup_adc_ports(sAN0|sAN1|sAN2|sAN3|sAN4|sAN5|sAN6|sAN7|sAN8|sAN9|sAN10|sAN11,VREF_VREF);
   setup_adc(ADC_CLOCK_DIV_4);
   //setup_adc(ADC_CLOCK_DIV_4|ADC_TAD_MUL_16);
   set_adc_channel(0);
 
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_2);     
   setup_timer_1(T1_INTERNAL|T1_DIV_BY_8);     
   setup_timer_2(T2_DIV_BY_16,255,16);     

   setup_timer_3(T3_DISABLED | T3_DIV_BY_1);
   setup_timer_4(T4_DISABLED,0,1);

   setup_timer_5(T5_DISABLED | T5_DIV_BY_1);
   setup_timer_6(T6_DISABLED,0,1);
   setup_timer_7(T7_DISABLED | T7_DIV_BY_1);
   setup_timer_8(T8_DISABLED,0,1);
   setup_timer_10(T10_DISABLED,0,1);
   setup_timer_12(T12_DISABLED,0,1);

   setup_comparator(NC_NC_NC_NC);

   output_low(STATUS_LED);
     
   //enable_interrupts(INT_TIMER0);
   //enable_interrupts(INT_TIMER1);
   //enable_interrupts(INT_TIMER2);
   //enable_interrupts(INT_TIMER3);
   enable_interrupts(INT_RDA);
   //enable_interrupts(INT_TBE);
   enable_interrupts(INT_RDA2);
   //enable_interrupts(INT_TBE2);
   enable_interrupts(GLOBAL);
}


Last edited by RickDaystorm on Tue Oct 14, 2014 7:51 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 14, 2014 7:30 pm     Reply with quote

You have enabled serial interrupt without anything in the serial interrupt handlers to clear the interrupts. Naturally it is going to crash.
_________________
Regards, Andrew

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



Joined: 01 Jul 2012
Posts: 12

View user's profile Send private message

PostPosted: Tue Oct 14, 2014 7:50 pm     Reply with quote

Thanks for the quick response asmallri.

That was definitely embarassing, especially given that I'd just spent hours ruining nearly all nMCLR-related passives on this board.

I disabled those serial interrupts and the program now runs perfectly well on each power-up.

Rick
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 14, 2014 8:03 pm     Reply with quote

RickDaystorm wrote:
Thanks for the quick response asmallri.

That was definitely embarassing, especially given that I'd just spent hours ruining nearly all nMCLR-related passives on this board.

I disabled those serial interrupts and the program now runs perfectly well on each power-up.

Rick


We all have our bad days :-)
_________________
Regards, Andrew

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



Joined: 11 Mar 2010
Posts: 19536

View user's profile Send private message

PostPosted: Wed Oct 15, 2014 12:59 am     Reply with quote

Yes.

This is one of those ones, that every single person here who has worked with code/hardware for any length of time, will have encountered at some point.

You get 'hooked' on where you think the problem is, go round in little circles, looking at this, and miss something that should be obvious, or should at least be checked.....

I've said in other threads, that the only way to sometimes find this type of thing, is to 'step away' and do something completely unconnected. Things like mowing the lawn, chopping logs, doing a bike ride etc., then often when you return there is the sudden 'oh' moment. Smile

I talk about "wall, head, impact technology testing".

Nice quick spot from Asmallri.
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Wed Oct 15, 2014 12:49 pm     Reply with quote

The other problem solving method that often works quite well is to explain the problem to someone else in detail (even if they don't understand what you are saying). Often, halfway through the explanation, you have one of those "duh ... never mind" moments where it all becomes obvious. Very Happy

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
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