• AVR Freaks

Hot!PIC18F45Q10 timer interrupt blinking led.

Author
henbez_72
New Member
  • Total Posts : 21
  • Reward points : 0
  • Joined: 2020/10/20 11:27:10
  • Location: 0
  • Status: offline
2020/10/21 08:45:20 (permalink)
0

PIC18F45Q10 timer interrupt blinking led.

Trying to blink LED using timer and interrupt routine.See code below.

LED on pin RD0 blink with delay function no problem

LED on pin RD1 no response.

Program compile no warnings all good.

Thanks for help

/***********************************************
* Microcontroller used is the PIC18F45Q10
* Compiler used is XC8 VERSION v2.1
* This program blinks an LED using interrupt
****************************/


// CONFIG1L
#pragma config FEXTOSC = ECH // External Oscillator mode Selection bits (EC (external clock) above 8 MHz; PFM set to high power)
#pragma config RSTOSC = EXTOSC // Power-up default value for COSC bits (EXTOSC operating per FEXTOSC bits (device manufacturing default))

// CONFIG1L
#pragma config FEXTOSC = ECH // External Oscillator mode Selection bits (EC (external clock) above 8 MHz; PFM set to high power)
#pragma config RSTOSC = EXTOSC // Power-up default value for COSC bits (EXTOSC operating per FEXTOSC bits (device manufacturing default))

// CONFIG1H
#pragma config CLKOUTEN = ON // Clock Out Enable bit (CLKOUT function is disabled)
#pragma config CSWEN = ON // Clock Switch Enable bit (Writing to NOSC and NDIV is allowed)
#pragma config FCMEN = ON // Fail-Safe Clock Monitor Enable bit (Fail-Safe Clock Monitor enabled)

// CONFIG2L
#pragma config MCLRE = EXTMCLR // Master Clear Enable bit (MCLR pin (RE3) is MCLR)
#pragma config PWRTE = OFF // Power-up Timer Enable bit (Power up timer disabled)
#pragma config LPBOREN = OFF // Low-power BOR enable bit (Low power BOR is disabled)
#pragma config BOREN = SBORDIS // Brown-out Reset Enable bits (Brown-out Reset enabled , SBOREN bit is ignored)

// CONFIG2H
#pragma config BORV = VBOR_190 // Brown Out Reset Voltage selection bits (Brown-out Reset Voltage (VBOR) set to 1.90V)
#pragma config ZCD = OFF // ZCD Disable bit (ZCD disabled. ZCD can be enabled by setting the ZCDSEN bit of ZCDCON)
#pragma config PPS1WAY = ON // PPSLOCK bit One-Way Set Enable bit (PPSLOCK bit can be cleared and set only once; PPS registers remain locked after one clear/set cycle)
#pragma config STVREN = ON // Stack Full/Underflow Reset Enable bit (Stack full/underflow will cause Reset)
#pragma config XINST = OFF // Extended Instruction Set Enable bit (Extended Instruction Set and Indexed Addressing Mode disabled)

// CONFIG3L
#pragma config WDTCPS = WDTCPS_31// WDT Period Select bits (Divider ratio 1:65536; software control of WDTPS)
#pragma config WDTE = ON // WDT operating mode (WDT always enabled)

// CONFIG3H
#pragma config WDTCWS = WDTCWS_7// WDT Window Select bits (window always open (100%); software control; keyed access not required)
#pragma config WDTCCS = SC // WDT input clock selector (Software Control)

// CONFIG4L
#pragma config WRT0 = OFF // Write Protection Block 0 (Block 0 (000800-001FFFh) not write-protected)
#pragma config WRT1 = OFF // Write Protection Block 1 (Block 1 (002000-003FFFh) not write-protected)
#pragma config WRT2 = OFF // Write Protection Block 2 (Block 2 (004000-005FFFh) not write-protected)
#pragma config WRT3 = OFF // Write Protection Block 3 (Block 3 (006000-007FFFh) not write-protected)

// CONFIG4H
#pragma config WRTC = OFF // Configuration Register Write Protection bit (Configuration registers (300000-30000Bh) not write-protected)
#pragma config WRTB = OFF // Boot Block Write Protection bit (Boot Block (000000-0007FFh) not write-protected)
#pragma config WRTD = OFF // Data EEPROM Write Protection bit (Data EEPROM not write-protected)
#pragma config SCANE = ON // Scanner Enable bit (Scanner module is available for use, SCANMD bit can control the module)
#pragma config LVP = ON // Low Voltage Programming Enable bit (Low voltage programming enabled. MCLR/VPP pin function is MCLR. MCLRE configuration bit is ignored)

// CONFIG5L
#pragma config CP = OFF // UserNVM Program Memory Code Protection bit (UserNVM code protection disabled)
#pragma config CPD = OFF // DataNVM Memory Code Protection bit (DataNVM code protection disabled)

// CONFIG5H

// CONFIG6L
#pragma config EBTR0 = OFF // Table Read Protection Block 0 (Block 0 (000800-001FFFh) not protected from table reads executed in other blocks)
#pragma config EBTR1 = OFF // Table Read Protection Block 1 (Block 1 (002000-003FFFh) not protected from table reads executed in other blocks)
#pragma config EBTR2 = OFF // Table Read Protection Block 2 (Block 2 (004000-005FFFh) not protected from table reads executed in other blocks)
#pragma config EBTR3 = OFF // Table Read Protection Block 3 (Block 3 (006000-007FFFh) not protected from table reads executed in other blocks)

// CONFIG6H
#pragma config EBTRB = OFF // Boot Block Table Read Protection bit (Boot Block (000000-0007FFh) not protected from table reads executed in other blocks)


#include <xc.h>
#define _XTAL_FREQ 20000000 // 20MHz crystal

//Variables
#define LED1 PORTDbits.RD1 //ISR
#define LED0 PORTDbits.RD0 //delay

volatile int count = 0; //volatile means value may be changed externally without program doing anything
volatile int num_overflows = 19;

// interrupt service routine
void __interrupt() ISR(void) {
// has the interrupt been fired by timer 1?
if(PIR0bits.TMR0IF == 1) {
// increase the number of times interrupt has been fired
count++;
// count till 19 interrupts have been fired (about 1 second has elapsed)using 20 MHZ clock

if(count == num_overflows) {
// toggle RD1 pin
LATDbits.LATD1 ^= 1;
//PORTDbits.RD1 = ~PORTDbits.RD1; //flip the bit
// reset counter
count = 0;
}
// reset the overflow interrupt flag
PIR0bits.TMR0IF = 0;
}
}
//Timer_0
void timer_init(){
//T0CON0 reg
T0CON0bits.T0EN =1; //enable timer0
T0CON0bits.T016BIT =1; //enable 16bit timer

T0CON0bits.T0OUTPS0=0; //postcaler =1
T0CON0bits.T0OUTPS1=0;
T0CON0bits.T0OUTPS2=0;
T0CON0bits.T0OUTPS3=0;

//T0CON1 reg
T0CON1bits.T0CS0=0; //clock source FOSC/4 for timer0
T0CON1bits.T0CS1=1;
T0CON1bits.T0CS2=0;

T0CON1bits.T0ASYNC=0; //sync to fosc/4

T0CON1bits.T0CKPS0=0; //prescaler =4
T0CON1bits.T0CKPS1=1;
T0CON1bits.T0CKPS2=0;
T0CON1bits.T0CKPS3=0;

// clear timer1 high and low holding registers
TMR0H = 0;
TMR0L = 0;
// enable global interrupts
INTCONbits.GIE = 1; // enable global interrupts
// enable peripheral interrupts
INTCONbits.PEIE = 1;
// interupt priority
INTCONbits.IPEN = 1;
// enable interrupt flag for timer 1
PIE0bits.TMR0IE = 1;
// TMR0 priority high
IPR0bits.TMR0IP = 1;
// reset the overflow interrupt flag
PIR0bits.TMR0IF = 0;
}
void init_port()
{
ANSELD = 0b00000000; //Configure PORTD as digital
TRISD = 0b00000000; //Configure PORTD as output
//LED1 = 0;

}

