

# µPD8253 PROGRAMMABLE INTERVAL TIMER

# Description

The NEC  $\mu$ PD8253 contains three independent, programmable, multi-model 16-bit counter/timers. It is designed as a general purpose device, fully compatible with the 8080 family. The  $\mu$ PD8253 interfaces directly to the buses of the processor as an array of I/O ports.

The  $\mu$ PD8253 can generate accurate time delays under the control of system software. The three independent 16-bit counters can be clocked at rates from DC to 5 MHz. The system software controls the loading and starting of the counters to provide accurate multiple time delays. The counter output flags the processor at the completion of the time-out cycles.

System overhead is greatly improved by relieving the software from the maintenance of timing loops. Some other common uses for the  $\mu$ PD8253 in microprocessor based systems are:

- · Programmable baud rate generator
- Event counter
- · Binary rate multiplier
- Real time clock
- · Digital one-shot
- Complex motor controller

### Features

- □ Three independent 16-bit counters
- □ Clock rate: DC to 5 MHz
- □ Binary count or BCD
- $\Box$  Single +5 V power supply, ±10%

## **Ordering Information**

| Part<br>Number | Package Type       | Max Frequency<br>of Operation |  |
|----------------|--------------------|-------------------------------|--|
| µPD8253C-2     | 24-pin plastic DIP | 5 MHz                         |  |
| µPD8253C-5     | 24-pin plastic DIP | 4 MHz                         |  |

## **Pin Configuration**

# **Pin Identification**

| No.      | Symbol                         | Function                 |
|----------|--------------------------------|--------------------------|
| 1-8      | D <sub>7</sub> -D <sub>0</sub> | Three-state data bus     |
| 9,15,18  | CLK 0,1,2                      | Counter clock inputs 0-2 |
| 10,13,17 | OUT 0,1,2                      | Counter outputs 0-2      |
| 11,14,16 | GATE 0,1,2                     | Counter gate inputs 0-2  |
| 12       | GND                            | Ground                   |
| 19,20    | A0,A1                          | Counter select           |
| 21       | ĈŜ                             | Chip select              |
| 22       | RD                             | Read counter             |
| 23       | WR                             | Write command or data    |
| 24       | V <sub>CC</sub>                | +5 V power supply        |



# **Pin Functions**

# D7-D0 (Data Bus)

These pins form a three-state, bidirectional data bus that interfaces with the 8080AF/8085 microprocessor system.

## CLK 0,1,2 (Counter Clock Inputs 0-2)

CLK 0, CLK 1, and CLK 2 input the clock signal for counter 0, counter 1, and counter 2, respectively.

## OUT 0,1,2 (Counter Outputs 0-2)

OUT 1, OUT 2, and OUT 3 are outputs signals for counter 0, counter 1, and counter 2, respectively.

## GATE 0,1,2 (Counter Gate Inputs 0-2)

The GATE 0, GATE 1, and GATE 2 inputs gate counter 0, counter 1, and counter 2, respectively.

### GND (Ground)

Connection to ground.

# A<sub>0</sub>, A<sub>1</sub> (Counter Select)

These inputs are normally connected to the processor's address bus. Their function is to select which of the three counters will be operated on, and to address the control word register for mode selection.

# CS (Chip Select)

A low level input to this pin enables the  $\mu$ PD8253. Reading and writing will not occur unless the device is selected. This input has no effect on the actual operation of the counters.

# **RD** (Read Counter)

A low level input to this pin instructs the  $\mu$ PD8253 to send the selected counter value to the processor.

### WR (Write Command or Data)

A low level input to this pin instructs the  $\mu$ PD8253 to receive mode information or counter input data from the processor.

## Vcc

+5 V power supply.

# **Block Diagram**





# **Functional Description**

The three-state, bidirectional data bus buffer interfaces the  $\mu$ PD8253 to the 8080AF/8085A microprocessor system. Data transfer is according to the input or output instructions executed by the processor. The data bus buffer has three basic functions:

- Programming the µPD8253 modes
- Loading the count registers
- Reading the count values

The read/write logic controls the overall operation of the  $\mu$ PD8253 and is governed by inputs received from the processor system bus.

When  $A_0$  and  $A_1$  are high level, data from the data bus buffer is stored in the control word register. This data controls the operational mode of the counters, the selection of BCD or binary counting, and the loading of the count registers.

Counters 0, 1, and 2 are identical 16-bit down counters that are functionally independent, allowing for separate mode configurations and counting operations. Each counter can operate in either binary or BCD. Gate, input, and output line configurations are determined by the operational mode data stored in the control word register. System software overhead can be reduced by allowing the control word to govern the loading of the count data.

It is possible to read the contents of a counter when it is operating, without disturbing its operation. The following table shows how the counters are manipulated by input signals to the read/write logic.

| ĈŜ | RD | WR | A <sub>1</sub> | A <sub>0</sub> | Function              |
|----|----|----|----------------|----------------|-----------------------|
| 0  | 1  | 0  | 0              | 0              | Load counter no. 0    |
| 0  | 1  | 0  | 0              | 1              | Load counter no. 1    |
| 0  | 1  | 0  | 1              | 0              | Load counter no. 2    |
| 0  | 1  | 0  | 1              | 1              | Write mode word       |
| 0  | 0  | 1  | 0              | 0              | Read counter no. 0    |
| 0  | 0  | 1  | 0              | 1              | Read counter no. 1    |
| 0  | 0  | 1  | 1              | 0              | Read counter no. 2    |
| 0  | 0  | 1  | 1              | 1              | No-operation, 3-state |
| 1  | Х  | Х  | Х              | Х              | Disable, 3-state      |
| 0  | 1  | 1  | Х              | X              | No-operation, 3-state |
|    |    |    |                |                |                       |

# Absolute Maximum Ratings

| Operating temperature | 0°C to +70°C         |
|-----------------------|----------------------|
| Storage temperature   | -65°C to +150°C      |
| Voltage on any pin    | -0.5 to +7 volts (1) |

#### Note:

(1) With respect to ground.

**Comment:** Exposing the device to stresses above those listed in Absolute Maximum Ratings could cause permanent damage. The device is not meant to be operated under conditions outside the limits described in the operational sections of this specification. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

#### Capacitance

 $T_A = 25^{\circ}C; V_{CC} = GND = 0 V$ 

|                             |                  | Limits  |  |     |      | Test                                        |  |
|-----------------------------|------------------|---------|--|-----|------|---------------------------------------------|--|
| Parameter                   | Symbol           | Min Typ |  | Max | Unit | Conditions                                  |  |
| Input capacitance           | CIN              |         |  | 10  | рF   | $f_c = 1 \text{ MHz}$                       |  |
| Input/Output<br>capacitance | C <sub>1/0</sub> |         |  | 20  | рF   | Unmeasured pins returned to V <sub>SS</sub> |  |

# **DC Characteristics**

 $T_A = 0^{\circ}C \text{ to } + 70^{\circ}C; V_{CC} = +5 \text{ V} \pm 10\%$ 

|                                 |                     |      | Limit |                          | Test |                                     |  |
|---------------------------------|---------------------|------|-------|--------------------------|------|-------------------------------------|--|
| Parameter                       | Symbol              | Min  | Тур   | Max                      | Unit | Conditions                          |  |
| Input low voltage               | VIL                 | -0.5 |       | 0.8                      | ٧    |                                     |  |
| Input high voltage              | V <sub>IH (1)</sub> | 2.0  |       | V <sub>CC</sub><br>+ 0.5 | ۷    |                                     |  |
| Output low voltage              | VOL                 |      |       | 0.45                     | ٧    | $I_{0L} = 2.2 \text{ mA}$           |  |
| Output high voltage             | VOH                 | 2.4  |       |                          | V    | $I_{0H} = -400 \ \mu A$             |  |
| Input load current              | Ι <sub>ΙL</sub>     |      |       | ±10                      | μA   | $0 \leq V_{\rm IN} \leq V_{\rm CC}$ |  |
| Output float<br>leakage current | 10FL                |      |       | ±10                      | μA   | $0.45 \leq V_{OUT} \leq V_{CC}$     |  |
| V <sub>CC</sub> supply current  | lcc                 |      |       | 140                      | mΑ   |                                     |  |

#### Note:

(1) VIH 2.2 min for µPD8253-2.



## **AC Characteristics**

 $T_A = 0^{\circ}C$  to +70°C;  $V_{CC} = +5 V \pm 10\%$ ; GND = 0 V

|                              |                  |     | nits<br> 253-2 |      | nits<br>253-5 |      | Test<br>Conditions       |
|------------------------------|------------------|-----|----------------|------|---------------|------|--------------------------|
| Parameter                    | Symbol           | Min | Max            | Min  | Max           | Unit |                          |
| Read                         |                  |     |                |      |               |      |                          |
| Address stable before READ   | t <sub>AR</sub>  | 30  |                | 0    |               | ns   |                          |
| Address hold time for READ   | t <sub>RA</sub>  | 0   |                | 0    |               | ns   |                          |
| READ pulse width             | t <sub>RR</sub>  | 200 |                | 250  |               | ns   |                          |
| Data delay from READ         | t <sub>RD</sub>  |     | 140            |      | 170           | ns   | $C_L = 150 \text{ pF}$   |
| READ to data floating        | t <sub>DF</sub>  | 10  | 85             | 25   | 100           | ns   | $C_{L} = 150 \text{ pF}$ |
| Recovery time between READS  | t <sub>RV</sub>  | 200 |                | 1000 |               | ns   |                          |
| Write                        |                  |     |                |      |               |      |                          |
| Address stable before WRITE  | t <sub>AW</sub>  | 0   |                | 0    |               | ns   |                          |
| Address hold time for WRITE  | twa              | 0   |                | 0    |               | ns   |                          |
| WRITE pulse width            | tww              | 160 |                | 250  |               | ns   |                          |
| Data set up time for WRITE   | t <sub>DW</sub>  | 130 |                | 150  |               | ns   |                          |
| Data hold time for WRITE     | t <sub>WD</sub>  | 0   |                | 0    |               | ns   |                          |
| Recovery time between WRITES | t <sub>RV</sub>  | 200 |                | 1000 |               | ns   |                          |
| Clock and Gate Timing        |                  |     |                |      |               |      |                          |
| Clock period                 | <sup>t</sup> CLK | 200 |                | 250  | DC            | ns   |                          |
| High pulse width             | 1PWH             | 80  |                | 160  |               | ns   |                          |
| Low pulse width              | tpwL             | 80  |                | . 90 |               | ns   |                          |
| Gate pulse width high        | t <sub>GW</sub>  | 120 |                | 150  |               | ns   |                          |
| Gate set up time to clock 1  | t <sub>GS</sub>  | 70  |                | 100  |               | ns   |                          |
| Gate hold time after clock † | t <sub>GH</sub>  | 50  |                | 50   |               | ns   |                          |
| Low gate width               | t <sub>GL</sub>  | 120 |                | 100  |               | ns   |                          |
| Output delay from Clock +    | top              |     | 250            |      | 300           | ns   | $C_L = 150 \text{ pF}$   |
| Output delay from gate       | todg             |     | 250            |      | 300           | R\$  | $C_{L} = 150 \text{ pF}$ |

#### Note:

(1) AC timing measured at V\_OH = 2.0 V; V\_OL = 0.8 V.

# **Timing Waveforms**

#### **AC Test Conditions**



### Read Timing



## Write Timing



### Read and Write Timing



# **Timing Waveforms (cont)**

### Clock and Gate Timing



# Programming the $\mu$ PD8253

The programmer can select any of the six operational MODES for the counters using system software. Individual counter programming is accomplished by loading the CONTROL WORD REGISTER with the appropriate control word data ( $A_0$ ,  $A_1 = 11$ ).

## **Control Word Format**

| Γ | D <sub>7</sub> | 06              | D <sub>5</sub>  | D4              | D <sub>3</sub> | Dz | D1 | Do  |
|---|----------------|-----------------|-----------------|-----------------|----------------|----|----|-----|
| ſ | SC1            | SC <sub>0</sub> | RL <sub>1</sub> | RL <sub>0</sub> | M <sub>2</sub> | M1 | Mo | BCD |

#### RL - Read/Load

| RL <sub>1</sub> | RL <sub>O</sub> |                                                                    |
|-----------------|-----------------|--------------------------------------------------------------------|
| 0               | 0               | Counter latching operation                                         |
| 1               | 0               | Read/Load most significant byte only                               |
| 0               | 1               | Read/Load least significant byte only                              |
| 1               | 1               | Read/Load least significant byte first, then most significant byte |

### SC - Select Counter

| SC1 | SC <sub>0</sub> |                  |  |
|-----|-----------------|------------------|--|
| 0   | 0               | Select counter 0 |  |
| 0   | 1               | Select counter 1 |  |
| 1   | 0               | Select counter 2 |  |
| 1   | 1               | Invalid          |  |

## BCD

| 0 | Binary counter, 16-bits |
|---|-------------------------|
| 1 | BCD counter, 4-decades  |

### M-Mode

| M <sub>2</sub> | M <sub>1</sub> | Mo |        |
|----------------|----------------|----|--------|
| 0              | 0              | 0  | Mode 0 |
| 0              | 0              | 1  | Mode 1 |
| Х              | 1              | 0  | Mode 2 |
| Х              | 1              | 1  | Mode 3 |
| 1              | 0              | 0  | Mode 4 |
| 1              | 0              | 1  | Mode 5 |



## **Operational Modes**

Each of the three counters can be individually programmed with different operating MODES by appropriately formatted control words. The following is a summary of the MODE operations.

### Mode O: Interrupt on Terminal Count

The initial MODE set operation forces the OUTPUT low. When the specified counter is loaded with the count value, it will begin counting. The OUTPUT will remain low until the terminal count sets it high. It will remain in the high state until the trailing edge of the second WR pulse loads in COUNT data. If data is loaded during the counting process, the first WR stops the count. Counting starts with the new count data triggered by the falling clock edge after the second WR. If a GATE pulse is asserted while counting, the count is terminated for the duration of GATE. The falling edge of CLK following the removal of GATE restarts counting from the terminated point.





### Mode 1: Programmable One-Shot

The OUTPUT is set low by the falling edge of CLOCK following the trailing edge of GATE. The OUTPUT is set high again at the terminal count. The output pulse is not affected if new count data is loaded while the OUTPUT is low. The new data will be loaded on the rising edge of the next trigger pulse. The assertion of a trigger pulse while OUTPUT is low, resets and retriggers the one-shot. The OUTPUT will remain low for the full count value after the rising edge of TRIGGER.

#### Mode 1: Programmable One-Shot





### Mode 2: Rate Generator

The RATE GENERATOR is a variable modulus counter. The OUTPUT goes low for one full CLOCK period as shown in the following timing diagram. The count data sets the time between OUTPUT pulses. If the count register is reloaded between output pulses the present period will not be affected. The subsequent period will reflect the new value. The OUTPUT will remain high for the duration of the asserted GATE input. Normal operation resumes on the falling CLOCK edge following the rising edge of GATE.

### Mode 2: Rate Generator



μ**PD8253** 

### Mode 3: Square Wave Generator

MODE 3 resembles MODE 2 except the OUTPUT will be high for half of the count and low for the other half (for even values of data). For odd values of count data the OUTPUT. Put will be high one clock cycle longer than when it is low (High Period  $\rightarrow \frac{N+1}{2}$  clock cycles; Low Period  $\rightarrow \frac{N-1}{2}$  clock periods, where N is the decimal value of count data). If the count register is reloaded with a new value during counting, the new value will be reflected immediately after the output transition of the current count.

The OUTPUT will be held in the high state while GATE is asserted. Counting will start from the full count data after the GATE has been removed.



#### Mode 3: Square Wave Generator

8



## Mode 4: Software Triggered Strobe

The OUTPUT goes high when MODE 4 is set, and counting begins after the second byte of data has been loaded. When the terminal count is reached, the OUTPUT will pulse low for one clock period. Changes in count data are reflected in the OUTPUT as soon as the new data has been loaded into the count registers. During the loading of new data, the OUTPUT is held high and counting is inhibited.

The OUTPUT is held high for the duration of GATE. The counters are reset and counting begins from the full data value after GATE is removed.



#### Mode 4: Software Triggered Strobe

## Mode 5: Hardware Triggered Strobe

Loading MODE 5 sets OUTPUT high. Counting begins when count data is loaded and GATE goes high. After terminal count is reached, the OUTPUT will pulse low for one clock period. Subsequent trigger pulses will restart the counting sequence with the OUTPUT pulsing low on terminal count following the last rising edge of the trigger input. (Reference the bottom half of the timing diagram.)

### Mode 5: Hardware Triggered Strobe

