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

slow pic chip

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



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

slow pic chip
PostPosted: Mon Feb 15, 2010 5:46 pm     Reply with quote

This is a problem that I've encountered before, but I've never solved it. My pic chip is running about 50 times too slow. I'm trying to blink an led 100 times a second, but it blinks about 2.7 times a second. Does anyone have a suggestion about what this could be?

Thanks!
Richard

chip: pic18f4682
compiler: 4.88.17.16
breadboard with masterclear 47k resistor, external oscilator

Code:
#include "C:\Documents and Settings\Liz Jaquette\Desktop\submersible\4682\4682a.h"
#use delay(clock=20,000,000)


void main()
{

   setup_adc_ports(NO_ANALOGS|VSS_VDD);
   setup_adc(ADC_OFF|ADC_TAD_MUL_0);
   setup_psp(PSP_DISABLED);
   setup_spi(SPI_SS_DISABLED);
   setup_wdt(WDT_OFF);
   setup_timer_0(RTCC_INTERNAL);
   setup_timer_1(T1_DISABLED);
   setup_timer_2(T2_DISABLED,0,1);
   setup_comparator(NC_NC_NC_NC);
   setup_vref(FALSE);
//Setup_Oscillator parameter not selected from Intr Oscillator Config tab

   // TODO: USER CODE!!
   WHILE (true)
   {
      output_toggle(PIN_D1);
      delay_ms(10);
   }

}


.h:


Code:
#include <18F4682.h>
#device adc=8

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES WDT128                   //Watch Dog Timer uses 1:128 Postscale
#FUSES LP                       //Low power osc < 200 khz
#FUSES NOPROTECT                //Code not protected from reading
#FUSES NOBROWNOUT               //No brownout reset
#FUSES BORV20                   //Brownout reset at 2.0V
#FUSES NOPUT                    //No 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 BBSIZ4K                  //4K words Boot Block size
#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 LPT1OSC                  //Timer1 configured for low-power operation
#FUSES MCLR                     //Master Clear pin enabled
#FUSES NOXINST                  //Extended set extension and Indexed Addressing mode disabled (Legacy mode)

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

ckielstra



Joined: 18 Mar 2004
Posts: 3680
Location: The Netherlands

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 5:56 pm     Reply with quote

Quote:
external oscilator
You mean a crystal or a real oscillator module?

Code:
#FUSES LP                       //Low power osc < 200 khz
It is already in the comments...
For crystal frequencies 4MHz and higher you have to use the HS fuse. Or when using a real oscillator module use the EC fuse.

Code:
   setup_spi(SPI_SS_DISABLED);
This is an error in the wizard and creates an invalid setup with undefined behaviour. Change to:
Code:
   setup_spi(FALSE);


Code:
#use delay(clock=20,000,000)
Remove this line. You already have a '#use delay' line in your header file. Two lines might confuse the compiler, at least it is confusing me. Also, I don't know if all compiler versions handle the decimal separators correctly.

Last edited by ckielstra on Mon Feb 15, 2010 6:00 pm; edited 1 time in total
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 5:57 pm     Reply with quote

Quote:
#FUSES LP //Low power osc < 200 khz


#use delay(clock=20000000)

You have a 20 MHz crystal but you're using the LP fuse. You need to
use the HS fuse instead.

Is this a Proteus project ?
rwjzownts



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:03 pm     Reply with quote

Thanks. I've changed the fuse. (I had it this way earlier and thought it might be the problem):

#FUSES HS

I also commented out the second #use delay. The light still blinks about 50 times too slow. Any other suggestions?
rwjzownts



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:04 pm     Reply with quote

Also changed the setup_spi line without any luck.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:10 pm     Reply with quote

Try a more simple program. Example:
This program will blink the LED on pin D1 once per second.
Code:

#include <18F4682.h>
#fuses HS,NOWDT,PUT,BROWNOUT,NOLVP
#use delay(clock=20000000)

//==============================
void main()
{
   
while(1)
  {
   output_high(PIN_D1);
   delay_ms(500);
   output_low(PIN_D1);
   delay_ms(500);
  }
 
}
 
rwjzownts



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:30 pm     Reply with quote

Weird. I tried this simpler program and now the light doesn't blink. I tested different timings to be sure that I wasn't missing it. Other ideas?
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:33 pm     Reply with quote

What is the version of your compiler ? The version number is not what
you posted. The version is a 4-digit number in this format: x.xxx
It's given at the top of the .LST file. The .LST file will be in your project
directory after a successful compilation. Examples of CCS version
numbers:
http://www.ccsinfo.com/devices.php?page=versioninfo

Are you testing this program in real hardware or is this a Proteus project?
If it's real hardware, did you build the board yourself, or did you buy it ?
If you bought it, post the manufacturer and part number of the board.
rwjzownts



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:38 pm     Reply with quote

The version is 4.088. This is not a proteus project. I'm just using a breadboard.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:45 pm     Reply with quote

1. What voltage is the PIC running at ? Is it +5 volts ? Does it come
from a regulated power supply ?

2. Describe the circuit on the MCLR pin, including component values.
I know you said 47K, but does the pull-up resistor go to +5 volts ?

3. Describe the oscillator circuit, including component values.

4. Are you trying to run this board in Debug mode, using a hardware
debugger, such as the ICD2, or ICD-U40, etc. ? Or, are you running
it in "standalone" mode (without the debugger) ?
rwjzownts



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 6:51 pm     Reply with quote

1. The pic is running +5 volts from a computer's usb.

2. The 47k resistor on masterclear goes to 5v.

3. I'm using this crystal on pins 11 & 12:
http://mouser.com/ProductDetail/Vishay/XT9SNLANA20M/?qs=x1SoKP%252b681dNPEFI3iiNSQ%3d%3d

Each pin has a 22pf capacitor going to ground.

4. I'm using icd-u40, but I'm not using it as a debugger.

Thanks for your help! I really appreciate it!
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 7:06 pm     Reply with quote

Quote:
1. The pic is running +5 volts from a computer's usb.

Do we trust this ? Is this a stable, solid, accurate +5v supply ?

Quote:

3. I'm using this crystal on pins 11 & 12:

Mouser Part #: 73-XT49S2000-S
Manufacturer Part #: XT9SNLANA20M
Manufacturer: Vishay/Dale
Description: Crystals 20MHz SERIES

That's a series-resonant crystal.
The PIC's oscillator circuit expects you to use a parallel-resonant crystal.

I've never tried to use a series resonant crystal with a PIC. I don't think
we even have any here at the company. Based on what I've read, it
should oscillate but it might be off frequency. I have no way to verify
this in hardware.

Just as a test, try using the internal oscillator in the PIC and see if it
starts working. Change the oscillator fuse to INTRC_IO and change
the #use delay() to 8 MHz, as shown below:
Quote:

#include <18F4682.h>
#fuses INTRC_IO,NOWDT,PUT,BROWNOUT,NOLVP
#use delay(clock=8000000)

//==============================
void main()
{

while(1)
{
output_high(PIN_D1);
delay_ms(500);
output_low(PIN_D1);
delay_ms(500);
}

}


Last edited by PCM programmer on Mon Feb 15, 2010 7:13 pm; edited 2 times in total
rwjzownts



Joined: 19 Jul 2008
Posts: 16

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 7:12 pm     Reply with quote

That works, so it must be the crystal. I've used these crystals with my 18f2620 and they've worked fine. I'll get the proper crystals. Do you have any part recommendations?

Thanks again!
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 15, 2010 8:48 pm     Reply with quote

This one will work:
Quote:

Mouser Part #: 520-HCU2000-20X
Manufacturer Part #: ECS-200-20-4X
Manufacturer: ECS
Description: Crystals 20MHz 20pF

Frequency: 20 MHz
Tolerance: 30 PPM
Frequency Stability: 50 PPM
Load Capacitance: 20 pF
Termination Style: Radial
Package / Case: HC-49/US
Operating Temperature Range: - 10 C to + 70 C
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