GPS Project: PIC18F26K22 or PIC18F46K22


Closed Thread
Results 1 to 40 of 69

Hybrid View

  1. #1
    Join Date
    Oct 2010
    Posts
    413


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    Second Question is: How to do we set the configuration fuses for the PIC, especially for the PIC18F26K22?

    Right now the first step is to Flash an LED at port RC3 ( pin14 ) of the PIC18F26K22.

    The following code is written in order to Flash the LED on the specific port.

    For me at the moment is quit difficult to explain the configuration fuses for all the setups, mostly important to the ones setting the frequency at high external speed HS of 64Mhz.

    From the manual it says that we need to enable the PLL bit and also specify that we are going to use the external OSC.

    I might need the help of the ones are most expirienced to help me out regarding the setting for 64 MHZ with an external crystal 16Mhz.

    Code:
    @ ERRORLEVEL -306 ; this command prevents the compiler to give you a notice of   *
                      ; crossing page boundary - make sure bits are set              *
    '********************************************************************************* 
     
      #CONFIG   ;  The PBP default configuration for the PIC18F26K22 is:
    ;    CONFIG FOSC = RCIO6	          ; External RC oscillator
        CONFIG FOSC = HSHP	          ; HS oscillator (high power > 16 MHz)
    ;    CONFIG  FOSC = INTIO67       ; Internal oscillator block
    ;    CONFIG  PLLCFG = ON          ; Oscillator used directly
        CONFIG  PRICLKEN = ON         ; Primary clock can be disabled by software
        CONFIG  FCMEN = OFF           ; Fail-Safe Clock Monitor disabled
        CONFIG  IESO = OFF            ; Oscillator Switchover mode disabled
        CONFIG  PWRTEN = OFF          ; Power up timer disabled
        CONFIG  BOREN = SBORDIS       ; Brown-out Reset enabled in hardware only (SBOREN is disabled)
    ;    CONFIG  BORV = 190           ; VBOR set to 1.90 V nominal
        
    ;*--------------------------------------------------------------------------------------------------------;|
        CONFIG  WDTEN = ON            ; WDT is always enabled. SWDTEN bit has no effect                       ;|
        CONFIG  WDTPS = 32768         ; 1:32768 ---> HERE enable the watchdog timer with a 1:32768 postscale  ;|
    ;*--------------------------------------------------------------------------------------------------------;|
    
    ;     CONFIG  CCP2MX = PORTC1      ; CCP2 input/output is multiplexed with RC1
    ;     CONFIG  PBADEN = OFF         ; PORTB<5:0> pins are configured as digital I/O on Reset
    ;     CONFIG  CCP3MX = PORTB5      ; P3A/CCP3 input/output is multiplexed with RB5
        CONFIG  HFOFST = ON           ; HFINTOSC output and ready status are not delayed by the oscillator stable status
    ;    CONFIG  T3CMX = PORTC0       ; T3CKI is on RC0
    ;    CONFIG  P2BMX = PORTB5       ; P2B is on RB5
        CONFIG  MCLRE = EXTMCLR       ; MCLR pin enabled, RE3 input pin disabled
    ;    CONFIG  STVREN = ON          ; Stack full/underflow will cause Reset
        CONFIG  LVP = OFF             ; Single-Supply ICSP disabled
        CONFIG  XINST = OFF           ; Instruction set extension and Indexed Addressing mode disabled (Legacy mode)
        CONFIG  DEBUG = OFF           ; Disabled
    
    ;*----------------------------------------------------------------------------------|
    ;*---------------Available configuration settings for PIC18F26K22-------------------|
    ;*----------------------------------------------------------------------------------|
    ;
    ;  Oscillator Selection bits
    ;    CONFIG FOSC = RC	    ;111X External RC oscillator, CLKOUT function on RA6
    ;    CONFIG FOSC = ECLPIO6  ;EC oscillator (low power, &lt;500 kHz)
    ;    CONFIG FOSC = ECLP	    ;EC oscillator, CLKOUT function on OSC2 (low power, &lt;500 kHz)
    ;    CONFIG FOSC = ECMPIO6  ;EC oscillator (medium power, 500 kHz-16 MHz)
    ;    CONFIG FOSC = ECMP	    ;EC oscillator, CLKOUT function on OSC2 (medium power, 500 kHz-16 MHz)
    ;    CONFIG FOSC = INTIO7   ;Internal oscillator block, CLKOUT function on OSC2
    ;    CONFIG FOSC = INTIO67  ;Internal oscillator block
    ;    CONFIG FOSC = RCIO6    ;External RC oscillator
    ;    CONFIG FOSC = RC	    ;External RC oscillator, CLKOUT function on OSC2
    ;    CONFIG FOSC = ECHPIO6  ;EC oscillator (high power, &gt;16 MHz)
    ;    CONFIG FOSC = ECHP	    ;EC oscillator, CLKOUT function on OSC2 (high power, &gt;16 MHz)
    ;    CONFIG FOSC = HSMP	    ;HS oscillator (medium power 4-16 MHz)
    ;    CONFIG FOSC = HSHP	    ;HS oscillator (high power &gt; 16 MHz)
    ;    CONFIG FOSC = XT	    ;XT oscillator
    ;    CONFIG FOSC = LP	    ;LP oscillator
    ;
    ;*------------------------------------------------------------------------------------*|
    ;*                                                                                    *|
    ;*---------------------------------4x PLL ENABLE--------------------------------------*|
    ;*                                                                                    *|
    ;*------------------------------------------------------------------------------------*|
    ;*                                                                                    *|
    ;*  4X PLL Enable                                                                     *|
    ;*    CONFIG PLLCFG = OFF	;Oscillator used directly                                 *|
        CONFIG PLLCFG = ON	    ;Oscillator multiplied by 4                               *|
    ;*                                                                                    *|
    ;*------------------------------------------------------------------------------------*|
    ;
    ;  Primary clock enable bit
    ;    CONFIG PRICLKEN = OFF	    ;Primary clock can be disabled by software
    ;    CONFIG PRICLKEN = ON	    ;Primary clock enabled
    ;
    ;  Fail-Safe Clock Monitor Enable bit
    ;    CONFIG FCMEN = OFF	    ;Fail-Safe Clock Monitor disabled
    ;    CONFIG FCMEN = ON	    ;Fail-Safe Clock Monitor enabled
    ;
    ;  Internal/External Oscillator Switchover bit
    ;    CONFIG IESO = OFF	    ;Oscillator Switchover mode disabled
    ;    CONFIG IESO = ON	    ;Oscillator Switchover mode enabled
        
    ;*--------------------------------------------------------------------------------------------------------|
    ;*                                  | -------------------------- |                                        |
    ;*  -----------------------------   |  [PROTECTED OPTION FUSES]  |  ------------------------------------  |
    ;*                                  | -------------------------- |                                        |
    ;*--------------------------------------------------------------------------------------------------------|
    
        CONFIG  CP0 = OFF             ; Block 0 (000800-003FFFh) not code-protected
        CONFIG  CP1 = OFF             ; Block 1 (004000-007FFFh) not code-protected
        CONFIG  CP2 = OFF             ; Block 2 (008000-00BFFFh) not code-protected
        CONFIG  CP3 = OFF             ; Block 3 (00C000-00FFFFh) not code-protected
        CONFIG  CPB = OFF             ; Boot block (000000-0007FFh) not code-protected
        CONFIG  CPD = OFF             ; Data EEPROM not code-protected
        CONFIG  WRT0 = OFF            ; Block 0 (000800-003FFFh) not write-protected
        CONFIG  WRT1 = OFF            ; Block 1 (004000-007FFFh) not write-protected
        CONFIG  WRT2 = OFF            ; Block 2 (008000-00BFFFh) not write-protected
        CONFIG  WRT3 = OFF            ; Block 3 (00C000-00FFFFh) not write-protected
        CONFIG  WRTC = OFF            ; Configuration registers (300000-3000FFh) not write-protected
        CONFIG  WRTB = OFF            ; Boot Block (000000-0007FFh) not write-protected
        CONFIG  WRTD = OFF            ; Data EEPROM not write-protected
        CONFIG  EBTR0 = OFF           ; Block 0 (000800-003FFFh) not protected from table reads executed in other blocks
        CONFIG  EBTR1 = OFF           ; Block 1 (004000-007FFFh) not protected from table reads executed in other blocks
        CONFIG  EBTR2 = OFF           ; Block 2 (008000-00BFFFh) not protected from table reads executed in other blocks
        CONFIG  EBTR3 = OFF           ; Block 3 (00C000-00FFFFh) not protected from table reads executed in other blocks
        CONFIG  EBTRB = OFF           ; Boot Block (000000-0007FFh) not protected from table reads executed in other blocks
    
    ;*---------------------------------------------------------------------------------------------------------|
    ;*---------------------------------------------------------------------------------------------------------|
    
      #ENDCONFIG
    
    define  OSC 64
    
            INCLUDE "modedefs.bas"
            INCLUDE"ALLDIGITAL.pbp"
    
    OSCCON    = %01110000   ; 64Mhz
    OSCTUNE.6 = 1           ; Enable 4x PLL
    
    LED var PORTC.3
    
    
    main:
    high LED
    pause 10
    low LED
    pause 1000
    goto main
    Last edited by astanapane; - 1st July 2018 at 12:56.

  2. #2
    Join Date
    Nov 2003
    Location
    Greece
    Posts
    4,132


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    pause 10 is too little time.

    Maybe you need to make this 1000.

    Then check with a timer that it actually pauses every 1 sec confirming that osc is setup correctly.

    Recently I had similar matter setting up system oscillator again with 4xPLL and was running slow. Richard got it and we are OK now.

    Ioannis

  3. #3
    Join Date
    Oct 2010
    Posts
    413


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    Quote Originally Posted by Ioannis View Post
    pause 10 is too little time.

    Maybe you need to make this 1000.

    Then check with a timer that it actually pauses every 1 sec confirming that osc is setup correctly.

    Recently I had similar matter setting up system oscillator again with 4xPLL and was running slow. Richard got it and we are OK now.

    Ioannis
    Ioanni,

    thanks a lot for the help. I'll do it tonight and try to increase the time.

    To be honest i made many changing to the pause commands like : 10ms , 100ms, 1000ms, 2000ms. All seem to work fine.

    It would be a good practice to see how could we identify that the PIC clock now is running at 64Mhz?

    Is there any way to measure this with an Oscilloscope? I believe that this is a question have been asked many times.

    If someone could help me to identify the cpu clock speed of the PIC with the new setting of external 16Mhz crystal and 4xPLL, i can do the testing, and share the information step by step in here. If there is already posted an example like this i would like to have a look at it.

    thanks a lot.

  4. #4
    Join Date
    May 2013
    Location
    australia
    Posts
    2,644


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    Is there any way to measure this with an Oscilloscope?
    measure the led on/off time with the Oscilloscope if the osc is correct then the on/off times will be as per your code


    I would leave CONFIG PWRTEN = ON


    AND ADD THIS
    OSCCON = %01110000 ; 64Mhz
    OSCTUNE.6 = 1 ; Enable 4x PLL
    while ! osccon2.7 :WEND

    to make sure the pll has stabilised before you run any other code , if timing is critical
    Warning I'm not a teacher

  5. #5
    Join Date
    Oct 2010
    Posts
    413


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    Quote Originally Posted by richard View Post
    measure the led on/off time with the Oscilloscope if the osc is correct then the on/off times will be as per your code


    I would leave CONFIG PWRTEN = ON


    AND ADD THIS
    OSCCON = %01110000 ; 64Mhz
    OSCTUNE.6 = 1 ; Enable 4x PLL
    while ! osccon2.7 :WEND

    to make sure the pll has stabilised before you run any other code , if timing is critical
    Hi Richard,

    Thanks, i will do that. So that means that the 8th Bit of the OSCCON2 which is the .7 must be presented?
    Attached Images Attached Images  

  6. #6
    Join Date
    May 2013
    Location
    australia
    Posts
    2,644


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    I seldom use crystals [you lose two pins for marginal increase in accuracy ] but I believe you can set pll mode in the config section and is all you need

    CONFIG PLLCFG = ON
    ;CONFIG PLLCFG = OFF // pll can only be engaged with software selection for int osc


    and then all this is not valid , it applies to internal osc only

    OSCCON = %01110000 ; 64Mhz
    OSCTUNE.6 = 1 ; Enable 4x PLL


    this may or may not be necessary with xtal osc , I have found bootloaders won't sync up unless this is done using int osc with pll.
    the PLLRDY bit is asserted when pll is stable [although I can find no mention in data sheet]
    while ! osccon2.7 :WEND
    Warning I'm not a teacher

  7. #7
    Join Date
    Oct 2010
    Posts
    413


    Did you find this post helpful? Yes | No

    Default Re: GPS Project: PIC18F26K22 or PIC18F46K22

    Hi Richard,

    i got confused. Really im reading the datasheet and there is nowhere clear setting for using external crystal.

    I came up with the following

    Code:
    OSCCON = %01110000 ; 64Mhz
    OSCTUNE.6 = 1 ; Enable 4x PLL
    Because i was thinking that in order to specify the OSCCON, and the multiplier PLL we need to add those lines even if it is for internal or external source. I didnt think that those where valid only for internal OSC.

    So what should i add as OSCCON value, as i use and external crystal 16Mhz? How do i specify the OSCCON value for 64Mhz?

    thanks once again. Apologize for all my questions.

Similar Threads

  1. PIC18F46K22 config issue
    By LGabrielson in forum mel PIC BASIC Pro
    Replies: 2
    Last Post: - 29th September 2012, 03:20
  2. Replies: 1
    Last Post: - 27th July 2008, 06:14
  3. Pic GPS project Demo
    By Art in forum GPS
    Replies: 0
    Last Post: - 28th October 2007, 03:05
  4. GPS project question
    By mjp130 in forum GPS
    Replies: 6
    Last Post: - 4th July 2007, 20:09
  5. gps project
    By chuckad in forum GPS
    Replies: 2
    Last Post: - 9th February 2007, 02:52

Members who have read this thread : 1

You do not have permission to view the list of names.

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts