Thursday, August 12, 2021

Programming Timer0 of PIC16F818 in XC8

 

Introduction

Timer of a microcontroller is an auto-incremental register configured by user’s program. It’s useful for creating a timing delay, measuring the duration of external event, etc.

Programming Timer0 of PIC16F818 in XC8
A software simulation sample of this programming example


Timer0 of PIC16F818

Timer0 is an 8-bit read/write register locates at the address 01h and 101h in SFR. Timer0 works in both timer and counter mode, but we mention only timer mode in this post.

Programming Timer0 of PIC16F818 in XC8
Block Diagram of Timer0/WDT Prescaler

This peripheral module contains its storage register TMR0, control registers and its interrupt flag.

Prescaler Selection

Both timer and counter mode have a programmable prescaler, as it’s configured in Option register (OPTION_REG).

Programming Timer0 of PIC16F818 in XC8
OPTION_REG of PIC16F818

Its 8-bit Prescaler must between Timer0 and Watch Dog Timer (WDT) prescaler. These two prescaler selection is set in Prescaler Assignment bit (PSA). Setting PSA assigns its prescaler to the WDT, otherwise it’s assigned to Timer0 module.

Prescaler Rate Select bits (PS2:0) of the OPTION_REG configures the prescaler between 1:1 and 1:256.

Programming Timer0 of PIC16F818 in XC8
Prescaler Rate Select bits (PS2:0)

To get a 1:1 prescaler it must switch to WDT Rate. But getting a 1:256 prescaler rate it must switch to TMR0 Rate as listed above.

Timer0 Overflow and Interrupt

Timer0 register TMR0 is an 8-bit wide register. As it’s configured to a free running register that clocks from the microcontroller instruction clock, it triggers an interrupt flag at the time it reaches 0xFF (255 in decimal) and rolls back to 0. This interrupt flag is called Timer0 Overflow Interrupt Flag (TMR0IF), locates in the INTCON.

Programming Timer0 of PIC16F818 in XC8
Timer0 Overflow Interrupt Flag (TMR0IF) of INTCON

User’s program must clear this flag in code. This flag is auto-set whenever the overflow happens regardless of Timer0 Interrupt Enable bit (TMR0IE). We will show about timer 0 interrupt programming in later post.

Timer0 Programming in XC8

We have mentioned about timer utilization in microcontroller. Now we will use this microcontroller inside’s to create a timing delay of about one second. This one second pulse blink the LED.

Circuit Design

Microcontroller system circuit is very simple. It’s just build with a +5V power supply unit and its output LED connects to RB7. We don’t need microcontroller reset circuit and crystal oscillator.

Programming Timer0 of PIC16F818 in XC8
Circuit diagram without reset and clock circuit

Calculation for Timer 0 Overflow

With its feature of internal RC oscillator, the system select its 8MHz maximum clock frequency to heart-beat the CPU. For Mid-Range PIC device its instruction rate is,

Fosc/4 = 8MHz/4 = 2MHz or 2MIPS , as its instruction executing time is mostly completed in only one instruction cycle.

The cycle time of its instruction clock is,

1/(2MHz) = 0.5us.

I choose the 1:256 prescaler. So timer 0 clock input has a rate of.

256*0.5us = 128us.

Eight-bit TMR0 register overflows and set its interrupt flag within this duration,

256*128us = 32.768ms.

To find an approximate 1 second delay,

1/(32.768ms) = 30.51 counts or 31 counts.

All setting will be set and shown in programming section next time.

XC8 Programming

XC8 program set the controller to utilize its 8MHz maximum clock frequency as it’s done with OSCCON register. Option register configure timer 0 mode of operation to work as a free running counter with a prescaler of 1:256.

The program main loop regularly test the interrupt flag (TMR0IF). As it’s set a C variable will increase by 1, until it reaches a one second count. The the time of getting its one second count, RB7 toggles its output LED.

Its C program made of between 40 and 50 lines of code.

/*
 */
