

#### Microprocessors and Interfaces: 2021-22 Lecture 29 : 8253/8254 Timer Part:1

# By Dr. Sanjay Vidhyadharan



#### **Features of 8253/8254**

- The 8254 consists of three independent 16-bit programmable counters (timers).
- Each counter is capable of counting in binary or binary-coded decimal (BCD).
- Maximum allowable input frequency to any counter is 10 MHz
- Useful where the microprocessor must control real-time events. Ex: real-time clocks, event counters, and motor speed/direction control.

8253 8254 Its operating frequency is 0 - 2.6 MHz Its operating frequency is 0 - 10 MHz It uses N-MOS technology It uses H-MOS technology Read-Back command is not available Read-Back command is available 8/30/2021

# Pin diagram of 8253/8254



#### **Features of 8253/8254**

- Each timer contains:
  - a CLK input which provides the basic operating frequency to the timer
  - a Gate input pin which controls the timer in some modes.
- an **output** (OUT) connection to obtain the output of the timer.

#### **Memory mapping**

|   | CS' | <b>A</b> <sub>1</sub> | A <sub>o</sub> | Selected               |
|---|-----|-----------------------|----------------|------------------------|
|   | 0   | 0                     | 0              | Counter 0              |
|   | 0   | 0                     | 1              | Counter 1              |
|   | 0   | 1                     | 0              | Counter 2              |
|   | 0   | 1                     | 1              | Control Register       |
| S | 1   | Х                     | Х              | 8253/8254 Not Selected |

#### **Control word Format**



#### **Programming the Counters**

Before you can use.....

- 1. Initialize the mode of every counter planned to be used
- This is done by sending individual command words for every counter
- 3. These CWs are sent at  $A_1A_0 = 11$
- 4. Send counts to the counters
- 5. This is done at counter addresses
- 6. Enable gates for counting to start

#### **Control word Format**



#### **Control word Format**



# **Reading the Counters**

#### Simple Read Operation

Counter selected with the A1, A0 inputs, the CLK input of the selected Counter must be inhibited by using either the GATE input or external logic. Otherwise, the count may be in the process of changing when it is read, giving an undefined result. Two I/O read operation are performed by the MPU

- 1. The first I/O operation reads the low order byte.
- 2. The second I/O operation reads high order byte.

#### **Counter Latch Command**

This allows reading the contents of the Counters "on the fly" without affecting counting in progress.

The selected Counter's output latch (OL) latches the count at the time the Counter Latch Command is received. This count is held in the latch until it is read by the CPU (or until the Counter is reprogrammed). The count is then unlatched automatically and the OL returns to "following" the counting element (CE).

# **Reading the Counters**



8/30/2021

### **Read-Back Command**

This command is used to read several counters at a time. It eliminates the need of writing separate counter-latch commands for different counters. It allows the user to check the count value, programmed Mode, and current states of the OUT pin and Null Count flag of the selected counter/ counters. The read back command is written to the Control Word Register. is reprogrammed). The counter is automatically unlatched when read, but other counters remain latched until they are read.

|           | A0,                                                                                              | <b>A</b> 1                      | = 11                                                      | 11 <b>CS</b> =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                      | D = 1                 | $\overline{WR} = 0$ |                |
|-----------|--------------------------------------------------------------------------------------------------|---------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------|---------------------|----------------|
|           | D7                                                                                               | D <sub>6</sub>                  | $D_5$                                                     | $D_4$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | $D_3$                | D <sub>2</sub>        | D <sub>1</sub>      | D <sub>0</sub> |
|           | 1                                                                                                | 1                               | COUNT                                                     | STATUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CNT 2                | CNT 1                 | CNT 0               | 0              |
| san       | D <sub>5</sub> :<br>D <sub>4</sub> :<br>D <sub>3</sub> :<br>D <sub>2</sub> :<br>D <sub>1</sub> : | 0 =<br>0 =<br>1 =<br>1 =<br>1 = | Latch co<br>Latch sta<br>Select C<br>Select C<br>Select C | ount of selectures of selectures of selectures of selectures and selectures and selectures of select | ected co<br>ected co | ounter(s)<br>ounters( | s)                  |                |
| 8/30/2021 | D <sub>0</sub> :                                                                                 | Res                             | erved for                                                 | future exp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ansion;              | Must be               | 0                   |                |

8/30/2021

#### Figure Read-Back Command Format

### **Read-Back Command**

The read-back command may be used to latch multiple counter output latches (OL) by setting the COUNT bit D5 =0 and selecting the desired counter(s). A single read back command is functionally equivalent to several counter latch commands.

Each counter's latched count is held in the OL until it is read (or the counter is reprogrammed). The counter is automatically unlatched when read, but other counters remain latched until they are read.

The read-back command may also be used to latch status information of selected counter(s) by setting STATUS bit D4 = 0. Status must be latched to be read; status of a counter is accessed by a read from that counter.

The counter status format is shown in Figure below.

8/30/2021

| D7                                                                | D <sub>7</sub> D <sub>6</sub> |  | D4     | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |  |  |
|-------------------------------------------------------------------|-------------------------------|--|--------|----------------|----------------|----------------|----------------|--|--|
| Output                                                            | output Null<br>Count          |  | RW0 M2 |                | M1             | мо             | BCD            |  |  |
| $D_7 \qquad 1 = OUT \text{ Pin is 1} \\ 0 = OUT \text{ Pin is 0}$ |                               |  |        |                |                |                |                |  |  |
| D <sub>6</sub> 1 = Null Count<br>0 = Count available for reading  |                               |  |        |                |                |                |                |  |  |
| D5-D0 Counter programmed mode                                     |                               |  |        |                |                |                |                |  |  |

#### **Read-Back Command**

Example:

Count and Status latched for counter 0 MOV DX, C\_REG MOV AL, 11000010B ; count latched for counter 0 OUT DX, AL

Reading the latched status for count 0 MOV DX, TRM0 IN AL, DX ; Reading Status MOV AH, AL Reading the latched count for counter 0 IN AL, DX ; Reading LSB of counter 0 MOV BL, AL IN AL, DX ; Reading MSB of counter 0 MOV BH, AL



Figure Read-Back Command Format

#### **Control word Format**

| <b>D</b> <sub>7</sub> |                        | <b>D</b> <sub>6</sub> | D <sub>5</sub> D                 |       | <b>D</b> <sub>4</sub> | <b>D</b> <sub>3</sub> |                                                    | D <sub>2</sub> | D    | D <sub>o</sub>                                    |
|-----------------------|------------------------|-----------------------|----------------------------------|-------|-----------------------|-----------------------|----------------------------------------------------|----------------|------|---------------------------------------------------|
| SC1                   |                        | SC0                   | RW1 RWO                          |       | M2                    |                       | M1                                                 | MO             | BCD  |                                                   |
| Selects Counter       |                        |                       | Read/Write<br>Control            |       | Timer                 | 0 –                   |                                                    |                |      |                                                   |
|                       |                        |                       |                                  |       | 000                   | Inte                  | errupt on T/                                       | binary         |      |                                                   |
| 00                    | Cou                    | unter 0               | 00                               | Latch |                       | 001                   | 001h/w re-Triggerable one<br>shot010rate generator |                |      | 0000 <sub>h</sub><br>FFFF <sub>h</sub><br>1 – BCD |
| 01                    | Cou                    | nter 1                | 01 Cou                           |       | nter<br>LSB           | 010                   |                                                    |                |      |                                                   |
| 10                    | Cou                    | nter 2                | 10                               | R/W   | MSB                   | 011                   | Square wave generator                              |                |      | 0000                                              |
| 11                    | 1 Read Back<br>Command |                       | 11 R/W LSB<br>followed by<br>MSB |       | 1x0                   | s/w triggered strobe  |                                                    |                | 9999 |                                                   |
|                       |                        |                       |                                  |       | 1x1                   | h/w triggered strobe  |                                                    |                |      |                                                   |
|                       |                        |                       |                                  |       |                       |                       |                                                    |                |      |                                                   |

#### Programming of 8253/8254

- Each counter is programmed by writing a control word, followed by the initial count.
- > The control word allows the programmer to select
- the counter,
- mode of operation, and
- type of operation (read/write).
- also selects either a binary or BCD count

# **Mode of Operation**

–Six modes (Mode 0–Mode 5) of operation are available to each of the 8254 counters

-each mode functions with the CLK input, the gate (G) control signal, and OUT signal.

#### **Modes of counting**

i narana

- Interrupt on terminal count
- Programmable one shot
- Square wave generator
- Rate generator
- Software triggered strobe
- Hardware triggered strobe

**S**3U

#### **Mode 0 – Interrupt on Terminal count**

#### Interrupt on terminal count (event counter)

- Out pin goes low when mode word or new count is written
- Now if clock is applied and gate=1, countdown begins
- Countdown stops if gate=0: resumes if gate=1
- If count written is N then OUT becomes high after N+1 clocks
- OUT remains high till a new count is written
- $\geq$  Countdown continues as FF<sub>H</sub>, FE<sub>H</sub> if gate =1
- Application object counting

#### **Mode 0 – Interrupt on Terminal count**



#### Mod 0 : Case 1



 $\geq$  If count written is N then OUT becomes high after N+1

clocks

8/30/2021

21

#### Mod 0 : Case 2



#### Mod 0 : Case 3



#### Mode 1 – Hardware retriggerable one-shot



#### Mod 1: Case 1



#### Mod 1: Case 2



#### Mod 1: Case 3



#### **Modes of counting : Mode 1**



# Thank You Sanjay