Chap9 8051 Timer Programming
Chap9 8051 Timer Programming
OBJECTIVES
List
the timers of the 8051 and their associated registers Describe the various modes of the 8051 timers Program the 8051 timers in Assembly to generate time delay
Timer 0 and Timer 1 are 16 bits wide each 16-bit timer is accessed as two separate registers of low byte and high byte.
Timer 0 registers
low byte register is called TL0 (Timer 0 low byte) and the high byte register is referred to as TH0 (Timer 0 high byte) can be accessed like any other register, such as A, B, R0, R1, R2, etc. "MOV TL0, #4 FH" moves the value 4FH into TL0 "MOV R5, TH0" saves TH0 (high byte of Timer 0) in R5
Figure 91
Timer 0 Registers
1 registers
also 16 bits split into two bytes TL1 (Timer 1 low byte) and TH1 (Timer 1 high byte) accessible in the same way as the registers of Timer 0.
Figure 92
Timer 1 Registers
timers 0 and 1 use TMOD register to set operation modes (only learn Mode 1 and 2) 8-bit register lower 4 bits are for Timer 0 upper 4 bits are for Timer 1 lower 2 bits are used to set the timer mode
Figure 93
TMOD Register
timer needs a clock pulse to tick if C/T = 0, the crystal frequency attached to the 8051 is the source of the clock for the timer frequency for the timer is always 1/12th the frequency of the crystal attached to the 8051 XTAL = 11.0592 MHz allows the 8051 system to communicate with the PC with no errors In our case, the timer frequency is 1MHz since our crystal frequency is 12MHz
10
Mode 1 programming 16-bit timer, values of 0000 to FFFFH TH and TL are loaded with a 16-bit initial value timer started by "SETB TR0" for Timer 0 and "SETB TR1" for Timer l timer count ups until it reaches its limit of FFFFH rolls over from FFFFH to 0000H sets TF (timer flag) when this timer flag is raised, can stop the timer with "CLR TR0" or "CLR TR1 after the timer reaches its limit and rolls over, the registers TH and TL must be reloaded with the original value and TF must be reset to 0
11
12
Figure 95a
13
Figure 95b
to program in mode 1
Set timer mode 1 or 2 Set TL0 and TH0 (for mode 1 16 bit mode) Set TH0 only (for mode 2 8 bit auto reload mode) Run the timer Monitor the timer flag bit
14
Example 9-4 In the following program, we are creating a square wave of 50% duty cycle (with equal portions high and low) on the P1.5 bit. Timer 0 is used to generate the time delay
15
Example 9-9 The following program generates a square wave on pin P 1.5 continuously using Timer 1 for a time delay. Find the frequency of the square wave if XTAL = 11.0592 MHz. In your calculation do not include the overhead due to the timer setup instructions in the loop.
16
XTAL = 11.0592 MHz (12MHz) divide the desired time delay by 1.085 s (1 s) to get n 65536 n = N convert N to hex yyxx set TL = xx and TH = yy
17
Example 9-12 Assuming XTAL = 11.0592 MHz, write a program to generate a square wave of 50 Hz frequency on pin P2.3.
= 1/50 Hz = 20 ms 1/2 of it for the high and low portions of the pulse = 10 ms 10 ms / 1.085 us = 9216 65536 - 9216 = 56320 in decimal = DC00H TL = 00 and TH = DCH The calculation for 12MHz crystal uses the same steps
18
Example 9-12 (cont) Assuming XTAL = 11.0592 MHz, write a program to generate a square wave of 50 Hz frequency on pin P2.3.
19
crystal
largest time delay is achieved by making both TH and TL zero what if that is not enough?
20
Windows scientific calculator can be use to find the TH, TL values Lets say we would like to find the TH, TL values for a time delay that uses 35,000 clocks of 1.085 s
1. 2. 3. 4. 5.
open scientific calculator and select decimal enter 35,000 select hex - converts 35,000 to hex 88B8H select +/- to give -35000 decimal (7748H) the lowest two digits (48) of this hex value are for TL and the next two (77) are for TH
21
Example 9-13 Examine the following program and find the time delay in seconds. Exclude the time delay due to the instructions in the loop.
22
works like mode 1 13-bit timer instead of 16-bit 13-bit counter hold values 0000 to 1FFFH when the timer reaches its maximum of 1FFFH, it rolls over to 0000, and TF is set
23
Mode 2 programming
8-bit timer, allows values of 00 to FFH TH is loaded with the 8-bit value a copy is given to TL timer is started by ,"SETB TR0" or "SETB TR1 starts to count up by incrementing the TL register counts up until it reaches its limit of FFH when it rolls over from FFH to 00, it sets high TF TL is reloaded automatically with the value in TH To repeat, clear TF mode 2 is an auto-reload mode
24
load TMOD, select mode 2 load the TH start timer monitor the timer flag (TF) with "JNB get out of the loop when TF=1 clear TF go back to Step 4 since mode 2 is autoreload
25
Example 9-14 Assuming that XTAL = 11.0592 MHz, find (a) the frequency of the square wave generated on pin P1.0 and (b) the smallest frequency achievable in this program, and the TH value to do that.
26
can let the assembler calculate the value for TH and TL which makes the job easier "MOV TH1, # -100", the assembler will calculate the -100 = 9CH "MOV TH1,#high(-10000) " "MOV TL1,#low(-10000) "
27
used as a timer, the 8051's crystal is used as the source of the fre-quency used as a counter, pulse outside the 8051 increments the TH, TL registers counter mode, TMOD and TH, TL registers are the same as for the timer timer modes are the same as well
28
C/T bit in the TMOD register decides the source of the clock for the timer C/T = 0, timer gets pulses from crystal C/T = 1, the timer used as counter and gets pulses from outside the 8051 C/T = 1, the counter counts up as pulses are fed from pins 14 and 15 pins are called T0 (Timer 0 input) and T1 (Timer 1 input) these two pins belong to port 3 Timer 0, when C/T = 1, pin P3.4 provides the clock pulse and the counter counts up for each clock pulse coming from that pin Timer 1, when C/T = 1 each clock pulse coming in from pin P3.5 makes the counter count up
29
Table 91
30
Example 9-18 Assuming that clock pulses are fed into pin T1, write a program for counter 1 in mode 2 to count the pulses and display the state of the TL1 count on P2. (for information only)
to LEDs
31
32
Figure 96
33
Figure 97
34
35
36
Table 91
TCON register
TR0 and TR1 flags turn on or off the timers bits are part of a register called TCON (timer control) upper four bits are used to store the TF and TR bits of both Timer 0 and Timer 1 lower four bits are set aside for controlling the interrupt bits "SETB TRl" and "CLR TRl "SETB TCON. 6" and "CLR TCON. 6
37
38
Table 92
GATE = 0, the timer is started with instructions "SETB TR0" and "SETB TR1 GATE = 1, the start and stop of the timers are done externally through pins P3.2 and P3.3 allows us to start or stop the timer externally at any time via a simple switch
39
40
Figure 98
Timer/Counter 0
41
Figure 99
Timer/Counter 1
Next
Lecture
Answer as many questions as you can and submit via MeL before the end of the lecture.
Proteus
Exercise 8
Do as much of the Proteus exercise as you can and submit via MeL before the end of the lecture.
42