#include <xc.h>
// PIC16F818 Configuration Bit Settings
// CONFIG
#pragma config FOSC = INTOSCIO  // Oscillator Selection bits (INTRC oscillator; port I/O function on both RA6/OSC2/CLKO pin and RA7/OSC1/CLKI pin)
#pragma config WDTE = OFF       // Watchdog Timer Enable bit (WDT disabled)
#pragma config PWRTE = OFF      // Power-up Timer Enable bit (PWRT disabled)
#pragma config MCLRE = OFF      // RA5/MCLR/VPP Pin Function Select bit (RA5/MCLR/VPP pin function is digital I/O, MCLR internally tied to VDD)
#pragma config BOREN = ON       // Brown-out Reset Enable bit (BOR enabled)
#pragma config LVP = OFF        // Low-Voltage Programming Enable bit (RB3/PGM pin has digital I/O function, HV on MCLR must be used for programming)
#pragma config CPD = OFF        // Data EE Memory Code Protection bit (Code protection off)
#pragma config WRT = OFF        // Flash Program Memory Write Enable bits (Write protection off)
#pragma config CCPMX = RB2      // CCP1 Pin Selection bit (CCP1 function on RB2)
#pragma config CP = OFF         // Flash Program Memory Code Protection bit (Code protection off)
#define onSecondCounts  31
void main(void){
    unsigned int intCounts=0;
    /*Select 8MHz Crystal Frequency*/
    OSCCONbits.IRCF=0x07;
    /*Clear Port B*/
    PORTB=0x00;
    /*RB7 digital output*/
    TRISB&=~(1<<7);
    /*Select internal MCU clock for Timer0*/
    T0CS=0;
    /*Select Timer 0 Prescaler*/
    PSA=0;
    /*Select 1:256 Prescaler*/
    OPTION_REGbits.PS=0x07;
    /*Clear timer 0 overflow interrupt flag*/
    TMR0IF=0;
    /*Clear Timer 0*/
    TMR0=0;
    while(1){
        if(TMR0IF){
            TMR0IF=0;
            intCounts+=1;
        }
        if(intCounts>=onSecondCounts){
            intCounts=0;
            RB7^=1;
        }
    }
}

Generated hex file requires only 4.7% of the total program memory space.

Program Testing

Both software simulation and physical hardware experiment work in the same manner. However in Proteus simulator the delay time is shorter than in physical hardware experiment.

Programming Timer0 of PIC16F818 in XC8
microcontroller program experiment on breadboard

I don’t show the picture of Proteus simulation here due its duplication. Click here to download this example in zip file format.


No comments:

Post a Comment

Search This Blog

Labels

25AA010A (1) 8051 (7) 93AA46B (1) ADC (30) Analog Comparator (1) Arduino (15) ARM (6) AT89C52 (7) ATMega32 (56) AVR (57) CCS PICC (28) DAC (1) DHT11 (2) Display (105) Distance Sensor (3) DS18B20 (3) dsPIC (2) dsPIC30F1010 (2) EEPROM (5) Environment Sensor (4) esp8266 (1) I2C (29) Input/Output (67) Interrupt (19) Keil (5) Keypad (10) LCD (47) Master/Slave (1) MAX7221 (1) MCP23017 (5) MCP23S17 (4) Meter (3) MikroC (2) Motor (15) MPLABX (71) Nokia 5110 LCD (3) OLED (2) One-Wire (6) Oscillator (8) PCB (6) PCD8544 (3) PCF8574 (5) PIC (107) PIC12F (2) PIC16F628A (2) PIC16F630 (1) PIC16F716 (3) PIC16F818 (10) PIC16F818/819 (2) PIC16F84A (15) PIC16F876A (1) PIC16F877A (9) PIC16F88 (1) PIC16F887 (60) PIC18 (19) PIC18F1220 (4) PIC18F2550 (3) PIC18F4550 (12) PWM (11) RTC (8) Sensor (10) SH1106 (1) Shift Register (11) Shift Registers (3) SPI (24) STM32 (6) STM32 Blue Pill (6) STM32CubeIDE (6) STM32F103C8T6 (6) SysTick (3) temperature sensor (11) Thermometer (21) Timer/Counter (31) TM1637 (2) UART (7) Ultrasonic (4) Voltmeter (7) WDT (1) XC16 (2) XC8 (94)