int main()
{
init_port();
timer_init();//timer0 init


while(1)//infinite loop or use while(1)
{
LED0 = 1; //LED0 ON
__delay_ms(10);
LED0 = 0; //LED0 OFF
__delay_ms(100);



}
}
#1

13 Replies Related Threads

    hexreader
    Super Member
    • Total Posts : 1107
    • Reward points : 0
    • Joined: 2008/05/04 03:06:55
    • Location: England
    • Status: online
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 10:42:54 (permalink)
    0
    A lot of mistakes - here are the ones I can see after a quick view
     
    1) Please use code tags to make your code readable.
    2) CONFIG1L is listed twice. Harmless, but confusing
    3) Turn off watchdog timer
    4) Possibly Turn off LVP    (EDIT: unless your programmer only supports LVP) - see later posts 
    5) comment does not match setting "#pragma config CLKOUTEN = ON // Clock Out Enable bit (CLKOUT function is disabled)"
    6) change:
    #define LED1 PORTDbits.RD1 //ISR
    #define LED0 PORTDbits.RD0 //delay
    to:
    #define LED1 LATDbits.LATD1 //ISR
    #define LED0 LATDbits.LATD0 //delay

     
    Maybe that is enough. Try it and report on how it goes...
     
    /***********************************************
    * Microcontroller used is the PIC18F45Q10
    * Compiler used is XC8 VERSION v2.1
    * This program blinks an LED using interrupt
    ****************************/


    // CONFIG1L
    #pragma config FEXTOSC = ECH // External Oscillator mode Selection bits (EC (external clock) above 8 MHz; PFM set to high power)
    #pragma config RSTOSC = EXTOSC // Power-up default value for COSC bits (EXTOSC operating per FEXTOSC bits (device manufacturing default))

    // CONFIG1L
    #pragma config FEXTOSC = ECH // External Oscillator mode Selection bits (EC (external clock) above 8 MHz; PFM set to high power)
    #pragma config RSTOSC = EXTOSC // Power-up default value for COSC bits (EXTOSC operating per FEXTOSC bits (device manufacturing default))

    // CONFIG1H
    #pragma config CLKOUTEN = ON // Clock Out Enable bit (CLKOUT function is disabled)
    #pragma config CSWEN = ON // Clock Switch Enable bit (Writing to NOSC and NDIV is allowed)
    #pragma config FCMEN = ON // Fail-Safe Clock Monitor Enable bit (Fail-Safe Clock Monitor enabled)

    // CONFIG2L
    #pragma config MCLRE = EXTMCLR // Master Clear Enable bit (MCLR pin (RE3) is MCLR)
    #pragma config PWRTE = OFF // Power-up Timer Enable bit (Power up timer disabled)
    #pragma config LPBOREN = OFF // Low-power BOR enable bit (Low power BOR is disabled)
    #pragma config BOREN = SBORDIS // Brown-out Reset Enable bits (Brown-out Reset enabled , SBOREN bit is ignored)

    // CONFIG2H
    #pragma config BORV = VBOR_190 // Brown Out Reset Voltage selection bits (Brown-out Reset Voltage (VBOR) set to 1.90V)
    #pragma config ZCD = OFF // ZCD Disable bit (ZCD disabled. ZCD can be enabled by setting the ZCDSEN bit of ZCDCON)
    #pragma config PPS1WAY = ON // PPSLOCK bit One-Way Set Enable bit (PPSLOCK bit can be cleared and set only once; PPS registers remain locked after one clear/set cycle)
    #pragma config STVREN = ON // Stack Full/Underflow Reset Enable bit (Stack full/underflow will cause Reset)
    #pragma config XINST = OFF // Extended Instruction Set Enable bit (Extended Instruction Set and Indexed Addressing Mode disabled)

    // CONFIG3L
    #pragma config WDTCPS = WDTCPS_31// WDT Period Select bits (Divider ratio 1:65536; software control of WDTPS)
    #pragma config WDTE = OFF // WDT operating mode (WDT always enabled)

    // CONFIG3H
    #pragma config WDTCWS = WDTCWS_7// WDT Window Select bits (window always open (100%); software control; keyed access not required)
    #pragma config WDTCCS = SC // WDT input clock selector (Software Control)

    // CONFIG4L
    #pragma config WRT0 = OFF // Write Protection Block 0 (Block 0 (000800-001FFFh) not write-protected)
    #pragma config WRT1 = OFF // Write Protection Block 1 (Block 1 (002000-003FFFh) not write-protected)
    #pragma config WRT2 = OFF // Write Protection Block 2 (Block 2 (004000-005FFFh) not write-protected)
    #pragma config WRT3 = OFF // Write Protection Block 3 (Block 3 (006000-007FFFh) not write-protected)

    // CONFIG4H
    #pragma config WRTC = OFF // Configuration Register Write Protection bit (Configuration registers (300000-30000Bh) not write-protected)
    #pragma config WRTB = OFF // Boot Block Write Protection bit (Boot Block (000000-0007FFh) not write-protected)
    #pragma config WRTD = OFF // Data EEPROM Write Protection bit (Data EEPROM not write-protected)
    #pragma config SCANE = ON // Scanner Enable bit (Scanner module is available for use, SCANMD bit can control the module)
    #pragma config LVP = ON // Low Voltage Programming Enable bit (Low voltage programming enabled. MCLR/VPP pin function is MCLR. MCLRE configuration bit is ignored)

    // CONFIG5L
    #pragma config CP = OFF // UserNVM Program Memory Code Protection bit (UserNVM code protection disabled)
    #pragma config CPD = OFF // DataNVM Memory Code Protection bit (DataNVM code protection disabled)

    // CONFIG5H

    // CONFIG6L
    #pragma config EBTR0 = OFF // Table Read Protection Block 0 (Block 0 (000800-001FFFh) not protected from table reads executed in other blocks)
    #pragma config EBTR1 = OFF // Table Read Protection Block 1 (Block 1 (002000-003FFFh) not protected from table reads executed in other blocks)
    #pragma config EBTR2 = OFF // Table Read Protection Block 2 (Block 2 (004000-005FFFh) not protected from table reads executed in other blocks)
    #pragma config EBTR3 = OFF // Table Read Protection Block 3 (Block 3 (006000-007FFFh) not protected from table reads executed in other blocks)

    // CONFIG6H
    #pragma config EBTRB = OFF // Boot Block Table Read Protection bit (Boot Block (000000-0007FFh) not protected from table reads executed in other blocks)


    #include <xc.h>
    #define _XTAL_FREQ 20000000 // 20MHz crystal

    //Variables
    #define LED1 LATDbits.LATD1 //ISR
    #define LED0 LATDbits.LATD0 //delay

    volatile int count = 0; //volatile means value may be changed externally without program doing anything
    volatile int num_overflows = 19;

    // interrupt service routine
    void __interrupt() ISR(void) {
        // has the interrupt been fired by timer 1?
        if(PIR0bits.TMR0IF == 1) {
        // increase the number of times interrupt has been fired
        count++;
        // count till 19 interrupts have been fired (about 1 second has elapsed)using 20 MHZ clock

        if(count == num_overflows) {
        // toggle RD1 pin
        LATDbits.LATD1 ^= 1;
        //PORTDbits.RD1 = ~PORTDbits.RD1; //flip the bit
        // reset counter
        count = 0;
        }
        // reset the overflow interrupt flag
        PIR0bits.TMR0IF = 0;
        }
    }
    //Timer_0
    void timer_init(){
        //T0CON0 reg
        T0CON0bits.T0EN =1; //enable timer0
        T0CON0bits.T016BIT =1; //enable 16bit timer

        T0CON0bits.T0OUTPS0=0; //postcaler =1
        T0CON0bits.T0OUTPS1=0;
        T0CON0bits.T0OUTPS2=0;
        T0CON0bits.T0OUTPS3=0;

        //T0CON1 reg
        T0CON1bits.T0CS0=0; //clock source FOSC/4 for timer0
        T0CON1bits.T0CS1=1;
        T0CON1bits.T0CS2=0;

        T0CON1bits.T0ASYNC=0; //sync to fosc/4

        T0CON1bits.T0CKPS0=0; //prescaler =4
        T0CON1bits.T0CKPS1=1;
        T0CON1bits.T0CKPS2=0;
        T0CON1bits.T0CKPS3=0;

        // clear timer1 high and low holding registers
        TMR0H = 0;
        TMR0L = 0;
        // enable global interrupts
        INTCONbits.GIE = 1; // enable global interrupts
        // enable peripheral interrupts
        INTCONbits.PEIE = 1;
        // interupt priority
        INTCONbits.IPEN = 1;
        // enable interrupt flag for timer 1
        PIE0bits.TMR0IE = 1;
        // TMR0 priority high
        IPR0bits.TMR0IP = 1;
        // reset the overflow interrupt flag
        PIR0bits.TMR0IF = 0;
    }

    void init_port()
    {
        ANSELD = 0b00000000; //Configure PORTD as digital
        TRISD = 0b00000000; //Configure PORTD as output
        //LED1 = 0;

    }

    int main()
    {
        init_port();
        timer_init(); //timer0 init


        while(1) //infinite loop or use while(1)
        {
            LED0 = 1; //LED0 ON
            __delay_ms(10);
            LED0 = 0; //LED0 OFF
            __delay_ms(100);
        }
    }

    post edited by hexreader - 2020/10/21 11:36:21

    Experienced Hobbyist
    #2
    mbrowning
    USNA79
    • Total Posts : 1824
    • Reward points : 0
    • Joined: 2005/03/16 14:32:56
    • Location: Melbourne, FL
    • Status: online
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 10:53:44 (permalink)
    0
    hexreader
    4) Turn off LVP
    Why do you recommend this? I consider HVP to be the archaic method and only use LVP. Certainly Microchip does too as the Snap doesn't support HVP. I believe NSDSP also only uses LVP (unless extra hardware is added).
     
    edited
    post edited by mbrowning - 2020/10/21 10:55:25
    #3
    hexreader
    Super Member
    • Total Posts : 1107
    • Reward points : 0
    • Joined: 2008/05/04 03:06:55
    • Location: England
    • Status: online
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 11:18:33 (permalink)
    +2 (2)
    Habit from history maybe - but for older PICs
    1) Saves a pin
    2) No need for pull-down resistor to prevent going into program mode during operation or on first programming
    3) Have never used a programmer that did not have HVP available - If I had a LVP-only programmer, then I might change habit
     
    Maybe I am out of date...  happy to be corrected.
     
    Have edited earlier post with LVP clarification and LVP enabled just in case
    post edited by hexreader - 2020/10/21 11:27:04

    Experienced Hobbyist
    #4
    henbez_72
    New Member
    • Total Posts : 21
    • Reward points : 0
    • Joined: 2020/10/20 11:27:10
    • Location: 0
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 11:56:46 (permalink)
    0
    Disabling the watchdog timer solved the issue.
    Thanks
    Smile: Smile
    #5
    henbez_72
    New Member
    • Total Posts : 21
    • Reward points : 0
    • Joined: 2020/10/20 11:27:10
    • Location: 0
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:03:17 (permalink)
    0
    With the oscillator frequency , prescale value of  and its resolution is RES=2^16 bits. Therefore, using the equation ,I get that the output frequency is , therefore the period of setting interrupt flag is . Since I want the LED to blink in 1/2Hz period, the time the LED is on or off is equal to 1s = 1000ms and so the number of overflows causing the interrupt flag to be set needs to be .
     
    Using this number I dont see the LED blinking as it should it is on 3sec and off for 3 sec.Something wrong with the clock?
     
     
    #6
    ric
    Super Member
    • Total Posts : 28975
    • Reward points : 0
    • Joined: 2003/11/07 12:41:26
    • Location: Australia, Melbourne
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:32:49 (permalink)
    0
    (Deleted, incorrect comment)
    post edited by ric - 2020/10/21 12:34:23

    I also post at: PicForum
    Links to useful PIC information: http://picforum.ric323.co...opic.php?f=59&t=15
    NEW USERS: Posting images, links and code - workaround for restrictions.
    To get a useful answer, always state which PIC you are using!
    #7
    henbez_72
    New Member
    • Total Posts : 21
    • Reward points : 0
    • Joined: 2020/10/20 11:27:10
    • Location: 0
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:38:25 (permalink)
    0
    Yes it does.
    The ISR execute 19 times then the LED toggle.But timing seem to be off.I wonder if it is the clock source I selected?
    [image][/image]
    #8
    ric
    Super Member
    • Total Posts : 28975
    • Reward points : 0
    • Joined: 2003/11/07 12:41:26
    • Location: Australia, Melbourne
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:40:01 (permalink)
    0
    I immediately realised I'd missed your ISR, and deleted the comment within 60 seconds.
    You can't drag an image into a post, you have to "Open Full Version" and use the "Attach" button.
     

    I also post at: PicForum
    Links to useful PIC information: http://picforum.ric323.co...opic.php?f=59&t=15
    NEW USERS: Posting images, links and code - workaround for restrictions.
    To get a useful answer, always state which PIC you are using!
    #9
    1and0
    Access is Denied
    • Total Posts : 11506
    • Reward points : 0
    • Joined: 2007/05/06 12:03:20
    • Location: Harry's Gray Matter
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:46:29 (permalink)
    0
    henbez_72
    // CONFIG1L
    #pragma config FEXTOSC = ECH // External Oscillator mode Selection bits (EC (external clock) above 8 MHz; PFM set to high power)
    #pragma config RSTOSC = EXTOSC // Power-up default value for COSC bits (EXTOSC operating per FEXTOSC bits

    #define _XTAL_FREQ 20000000 // 20MHz crystal

    Are you using a crystal or oscillator?
    #10
    hexreader
    Super Member
    • Total Posts : 1107
    • Reward points : 0
    • Joined: 2008/05/04 03:06:55
    • Location: England
    • Status: online
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:47:54 (permalink)
    +1 (1)
    I too had a problem with the clock frequency.
     
    Fail-safe clock appears to switch from external 20MHz 2-pin crystal (and 2x 22pF cap) to 4MHz internal oscillator.
     
    Disabling switch-over and FSCM in config forces external 20MHz crystal, but then everything dies.
     
    I made delay function accurate by changing to  
     
    "#define _XTAL_FREQ 4000000 // 20MHz crystal fails on my dev board so switch to internal clock 4MHz"
     
    I have NO IDEA why external oscillator is not working :(
     
    We will both have to wait for an expert to chip-in (pun intended)
     
    (In the interest of full disclosure - I have no PIC18F45Q10, so I use PIC18F47Q10 and ignore ID warnings when burning)
    post edited by hexreader - 2020/10/21 12:49:19

    Experienced Hobbyist
    #11
    hexreader
    Super Member
    • Total Posts : 1107
    • Reward points : 0
    • Joined: 2008/05/04 03:06:55
    • Location: England
    • Status: online
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 12:57:50 (permalink)
    +2 (2)
    DOH !!!!
     
    I am being an idiot.
     
    Oscillator mode needs to be HS !
     
    #pragma config FEXTOSC = HS // 

     
    So here is what I have after improving the formatting:
    /***********************************************
    * Microcontroller used is the PIC18F45Q10
    * Compiler used is XC8 VERSION v2.1
    * This program blinks an LED using interrupt
    ****************************/

    // CONFIG1L
    #pragma config FEXTOSC = HS //
    #pragma config RSTOSC = EXTOSC // Power-up default value for COSC bits (EXTOSC operating per FEXTOSC bits (device manufacturing default))

    // CONFIG1H
    #pragma config CLKOUTEN = OFF // Clock Out Enable bit (CLKOUT function is disabled)
    #pragma config CSWEN = ON // Clock Switch Enable bit (Writing to NOSC and NDIV is allowed)
    #pragma config FCMEN = ON // Fail-Safe Clock Monitor Enable bit (Fail-Safe Clock Monitor enabled)

    // CONFIG2L
    #pragma config MCLRE = EXTMCLR // Master Clear Enable bit (MCLR pin (RE3) is MCLR)
    #pragma config PWRTE = OFF // Power-up Timer Enable bit (Power up timer disabled)
    #pragma config LPBOREN = OFF // Low-power BOR enable bit (Low power BOR is disabled)
    #pragma config BOREN = SBORDIS // Brown-out Reset Enable bits (Brown-out Reset enabled , SBOREN bit is ignored)

    // CONFIG2H
    #pragma config BORV = VBOR_190 // Brown Out Reset Voltage selection bits (Brown-out Reset Voltage (VBOR) set to 1.90V)
    #pragma config ZCD = OFF // ZCD Disable bit (ZCD disabled. ZCD can be enabled by setting the ZCDSEN bit of ZCDCON)
    #pragma config PPS1WAY = ON // PPSLOCK bit One-Way Set Enable bit (PPSLOCK bit can be cleared and set only once; PPS registers remain locked after one clear/set cycle)
    #pragma config STVREN = ON // Stack Full/Underflow Reset Enable bit (Stack full/underflow will cause Reset)
    #pragma config XINST = OFF // Extended Instruction Set Enable bit (Extended Instruction Set and Indexed Addressing Mode disabled)

    // CONFIG3L
    #pragma config WDTCPS = WDTCPS_31// WDT Period Select bits (Divider ratio 1:65536; software control of WDTPS)
    #pragma config WDTE = OFF // WDT operating mode (WDT always enabled)

    // CONFIG3H
    #pragma config WDTCWS = WDTCWS_7// WDT Window Select bits (window always open (100%); software control; keyed access not required)
    #pragma config WDTCCS = SC // WDT input clock selector (Software Control)

    // CONFIG4L
    #pragma config WRT0 = OFF // Write Protection Block 0 (Block 0 (000800-001FFFh) not write-protected)
    #pragma config WRT1 = OFF // Write Protection Block 1 (Block 1 (002000-003FFFh) not write-protected)
    #pragma config WRT2 = OFF // Write Protection Block 2 (Block 2 (004000-005FFFh) not write-protected)
    #pragma config WRT3 = OFF // Write Protection Block 3 (Block 3 (006000-007FFFh) not write-protected)

    // CONFIG4H
    #pragma config WRTC = OFF // Configuration Register Write Protection bit (Configuration registers (300000-30000Bh) not write-protected)
    #pragma config WRTB = OFF // Boot Block Write Protection bit (Boot Block (000000-0007FFh) not write-protected)
    #pragma config WRTD = OFF // Data EEPROM Write Protection bit (Data EEPROM not write-protected)
    #pragma config SCANE = ON // Scanner Enable bit (Scanner module is available for use, SCANMD bit can control the module)
    #pragma config LVP = ON // Low Voltage Programming Enable bit (Low voltage programming enabled. MCLR/VPP pin function is MCLR. MCLRE configuration bit is ignored)

    // CONFIG5L
    #pragma config CP = OFF // UserNVM Program Memory Code Protection bit (UserNVM code protection disabled)
    #pragma config CPD = OFF // DataNVM Memory Code Protection bit (DataNVM code protection disabled)

    // CONFIG5H

    // CONFIG6L
    #pragma config EBTR0 = OFF // Table Read Protection Block 0 (Block 0 (000800-001FFFh) not protected from table reads executed in other blocks)
    #pragma config EBTR1 = OFF // Table Read Protection Block 1 (Block 1 (002000-003FFFh) not protected from table reads executed in other blocks)
    #pragma config EBTR2 = OFF // Table Read Protection Block 2 (Block 2 (004000-005FFFh) not protected from table reads executed in other blocks)
    #pragma config EBTR3 = OFF // Table Read Protection Block 3 (Block 3 (006000-007FFFh) not protected from table reads executed in other blocks)

    // CONFIG6H
    #pragma config EBTRB = OFF // Boot Block Table Read Protection bit (Boot Block (000000-0007FFh) not protected from table reads executed in other blocks)

    #include <xc.h>
    #define _XTAL_FREQ 20000000 // 20MHz 2-pin crystal

    #define LED1 LATDbits.LATD1 //ISR
    #define LED0 LATDbits.LATD0 //delay

    // global Variables
    volatile int count = 0; //volatile means value may be changed externally without program doing anything
    volatile int num_overflows = 19;

    // interrupt service routine
    void __interrupt() ISR(void) {
        
        if(PIR0bits.TMR0IF == 1) { // has the interrupt been fired by timer 1?
            count++; // increase the number of times interrupt has been fired
            if(count == num_overflows) { // count till 19 interrupts have been fired (about 1 second has elapsed)using 20 MHZ clock
                LATDbits.LATD1 ^= 1; // toggle RD1 pin
                //PORTDbits.RD1 = ~PORTDbits.RD1; //flip the bit
                count = 0; // reset counter
            }
            PIR0bits.TMR0IF = 0; // reset the overflow interrupt flag
        }
    }

    // Timer_0 init
    void timer_init(){
        //T0CON0 reg
        T0CON0bits.T0EN = 1; // enable timer0
        T0CON0bits.T016BIT = 1; // enable 16bit timer

        T0CON0bits.T0OUTPS0 = 0; // post-scaler = 1
        T0CON0bits.T0OUTPS1 = 0;
        T0CON0bits.T0OUTPS2 = 0;
        T0CON0bits.T0OUTPS3 = 0;

        //T0CON1 reg
        T0CON1bits.T0CS0 = 0; // clock source FOSC/4 for timer0
        T0CON1bits.T0CS1 = 1;
        T0CON1bits.T0CS2 = 0;

        T0CON1bits.T0ASYNC = 0; // sync to fosc/4

        T0CON1bits.T0CKPS0 = 0; // pre-scaler = 4
        T0CON1bits.T0CKPS1 = 1;
        T0CON1bits.T0CKPS2 = 0;
        T0CON1bits.T0CKPS3 = 0;

        TMR0H = 0; // clear timer1 high and low holding registers
        TMR0L = 0;
        INTCONbits.GIE = 1; // enable global interrupts
        INTCONbits.PEIE = 1; // enable peripheral interrupts
        INTCONbits.IPEN = 1; // interrupt priority
        PIE0bits.TMR0IE = 1; // enable interrupt flag for timer 1
        IPR0bits.TMR0IP = 1; // TMR0 priority high
        PIR0bits.TMR0IF = 0; // reset the overflow interrupt flag
    }

    void init_port()
    {
        ANSELD = 0b00000000; // Configure PORTD as digital
        TRISD = 0b00000000; // Configure PORTD as output
        //LED1 = 0;
    }

    int main()
    {
        init_port();
        timer_init(); // timer0 init

        while(1) // infinite loop or use while(1)
        {
            LED0 = 1; // LED0 ON
            __delay_ms(500); // half second delay foe 1Hz flash rate
            LED0 = 0; // LED0 OFF
            __delay_ms(500); // half second delay foe 1Hz flash rate
        }
    }

    post edited by hexreader - 2020/10/21 13:15:00

    Experienced Hobbyist
    #12
    henbez_72
    New Member
    • Total Posts : 21
    • Reward points : 0
    • Joined: 2020/10/20 11:27:10
    • Location: 0
    • Status: offline
    Re: PIC18F45Q10 timer interrupt blinking led. 2020/10/21 13:48:20 (permalink)
    0
    Changing the Oscillator mode needs to  HS  FIXED it...Thank you very much..
    #13
    Jump to:
    © 2020 APG vNext Commercial Version 4.5