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

18F47J13 clock configuration

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



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

18F47J13 clock configuration
PostPosted: Tue Mar 20, 2012 11:05 am     Reply with quote

The 47J13 has a very competent (i.e. complex) clock configuration, and I want to use the internal oscillator at 8MHz to drive the 96MHz PLL. It is far from clear what the "magic spells" are.

I currently have (set by the project wizard)
Code:

#fuses PLL2
#fuses PLL96MHZ
#use delay( int=48000000, restart_wdt)
setup_oscillator(OSC_8MHZ | OSC_INTRC | OSC_31250 | OSC_PLL_OFF);

and the compiler complains about the use_delay line with error 99 "option invalid internal osc freq wrong"

Can anyone help, please?
_________________
- peter -
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Tue Mar 20, 2012 4:50 pm     Reply with quote

I don't have this PIC to test, but try this LED blinking program and
see if it works:
Code:

#include <18F47J53.h>
#fuses INTRC_PLL_IO, PLL2, PLLEN, NOWDT
#use delay(clock=48M)

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

// Blink LED at 1 Hz rate.
while(1)
  {
   output_toggle(PIN_B0);
   delay_ms(500);
  }
}
peterpanic



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

PostPosted: Wed Mar 21, 2012 2:06 pm     Reply with quote

> try this LED blinking program and see if it works:

works fine, except the actual delay period measures 1500ms, not 500. But at least the compiler doesn't barf. Working on it, and will report...
_________________
- peter -
peterpanic



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

PostPosted: Wed Mar 21, 2012 5:41 pm     Reply with quote

Looks to me like two compiler bugs; the first is that the compiler doesn't "understand" the 96MHz PLL, and the second is that when using the ICD U-64, the config words get mangled - as well as changing the DEBUG and STVREN bits it also changes PLLSEL and WTDPS1 bits. Reported (not via the IDE reporting system which seems to be broken for me).
_________________
- peter -
dyeatman



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

View user's profile Send private message

PostPosted: Wed Mar 21, 2012 6:28 pm     Reply with quote

Where did you get the info that the PLL went to 96MHZ? From page
11 of the data sheet:

Quote:
A Phase Lock Loop (PLL) frequency multiplier
available to the high-speed crystal, and external
and internal oscillators, providing a clock speed
up to 48 MHz.

_________________
Google and Forum Search are some of your best tools!!!!
peterpanic



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

PostPosted: Thu Mar 22, 2012 2:31 am     Reply with quote

PLL runs at 96MHz, its output is divided by two to provide the 48MHz (max) processor clock.

p35 of data sheet: "The PIC18F47J13 provides two PLL circuits: a 4x multiplier PLL and a 96 MHz PLL enabling 48 MHz operation from the 8 MHz
internal oscillator."
_________________
- peter -
Ttelmah



Joined: 11 Mar 2010
Posts: 19496

View user's profile Send private message

PostPosted: Thu Mar 22, 2012 4:57 am     Reply with quote

I always start by working out what bits have to be set where to do what I want.

So, working through the clock diagram from fig 3-1, we need FOSC:2=0 to say feed the internal oscillator to the PLL. Then PLLSEL set to 0. Then PLLDIV set to 110, and either PLLEN, or CFGPLLEN set to 1. FOSC 2:0 = something other than 00. OSCCON 1:0 = 00.

So then look where these come from. CFGPLLEN, PLLDIV, PLLSEL, & FOSC, are all in the fuses, while OSCCON is a user setting.

Then step into the device editor, and look at what CCS setting sets these bits. This is the little window in the top right of device editor, which shows CCS fuse 'names', and what registers/bits are masked and set for each of these. So, need to get : xxx1110x in the first register and xxxxx01x in the second. PLL2, correctly gives the low nibble for the first, and PLLEN, the high nibble. Then INTRC_PLL, or INT_RC_PLL_IO look to give the required bits in the second byte. PLLSEL requires bit 2 of byte 5, and this is set by the PLL fuse.
So we should need:

PLL, INTRC_PLL_IO, PLL2

Then 'be careful' CCS has become increasingly complex regarding the 'clock' setting. If you say 'crystal', 'internal', or other similar keywords, it overrides individual fuses to setup what it 'thinks' is right. Safer, to just use the 'clock' keyword, which appears to always leave your fuses as they are. This may be the 'core' problem.

So, now all that is needed is the OSCCON bits. Two choices 'setup_oscillator', or go 'DIY'. Looking at the setup_oscillator settings, 'OSC_NORMAL' is '00' for the required bits. This should be the 'default', but select it anyway.

So then trying:
Code:

#include <18F47J13.h>
#device adc=16

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES PLL2                     //Divide By 2(8MHz oscillator input)
#FUSES PLLEN                 
#FUSES NOXINST                  //Extended set extension and Indexed Addressing mode disabled (Legacy mode)
#FUSES INTRC_PLL_IO         
#FUSES NOCLOCKOUT           
#FUSES NOFCMEN                  //Fail-safe clock monitor disabled
#FUSES NOIESO                   //Internal External Switch Over mode disabled

#use delay(clock=48000000)

void main()
{
   setup_oscillator(OSC_NORMAL);
   setup_comparator(NC_NC_NC_NC);
   do {
      output_toggle(PIN_A0);
   } while (TRUE);
}


Seems to have every fuse and register that needs to be setup for the 48MHz operation, set 'right'. Haven't got a chip of this type to try, but in the debugger, everything does appear 'right'.

Best Wishes
peterpanic



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

PostPosted: Thu Mar 22, 2012 7:01 am     Reply with quote

Quote:
Then step into the device editor, and look at what CCS setting sets these bits. This is the little window in the top right of device editor, which shows CCS fuse 'names', and what registers/bits are masked and set for each of these.


Thanks - that was one of the missing links for me.

Tried the code and... it runs at 31kHz! (I changed NOCLOCKOUT to CLOCKOUT and INTRC_PLL_IO to INTRC_PLL and measured the period on the CLKOUT pin - 7.83kHz)
_________________
- peter -
Ttelmah



Joined: 11 Mar 2010
Posts: 19496

View user's profile Send private message

PostPosted: Thu Mar 22, 2012 9:50 am     Reply with quote

OK.
The accuracy of this, suggests it is from the 8MHz source divided down, rather than from the separate INTRC source.
So only routes are:

OSCTUNE 7 = 1 (fair enough we are not changing this, might well be 1).
OSCCON 6:4 = 000 (OK, we set this whole register to 0).

Then _either_ OSCCON 1:0 = 11, or FOSC 2:1 = 00, to give 31KHz out.

Now, for me, OSCCON 1:0, is set to 00, and the fuses have FOSC 2:1 set to 10

What do these show for your, if you load the code into a simulator like MPLAB?.

What compiler version are you using?.

Best Wishes
peterpanic



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

PostPosted: Thu Mar 22, 2012 5:52 pm     Reply with quote

Quote:
Now, for me, OSCCON 1:0, is set to 00, and the fuses have FOSC 2:1 set to 10


FOSC should be 01 (so that the 96M prescaler sees internal rather than external). That's what the hex file loads.


Quote:
What compiler version are you using?.


4.130


I note that there's an error in the CCS header file - if defines OSC_INTRC as 2 which is reserved - should be 3.


Sorry, but I have run out of time - I'm going to use it at 32MHz and sort this out when the job is done (should have been several days ago). Thanks for listening...
_________________
- peter -
peterpanic



Joined: 05 Apr 2010
Posts: 17
Location: UK

View user's profile Send private message

PostPosted: Thu Mar 22, 2012 6:09 pm     Reply with quote

I also see there is a Mchip silicon errata item which explains that, even though it's not used, you have to set the INTOSC prescaler selector to 4MHz or 8MHz.
_________________
- peter -
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