

## 19.1 Introduction

oller)

than al to

rupt

ALL slave

d the

iving

r, the

just

te in

Write short note on 8254, Programmable interval timer.

In Microprocessor Based System, we come across two important modes i.e. timer → to provide delay and counter → to count incoming pulses. Presently, the way we implement timer/counter in 8086 based system as studied in earlier has following drawbacks:

Delay: The 8086 can provide delays of any value, but it uses software to implement the delay. The instructions are arranged to waste time. The main disadvantage of this scheme is 8086 is executing some instructions, it means that it is busy in doing

Counter: The 8086 can count number of pulses arriving at port. To implement this 8086 goes on checking port, if it is active it increments counter by 1 and again goes (ii) on checking port. The same disadvantage, 8086 will have to execute

In large systems, where 8086 wastage time is critical, a separate timer IC 8254 can be used. The 8254 consists of 3 identical 16 bit counters. These counters can work as counter or can provide accurate time delays. To operate as a counter, a 16 bit count is loaded and the desired mode of operation is selected. The counters will work independently and generate the desired output. Now the 8086 job is to initialise and load

In this chapter, we will discuss 8254 IC. Unless and until it is specified for 8253, the counters. discussion of all points remains same in all respects to both ICs.

The two IC's 8253 and 8254 are timer ICs. Both are similar except following differences:

# How does 8254 differ from 8253?

| Q. | How does 8254 differ from 8253 7                            | 8254                                                     |
|----|-------------------------------------------------------------|----------------------------------------------------------|
|    | 8253                                                        | 4. 10 10 10 10 10 10 10 10 10 10 10 10 10                |
| 1  | Operating frequency 0 - 2.6 MHz.                            | Operating frequency 0 - 10 MHz.                          |
|    | TT 37370C technology                                        | Uses H-MOS technology.                                   |
| 3  | 11                                                          | Read-Back command is available.                          |
| 4. | Reads and writes of the same counter cannot be interleaved. | Reads and writes of the same counter can be interleaved. |

Mic

# 19.2 Features of Programmable Interval Timer

- Three independent 16 bit down counters.
- Counters can be programmed in 6 different programmable counter modes.
- Counting facility in both binary or BCD number system.
- Compatible with Intel and other microprocessors.
- Single + 5V supply.
- 24 pin dual in-line package.
- It is completely TTL compatible.
- It has a powerful command called READ BACK COMMAND which allows the user to check the count value, programmed mode and current mode and the current status of the counter (Only for 8254).
- Operating frequency range; For 8253 DC to 2.6 MHz; For 8254 DC to 10 MHz.

# Pin Configuration of 8254

#### Draw and explain the pin configuration of 8254. Q.

The pin configuration of 8254 programmable interval timer is as shown in Fig. 19.3.1

| $D_7 - D_0$                     | NO | DATA BUS            |
|---------------------------------|----|---------------------|
| CLK <sub>N</sub>                | I  | Counter inputs      |
| GATEN                           | ·I | Counter gate inputs |
| OUTN                            | 0  | Counter outputs     |
| RD                              | Ι  | Read                |
| WR                              | Ι  | Write               |
| <b>CS</b>                       | I  | Chip select         |
| A <sub>0</sub> - A <sub>1</sub> | I  | Counter select      |
| V <sub>cc</sub> /GND            | I  | + 5 V supply/Ground |



Fig. 19.3.1: Pin diagram of 8254

#### Pin Description

| Sr.<br>No | Symbol                         | Name and function                                                                                                                                                                                                   |
|-----------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1         | D <sub>0</sub> -D <sub>7</sub> | Data bus: These are 8 bit bidirectional data bus lines, connected to the system data bus for data transfer between 8086 and 8254.                                                                                   |
| 2         | ČS                             | Chip select: This is an active low input signal, used to select the 8254 IC. If $\overline{CS} = 0$ then 8254 will be active and take part in data transfer from/to 8086, otherwise 8254 will be in deactive state. |

8253

user rent

| Sr             | Symbol                          | Name and function                                                                                                                                                 |  |  |
|----------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <b>No</b><br>3 | RD                              | Read: This is an active low input signal, used in coordination with $A_0$ , $A_1$ to send data from appropriate counter to data lines                             |  |  |
|                |                                 | D <sub>0</sub> - D <sub>7</sub> .                                                                                                                                 |  |  |
| 4              | WR                              | Write: This is an active low input signal, used in coordination with $A_0$ , $A_1$ to load counters or to initialize counters.                                    |  |  |
| 5              | A <sub>0</sub> - A <sub>1</sub> | Address lines: These are input address lines used to distinguish different parts of 8254 such as Counter 0, Counter 1, Counter 2, Control word register.          |  |  |
|                |                                 | A Selected part                                                                                                                                                   |  |  |
|                |                                 | 0         0         Counter 0           0         1         Counter 1           1         0         Counter 2           1         1         Control word register |  |  |
| 6              | CLK <sub>0-2</sub>              | Clock input: These are clock inputs to 3 independent counters.  The pulses applied at these pins will be counted by respective counters.                          |  |  |
| 7              | GATE <sub>0-2</sub>             | in high input signals used to allow                                                                                                                               |  |  |
| 8              | OLT.                            | Output: These lines are active high, output lines. The output is                                                                                                  |  |  |

# 19.4 8254 Functional Block Diagram

Explain 8254 with its functional block diagram. Q.

The block diagram of 8254 is as shown in Fig. 19.4.1.

dependent on operating mode.



Fig. 19.4.1: Functional block diagram of 8254 It includes data bus buffer, read/write logic, control word register and counters 0, 1, 2.

2)

ordination

data lines

ordination

stinguish ounter 2

unters.

pective

allow

nction

put is

Data bus buffer It is tristate, bi-directional 8 bit data bus buffer.

It is used to interface 8254 data bus with system data bus.

It is used to internal data bus and its outer pins  $D_0 - D_7$  are It is internally outer pins  $D_0 \cdot D_7$  are connected to system data bus. The direction of data buffer is decided by read control signals. and write control signals.

Read/Write logic

This block accepts inputs from system control bus and address bus.

In I/O mapped I/O, the signals RD and WR are connected to IOR and IOW.

In memory mapped I/O, RD and WR, are connected to MEMR and MEMW.  $A_0$  and  $A_1$  are directly connected to address lines  $A_0$  and  $A_1$ .

CS is connected to address decoder.

The 8254 operation/selection is enabled/disabled by CS signal. A, A selects a specific part WR, RD decides writing data to 8254 or reading data from 8254. The control word registers and the counters are selected according to the

signals on lines  $A_0$  and  $A_1$ .

| A <sub>1</sub> | A <sub>0</sub> | Selection             |
|----------------|----------------|-----------------------|
| 0              | 0              | Counter 0             |
| 0              | 1              | Counter 1             |
| 1              | 0              | Counter 2             |
| 1              | 1              | Control word register |

### Control word register

This register of 8254 gets selected when  $A_0 = 1$  and  $A_1 = 1$ .

It is used to specify the BCD or binary counter to be used, its mode of operation and the data transfer to be used i.e. read or write the data bytes (LSB, MSB or both).

If the CPU performs a write operation, the data is stored in the control word register and is referred to as Control Word. It is used to define counter

The data can only be written into control word register, no read operation is allowed. Status information is available with the help of Read Back Command.

# Counters

There are three independent, 16 bit down counters.

They can be programmed separately through control word register to decide mode of counter.

Microprocessors & Interfa-

Each cour

CLK is u The coun

The load clock in counter

#### 19.5 Control

Q. Explain the

The control v

Note: SC = 1 and

The control counter. W Similarly, initialize tl

> counters by ii) The bits R both LSB

The bits iii) Mode0 - N

The bit, F iv)

> SC, SCo 0 0

he

of

es

rd

er

is

ck

de



- Each counter is having 2 inputs viz. CLK and GATE.
- CLK is used as an input to counter and GATE is used to control the counter.
- The loaded count value in counter will be decremented by counter at each The counters give output on OUT pin. clock input pulse. The programmer can read counter without disturbing counter operation.

# 19.5 Control Word Register Format

- Explain the control word register format of 8254. Q.
- The control word register format is as shown in Fig. 19.5.1.

Note:  $SC_0 = 1$  and  $SC_1 = 1$ , this combination is used to give read back command (Only for 8254).

- The control word register bits, SC1 and SC0, select the control word register for counter. When  $SC_0 = 0$  and  $SC_1 = 0$ , the control word for counter 0 is selected. Similarly, other counter control words, are selected by SCo and SC1 and used to initialize the counters. Ao and A1 selects counter(s), but they are used to read/load
- The bits RLo and RLo are used to read/load, data bytes i.e. LSB byte, MSB byte or ii)
- The bits M2, M1 and M0 decides the mode of operation for selected counter, iii)
- The bit, BCD, decides the mode of counting i.e. BCD counter or binary counter. Mode0 - Mode5. iv)



Fig. 19.5.1: Control word register format

Micr

### 19.6 8254 Write Operation

The 8254 initialisation and count value loading operations are important operations performed by system software. Once 8254 is programmed it is ready to perform operations. The order of initialisation and count value loading for counter 0, counter 1 and counter 2 are sequence independent. But the number of data bytes programmed by  $RL_0$  and  $RL_1$  must be completed. The example format for this is as follows:

| Sr. No. | A <sub>1</sub> | A <sub>0</sub> | process serial as a cown            |
|---------|----------------|----------------|-------------------------------------|
| 1       | 1              | 1              | Control word register for counter 0 |
| 2       | 0              | 0              | LSB count for counter 0             |
| 3       | 0              | 0              | MSB count for counter 0             |
| 4       | 1              | 1              | Control word register for counter 1 |
| . 5     | 0              | 1              | LSB count for counter 1             |
| 6       | 0              | 1              | MSB count for counter 1             |
| 7       | 1              | 1              | Control word register for counter 2 |
| 8       | 1              | 0              | LSB count for counter 2             |
| 9       | 1              | 0              | MSB count for counter 2             |

In above format, all the 3 counters are used with 16 bit count values.

#### Interleaved read and write

The special feature of 8254 is that the read and write operation of any counter may be interleaved. This feature allows us to read LSB byte then write LSB byte and read MSB byte then write MSB byte.

### 19.7 8254 Read Operations

The counter application, requires reading the value of the counter in progress. The 8254 contains logic that allows the programmer to read the contents of counters without disturbing the actual count in progress. There are 3 methods for 8254 as follows:

Method 1 : Simple Read

• Method 2: Counter Latch Operation

Method 3: Read Back Command (Only for 8254)

### 19.7.1 Method 1 : Simple Read

- The method 1 involves, the simple I/O read operations for the selected counter by using A<sub>0</sub>, A<sub>1</sub> address inputs.
- The precaution should be taken that the RL<sub>0</sub>- RL<sub>1</sub> bits programmed for reading the number of data bytes is followed.
- To perform the operation microprocessor issues RD control signal and takes count value from selected counter.

3253

ons

rm

ind

 $L_0$ 

If two bytes are programmed to be read, then two bytes must be read, before any write operation to the same counter.

The description is the description of the same counter.

The description is the description of the same counter.

The requirement of this method for stable count reading is the counter should be inhibited. Because if a counter is changing its state and in the mean time when you read the contents, the count value will not be correct. To avoid such conditions the counter can be inhibited either by controlling the gate input or by external logic that inhibits the clock input. For example if the current count is 0100H. You read the lower byte and get it as 00H. Before you read the higher byte a pulse is applied on CLKn pin and the counter decrements i.e. it becomes 00FFH. Now when you read the upper byte, you get it as 00H. Hence the count you read is 0000H, which is incorrect, 0100H or 00FFH was correct.

# 19.7.2 Method 2 : Counter Latch Operation

- The problem with the method 1 is, there are chances of reading incorrect count. To avoid this the 8254 provides counter latch operation. ( $RL_1 RL_0 = 00$ )
- The control word format for latching counter is as follows:



- When the above format is loaded in control register, it will latch the count value at that instant into special register.
- The contents of special register will be an accurate and stable quantity at that instant.
- The programmer then gives normal read commands to counter same as method 1
  and contents of the latched register will be available. This type of reading count
  value contents is also called as reading on fly.

## 19.7.3 Method 3: Read Back Command (Only for 8254)

• In this method to get a stable count a counter is latched with a read back command.

The format for read back command word is as follows:



In above of is a read is a read in the latch  $D_4$  - latch  $D_3$   $D_2$   $D_1$  The adverting reading

D7-

The sta

D6

 $\mathbf{D}_{\mathbf{5}}$ 

D

D

19.8

Q.

19

Select counter 1

Select counter 2

and BCD counter will be,

The thr

Cas

(i)

(i



Fig. 19.8.1: Mode 0 timing diagram

is

only

- The counter initialisation and loading operation is performed using two write Case (a): Normal operation operations. First write to load control word register for counter 0 (CWR = 11 H) and second to load count value (Data = 05 H). When counter is initialised in mode 0, the (i)
- When the data 05 H is loaded, it is transferred to counter on next negative going edge of CLK, after WR. Loading count value will start counter and counter will (ii) decrement count by 1 for each CLK<sub>0</sub> pulse.
- (iii) When counter reaches zero the OUT, pin will go HIGH and remain HIGH. In case (a) we assume the status of GATE input is HIGH.

# Case (b) : Gate disable

In this case counter operation is same as case (a). Only change is GATE input. If the GATE input becomes LOW the counter suspends counting. Again, when GATE becomes HIGH it will resume counting upto zero.

#### Case (c): New count

In this case, counter operation is same as case (a). The only change is, loading new count value previous reaches to ZERO.

- (i) If a new count value is loaded before counter reaches zero, the counter will take new count value and restart decrementing count value upto zero.
- (ii) If a 16 bit counter (i.e. LSB and MSB) is used, then loading of LSBs, stops the current count and loading of MSB, restarts counter with new value.
  The output in all 3 cases is made HIGH when count reaches zero. It remains HIGH until a new count value is loaded or mode of operation is changed. This output can

# 19.8.2 Mode 1 : Programmable One Shot / Hardware Triggerable One Shot

be used as an interrupt, therefore the name given is Interrupt on terminal count.



Fig. 19.8.2: Mode 1 timing diagram

The control word format required for Mode 1, counter 0, Read / Load LSB data byte and BCD counter will be

The three cases are as shown in Fig. 19.8.2 and their details are as follows: