PIC Timer 0 Calculation Example
PIC Timer 0 Calculation Example
overflows i.e. for an 8 bit timer that means when the count value goes from 256 to zero.
PIC Timer 0 : Calculation example
Here is an example of the typical calculations for creating an 18ms interrupt repeat rate
using PIC Timer 0.
Selecting a prescaler ratio of 1:128 gives the following interrupt period (with Fosc/4 or
4MHz/4 = 1MHz) and using the maximum overflow from Timer 0.
1/(1MHz/128/256) = 32.768ms
Obviously this is longer than you need but you can cut it down by changing the overflow
point (in the interrupt). To do this you need the period of the frequency input to Timer 0
which is:
1/(1MHz/128) = 128us
This is the period of time for each count in Timer 0 i.e.
256 * 128us = 32.768ms
So by manipulating the overflow point you can set the overall interrupt period. The
required period is 18ms so using some calculations:
18ms/128us = 140.625 (nearest integer value is 141)
This is the number of counts required after which the interrupt is generated. To use it
Timer 0 it is loaded in the following manner:
TMR0 = 256-141+2; // Need 141 but Timer 0 looses 2 at load.
From this point on every 128us is counted by Timer 0 and it will overflow after 141
counts (or 18ms)
141 * 128us = 18ms(approx), The precise period is 18.048ms.
Note: "When writing to TMR0, two instruction clock cycles are lost. Often you have a
specic time period you want to count, say 100 decimal. In that case you might put 156
into TMR0 (256 - 100 = 156). However, since two instruction cycles are lost when you
write to TMR0 (for internal logic synchronization), you should actually write 158 to the
timer".[source mid-range reference manual : DS31011]
Note: If you look at the Timer 0 block diagram in the datasheet the internal clock
synchronization uses Fosc/4, so do not add 2 when calculating the period if you are not
using the internal clock as a clock source! The main calculation will use your external
clock and you need to add 2 Fosc/4 cycles to that period.
TCL Scripts for PIC Timer calculation
Every time you use any built in PIC timer you have to do these type of calculations and
the hardware in each timer is different and you'll also have to do battle with interrupts.
To make the process easy you can use three on-line (free) interactive script modules
written in TCL (Tool Command Language). They operate in a similar way to a Java
applets.
Each of these scripts is geared towards the most typical use of each timer and lets you
change prescaler, postscaler or register value using slider controls. This makes it easy to
experiment with different values as the result is immediately displayed in the web page
(frequency and period are displayed from each part of the timer e.g. after the prescaler,
after the register, after the postscaler).
The above calculation is now trivial just move the sliders around until you get close to
your desired PIC timer period and then adjust the timer value to home in on the correct
answer.
So you can do what-if type operations (all without a calculator in sight) e.g. 'I need a
15ms repeat rate'.
From Timer 2 the closest I could get is 15.136 (took 1 minutes to test) - perhaps I'll try
timer 1 - Ah that gives an exact 15ms (took 30 seconds to test). Just check with Timer 0
- this gives 15.040ms (took ~30 seconds to test).
Of course you can also set the main clock frequency (internal or external crystal) as well.
PIC Timer 0
This has an 8 bit prescaler and an 8 bit timer and can be driven from an external clock.
Prescaler : 8 bit
Timer register : 8 bit
Link to Timer 0 calculator
Note: In 18F Series devices Timer 0 is enhanced to be 16 bit capable (although it is
backwards compatible with the 8 bit version).
PIC Timer 1
This has a 4 bit prescaler and an 16 bit timer and can be driven from an external clock. It
can also be driven from a slow speed crystal e.g. 32kHz.
Prescaler : 4 bit
Timer register: 16 bit
Link to Timer 1 calculator.
Note: In 18F Series devices Timer1 has enhanced 16 readability (High byte is double
buffered to allow easy, exact, capturing of the timer register value.
PIC Timer 2
This has a 4 bit prescaler and an 8 bit timer and an 8 bit period register and is only
driven from the internal clock (Fosc/4)
Note: In 18F Series devices Timer 2 has the same structure as in 16F versions.