## LAMPIRAN-A

## DATASHEET KOMPONEN

# 2803 mav 2824 

## HIGH-VOLTAGE, HIGH-CURRENT DARLINGTON ARRAYS



Dwg. No. A-10,322A
Note that the ULx28xxA series (dual in-line package) and ULx28xxLW series (smalloutline IC package) are electrically identical and share a common terminal number assignment.
ABSOLUTE MAXIMUM RATINGSOutput Voltage, $\mathrm{V}_{\mathrm{CE}}$
(x2803x and x2804x) ..... 50 V
(x2823x and x2824x) ..... 95 V
Input Voltage, $\mathrm{V}_{\text {IN }}$ ..... 30 V
Continuous Output Current, $\mathrm{I}_{\mathrm{C}} \ldots . .500 \mathrm{~mA}$
Continuous Input Current, $\mathrm{I}_{\mathrm{IN}}$ ..... 25 mA
Power Dissipation, $\mathrm{P}_{\mathrm{D}}$
(one Darlington pair) ..... 1.0 W
(total package) ..... See Graph
Operating Temperature Range, $\mathrm{T}_{\mathrm{A}}$
Prefix 'ULN' ..... $-20^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Prefix 'ULQ'

$\qquad$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature Range,

Featuring continuous load current ratings to 500 mA for each of the drivers, the Series ULN28xxA/LW and ULQ28xxA/LW highvoltage, high-current Darlington arrays are ideally suited for interfacing between low-level logic circuitry and multiple peripheral power loads. Typical power loads totaling over $260 \mathrm{~W}(350 \mathrm{~mA} \times 8,95 \mathrm{~V})$ can be controlled at an appropriate duty cycle depending on ambient temperature and number of drivers turned on simultaneously. Typical loads include relays, solenoids, stepping motors, magnetic print hammers, multiplexed LED and incandescent displays, and heaters. All devices feature open-collector outputs with integral clamp diodes.

The ULx2803A, ULx2803LW, ULx2823A, and ULN2823LW have series input resistors selected for operation directly with 5 V TTL or CMOS. These devices will handle numerous interface needs particularly those beyond the capabilities of standard logic buffers.

The ULx2804A, ULx2804LW, ULx2824A, and ULN2824LW have series input resistors for operation directly from 6 V to 15 V CMOS or PMOS logic outputs.

The ULx2803A/LW and ULx2804A/LW are the standard Darlington arrays. The outputs are capable of sinking 500 mA and will withstand at least 50 V in the off state. Outputs may be paralleled for higher load current capability. The ULx2823A/LW and ULx2824A/ LW will withstand 95 V in the off state.

These Darlington arrays are furnished in 18-pin dual in-line plastic packages (suffix 'A') or 18-lead small-outline plastic packages (suffix 'LW'). All devices are pinned with outputs opposite inputs to facilitate ease of circuit board layout. Prefix 'ULN' devices are rated for operation over the temperature range of $-20^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$; prefix 'ULQ' devices are rated for operation to $-40^{\circ} \mathrm{C}$.

## FEATURES

- TTL, DTL, PMOS, or CMOS Compatible Inputs
$\square$ Output Current to 500 mA
■ Output Voltage to 95 V
$\square$ Transient-Protected Outputs
$\square$ Dual In-Line Package or Wide-Body Small-Outline Package
The ULx2804, ULx2823, \& ULx2824 are last-time buy. Orders accepted until October 19, 2001.
$x=$ Character to identify specific device. Characteristic shown applies to family of devices with remaining digits as shown. See matrix on next page.

DEVICE PART NUMBER DESIGNATION

| $V_{\text {CE(MAX) }}$ | 50 V | 95 V |
| :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{C}(\mathrm{MAX})}$ | 500 mA | 500 mA |
| Logic | Part Number |  |
| $\begin{array}{c}\text { 5V } \\ \text { TTL, CMOS }\end{array}$ | $\begin{array}{c}\text { ULN2803A* } \\ \text { ULN2803LW* }\end{array}$ | $\begin{array}{c}\text { ULN2823A* } \\ \text { ULN2823LW }\end{array}$ |
| $\begin{array}{c}\text { 6-15 }\end{array}$ |  |  |
| CMOS, PMOS |  |  |\(\left.\quad \begin{array}{c}ULN2804A* <br>


ULN2804LW*\end{array}\right]\)| ULN2824A* |
| :---: |
| ULN2824LW |

*Also available for operation between $-40^{\circ} \mathrm{C}$ and $+85^{\circ} \mathrm{C}$. To order, change prefix from 'ULN' to 'ULQ'.

## PARTIAL SCHEMATICS

ULx28x3A/LW (Each Driver)


## ULx28x4A/LW (Each Driver)



The ULx2804, ULx2823, \& ULx2824 are last-time buy. Orders accepted until October 19, 2001.


Dwg. GP-018B
$\mathrm{x}=$ Character to identify specific device. Specification shown applies to family of devices with remaining digits as shown. See matrix above.

## Types ULx2803A, ULx2803LW, ULx2804A, and ULx2804LW ELECTRICAL CHARACTERISTICS at $+25^{\circ} \mathrm{C}$ (unless otherwise noted).

| Characteristic | Symbol | Test <br> Fig. | Applicable Devices | Test Conditions | Limits |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min. | Typ. | Max. | Units |
| Output Leakage Current | $I_{\text {CEX }}$ | 1A | All | $\mathrm{V}_{C E}=50 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | - | < 1 | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=50 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ | - | < 1 | 100 | $\mu \mathrm{A}$ |
|  |  | 1B | ULx2804x | $\mathrm{V}_{\mathrm{CE}}=50 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{IN}}=1.0 \mathrm{~V}$ | - | < 5 | 500 | $\mu \mathrm{A}$ |
| Collector-Emitter Saturation Voltage | $\mathrm{V}_{\text {CE(SAT }}$ | 2 | All | $\mathrm{I}_{\mathrm{C}}=100 \mathrm{~mA}, \mathrm{I}_{\mathrm{B}}=250 \mu \mathrm{~A}$ | - | 0.9 | 1.1 | V |
|  |  |  |  | $\mathrm{I}_{\mathrm{C}}=200 \mathrm{~mA}, \mathrm{I}_{\mathrm{B}}=350 \mu \mathrm{~A}$ | - | 1.1 | 1.3 | V |
|  |  |  |  | $\mathrm{I}_{\mathrm{C}}=350 \mathrm{~mA}, \mathrm{I}_{\mathrm{B}}=500 \mu \mathrm{~A}$ | - | 1.3 | 1.6 | V |
| Input Current | $\mathrm{I}_{\mathrm{IN}(\mathrm{ON})}$ | 3 | ULx2803x | $\mathrm{V}_{\text {IN }}=3.85 \mathrm{~V}$ | - | 0.93 | 1.35 | mA |
|  |  |  | ULx2804x | $\mathrm{V}_{\text {IN }}=5.0 \mathrm{~V}$ | - | 0.35 | 0.5 | mA |
|  |  |  |  | $\mathrm{V}_{\text {IN }}=12 \mathrm{~V}$ | - | 1.0 | 1.45 | mA |
|  | $\mathrm{I}_{\text {IN(OFF) }}$ | 4 | All | $\mathrm{I}_{\mathrm{C}}=500 \mu \mathrm{~A}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ | 50 | 65 | - | $\mu \mathrm{A}$ |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}(\mathrm{ON})}$ | 5 | ULx2803x | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=200 \mathrm{~mA}$ | - | - | 2.4 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=250 \mathrm{~mA}$ | - | - | 2.7 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=300 \mathrm{~mA}$ | - | - | 3.0 | V |
|  |  |  | ULx2804x | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=125 \mathrm{~mA}$ | - | - | 5.0 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=200 \mathrm{~mA}$ | - | - | 6.0 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=275 \mathrm{~mA}$ | - | - | 7.0 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=350 \mathrm{~mA}$ | - | - | 8.0 | V |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | All |  | - | 15 | 25 | pF |
| Turn-On Delay | $t_{\text {PLH }}$ | 8 | All | $0.5 \mathrm{E}_{\text {IN }}$ to $0.5 \mathrm{E}_{\text {OUT }}$ | - | 0.25 | 1.0 | $\mu \mathrm{s}$ |
| Turn-Off Delay | $\mathrm{t}_{\mathrm{PHL}}$ | 8 | All | $0.5 \mathrm{E}_{\text {IN }}$ to $0.5 \mathrm{E}_{\text {OUT }}$ | - | 0.25 | 1.0 | $\mu \mathrm{s}$ |
| Clamp Diode Leakage Current | $\mathrm{I}_{\mathrm{R}}$ | 6 | All | $\mathrm{V}_{\mathrm{R}}=50 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | - | - | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{R}}=50 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ | - | - | 100 | $\mu \mathrm{A}$ |
| Clamp Diode Forward Voltage | $\mathrm{V}_{\mathrm{F}}$ | 7 | All | $\mathrm{I}_{\mathrm{F}}=350 \mathrm{~mA}$ | - | 1.7 | 2.0 | V |

Complete part number includes prefix to operating temperature range: ULN $=-20^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, ULQ $=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ and a suffix to identify package style: A = DIP, LW = SOIC.

The ULx2804 is last-time buy. Orders accepted until October 19, 2001.

## Types ULx2823A, ULN2823LW, ULx2824A, and ULN2824LW

 ELECTRICAL CHARACTERISTICS at $\mathbf{+ 2 5 ^ { \circ }}$ ( unless otherwise noted).| Characteristic | Symbol | $\begin{array}{\|l\|} \hline \text { Test } \\ \text { Fig. } \\ \hline \end{array}$ | Applicable Devices | Test Conditions | Limits |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min. | Typ. | Max. | Units |
| Output Leakage Current | $I_{\text {CEX }}$ | 1A | All | $\mathrm{V}_{C E}=95 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | - | <1 | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{C E}=95 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ | - | <1 | 100 | $\mu \mathrm{A}$ |
|  |  | 1B | ULx2824x | $\mathrm{V}_{\mathrm{CE}}=95 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{IN}}=1.0 \mathrm{~V}$ | - | < 5 | 500 | $\mu \mathrm{A}$ |
| Collector-Emitter Saturation Voltage | $\mathrm{V}_{\text {CE(SAT }}$ | 2 | All | $\mathrm{I}_{\mathrm{C}}=100 \mathrm{~mA}, \mathrm{I}_{\mathrm{B}}=250 \mu \mathrm{~A}$ | - | 0.9 | 1.1 | V |
|  |  |  |  | $\mathrm{I}_{\mathrm{C}}=200 \mathrm{~mA}, \mathrm{I}_{\mathrm{B}}=350 \mu \mathrm{~A}$ | - | 1.1 | 1.3 | V |
|  |  |  |  | $\mathrm{I}_{\mathrm{C}}=350 \mathrm{~mA}, \mathrm{I}_{\mathrm{B}}=500 \mu \mathrm{~A}$ | - | 1.3 | 1.6 | V |
| Input Current | İN(ON) | 3 | ULx2824x | $\mathrm{V}_{\text {IN }}=3.85 \mathrm{~V}$ | - | 0.93 | 1.35 | mA |
|  |  |  |  | $\mathrm{V}_{\text {IN }}=5.0 \mathrm{~V}$ | - | 0.35 | 0.5 | mA |
|  |  |  |  | $\mathrm{V}_{\text {IN }}=12 \mathrm{~V}$ | - | 1.0 | 1.45 | mA |
|  | $\mathrm{I}_{\text {IN(OFF) }}$ | 4 | All | $\mathrm{I}_{\mathrm{C}}=500 \mu \mathrm{~A}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ | 50 | 65 | - | $\mu \mathrm{A}$ |
| Input Voltage | $\mathrm{V}_{\text {IN(ON) }}$ | 5 | ULx2823x | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=200 \mathrm{~mA}$ | - | - | 2.4 | V |
|  |  |  |  | $\mathrm{V}_{\text {CE }}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=250 \mathrm{~mA}$ | - | - | 2.7 | V |
|  |  |  |  | $\mathrm{V}_{\text {CE }}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=300 \mathrm{~mA}$ | - | - | 3.0 | V |
|  |  |  | ULx2824x | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=125 \mathrm{~mA}$ | - | - | 5.0 | V |
|  |  |  |  | $\mathrm{V}_{\text {CE }}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=200 \mathrm{~mA}$ | - | - | 6.0 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=275 \mathrm{~mA}$ | - | - | 7.0 | V |
|  |  |  |  | $\mathrm{V}_{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=350 \mathrm{~mA}$ | - | - | 8.0 | V |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | All |  | - | 15 | 25 | pF |
| Turn-On Delay | $\mathrm{tpLH}^{\text {l }}$ | 8 | All | $0.5 \mathrm{E}_{\text {IN }}$ to $0.5 \mathrm{E}_{\text {OUT }}$ | - | 0.25 | 1.0 | $\mu \mathrm{s}$ |
| Turn-Off Delay | $\mathrm{t}_{\text {PHL }}$ | 8 | All | $0.5 \mathrm{E}_{\text {IN }}$ to $0.5 \mathrm{E}_{\text {OUT }}$ | - | 0.25 | 1.0 | $\mu \mathrm{s}$ |
| Clamp Diode Leakage Current | $\mathrm{I}_{\mathrm{R}}$ | 6 | All | $\mathrm{V}_{\mathrm{R}}=95 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | - | - | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{R}}=95 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ | - | - | 100 | $\mu \mathrm{A}$ |
| Clamp Diode Forward Voltage | $V_{F}$ | 7 | All | $\mathrm{I}_{\mathrm{F}}=350 \mathrm{~mA}$ | - | 1.7 | 2.0 | V |

Complete part number includes prefix to operating temperature range: ULN $=-20^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{ULQ}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ and a suffix to identify package style: A = DIP, LW = SOIC. Note that the ULQ2823LW and ULQ2824LW are not presently available.

The ULx2823 \& ULx2824 are last-time buy. Orders accepted until October 19, 2001.

## 2803 THRU 2824 HIGH-VOLTAGE, HIGH-CURRENT DARLINGTON ARRAYS

FIGURE 1A


Dwg. No. A-9729A

FIGURE 3


FIGURE 6

Dwg. No. A-9735A


## TEST FIGURES

FIGURE 1B


Dwg. No. A-9730A

FIGURE 4


Dwg. No. A-9733A


Dwg. No. A-9736A
FIGURE 7

FIGURE 2


Dwg. No. A-9731A

FIGURE 5


FIGURE 8


|  | $V_{\text {in }}$ |
| :---: | :---: |
|  | 3.5 V |
| ULx $28 \times 3 \times 4 \mathrm{x}$ | 12 V |

## ALLOWABLE COLLECTOR CURRENT AS A FUNCTION OF DUTY CYCLE ULx28xxA



Dwg. GP-070-2


Dwg. GP-070-1

ALLOWABLE COLLECTOR CURRENT AS A FUNCTION OF DUTY CYCLE ULx28xxLW


Dwg. GP-070-4

$x=$ Characters to identify specific device. Specification shown applies to family of devices with remaining digits as shown.

$\mathrm{x}=$ Characters to identify specific device. Characteristic shown applies to family of devices with remaining digits as shown.


NOTES: 1. Exact body and lead configuration at vendor's option within limits shown.
2. Lead spacing tolerance is non-cumulative.
3. Lead thickness is measured at seating plane or below.

## 2803 THRU 2824 HIGH-VOLTAGE, HIGH-CURRENT DARLINGTON ARRAYS

PACKAGE DESIGNATOR "LW" DIMENSIONS
Dimensions in Inches
(for reference only)


Dwg. MA-008-18A in


Dwg. MA-008-18A mm
NOTES: 1. Exact body and lead configuration at vendor's option within limits shown.
2. Lead spacing tolerance is non-cumulative.

2803 THRU 2824 HIGH-VOLTAGE, HIGH-CURRENT DARLINGTON ARRAYS

The products described here are manufactured under one or more U.S. patents or U.S. patents pending.

Allegro MicroSystems, Inc. reserves the right to make, from time to time, such departures from the detail specifications as may be required to permit improvements in the performance, reliability, or manufacturability of its products. Before placing an order, the user is cautioned to verify that the information being relied upon is current.

Allegro products are not authorized for use as critical components in life-support devices or systems without express written approval.

The information included herein is believed to be accurate and reliable. However, Allegro MicroSystems, Inc. assumes no responsibility for its use; nor for any infringement of patents or other rights of third parties which may result from its use.

## ADC0801/ADC0802/ADC0803/ADC0804/ADC0805 8-Bit $\mu$ P Compatible A/D Converters

## General Description

The ADC0801, ADC0802, ADC0803, ADC0804 and ADC0805 are CMOS 8-bit successive approximation A/D converters that use a differential potentiometric ladder-similar to the 256R products. These converters are designed to allow operation with the NSC800 and INS8080A derivative control bus with TRI-STATE output latches directly driving the data bus. These A/Ds appear like memory locations or I/O ports to the microprocessor and no interfacing logic is needed.
Differential analog voltage inputs allow increasing the common-mode rejection and offsetting the analog zero input voltage value. In addition, the voltage reference input can be adjusted to allow encoding any smaller analog voltage span to the full 8 bits of resolution.

## Features

- Compatible with $8080 \mu \mathrm{P}$ derivatives - no interfacing logic needed - access time - 135 ns
- Easy interface to all microprocessors, or operates "stand alone"
- Differential analog voltage inputs
- Logic inputs and outputs meet both MOS and TTL voltage level specifications
- Works with 2.5 V (LM336) voltage reference
- On-chip clock generator
- 0 V to 5 V analog input voltage range with single 5 V supply
- No zero adjust required
- 0.3 " standard width 20-pin DIP package
- 20-pin molded chip carrier or small outline package
- Operates ratiometrically or with $5 \mathrm{~V}_{\mathrm{DC}}, 2.5 \mathrm{~V}_{\mathrm{DC}}$, or analog span adjusted voltage reference


## Key Specifications

- Resolution
- Total error $\pm 1 / 4 \mathrm{LSB}, \pm 1 / 2 \mathrm{LSB}$ and $\pm 1 \mathrm{LSB}$ $100 \mu \mathrm{~s}$


## Connection Diagram

ADC080X
Dual-In-Line and Small Outline (SO) Packages

See Ordering Information
Ordering Information

| TEMP RANGE |  | $0^{\circ} \mathrm{C}$ TO $70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C} \mathrm{TO} 70^{\circ} \mathrm{C}$ | $-40^{\circ} \mathrm{C} \mathrm{TO} \mathrm{+85}{ }^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: |
| ERROR | $\pm 1 / 4$ Bit Adjusted |  |  | ADC0801LCN |
|  | $\pm 1 / 2$ Bit Unadjusted | ADC0802LCWM |  | ADC0802LCN |
|  | $\pm 1 / 2$ Bit Adjusted |  |  | ADC0803LCN |
|  | $\pm 1$ Bit Unadjusted | ADC0804LCWM | ADC0804LCN | ADC0805LCN/ADC0804LCJ |
| PACKAGE OUTLINE |  | M20B - Small Outline | N20A - Molded DIP |  |

[^0]Typical Applications


| Error Specification (Includes Full-Scale, <br> Zero Error, and Non-Linearity) |  |  |  |
| :---: | :---: | :---: | :---: |
| Pumber | Full- <br> Scale <br> Adjusted | $\mathbf{V}_{\text {REF }} / \mathbf{2 = 2 . 5 0 0} \mathbf{V}_{\text {DC }}$ <br> (No Adjustments) | $\mathbf{V}_{\text {REF }} / \mathbf{2}=$ No Connection <br> (No Adjustments) |
| ADC0801 | $\pm 1 / 4 \mathrm{LSB}$ |  |  |
| ADC0802 |  | $\pm 1 / 2 \mathrm{LSB}$ |  |
| ADC0803 | $\pm 1 / 2 \mathrm{LSB}$ |  |  |
| ADC0804 |  | $\pm 1 \mathrm{LSB}$ |  |
| ADC0805 |  |  | $\pm 1 \mathrm{LSB}$ |



Infrared (15 seconds)
$220^{\circ} \mathrm{C}$
Storage Temperature Range
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Package Dissipation at $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ 875 mW
ESD Susceptibility (Note 10) 800 V

## Operating Ratings (Notes 1, 2)

Temperature Range
ADC0804LCJ
ADC0801/02/03/05LCN
ADC0804LCN
ADC0802/04LCWM
Range of $\mathrm{V}_{\mathrm{Cc}}$

## Electrical Characteristics

The following specifications apply for $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{\mathrm{DC}}, \mathrm{T}_{\text {MIN }} \leq \mathrm{T}_{\mathrm{A}} \leq \mathrm{T}_{\text {MAX }}$ and $\mathrm{f}_{\mathrm{CLK}}=640 \mathrm{kHz}$ unless otherwise specified.

| Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADC0801: Total Adjusted Error (Note 8) | With Full-Scale Adj. (See Section 2.5.2) |  |  | $\pm 1 / 4$ | LSB |
| ADC0802: Total Unadjusted Error (Note 8) | $\mathrm{V}_{\text {REF }} / 2=2.500 \mathrm{~V}_{\mathrm{DC}}$ |  |  | $\pm 1 / 2$ | LSB |
| ADC0803: Total Adjusted Error (Note 8) | With Full-Scale Adj. (See Section 2.5.2) |  |  | $\pm 1 / 2$ | LSB |
| ADC0804: Total Unadjusted Error (Note 8) | $\mathrm{V}_{\text {REF }} / 2=2.500 \mathrm{~V}_{\mathrm{DC}}$ |  |  | $\pm 1$ | LSB |
| ADC0805: Total Unadjusted Error (Note 8) | $\mathrm{V}_{\text {REF }} / 2-$ No Connection |  |  | $\pm 1$ | LSB |
| $\mathrm{V}_{\text {REF }} / 2$ Input Resistance (Pin 9) | ADC0801/02/03/05 ADC0804 (Note 9) | $\begin{gathered} \hline 2.5 \\ 0.75 \\ \hline \end{gathered}$ | $\begin{aligned} & 8.0 \\ & 1.1 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \hline \end{aligned}$ |
| Analog Input Voltage Range | (Note 4) V (+) or V(-) | Gnd-0.05 |  | $\mathrm{V}_{\mathrm{CC}}+0.05$ | $\mathrm{V}_{\mathrm{DC}}$ |
| DC Common-Mode Error | Over Analog Input Voltage Range |  | $\pm 1 / 16$ | $\pm 1 / 8$ | LSB |
| Power Supply Sensitivity | $\begin{aligned} & \hline \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{\mathrm{DC}} \pm 10 \% \text { Over } \\ & \text { Allowed } \mathrm{V}_{\mathrm{IN}}(+) \text { and } \mathrm{V}_{\mathrm{IN}}(-) \\ & \text { Voltage Range (Note 4) } \\ & \hline \end{aligned}$ |  | $\pm 1 / 16$ | $\pm 1 / 8$ | LSB |

## AC Electrical Characteristics

The following specifications apply for $\mathrm{V}_{C C}=5 \mathrm{~V}_{\mathrm{DC}}$ and $\mathrm{T}_{\text {MIN }} \leq \mathrm{T}_{A} \leq \mathrm{T}_{\text {MAX }}$ unless otherwise specified.

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{C}}$ | Conversion Time | $\mathrm{f}_{\text {CLK }}=640 \mathrm{kHz}$ (Note 6) | 103 |  | 114 | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\mathrm{C}}$ | Conversion Time | (Notes 5, 6) | 66 |  | 73 | $1 / \mathrm{f}_{\text {CLK }}$ |
| $\mathrm{f}_{\text {CLK }}$ | Clock Frequency Clock Duty Cycle | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$, (Note 5) | $\begin{gathered} 100 \\ 40 \end{gathered}$ | 640 | $\begin{gathered} 1460 \\ 60 \end{gathered}$ | $\begin{gathered} \mathrm{kHz} \\ \% \end{gathered}$ |
| CR | Conversion Rate in Free-Running Mode | $\overline{\mathrm{N} T \mathrm{R}}$ tied to $\overline{\mathrm{WR}}$ with $\overline{\mathrm{CS}}=0 \mathrm{~V}_{\mathrm{DC}}, \mathrm{f}_{\mathrm{CLK}}=640 \mathrm{kHz}$ | 8770 |  | 9708 | conv/s |
| $\mathrm{t}_{\mathrm{W}}(\overline{\mathrm{WR}}) \mathrm{L}$ | Width of $\overline{\text { WR }}$ Input (Start Pulse Width) | $\overline{\mathrm{CS}}=0 \mathrm{~V}_{\mathrm{DC}}$ (Note 7) | 100 |  |  | ns |
| $\mathrm{t}_{\mathrm{ACC}}$ | Access Time (Delay from Falling Edge of $\overline{R D}$ to Output Data Valid) | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |  | 135 | 200 | ns |
| $\mathrm{t}_{1 \mathrm{H}}, \mathrm{t}_{\text {OH }}$ | TRI-STATE Control (Delay from Rising Edge of $\overline{R D}$ to Hi-Z State) | $\mathrm{C}_{\mathrm{L}}=10 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=10 \mathrm{k}$ <br> (See TRI-STATE Test Circuits) |  | 125 | 200 | ns |
| $\mathrm{t}_{\mathrm{WI}}, \mathrm{t}_{\mathrm{RI}}$ | Delay from Falling Edge of $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ to Reset of $\overline{\mathrm{NTR}}$ |  |  | 300 | 450 | ns |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance of Logic Control Inputs |  |  | 5 | 7.5 | pF |

## AC Electrical Characteristics (Continued)

The following specifications apply for $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}_{\mathrm{DC}}$ and $\mathrm{T}_{\text {MIN }} \leq \mathrm{T}_{A} \leq \mathrm{T}_{\text {MAX }}$ unless otherwise specified.

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| C Out $^{\text {TRI-STATE Output }}$Capacitance (Data Buffers) |  |  | 5 | 7.5 | pF |  |

CONTROL INPUTS [Note: CLK IN (Pin 4) is the input of a Schmitt trigger circuit and is therefore specified separately]

| $\mathrm{V}_{\mathrm{IN}}(1)$ | Logical "1" Input Voltage <br> (Except Pin 4 CLK IN) | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}_{\mathrm{DC}}$ | 2.0 |  | 15 | $\mathrm{~V}_{\mathrm{DC}}$ |
| :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| $\mathrm{V}_{\mathrm{IN}}(0)$ | Logical "0" Input Voltage <br> (Except Pin 4 CLK IN) | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}}$ |  |  | 0.8 | $\mathrm{~V}_{\mathrm{DC}}$ |
| $\mathrm{I}_{\mathrm{IN}}(1)$ | Logical "1" Input Current <br> (All Inputs) | $\mathrm{V}_{I N}=5 \mathrm{~V}_{\mathrm{DC}}$ | 0.005 | 1 | $\mu \mathrm{~A}_{\mathrm{DC}}$ |  |
| $\mathrm{I}_{\mathrm{IN}}(0)$ | Logical "0" Input Current <br> (All Inputs) | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}_{\mathrm{DC}}$ | -1 | -0.005 |  | $\mu \mathrm{~A}_{\mathrm{DC}}$ |

CLOCK IN AND CLOCK R

| $\mathrm{V}^{+}$ | CLK IN (Pin 4) Positive Going Threshold Voltage |  | 2.7 | 3.1 | 3.5 | $\mathrm{V}_{\mathrm{DC}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{V_{T}-}$ | CLK IN (Pin 4) Negative Going Threshold Voltage |  | 1.5 | 1.8 | 2.1 | $\mathrm{V}_{\mathrm{DC}}$ |
| $\mathrm{V}_{\mathrm{H}}$ | CLK IN (Pin 4) Hysteresis $\left(\mathrm{V}_{\mathrm{T}^{+}}\right)-\left(\mathrm{V}_{\mathrm{T}^{-}}\right)$ |  | 0.6 | 1.3 | 2.0 | $\mathrm{V}_{\mathrm{DC}}$ |
| $\mathrm{V}_{\text {OUT }}(0)$ | Logical "0" CLK R Output Voltage | $\begin{aligned} & \mathrm{I}_{\mathrm{O}}=360 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}} \end{aligned}$ |  |  | 0.4 | $\mathrm{V}_{\mathrm{DC}}$ |
| $\mathrm{V}_{\text {OUT }}{ }^{(1)}$ | Logical "1" CLK R Output Voltage | $\begin{aligned} & \mathrm{I}_{\mathrm{O}}=-360 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}} \end{aligned}$ | 2.4 |  |  | $\mathrm{V}_{\mathrm{DC}}$ |

DATA OUTPUTS AND INTR

| $\mathrm{V}_{\text {OUT }}(0)$ | Logical "0" Output Voltage <br> Data Outputs <br> INTR Output | $\begin{aligned} & \mathrm{l}_{\text {OUT }}=1.6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}} \\ & \mathrm{I}_{\text {OUT }}=1.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}} \end{aligned}$ |  |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{DC}} \\ & \mathrm{~V}_{\mathrm{DC}} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {OUT }}(1)$ | Logical "1" Output Voltage | $\mathrm{I}_{\mathrm{O}}=-360 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}}$ | 2.4 |  |  | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ (1) | Logical "1" Output Voltage | $\mathrm{I}_{\mathrm{O}}=-10 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}_{\mathrm{DC}}$ | 4.5 |  |  | $\mathrm{V}_{\mathrm{DC}}$ |
| $\mathrm{l}_{\text {OUt }}$ | TRI-STATE Disabled Output Leakage (All Data Buffers) | $\begin{aligned} & \mathrm{V}_{\text {OUT }}=0 \mathrm{~V}_{\mathrm{DC}} \\ & \mathrm{~V}_{\text {OUT }}=5 \mathrm{~V}_{\mathrm{DC}} \end{aligned}$ | -3 |  | 3 | $\mu \mathrm{A}_{\mathrm{DC}}$ <br> $\mu \mathrm{A}_{\mathrm{DC}}$ |
| $I_{\text {SOURCE }}$ |  | $\mathrm{V}_{\text {Out }}$ Short to Gnd, $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 4.5 | 6 |  | $m A_{D C}$ |
| $\mathrm{I}_{\text {SINK }}$ |  | $\mathrm{V}_{\text {OUT }}$ Short to $\mathrm{V}_{\mathrm{CC}}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 9.0 | 16 |  | $m A_{\text {DC }}$ |

POWER SUPPLY

| Supply Current (Includes <br> Ladder Current) | $\mathrm{f}_{\mathrm{CLK}}=640 \mathrm{kHz}$, <br> $\mathrm{V}_{\text {REE }} / 2=\mathrm{NC}, T_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> and $\overline{\mathrm{CS}}=5 \mathrm{~V}$ |
| :--- | :--- |
|  |  |


|  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |
|  | 1.1 | 1.8 | mA |
|  | 1.9 | 2.5 | mA |

Note 1: Absolute Maximum Ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications do not apply when operating the device beyond its specified operating conditions.
Note 2: All voltages are measured with respect to Gnd, unless otherwise specified. The separate A Gnd point should always be wired to the D Gnd.
Note 3: A zener diode exists, internally, from $\mathrm{V}_{\mathrm{CC}}$ to G , and has a typical breakdown voltage of $7 \mathrm{~V}_{\mathrm{DC}}$
Note 4: For $\mathrm{V}_{\mathrm{IN}}(-) \geq \mathrm{V}_{\mathrm{IN}}(+)$ the digital output code will be 00000000 . Two on-chip diodes are tied to each analog input (see block diagram) which will forward conduct for analog input voltages one diode drop below ground or one diode drop greater than the $\mathrm{V}_{\mathrm{Cc}}$ supply. Be careful, during testing at low $\mathrm{V}_{\mathrm{Cc}}$ levels (4.5V), as high level analog inputs ( 5 V ) can cause this input diode to conduct-especially at elevated temperatures, and cause errors for analog inputs near full-scale. The spec allows 50 mV forward bias of either diode. This means that as long as the analog $\mathrm{V}_{\mathrm{IN}}$ does not exceed the supply voltage by more than 50 mV , the output code will be correct. To achieve an absolute $0 \mathrm{~V}_{\mathrm{DC}}$ to $5 \mathrm{~V}_{\mathrm{DC}}$ input voltage range will therefore require a minimum supply voltage of $4.950 \mathrm{~V}_{\mathrm{DC}}$ over temperature variations, initial tolerance and loading
Note 5: Accuracy is guaranteed at $f_{C L K}=640 \mathrm{kHz}$. At higher clock frequencies accuracy can degrade. For lower clock frequencies, the duty cycle limits can be extended so long as the minimum clock high time interval or minimum clock low time interval is no less than 275 ns.
Note 6: With an asynchronous start pulse, up to 8 clock periods may be required before the internal clock phases are proper to start the conversion process. The start request is internally latched, see Figure 4 and section 2.0.

## AC Electrical Characteristics (Continued)

Note 7: The $\overline{\mathrm{CS}}$ input is assumed to bracket the $\overline{\mathrm{WR}}$ strobe input and therefore timing is dependent on the $\overline{\mathrm{WR}}$ pulse width. An arbitrarily wide pulse width will hold the converter in a reset mode and the start of conversion is initiated by the low to high transition of the $\overline{W R}$ pulse (see timing diagrams).
Note 8: None of these A/Ds requires a zero adjust (see section 2.5.1). To obtain zero code at other analog input voltages see section 2.5 and Figure 7.
Note 9: The $\mathrm{V}_{\mathrm{REF}} / 2$ pin is the center point of a two-resistor divider connected from $\mathrm{V}_{\mathrm{CC}}$ to ground. In all versions of the ADC0801, ADC0802, ADC0803, and ADC0805, and in the ADC0804LCJ, each resistor is typically $16 \mathrm{k} \Omega$. In all versions of the ADC0804 except the ADC0804LCJ, each resistor is typically $2.2 \mathrm{k} \Omega$.
Note 10: Human body model, 100 pF discharged through a $1.5 \mathrm{k} \Omega$ resistor.

## Typical Performance Characteristics



DS005671-38
$\mathbf{f}_{\mathbf{c L K}}$ vs. Clock Capacitor


## Output Current vs Temperature



Delay From Falling Edge of $\overline{R D}$ to Output Data Valid vs. Load Capacitance


Full-Scale Error vs Conversion Time


Power Supply Current vs Temperature (Note 9)


CLK IN Schmitt Trip Levels vs. Supply Voltage


Effect of Unadjusted Offset Error vs. $\mathrm{V}_{\text {Ref }} / \mathbf{2}$ Voltage


## Linearity Error at Low

 $\mathbf{V}_{\text {REF }} / \mathbf{2}$ Voltages

TRI-STATE Test Circuits and Waveforms

$\mathrm{t}_{\mathrm{r}}=20 \mathrm{~ns}$

$\mathrm{t}_{\mathrm{r}}=20 \mathrm{~ns}$
Timing Diagrams (All timing is measured from the $50 \%$ voltage points)


Timing Diagrams (All timing is measured from the $50 \%$ voltage points) (Continued)


Note: Read strobe must occur 8 clock periods $\left(8 / f_{\text {CLK }}\right)$ after assertion of interrupt to guarantee reset of $\overline{\text { INTR }}$.

## Typical Applications



Note: before using caps at $\mathrm{V}_{\mathrm{IN}}$ or $\mathrm{V}_{\text {REF }} / 2$,
see section 2.3.2 Input Bypass Capacitors.

Typical Applications (Continued)


Zero-Shift and Span Adjust: $\mathbf{2 V} \leq \mathrm{V}_{\mathrm{IN}} \leq 5 \mathrm{~V}$


DS005671-57

Typical Applications (Continued)

$V_{\text {REF }} / 2=256 \mathrm{mV}$

1 mV Resolution with $\mu \mathrm{P}$ Controlled Range

$\mathrm{V}_{\text {REF } / 2=128 \mathrm{mV}}$
$1 \mathrm{LSB}=1 \mathrm{mV}$
$\mathrm{V}_{\mathrm{DAC}} \leq \mathrm{V}_{\text {IN }} \leq\left(\mathrm{V}_{\mathrm{DAC}}+256 \mathrm{mV}\right)$
$0 \leq V_{\text {DAC }}<2.5 \mathrm{~V}$


Typical Applications (Continued)

Self-Clocking in Free-Running Mode


DS005671-65
*After power-up, a momentary grounding of the $\overline{\mathrm{WR}}$ input is needed to guarantee operation.

Operating with "Automotive" Ratiometric Transducers

$\mu \mathrm{P}$ Interface for Free-Running $A / D$


Ratiometric with $\mathbf{V}_{\text {REF }} / \mathbf{2}$ Forced

${ }^{*} \mathrm{~V}_{\text {IN }}(-)=0.15 \mathrm{~V}_{\mathrm{CC}}$
$15 \%$ of $\mathrm{V}_{\mathrm{CC}} \leq \mathrm{V}_{\mathrm{XDR}} \leq 85 \%$ of $\mathrm{V}_{\mathrm{CC}}$
$\mu \mathrm{P}$ Compatible Differential-Input Comparator with Pre-Set $\mathrm{V}_{\text {os }}$ (with or without Hysteresis)

*See Figure 5 to select $R$ value
DB7="1" for $\mathrm{V}_{\text {IN }}(+)>\mathrm{V}_{\text {IN }}(-)+\left(\mathrm{V}_{\text {REF }} / 2\right)$
Omit circuitry within the dotted area if
hysteresis is not needed

## Typical Applications (Continued)

*Beckman Instruments \#694-3-R10K resistor array

## Low-Cost, $\mu$ P Interfaced, Temperature-to-Digital

 Converter


${ }^{*}$ Circuit values shown are for $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+128^{\circ} \mathrm{C}$
${ }^{* * *}$ Can calibrate each sensor to allow easy replacement, then A/D can be calibrated with a pre-set input voltage.

Typical Applications (Continued)

$\mu \mathrm{P}$ Interfaced Comparator with Hysteresis


Protecting the Input


Diodes are 1N914

Typical Applications (Continued)


A Low-Cost, 3-Decade Logarithmic Converter

*LM389 transistors
A, B, C, D = LM324A quad op amp

Typical Applications (Continued)

3-Decade Logarithmic A/D Converter

$\mathrm{f}_{\mathrm{C}}=20 \mathrm{~Hz}$
Uses Chebyshev implementation for steeper roll-off unity-gain, 2nd order, low-pass filter
Adding a separate filter for each channel increases system response time if an analog multiplexer is used

Output Buffers with A/D Data Enabled

*A/D output data is updated 1 CLK period prior to assertion of INTR

Multiplexing Differential Inputs


Increasing Bus Drive and/or Reducing Time on Bus

*Allows output data to set-up at falling edge of $\overline{\mathrm{CS}}$

Typical Applications
(Continued)


Note 11: Oversample whenever possible [keep fs $>2 f(-60)$ to eliminate input frequency folding (aliasing) and to allow for the skirt response of the filter. Note 12: Consider the amplitude errors which are introduced within the passband of the filter.

70\% Power Savings by Clock Gating

(Complete shutdown takes $\approx 30$ seconds.)

## Power Savings by $A / D$ and $V_{\text {REF }}$ Shutdown



DS005671-80
*Use ADC0801, 02,03 or 05 for lowest power consumption.
Note: Logic inputs can be driven to $\mathrm{V}_{\mathrm{CC}}$ with $\mathrm{A} / \mathrm{D}$ supply at zero volts.
Buffer prevents data bus from overdriving output of $A / D$ when in shutdown mode.

## Functional Description

### 1.0 UNDERSTANDING A/D ERROR SPECS

A perfect A/D transfer characteristic (staircase waveform) is shown in Figure 1. The horizontal scale is analog input voltage and the particular points labeled are in steps of 1 LSB ( 19.53 mV with 2.5 V tied to the $\mathrm{V}_{\text {REF }} / 2 \mathrm{pin}$ ). The digital output codes that correspond to these inputs are shown as
$D-1, D$, and $D+1$. For the perfect $A / D$, not only will center-value ( $\mathrm{A}-1, \mathrm{~A}, \mathrm{~A}+1, \ldots$ ) analog inputs produce the correct output digital codes, but also each riser (the transitions between adjacent output codes) will be located $\pm 1 / 2$ LSB away from each center-value. As shown, the risers are ideal and have no width. Correct digital output codes will be provided for a range of analog input voltages that extend

## Functional Description <br> (Continued)

$\pm 1 / 2$ LSB from the ideal center-values. Each tread (the range of analog input voltage that provides the same digital output code) is therefore 1 LSB wide.
Figure 2 shows a worst case error plot for the ADC0801. All center-valued inputs are guaranteed to produce the correct output codes and the adjacent risers are guaranteed to be no closer to the center-value points than $\pm 1 / 4 \mathrm{LSB}$. In other words, if we apply an analog input equal to the center-value $\pm 1 / 4$ LSB, we guarantee that the A/D will produce the correct digital code. The maximum range of the position of the code transition is indicated by the horizontal arrow and it is guaranteed to be no more than $1 / 2$ LSB.
The error curve of Figure 3 shows a worst case error plot for the ADC0802. Here we guarantee that if we apply an analog input equal to the LSB analog voltage center-value the A/D will produce the correct digital code.

Next to each transfer function is shown the corresponding error plot. Many people may be more familiar with error plots than transfer functions. The analog input voltage to the $A / D$ is provided by either a linear ramp or by the discrete output steps of a high resolution DAC. Notice that the error is continuously displayed and includes the quantization uncertainty of the A/D. For example the error at point 1 of Figure 1 is $+1 / 2$ LSB because the digital code appeared $1 / 2$ LSB in advance of the center-value of the tread. The error plots always have a constant negative slope and the abrupt upside steps are always 1 LSB in magnitude.


Error Plot


DS005671-82
FIGURE 1. Clarifying the Error Specs of an A/D Converter
Accuracy $= \pm 0$ LSB: A Perfect A/D

FIGURE 2. Clarifying the Error Specs of an A/D Converter Accuracy $= \pm 1 / 4$ LSB

## Functional Description (Continued)



FIGURE 3. Clarifying the Error Specs of an A/D Converter
Accuracy $= \pm 1 / 2$ LSB

### 2.0 FUNCTIONAL DESCRIPTION

The ADC0801 series contains a circuit equivalent of the 256R network. Analog switches are sequenced by successive approximation logic to match the analog difference input voltage $\left[\mathrm{V}_{\mathbb{I N}}(+)-\mathrm{V}_{\mathbb{I N}}(-)\right]$ to a corresponding tap on the R network. The most significant bit is tested first and after 8 comparisons ( 64 clock cycles) a digital 8 -bit binary code (1111 1111 = full-scale) is transferred to an output latch and then an interrupt is asserted (INTR makes a high-to-low transition). A conversion in process can be interrupted by issuing a second start command. The device may be operated in the free-running mode by connecting INTR to the $\overline{\mathrm{WR}}$ input with $\overline{\mathrm{CS}}=0$. To ensure start-up under all possible conditions, an external $\overline{\mathrm{WR}}$ pulse is required during the first power-up cycle.
On the high-to-low transition of the $\overline{W R}$ input the internal SAR latches and the shift register stages are reset. As long as the $\overline{\mathrm{CS}}$ input and $\overline{W R}$ input remain low, the $\mathrm{A} / D$ will remain in a reset state. Conversion will start from 1 to 8 clock periods after at least one of these inputs makes a low-to-high transition.

A functional diagram of the A/D converter is shown in Figure 4. All of the package pinouts are shown and the major logic control paths are drawn in heavier weight lines.
The converter is started by having $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WR}}$ simultaneously low. This sets the start flip-flop (F/F) and the resulting "1" level resets the 8 -bit shift register, resets the Interrupt (INTR) F/F and inputs a " 1 " to the D flop, F/F1, which is at the input end of the 8 -bit shift register. Internal clock signals then transfer this " 1 " to the Q output of F/F1. The AND gate, G1, combines this " 1 " output with a clock signal to provide a reset signal to the start $F / F$. If the set signal is no longer present (either $\overline{W R}$ or $\overline{\mathrm{CS}}$ is a " 1 ") the start F/F is reset and the 8 -bit shift register then can have the " 1 " clocked in, which starts the conversion process. If the set signal were to still be present, this reset pulse would have no effect (both outputs of the start F/F would momentarily be at a " 1 " level) and the 8 -bit shift register would continue to be held in the reset mode. This logic therefore allows for wide $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WR}}$ signals and the converter will start after at least one of these signals returns high and the internal clocks again provide a reset signal for the start F/F.

Functional Description (Continued)


Note 13: $\overline{C S}$ shown twice for clarity.
Note 14: SAR = Successive Approximation Register.

## FIGURE 4. Block Diagram

After the " 1 " is clocked through the 8 -bit shift register (which completes the SAR search) it appears as the input to the D-type latch, LATCH 1. As soon as this " 1 " is output from the shift register, the AND gate, G2, causes the new digital word to transfer to the TRI-STATE output latches. When LATCH 1 is subsequently enabled, the Q output makes a high-to-low transition which causes the INTR F/F to set. An inverting buffer then supplies the $\overline{\mathrm{NTR}}$ input signal.
Note that this $\overline{\text { SET }}$ control of the INTR F/F remains low for 8 of the external clock periods (as the internal clocks run at $1 / 8$ of the frequency of the external clock). If the data output is continuously enabled ( $\overline{\mathrm{CS}}$ and $\overline{\mathrm{RD}}$ both held low), the INTR output will still signal the end of conversion (by a high-to-low transition), because the SET input can control the Q output of the INTR F/F even though the RESET input is constantly at a " 1 " level in this operating mode. This INTR output will therefore stay low for the duration of the SET signal, which is 8 periods of the external clock frequency (assuming the A/D is not started during this interval).
When operating in the free-running or continuous conversion mode (INTR pin tied to $\overline{W R}$ and $\overline{\mathrm{CS}}$ wired low-see also section 2.8), the START F/F is SET by the high-to-low transition of the INTR signal. This resets the SHIFT REGISTER
which causes the input to the D-type latch, LATCH 1, to go low. As the latch enable input is still present, the $\overline{\mathrm{Q}}$ output will go high, which then allows the INTR F/F to be RESET. This reduces the width of the resulting $\overline{\mathrm{NT} \text { TR }}$ output pulse to only a few propagation delays (approximately 300 ns ).
When data is to be read, the combination of both $\overline{\mathrm{CS}}$ and $\overline{\mathrm{RD}}$ being low will cause the INTR F/F to be reset and the TRI-STATE output latches will be enabled to provide the 8 -bit digital outputs.

### 2.1 Digital Control Inputs

The digital control inputs ( $\overline{\mathrm{CS}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ ) meet standard $\mathrm{T}^{2} \mathrm{~L}$ logic voltage levels. These signals have been renamed when compared to the standard A/D Start and Output Enable labels. In addition, these inputs are active low to allow an easy interface to microprocessor control busses. For non-microprocessor based applications, the $\overline{\mathrm{CS}}$ input (pin 1) can be grounded and the standard A/D Start function is obtained by an active low pulse applied at the $\overline{W R}$ input (pin 3 ) and the Output Enable function is caused by an active low pulse at the RD input (pin 2).

## Functional Description (Continued)

### 2.2 Analog Differential Voltage Inputs and Common-Mode Rejection

This A/D has additional applications flexibility due to the analog differential voltage input. The $\mathrm{V}_{\mathrm{IN}}(-)$ input (pin 7) can be used to automatically subtract a fixed voltage value from the input reading (tare correction). This is also useful in 4 $\mathrm{mA}-20 \mathrm{~mA}$ current loop conversion. In addition, common-mode noise can be reduced by use of the differential input.
The time interval between sampling $\mathrm{V}_{\mathrm{IN}}(+)$ and $\mathrm{V}_{\mathrm{IN}}(-)$ is $4-1 / 2$ clock periods. The maximum error voltage due to this slight time difference between the input voltage samples is given by:

$$
\Delta \mathrm{V}_{\mathrm{e}}(\mathrm{MAX})=\left(\mathrm{V}_{\mathrm{P}}\right)\left(2 \pi \mathrm{f}_{\mathrm{cm}}\right)\left(\frac{4.5}{\mathrm{f}_{\mathrm{CLK}}}\right)
$$

where:
$\Delta \mathrm{V}_{\mathrm{e}}$ is the error voltage due to sampling delay
$V_{P}$ is the peak value of the common-mode voltage
$\mathrm{f}_{\mathrm{cm}}$ is the common-mode frequency
As an example, to keep this error to $1 / 4 \mathrm{LSB}(\sim 5 \mathrm{mV})$ when operating with a 60 Hz common-mode frequency, $\mathrm{f}_{\mathrm{cm}}$, and using a 640 kHz A/D clock, $\mathrm{f}_{\mathrm{CLK}}$, would allow a peak value of the common-mode voltage, $\mathrm{V}_{\mathrm{P}}$, which is given by:

$$
\mathrm{V}_{\mathrm{P}}=\frac{\left[\Delta \mathrm{V}_{\mathrm{e}(\mathrm{MAX})}\left(\mathrm{f}_{\mathrm{CLK}}\right)\right]}{\left(2 \pi \mathrm{f}_{\mathrm{Cm}}\right)(4.5)}
$$

or

$$
V_{P}=\frac{\left(5 \times 10^{-3}\right)\left(640 \times 10^{3}\right)}{(6.28)(60)(4.5)}
$$

which gives

$$
V_{P} \simeq 1.9 \mathrm{~V}
$$

The allowed range of analog input voltages usually places more severe restrictions on input common-mode noise levels.
An analog input voltage with a reduced span and a relatively large zero offset can be handled easily by making use of the differential input (see section 2.4 Reference Voltage).

### 2.3 Analog Inputs

### 2.3 1 Input Current

## Normal Mode

Due to the internal switching action, displacement currents will flow at the analog inputs. This is due to on-chip stray capacitance to ground as shown in Figure 5.

$r_{\text {ON }}$ of SW 1 and SW $2 \simeq 5 \mathrm{k} \Omega$
$r=r_{O N} C_{S T R A Y} \simeq 5 \mathrm{k} \Omega \times 12 \mathrm{pF}=60 \mathrm{~ns}$
FIGURE 5. Analog Input Impedance
The voltage on this capacitance is switched and will result in currents entering the $\mathrm{V}_{\mathrm{IN}}(+)$ input pin and leaving the $\mathrm{V}_{\mathrm{IN}}(-)$ input which will depend on the analog differential input voltage levels. These current transients occur at the leading edge of the internal clocks. They rapidly decay and do not cause errors as the on-chip comparator is strobed at the end of the clock period.

## Fault Mode

If the voltage source applied to the $\mathrm{V}_{\mathrm{IN}}(+)$ or $\mathrm{V}_{\text {IN }}(-)$ pin exceeds the allowed operating range of $\mathrm{V}_{\mathrm{CC}}+50 \mathrm{mV}$, large input currents can flow through a parasitic diode to the $\mathrm{V}_{\mathrm{CC}}$ pin. If these currents can exceed the 1 mA max allowed spec, an external diode (1N914) should be added to bypass this current to the $\mathrm{V}_{\mathrm{CC}}$ pin (with the current bypassed with this diode, the voltage at the $\mathrm{V}_{\mathrm{IN}}(+)$ pin can exceed the $\mathrm{V}_{\mathrm{CC}}$ voltage by the forward voltage of this diode).

### 2.3.2 Input Bypass Capacitors

Bypass capacitors at the inputs will average these charges and cause a DC current to flow through the output resistances of the analog signal sources. This charge pumping action is worse for continuous conversions with the $\mathrm{V}_{\text {IN }}(+)$ input voltage at full-scale. For continuous conversions with a 640 kHz clock frequency with the $\mathrm{V}_{\mathrm{IN}}(+)$ input at 5 V , this DC current is at a maximum of approximately $5 \mu \mathrm{~A}$. Therefore, bypass capacitors should not be used at the analog inputs or the $V_{\text {REF }} / 2$ pin for high resistance sources ( $>1 \mathrm{k} \Omega$ ). If input bypass capacitors are necessary for noise filtering and high source resistance is desirable to minimize capacitor size, the detrimental effects of the voltage drop across this input resistance, which is due to the average value of the input current, can be eliminated with a full-scale adjustment while the given source resistor and input bypass capacitor are both in place. This is possible because the average value of the input current is a precise linear function of the differential input voltage.

### 2.3.3 Input Source Resistance

Large values of source resistance where an input bypass capacitor is not used, will not cause errors as the input currents settle out prior to the comparison time. If a low pass filter is required in the system, use a low valued series resistor ( $\leq 1 \mathrm{k} \Omega$ ) for a passive RC section or add an op amp RC active low pass filter. For low source resistance applications, ( $\leq 1 \mathrm{k} \Omega$ ), a $0.1 \mu \mathrm{~F}$ bypass capacitor at the inputs will prevent noise pickup due to series lead inductance of a long

## Functional Description (Continued)

wire. A $100 \Omega$ series resistor can be used to isolate this capacitor - both the $R$ and $C$ are placed outside the feedback loop-from the output of an op amp, if used.

### 2.3.4 Noise

The leads to the analog inputs (pins 6 and 7) should be kept as short as possible to minimize input noise coupling. Both noise and undesired digital clock coupling to these inputs can cause system errors. The source resistance for these inputs should, in general, be kept below $5 \mathrm{k} \Omega$. Larger values of source resistance can cause undesired system noise pickup. Input bypass capacitors, placed from the analog inputs to ground, will eliminate system noise pickup but can create analog scale errors as these capacitors will average the transient input switching currents of the A/D (see section 2.3.1.). This scale error depends on both a large source resistance and the use of an input bypass capacitor. This error can be eliminated by doing a full-scale adjustment of the $A / D$ (adjust $V_{\text {REF }} / 2$ for a proper full-scale reading - see section 2.5.2 on Full-Scale Adjustment) with the source resistance and input bypass capacitor in place.

### 2.4 Reference Voltage

### 2.4.1 Span Adjust

For maximum applications flexibility, these $\mathrm{A} / \mathrm{D}$ s have been designed to accommodate a $5 \mathrm{~V}_{\mathrm{DC}}, 2.5 \mathrm{~V}_{\mathrm{DC}}$ or an adjusted voltage reference. This has been achieved in the design of the IC as shown in Figure 6.


FIGURE 6. The $\mathrm{V}_{\text {Reference }}$ Design on the IC

Notice that the reference voltage for the IC is either $1 / 2$ of the voltage applied to the $\mathrm{V}_{\mathrm{Cc}}$ supply pin, or is equal to the voltage that is externally forced at the $\mathrm{V}_{\text {REF }} / 2$ pin. This allows for a ratiometric voltage reference using the $\mathrm{V}_{\mathrm{Cc}}$ supply, a 5 $\mathrm{V}_{\mathrm{DC}}$ reference voltage can be used for the $\mathrm{V}_{\mathrm{Cc}}$ supply or a voltage less than $2.5 \mathrm{~V}_{\mathrm{DC}}$ can be applied to the $\mathrm{V}_{\mathrm{REF}} / 2$ input for increased application flexibility. The internal gain to the $\mathrm{V}_{\mathrm{REF}} / 2$ input is 2 , making the full-scale differential input voltage twice the voltage at pin 9.
An example of the use of an adjusted reference voltage is to accommodate a reduced span-or dynamic voltage range of the analog input voltage. If the analog input voltage were to range from $0.5 \mathrm{~V}_{\mathrm{DC}}$ to $3.5 \mathrm{~V}_{\mathrm{DC}}$, instead of 0 V to $5 \mathrm{~V}_{\mathrm{DC}}$, the span would be 3 V as shown in Figure 7 . With $0.5 \mathrm{~V}_{\mathrm{DC}}$ applied to the $\mathrm{V}_{\mathrm{IN}}(-)$ pin to absorb the offset, the reference voltage can be made equal to $1 / 2$ of the 3 V span or $1.5 \mathrm{~V}_{\mathrm{DC}}$. The $\mathrm{A} / \mathrm{D}$ now will encode the $\mathrm{V}_{\mathrm{IN}}(+)$ signal from 0.5 V to 3.5 V with the 0.5 V input corresponding to zero and the $3.5 \mathrm{~V}_{\mathrm{DC}}$ input corresponding to full-scale. The full 8 bits of resolution are therefore applied over this reduced analog input voltage range.

### 2.4.2 Reference Accuracy Requirements

The converter can be operated in a ratiometric mode or an absolute mode. In ratiometric converter applications, the magnitude of the reference voltage is a factor in both the output of the source transducer and the output of the A/D converter and therefore cancels out in the final digital output code. The ADC0805 is specified particularly for use in ratiometric applications with no adjustments required. In absolute conversion applications, both the initial value and the temperature stability of the reference voltage are important factors in the accuracy of the $A / D$ converter. For $\mathrm{V}_{\text {REF }} / 2$ voltages of $2.4 \mathrm{~V}_{\mathrm{DC}}$ nominal value, initial errors of $\pm 10 \mathrm{mV}_{\mathrm{DC}}$ will cause conversion errors of $\pm 1$ LSB due to the gain of 2 of the $\mathrm{V}_{\mathrm{REF}} / 2$ input. In reduced span applications, the initial value and the stability of the $\mathrm{V}_{\mathrm{REF}} / 2$ input voltage become even more important. For example, if the span is reduced to 2.5 V , the analog input LSB voltage value is correspondingly reduced from 20 mV (5V span) to 10 mV and 1 LSB at the $\mathrm{V}_{\text {REF }} / 2$ input becomes 5 mV . As can be seen, this reduces the allowed initial tolerance of the reference voltage and requires correspondingly less absolute change with temperature variations. Note that spans smaller than 2.5 V place even tighter requirements on the initial accuracy and stability of the reference source.
In general, the magnitude of the reference voltage will require an initial adjustment. Errors due to an improper value of reference voltage appear as full-scale errors in the A/D transfer function. IC voltage regulators may be used for references if the ambient temperature changes are not excessive. The LM336B 2.5V IC reference diode (from National Semiconductor) has a temperature stability of 1.8 mV typ ( 6 mV max) over $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}$. Other temperature range parts are also available.

Functional Description (Continued)

a) Analog Input Signal Example

*Add if $\mathrm{V}_{\mathrm{REF}} / 2 \leq 1 \mathrm{~V}_{\mathrm{DC}}$ with LM358 to draw 3 mA to ground.
b) Accommodating an Analog Input from 0.5 V (Digital Out $=00_{\mathrm{HEX}}$ ) to 3.5 V (Digital Out= FF $_{\text {HEx }}$ )

FIGURE 7. Adapting the A/D Analog Input Voltages to Match an Arbitrary Input Signal Range

### 2.5 Errors and Reference Voltage Adjustments

### 2.5.1 Zero Error

The zero of the A/D does not require adjustment. If the minimum analog input voltage value, $\mathrm{V}_{\mathrm{IN}_{(\mathrm{MIN})} \text {, is not ground, }}$ a zero offset can be done. The converter can be made to output 00000000 digital code for this minimum input voltage by biasing the $A / D V_{\operatorname{IN}}(-)$ input at this $\mathrm{V}_{\operatorname{IN}(\operatorname{MIN})}$ value (see Applications section). This utilizes the differential mode operation of the A/D.
The zero error of the A/D converter relates to the location of the first riser of the transfer function and can be measured by grounding the $\mathrm{V}_{\mathrm{IN}}(-)$ input and applying a small magnitude positive voltage to the $\mathrm{V}_{\mathrm{IN}}(+)$ input. Zero error is the difference between the actual DC input voltage that is necessary to just cause an output digital code transition from 00000000 to 00000001 and the ideal $1 / 2$ LSB value ( $1 / 2 \mathrm{LSB}=9.8 \mathrm{mV}$ for $\left.\mathrm{V}_{\mathrm{REF}} / 2=2.500 \mathrm{~V}_{\mathrm{DC}}\right)$.

### 2.5.2 Full-Scale

The full-scale adjustment can be made by applying a differential input voltage that is $11 / 2$ LSB less than the desired analog full-scale voltage range and then adjusting the magnitude of the $\mathrm{V}_{\text {REF }} / 2$ input (pin 9 or the $\mathrm{V}_{\mathrm{CC}}$ supply if pin 9 is not used) for a digital output code that is just changing from 11111110 to 11111111.

### 2.5.3 Adjusting for an Arbitrary Analog Input Voltage Range

If the analog zero voltage of the A/D is shifted away from ground (for example, to accommodate an analog input signal that does not go to ground) this new zero reference should be properly adjusted first. A $\mathrm{V}_{\mathrm{IN}}(+)$ voltage that equals this desired zero reference plus $1 / 2$ LSB (where the LSB is calculated for the desired analog span, 1 LSB=analog span/
256) is applied to pin 6 and the zero reference voltage at pin 7 should then be adjusted to just obtain the $00_{\text {HEX }}$ to $01_{\text {HEX }}$ code transition.
The full-scale adjustment should then be made (with the proper $\mathrm{V}_{\mathbb{I N}}(-)$ voltage applied) by forcing a voltage to the $\mathrm{V}_{\text {IN }}(+)$ input which is given by:

$$
\mathrm{V}_{\mathrm{IN}}(+) \text { fs adj }=\mathrm{V}_{\mathrm{MAX}}-1.5\left[\frac{\left(\mathrm{~V}_{\mathrm{MAX}}-\mathrm{V}_{\mathrm{MIN}}\right)}{256}\right]
$$

where:
$\mathrm{V}_{\mathrm{MAX}}=$ The high end of the analog input range and
$\mathrm{V}_{\text {MIN }}=$ the low end (the offset zero) of the analog range. (Both are ground referenced.)
The $\mathrm{V}_{\text {REF }} / 2$ (or $\mathrm{V}_{\mathrm{CC}}$ ) voltage is then adjusted to provide a code change from $\mathrm{FE}_{\text {HEX }}$ to $\mathrm{FF}_{\text {HEX }}$. This completes the adjustment procedure.

### 2.6 Clocking Option

The clock for the A/D can be derived from the CPU clock or an external RC can be added to provide self-clocking. The CLK IN (pin 4) makes use of a Schmitt trigger as shown in Figure 8.

Functional Description (Continued)


DS005671-17
$\mathrm{f}_{\mathrm{CLK}} \cong \frac{1}{1.1 \mathrm{RC}}$
$R \cong 10 \mathrm{k} \Omega$

## FIGURE 8. Self-Clocking the A/D

Heavy capacitive or DC loading of the clock R pin should be avoided as this will disturb normal converter operation. Loads less than 50 pF , such as driving up to $7 \mathrm{~A} / \mathrm{D}$ converter clock inputs from a single clock $R$ pin of 1 converter, are allowed. For larger clock line loading, a CMOS or low power TTL buffer or PNP input logic should be used to minimize the loading on the clock R pin (do not use a standard TTL buffer).

### 2.7 Restart During a Conversion

If the $A / D$ is restarted ( $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WR}}$ go low and return high) during a conversion, the converter is reset and a new conversion is started. The output data latch is not updated if the conversion in process is not allowed to be completed, therefore the data of the previous conversion remains in this latch. The INTR output simply remains at the " 1 " level.

### 2.8 Continuous Conversions

For operation in the free-running mode an initializing pulse should be used, following power-up, to ensure circuit operation. In this application, the $\overline{\mathrm{CS}}$ input is grounded and the $\overline{\mathrm{WR}}$ input is tied to the $\overline{\mathrm{NNTR}}$ output. This $\overline{\mathrm{WR}}$ and $\overline{\mathrm{NTR}}$ node should be momentarily forced to logic low following a power-up cycle to guarantee operation.

### 2.9 Driving the Data Bus

This MOS A/D, like MOS microprocessors and memories, will require a bus driver when the total capacitance of the data bus gets large. Other circuitry, which is tied to the data bus, will add to the total capacitive loading, even in TRI-STATE (high impedance mode). Backplane bussing also greatly adds to the stray capacitance of the data bus.
There are some alternatives available to the designer to handle this problem. Basically, the capacitive loading of the data bus slows down the response time, even though DC specifications are still met. For systems operating with a relatively slow CPU clock frequency, more time is available in which to establish proper logic levels on the bus and therefore higher capacitive loads can be driven (see typical characteristics curves).
At higher CPU clock frequencies time can be extended for I/O reads (and/or writes) by inserting wait states (8080) or using clock extending circuits (6800).
Finally, if time is short and capacitive loading is high, external bus drivers must be used. These can be TRI-STATE buffers
(low power Schottky such as the DM74LS240 series is recommended) or special higher drive current products which are designed as bus drivers. High current bipolar bus drivers with PNP inputs are recommended.

### 2.10 Power Supplies

Noise spikes on the $\mathrm{V}_{\mathrm{Cc}}$ supply line can cause conversion errors as the comparator will respond to this noise. A low inductance tantalum filter capacitor should be used close to the converter $\mathrm{V}_{\mathrm{CC}}$ pin and values of $1 \mu \mathrm{~F}$ or greater are recommended. If an unregulated voltage is available in the system, a separate LM340LAZ-5.0, TO-92, 5V voltage regulator for the converter (and other analog circuitry) will greatly reduce digital noise on the $\mathrm{V}_{\mathrm{CC}}$ supply.

### 2.11 Wiring and Hook-Up Precautions

Standard digital wire wrap sockets are not satisfactory for breadboarding this A/D converter. Sockets on PC boards can be used and all logic signal wires and leads should be grouped and kept as far away as possible from the analog signal leads. Exposed leads to the analog inputs can cause undesired digital noise and hum pickup, therefore shielded leads may be necessary in many applications.
A single point analog ground that is separate from the logic ground points should be used. The power supply bypass capacitor and the self-clocking capacitor (if used) should both be returned to digital ground. Any $\mathrm{V}_{\mathrm{REF}} / 2$ bypass capacitors, analog input filter capacitors, or input signal shielding should be returned to the analog ground point. A test for proper grounding is to measure the zero error of the A/D converter. Zero errors in excess of $1 / 4$ LSB can usually be traced to improper board layout and wiring (see section 2.5.1 for measuring the zero error).

### 3.0 TESTING THE A/D CONVERTER

There are many degrees of complexity associated with testing an A/D converter. One of the simplest tests is to apply a known analog input voltage to the converter and use LEDs to display the resulting digital output code as shown in Figure 9. For ease of testing, the $\mathrm{V}_{\text {REF }} / 2$ (pin 9) should be supplied with $2.560 \mathrm{~V}_{\mathrm{DC}}$ and a $\mathrm{V}_{\mathrm{CC}}$ supply voltage of $5.12 \mathrm{~V}_{\mathrm{DC}}$ should be used. This provides an LSB value of 20 mV .
If a full-scale adjustment is to be made, an analog input voltage of $5.090 \mathrm{~V}_{\mathrm{DC}}\left(5.120-1 \frac{1}{2} \mathrm{LSB}\right)$ should be applied to the $\mathrm{V}_{\mathbb{I N}}(+)$ pin with the $\mathrm{V}_{\mathbb{I N}}(-)$ pin grounded. The value of the $\mathrm{V}_{\mathrm{REF}} / 2$ input voltage should then be adjusted until the digital output code is just changing from 11111110 to 11111111. This value of $\mathrm{V}_{\text {REF }} / 2$ should then be used for all the tests.
The digital output LED display can be decoded by dividing the 8 bits into 2 hex characters, the 4 most significant (MS) and the 4 least significant (LS). Table 1 shows the fractional binary equivalent of these two 4 -bit groups. By adding the voltages obtained from the "VMS" and "VLS" columns in Table 1, the nominal value of the digital display (when $\mathrm{V}_{\mathrm{REF}} / 2=2.560 \mathrm{~V}$ ) can be determined. For example, for an output LED display of 10110110 or B 6 (in hex), the voltage values from the table are $3.520+0.120$ or $3.640 \mathrm{~V}_{\mathrm{DC}}$. These voltage values represent the center-values of a perfect $A / D$ converter. The effects of quantization error have to be accounted for in the interpretation of the test results.

Functional Description (Continued)


FIGURE 9. Basic A/D Tester

For a higher speed test system, or to obtain plotted data, a digital-to-analog converter is needed for the test set-up. An accurate 10 -bit DAC can serve as the precision voltage source for the A/D. Errors of the A/D under test can be expressed as either analog voltages or differences in 2 digital words.
A basic A/D tester that uses a DAC and provides the error as an analog output voltage is shown in Figure 8. The 2 op amps can be eliminated if a lab DVM with a numerical subtraction feature is available to read the difference voltage, "A-C", directly. The analog input voltage can be supplied by a low frequency ramp generator and an X-Y plotter can be used to provide analog error ( Y axis) versus analog input (X axis).
For operation with a microprocessor or a computer-based test system, it is more convenient to present the errors digitally. This can be done with the circuit of Figure 11, where the output code transitions can be detected as the 10 -bit DAC is incremented. This provides $1 / 4 \mathrm{LSB}$ steps for the 8 -bit A/D under test. If the results of this test are automatically plotted with the analog input on the X axis and the error (in LSB's) as the Y axis, a useful transfer function of the A/D under test results. For acceptance testing, the plot is not necessary and the testing speed can be increased by establishing internal limits on the allowed error for each code.

### 4.0 MICROPROCESSOR INTERFACING

To dicuss the interface with 8080A and 6800 microprocessors, a common sample subroutine structure is used. The microprocessor starts the $A / D$, reads and stores the results of 16 successive conversions, then returns to the user's program. The 16 data bytes are stored in 16 successive memory locations. All Data and Addresses will be given in hexadecimal form. Software and hardware details are provided separately for each type of microprocessor.

### 4.1 Interfacing 8080 Microprocessor Derivatives (8048, 8085)

This converter has been designed to directly interface with derivatives of the 8080 microprocessor. The A/D can be mapped into memory space (using standard memory address decoding for $\overline{\mathrm{CS}}$ and the $\overline{\mathrm{MEMR}}$ and $\overline{\mathrm{MEMW}}$ strobes) or it can be controlled as an I/O device by using the I/O R and $\overline{1 / O ~ W}$ strobes and decoding the address bits $\mathrm{A} 0 \rightarrow \mathrm{~A} 7$ (or address bits A8 $\rightarrow$ A15 as they will contain the same 8 -bit address information) to obtain the $\overline{\mathrm{CS}}$ input. Using the I/O space provides 256 additional addresses and may allow a simpler 8 -bit address decoder but the data can only be input to the accumulator. To make use of the additional memory reference instructions, the $A / D$ should be mapped into memory space. An example of an A/D in I/O space is shown in Figure 12.

Functional Description


FIGURE 10. A/D Tester with Analog Error Output


FIGURE 11. Basic "Digital" A/D Tester
TABLE 1. DECODING THE DIGITAL OUTPUT LEDs


Note 15: Display Output=VMS Group + VLS Group

Functional Description (Continued)


Note 16: *Pin numbers for the DP8228 system controller, others are INS8080A.
Note 17: Pin 23 of the INS8228 must be tied to +12 V through a $1 \mathrm{k} \Omega$ resistor to generate the RST 7
instruction when an interrupt is acknowledged as required by the accompanying sample program.
FIGURE 12. ADC0801_INS8080A CPU Interface

Functional Description (Continued)

SAMPLE PROGRAM FOR Figure 12 ADC0801-INS8080A CPU INTERFACE

| 0038 | C3 0003 | RST 7 : | JMP LDDATA |  |
| :---: | :---: | :---: | :---: | :---: |
| $\bullet$ | - | - |  |  |
| - | - | - |  |  |
| 0100 | 210002 | START : | LXI H 0200H | ; HL pair will point to |
|  |  |  |  | ; datastorage locations |
| 0103 | 310004 | RETURN: | LXI SP 0400H | ; Initializestack pointer (Note 1) |
| 0106 | 7 D |  | MOV A, L | ; Test \# of bytes entered |
| 0107 | FE OF |  | CPI OFH | ; If \# = 16. JMP to |
| 0109 | CA 1301 |  | JZ CONT | ; user program |
| O10C | D3 E0 |  | OUT EOH | ; Start A/D |
| OlOE | FB |  | EI | ; Enable interrupt |
| 010F | 00 | L00P : | NOP | ; Loop until end of |
| 0110 | C3 OF 01 |  | JMP L00P | ; conversion |
| 0113 | - | CONT : | - |  |
| - | - | - | - |  |
| - | - | (User program to | $\bullet$ |  |
| - | - | process data) | - |  |
| - | $\bullet$ | - | $\bullet$ |  |
| - | - | - | - |  |
| 0300 | DB E0 | LD DATA : | IN EOH | ; Load data into accumulator |
| 0302 | 77 |  | MOV M, A | ; Store data |
| 0303 | 23 |  | INX H | ; Increment storage pointer |
| 0304 | C3 0301 |  | JMP RETURN |  |

Note 18: The stack pointer must be dimensioned because a RST 7 instruction pushes the PC onto the stack.
Note 19: All address used were arbitrarily chosen.

The standard control bus signals of the $8080 \overline{\mathrm{CS}}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ ) can be directly wired to the digital control inputs of the A/D and the bus timing requirements are met to allow both starting the converter and outputting the data onto the data bus. A bus driver should be used for larger microprocessor systems where the data bus leaves the PC board and/or must drive capacitive loads larger than 100 pF .

### 4.1.1 Sample 8080A CPU Interfacing Circuitry and Program

The following sample program and associated hardware shown in Figure 12 may be used to input data from the converter to the INS8080A CPU chip set (comprised of the INS8080A microprocessor, the INS8228 system controller and the INS8224 clock generator). For simplicity, the A/D is controlled as an I/O device, specifically an 8-bit bi-directional port located at an arbitrarily chosen port address, EO. The TRI-STATE output capability of the A/D eliminates the need for a peripheral interface device, however address decoding is still required to generate the appropriate $\overline{\mathrm{CS}}$ for the converter.

It is important to note that in systems where the A/D converter is 1 -of-8 or less I/O mapped devices, no address decoding circuitry is necessary. Each of the 8 address bits (A0 to A7) can be directly used as $\overline{\mathrm{CS}}$ inputs - one for each I/O device.

### 4.1.2 INS8048 Interface

The INS8048 interface technique with the ADC0801 series (see Figure 13) is simpler than the 8080A CPU interface. There are 24 I/O lines and three test input lines in the 8048. With these extra I/O lines available, one of the I/O lines (bit 0 of port 1 ) is used as the chip select signal to the A/D, thus eliminating the use of an external address decoder. Bus control signals $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ and $\overline{\mathrm{NT}}$ of the 8048 are tied directly to the A/D. The 16 converted data words are stored at on-chip RAM locations from 20 to 2F (Hex). The RD and WR signals are generated by reading from and writing into a dummy address, respectively. A sample interface program is shown below.

## Functional Description (Continued)



FIGURE 13. INS8048 Interface

SAMPLE PROGRAM FOR Figure 13 INS8048 INTERFACE

| 0410 |  | JMP | 10H | : Program starts at addr 10 |
| :---: | :---: | :---: | :---: | :---: |
|  |  | ORG | 3H |  |
| 0450 |  | JMP | 50 H | ; Interrupt jump vector |
|  |  | ORG | 10H | ; Main program |
| 99 FE |  | ANL | Pl, \#OFEH | ; Chip select |
| 81 |  | MOVX | A, @R1 | ; Readinthe lst data <br> ; to reset the intr |
| 8901 | START: | ORL | Pl, \#l | ; Set port pinhigh |
| B8 20 |  | MOV | R0, \#20H | ; Data address |
| B9 FF |  | MOV | Rl, \#OFFH | ; Dummy address |
| BA 10 |  | MOV | R2, \#10H | ; Counter for 16 bytes |
| 23 FF | AGAIN: | MOV | A, \#OFFH | ; Set ACC for intrloop |
| 99 FE |  | ANL | Pl, \#OFEH | ; Send CS (bit 0 of Pl) |
| 91 |  | MOVX | @R1, A | ; Send WR out |
| 05 |  | EN | I | ; Enable interrupt |
| 9621 | L00P : | JNZ | L00P | ; Wait for interrupt |
| EA 1B |  | DJNZ | R2, AGAIN | ; If 16 bytes are read |
| 00 |  | NOP |  | ; go to user's program |
| 00 |  | NOP |  |  |
|  |  | ORG | 50 H |  |
| 81 | INDATA: | MOVX | A, @Rl | ; Input data, CS still low |
| A0 |  | MOV | @RO, A | ; Store inmemory |
| 18 |  | INC | RO | ; Increment storage counter |
| 8901 |  | ORL | Pl, \#l | ; Reset CS signal |
| 27 |  | CLR | A | ; Clear ACC to get out of |
| 93 |  | RETR |  | ; the interrupt loop |

### 4.2 Interfacing the Z-80

The Z-80 control bus is slightly different from that of the 8080. General $\overline{R D}$ and $\overline{W R}$ strobes are provided and separate memory request, $\overline{M R E Q}$, and I/O request, $\overline{\mathrm{IORQ}}$, signals are used which have to be combined with the generalized strobes to provide the equivalent 8080 signals. An advantage of operating the A/D in I/O space with the Z-80 is that the CPU will automatically insert one wait state (the $\overline{\mathrm{RD}}$ and $\overline{W R}$ strobes are extended one clock period) to allow more time for the I/O devices to respond. Logic to map the A/D in I/O space is shown in Figure 14.


FIGURE 14. Mapping the $A / D$ as an I/O Device for Use with the Z-80 CPU

Additional I/O advantages exist as software DMA routines are available and use can be made of the output data transfer which exists on the upper 8 address lines (A8 to

## Functional Description <br> (Continued)

A15) during I/O input instructions. For example, MUX channel selection for the A/D can be accomplished with this operating mode.

### 4.3 Interfacing 6800 Microprocessor Derivatives (6502, etc.)

The control bus for the 6800 microprocessor derivatives does not use the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ strobe signals. Instead it employs a single $\mathrm{R} / \overline{\mathrm{W}}$ line and additional timing, if needed, can be derived fom the $\phi 2$ clock. All I/O devices are memory mapped in the 6800 system, and a special signal, VMA, indicates that the current address is valid. Figure 15 shows an interface schematic where the A/D is memory mapped in the 6800 system. For simplicity, the $\overline{C S}$ decoding is shown using $1 / 2$ DM8092. Note that in many 6800 systems, an already decoded $\overline{4 / 5}$ line is brought out to the common bus at pin 21 . This can be tied directly to the $\overline{C S}$ pin of the $A / D$, provided that no other devices are addressed at HX ADDR: 4 XXX or 5 XXX .
The following subroutine performs essentially the same function as in the case of the 8080A interface and it can be called from anywhere in the user's program.
In Figure 16 the ADC0801 series is interfaced to the M6800 microprocessor through (the arbitrarily chosen) Port B of the MC6820 or MC6821 Peripheral Interface Adapter, (PIA). Here the $\overline{C S}$ pin of the A/D is grounded since the PIA is
already memory mapped in the M6800 system and no $\overline{\mathrm{CS}}$ decoding is necessary. Also notice that the A/D output data lines are connected to the microprocessor bus under program control through the PIA and therefore the A/D $\overline{\mathrm{RD}}$ pin can be grounded.
A sample interface program equivalent to the previous one is shown below Figure 16. The PIA Data and Control Registers of Port B are located at HEX addresses 8006 and 8007, respectively.

### 5.0 GENERAL APPLICATIONS

The following applications show some interesting uses for the A/D. The fact that one particular microprocessor is used is not meant to be restrictive. Each of these application circuits would have its counterpart using any microprocessor that is desired.

### 5.1 Multiple ADC0801 Series to MC6800 CPU Interface

To transfer analog data from several channels to a single microprocessor system, a multiple converter scheme presents several advantages over the conventional multiplexer single-converter approach. With the ADC0801 series, the differential inputs allow individual span adjustment for each channel. Furthermore, all analog input channels are sensed simultaneously, which essentially divides the microprocessor's total system servicing time by the number of channels, since all conversions occur simultaneously. This scheme is shown in Figure 17.


Note 20: Numbers in parentheses refer to MC6800 CPU pin out.
Note 21: Number or letters in brackets refer to standard M6800 system common bus code.
FIGURE 15. ADC0801-MC6800 CPU Interface

Functional Description
(Continued)

SAMPLE PROGRAM FOR Figure 15 ADC0801-MC6800 CPU INTERFACE

| 0010 | DF 36 | Datain | STX | TEMP2 | ; Save contents of X |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0012 | CE 002 C |  | LDX | \#\$002C | ; Upon IRQ low CPU |
| 0015 | FFFFF8 |  | STX | \$FFF8 | ; jumps to 002C |
| 0018 | B7 5000 |  | STAA | \$5000 | ; Start ADC0801 |
| 001B | OE |  | CLI |  |  |
| 001C | 3E | CONVRT | WAI |  | ; Wait for interrupt |
| 001D | DE 34 |  | LDX | TEMP1 |  |
| 001F | 8C 02 OF |  | CPX | \#\$020F | ; Is Pinal data stored? |
| 0022 | 2714 |  | BEQ | ENDP |  |
| 0024 | B7 5000 |  | StAA | \$5000 | ; Restarts ADC0801 |
| 0027 | 08 |  | INX |  |  |
| 0028 | DF 34 |  | STX | TEMP1 |  |
| 002A | 20 FO |  | BRA | CONVRT |  |
| 002C | DE 34 | INTRPT | LDX | TEMPI |  |
| 002E | B6 5000 |  | LDAA | \$5000 | ; Read data |
| 0031 | A7 00 |  | STAA | X | ; Store it at X |
| 0033 | 3B |  | RTI |  |  |
| 0034 | 0200 | TEMP1 | FDB | \$0200 | ; Starting address for <br> ; data storage |
| 0036 | 0000 | TEMP2 | FDB | \$0000 |  |
| 0038 | CE 0200 | ENDP | LDX | \#\$0200 | ; Reinitialize TEMPI |
| 003B | DF 34 |  | STX | TEMP1 |  |
| 003D | DE 36 |  | LDX | TEMP2 |  |
| 003F | 39 |  | RTS |  | ; Return Prom subroutine <br> ; Touser's program |

DS005671-A1
Note 22: In order for the microprocessor to service subroutines and interrupts, the stack pointer must be dimensioned in the user's program.


FIGURE 16. ADC0801-MC6820 PIA Interface

SAMPLE PROGRAM FOR Figure 16 ADC0801-MC6820 PIA INTERFACE

| 0010 | CE 0038 | Datain | LDX | \#\$0038 | ; Upon IRQ low CPU |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0013 | FFFFF8 |  | STX | \$FFF8 | ; jumps to 0038 |
| 0016 | B6 8006 |  | LDAA | PIAORB | ; Clear possible $\overline{\text { IRQ Plags }}$ |
| 0019 | 4F |  | CLRA |  |  |
| 001A | B7 8007 |  | STAA | PIACRB |  |
| 001D | B7 8006 |  | STAA | PIAORB | ; Set Port B as input |
| 0020 | OE |  | CLI |  |  |
| 0021 | C6 34 |  | LDAB | \#\$34 |  |
| 0023 | 86 3D |  | LDAA | \#\$3D |  |
| 0025 | F7 8007 | CONVRT | STAB | PIACRB | ; Starts ADC0801 |
| 0028 | B7 8007 |  | STAA | PIACRB |  |
| 002B | 3E |  | WAI |  | ; Wait for interrupt |
| 002C | DE 40 |  | LDX | TEMP1 |  |
| 002E | 8C 020 F |  | CPX | \#\$020F | ; Is Pinal data stored? |
| 0031 | 27 0F |  | BEQ | ENDP |  |
| 0033 | 08 |  | INX |  |  |
| 0034 | DF 40 |  | STX | TEMP1 |  |
| 0036 | 20 ED |  | BRA | CONVRT |  |
| 0038 | DE 40 | INTRPT | LDX | TEMP1 |  |
| 003A | B6 8006 |  | LDAA | PIAORB | ; Read data in |
| 003D | A7 00 |  | STAA | X | ; Store it at X |
| 003F | 3B |  | RTI |  |  |
| 0040 | 0200 | TEMP1 | FDB | \$0200 | ; Starting address for <br> ; data storage |
| 0042 | CE 0200 | ENDP | LDX | \#\$0200 | ; Reinitialize TEMPI |
| 0045 | DF 40 |  | STX | TEMPI |  |
| 0047 | 39 |  | RTS |  | ; Return Prom subroutine |
|  |  | PIAORB | EQU | \$8006 | ; To user's program |
|  |  | PIACRB | EQU | \$8007 |  |

CPU, starts all the converters simultaneously and waits for the interrupt signal. Upon receiving the interrupt, it reads the converters (from HEX addresses 5000 through 5007) and stores the data successively at (arbitrarily chosen) HEX addresses 0200 to 0207, before returning to the user's program. All CPU registers then recover the original data they had before servicing DATA IN.

### 5.2 Auto-Zeroed Differential Transducer Amplifier and A/D Converter

The differential inputs of the ADC0801 series eliminate the need to perform a differential to single ended conversion for a differential transducer. Thus, one op amp can be eliminated since the differential to single ended conversion is provided by the differential input of the ADC0801 series. In general, a transducer preamp is required to take advantage of the full $\mathrm{A} / \mathrm{D}$ converter input dynamic range.

The following schematic and sample subroutine (DATA IN) may be used to interface (up to) 8 ADC0801's directly to the MC6800 CPU. This scheme can easily be extended to allow the interface of more converters. In this configuration the converters are (arbitrarily) located at HEX address 5000 in the MC6800 memory space. To save components, the clock signal is derived from just one RC pair on the first converter. This output drives the other A/Ds.
All the converters are started simultaneously with a STORE instruction at HEX address 5000. Note that any other HEX address of the form 5XXX will be decoded by the circuit, pulling all the $\overline{\mathrm{CS}}$ inputs low. This can easily be avoided by using a more definitive address decoding scheme. All the interrupts are ORed together to insure that all A/Ds have completed their conversion before the microprocessor is interrupted.
The subroutine, DATA IN, may be called from anywhere in the user's program. Once called, this routine initializes the

Functional Description (Continued)


Note 23: Numbers in parentheses refer to MC6800 CPU pin out.
Note 24: Numbers of letters in brackets refer to standard M6800 system common bus code.
FIGURE 17. Interfacing Multiple A/Ds in an MC6800 System

Functional Description (Continued)

SAMPLE PROGRAM FOR Figure 17 INTERFACING MULTIPLE A/D's IN AN MC6800 SYSTEM

| ADDRESS | HEX CODE |  | MNEMONICS |  |
| :--- | :--- | :--- | :--- | :--- |
| 0010 | DF 44 | DATAIN | STX | TEMP | | COMMENTS |
| :--- |
| ; Save Contents of X |

SAMPLE PROGRAM FOR Figure 17 INTERFACING MULTIPLE A/D's IN AN MC6800 SYSTEM

| ADDRESS | HEX CODE | MNEMONICS |  |  |
| :--- | :--- | :--- | :--- | :--- |
| 0033 | A7 00 |  | STAA | X |
| 0035 | $8 C 0207$ |  | CPX | \#\$0207 |
| 0038 | 2705 |  | BEQ | RETURN |
| 003A | 08 |  | INX |  |
| 003B | DF 42 |  | STX | INDEX2 |
| $003 D$ | 20 EB |  | BRA | INTRPT |
| $003 F$ | $3 B$ | RETURN | RTI |  |
| 0040 | 5000 | INDEXI | FDB | $\$ 5000$ |
| 0042 | 0200 | INDEX2 | FDB | $\$ 0200$ |
| 0044 | 0000 | TEMP | FDB | $\$ 0000$ |

## COMMENTS

```
; Store data at X
; Have all A/D's been read?
; Yes: branch to RETURN
; No: increment X by one
; X }->\mathrm{ INDEX2
; Branch to 002A
; Starting address for A/D
; Starting address for data storage
```

Note 25: In order for the microprocessor to service subroutines and interrupts, the stack pointer must be dimensioned in the user's program.

For amplification of DC input signals, a major system error is the input offset voltage of the amplifiers used for the preamp. Figure 18 is a gain of 100 differential preamp whose offset voltage errors will be cancelled by a zeroing subroutine which is performed by the INS8080A microprocessor system. The total allowable input offset voltage error for this preamp is only $50 \mu \mathrm{~V}$ for $1 / 4 \mathrm{LSB}$ error. This would obviously require very precise amplifiers. The expression for the differential output voltage of the preamp is:

where $I_{x}$ is the current through resistor $R_{x}$. All of the offset error terms can be cancelled by making $\pm I_{x} R_{X}=V_{\text {OS } 1}+$ $\mathrm{V}_{\mathrm{OS3}}-\mathrm{V}_{\mathrm{OS} 2}$. This is the principle of this auto-zeroing scheme.
The INS8080A uses the 3 I/O ports of an INS8255 Programable Peripheral Interface (PPI) to control the auto zeroing and input data from the ADC0801 as shown in Figure 19. The PPI is programmed for basic I/O operation (mode 0 ) with Port A being an input port and Ports B and C being output ports. Two bits of Port C are used to alternately open or close the 2 switches at the input of the preamp. Switch SW1 is closed to force the preamp's differential input to be zero during the zeroing subroutine and then opened and SW2 is then closed for conversion of the actual differential input signal. Using 2 switches in this manner eliminates concern for the ON resistance of the switches as they must conduct only the input bias current of the input amplifiers.
Output Port B is used as a successive approximation register by the 8080 and the binary scaled resistors in series with each output bit create a D/A converter. During the zeroing subroutine, the voltage at $\mathrm{V}_{\mathrm{x}}$ increases or decreases as required to make the differential output voltage equal to zero. This is accomplished by ensuring that the voltage at the output of A1 is approximately 2.5 V so that a logic " 1 " ( 5 V ) on

## Functional Description (Continued)

any output of Port $B$ will source current into node $\mathrm{V}_{\mathrm{X}}$ thus raising the voltage at $\mathrm{V}_{\mathrm{X}}$ and making the output differential more negative. Conversely, a logic " 0 " ( 0 V ) will pull current out of node $\mathrm{V}_{\mathrm{x}}$ and decrease the voltage, causing the differential output to become more positive. For the resistor values shown, $\mathrm{V}_{\mathrm{X}}$ can move $\pm 12 \mathrm{mV}$ with a resolution of $50 \mu \mathrm{~V}$, which will null the offset error term to $1 / 4$ LSB of full-scale for
the ADC0801. It is important that the voltage levels that drive the auto-zero resistors be constant. Also, for symmetry, a logic swing of 0 V to 5 V is convenient. To achieve this, a CMOS buffer is used for the logic output signals of Port B and this CMOS package is powered with a stable 5 V source. Buffer amplifier A1 is necessary so that it can source or sink the $\mathrm{D} / \mathrm{A}$ output current.


DS005671-91
Note 26: R2 = 49.5 R1
Note 27: Switches are LMC13334 CMOS analog switches.
Note 28: The 9 resistors used in the auto-zero section can be $\pm 5 \%$ tolerance.
FIGURE 18. Gain of 100 Differential Transducer Preamp

Functional Description (Continued)


FIGURE 19. Microprocessor Interface Circuitry for Differential Preamp

A flow chart for the zeroing subroutine is shown in Figure 20. It must be noted that the ADC0801 series will output an all
 Also, a logic inversion exists as all of the I/O ports are buffered with inverting gates.
Basically, if the data read is zero, the differential output voltage is negative, so a bit in Port B is cleared to pull $\mathrm{V}_{\mathrm{X}}$ more negative which will make the output more positive for the next conversion. If the data read is not zero, the output voltage is positive so a bit in Port $B$ is set to make $\mathrm{V}_{\mathrm{X}}$ more positive and the output more negative. This continues for 8 approximations and the differential output eventually converges to within 5 mV of zero.
The actual program is given in Figure 21. All addresses used are compatible with the BLC 80/10 microcomputer system. In particular:
Port A and the ADC0801 are at port address E4
Port $B$ is at port address E5
Port C is at port address E6
PPI control word port is at port address E7
Program Counter automatically goes to ADDR:3C3D upon
acknowledgement of an interrupt from the ADC0801

### 5.3 Multiple A/D Converters in a Z-80 Interrupt Driven Mode

In data acquisition systems where more than one A/D converter (or other peripheral device) will be interrupting program execution of a microprocessor, there is obviously a
need for the CPU to determine which device requires servicing. Figure 22 and the accompanying software is a method of determining which of 7 ADC0801 converters has completed a conversion (INTR asserted) and is requesting an interrupt. This circuit allows starting the A/D converters in any sequence, but will input and store valid data from the converters with a priority sequence of A/D 1 being read first, A/D 2 second, etc., through A/D 7 which would have the lowest priority for data being read. Only the converters whose INT is asserted will be read.

The key to decoding circuitry is the DM74LS373, 8-bit D type flip-flop. When the Z-80 acknowledges the interrupt, the program is vectored to a data input Z-80 subroutine. This subroutine will read a peripheral status word from the DM74LS373 which contains the logic state of the $\overline{\mathrm{NTR}}$ outputs of all the converters. Each converter which initiates an interrupt will place a logic " 0 " in a unique bit position in the status word and the subroutine will determine the identity of the converter and execute a data read. An identifier word (which indicates which A/D the data came from) is stored in the next sequential memory location above the location of the data so the program can keep track of the identity of the data entered.


FIGURE 20. Flow Chart for Auto-Zero Routine

Functional Description (Continued)

| 3D00 | 3E90 | MVI 90 |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 3D02 | D3E7 | Out Control Port |  | ; Program PPI |
| 3D04 | 2601 | MVI H 01 | Auto-Zero Subroutine |  |
| 3D06 | 7C | MOV A, H |  |  |
| 3D07 | D3E6 | OUT C |  | ; Close SWl open SW2 |
| 3D09 | 0680 | MVI B 80 |  | ; Initialize SAR bit pointer |
| 3DOB | 3E7F | MVI A 7F |  | ; Initialize SAR code |
| 3DOD | 4F | MOV C, A | Return |  |
| 3DOE | D3E5 | OUT B |  | ; Port B=SAR code |
| 3D10 | 31AA3D | LXI SP 3DAA | Start | ; Dimension stack pointer |
| 3D13 | D3E4 | OUT A |  | ; Start A/D |
| 3D15 | FB | IE |  |  |
| 3D16 | 00 | NOP | Loop | ; Loop until $\overline{\text { INT }}$ asserted |
| 3 D17 | C3163D | JMP Loop |  |  |
| 3D1A | 7A | MOV A, D | Auto-Zero |  |
| 3D1B | C600 | ADI 00 |  |  |
| 3D1D | CA2D3D | JZ Set C |  | ; Test A/D output data for zero |
| 3D20 | 78 | MOV A, B | Shift B |  |
| 3D21 | F600 | ORI 00 |  | ; Clear carry |
| 3D23 | 1 F | RAR |  | ; Shift "l" in B right one place |
| 3D24 | FE00 | CPI 00 |  | ; Is B zero? If yes last |
| 3D26 | CA373D | JZ Done |  | ; approximation has been made |
| 3D29 | 47 | MOV B, A |  |  |
| 3D2A | C3333D | JMP New C |  |  |
| 3D2D | 79 | MOV A, C | Set C |  |
| 3D2E | B0 | ORA B |  | ; Set bit in C that is in same |
| 3D2F | 4 F | MOV C, A |  | ; position as "l" in B |
| 3D30 | C3203D | JMP Shift B |  |  |
| 3D33 | A9 | XRA C | New C | ; Clear bit in C that is in |
| 3D34 | C30D3D | JMP Return |  | ; same position as "l" in $B$ |
| 3D37 | 47 | MOV B, A | Done | ; then out put new SAR code. |
| 3D38 | 7 C | MOV A, H |  | ; Open SW1, close SW2 then |
| 3D39 | EE03 | XRI 03 |  | ; proceed with program. Preamp |
| 3D3B | D3E6 | OUT C |  | ; is now zeroed. |
| 3D3D |  | - | Normal |  |
|  |  | $\bullet$ |  |  |
|  |  | $\bullet$ - |  |  |
|  |  | Program for processing proper data values |  |  |
| 3C3D | DBE4 | IN A | Read A/D Subroutine | ; Read A/D data |
| 3C3F | EEFF | XRI FF |  | ; Invert data |
| $3 \mathrm{C41}$ | 57 | MOV D, A |  |  |
| 3 C 42 | 78 | MOV A, B |  | ; Is $\mathrm{BReg}=0$ ? If not stay |
| 3 C 43 | E6FF | ANI FF |  | ; in auto zero subroutine |
| $3 \mathrm{C45}$ | C21A3D | JNZ Auto-Zero |  |  |
| $3 C 48$ | C33D3D | JMP Normal |  |  |

Note 29: All numerical values are hexadecimal representations.
FIGURE 21. Software for Auto-Zeroed Differential A/D

### 5.3 Multiple A/D Converters in a Z-80 Interrupt Driven Mode (Continued)

The following notes apply:

- It is assumed that the CPU automatically performs a RST 7 instruction when a valid interrupt is acknowledged (CPU is in interrupt mode 1). Hence, the subroutine starting address of X0038.
- The address bus from the Z-80 and the data bus to the Z-80 are assumed to be inverted by bus drivers.
- A/D data and identifying words will be stored in sequential memory locations starting at the arbitrarily chosen address X 3E00.
- The stack pointer must be dimensioned in the main program as the RST 7 instruction automatically pushes the PC onto the stack and the subroutine uses an additional 6 stack addresses.
- The peripherals of concern are mapped into I/O space with the following port assignments:


FIGURE 22. Multiple A/Ds with Z-80 Type Microprocessor

Functional Description

| INTERRUPT SERVICING SUBROUTINE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| LOC | OBJ CODE |  | STATEMENT | COMMENT |
| 0038 | E5 |  | PUSH HL | ; Save contents of all registers affected by |
| 0039 | C5 |  | PUSH BC | ; this subroutine. |
| 003A | F5 |  | PUSH AF | ; Assumed INT mode 1 earlier set. |
| 003B | 21003 E |  | LD (HL), X3E00 | ; Initialize memory pointer where data will be stored. |
| 003E | OE 01 |  | LD C, XO1 | ; C registerwill be port ADDR of A/D converters. |
| 0040 | D300 |  | OUT X00, A | ; Load peripheral status word into 8-bit latch. |
| 0042 | DB00 |  | IN A, X00 | ; Load status word into accumulator. |
| 0044 | 47 |  | LD B, A | ; Save the status word. |
| 0045 | 79 | TEST | LD A, C | ; Test to see if the status of all A/D's have |
| 0046 | FE 08 |  | CP, X08 | ; been checked. If so, exit subroutine |
| 0048 | CA 6000 |  | JPZ, DONE |  |
| 004B | 78 |  | LD A, B | ; Test a single bit in status word by looking for |
| 004C | 1 F |  | RRA | ; a "l" to be rotatedinto the CARRY (an INT |
| 004D | 47 |  | LD B, A | ; is loaded as a "l"). If CARRY is set then load |
| 004E | DA 5500 |  | JPC, LOAD | ; contents of A/D at port ADDR in C register. |
| 0051 | OC | NEXT | INC C | ; If CARRY is not set, increment C register to point |
| 0052 | C3 4500 |  | JP, TEST | ; to next A/D, then test next bit in status word. |
| 0055 | ED 78 | LOAD | INA, (C) | ; Read data frominterrupting $A / D$ and invert |
| 0057 | EEFF |  | XOR FF | ; the data. |
| 0059 | 77 |  | LD (HL) , A | ; Store the data |
| 005A | 2 C |  | INC L |  |
| 005B | 71 |  | LD (HL) , C | ; Store A/D identifier (A/D port ADDR) . |
| 005C | 2 C |  | INC L |  |
| 005D | C3 5100 |  | JP, NEXT | ; Test next bit in status word. |
| 0060 | Fl | DONE | POP AF | ; Re-establish all registers as they were |
| 0061 | Cl |  | POP BC | ; before the interrupt. |
| 0062 | El |  | POP HL |  |
| 0063 | C9 |  | RET | ; Return to original program |

Physical Dimensions inches (millimeters) unless otherwise noted


SO Package (M)
Order Number ADC0802LCWM or ADC0804LCWM NS Package Number M20B


Molded Dual-In-Line Package (N)
Order Number ADC0801LCN, ADC0802LCN, ADC0803LCN, ADC0804LCN or ADC0805LCN NS Package Number N20A

## Notes

## LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT AND GENERAL COUNSEL OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

1. Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
2. A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

| National Semiconductor Corporation <br> Americas <br> Email: support@nsc.com <br> www.national.com | National Semiconductor Europe <br> Fax: +49 (0) 180-530 8586 <br> Email: europe.support@nsc.com <br> Deutsch Tel: +49 (0) 6995086208 <br> English Tel: +44 (0) 8702402171 <br> Français Tel: +33 (0) 141918790 | National Semiconductor <br> Asia Pacific Customer <br> Response Group <br> Tel: 65-2544466 <br> Fax: 65-2504466 <br> Email: ap.support@nsc.com | National Semiconductor Japan Ltd. <br> Tel: 81-3-5639-7560 <br> Fax: 81-3-5639-7507 |
| :---: | :---: | :---: | :---: |

## General Purpose Type Distance Measuring Sensors

## General Description

SHARP's GP2D12/GP2D15 are general purpose type distance measuring sensors which consist of PSD* and infrared emitting diode and signal processing circuit. It enables to detect objects without any influence on the color of reflective objects, reflectivity, the lights of surroundings.
*PSD:Position Sensitive Detector

## Features

(1) Less influence on the color of reflective objects, reflectivity
(2) Line-up of distance output/distance judgement type Distance output type(analog voltage) : GP2D12 Detecting distance : 10 to 80 cm Distance judgement type : GP2D15 Judgement distance : 24 cm (Adjustable within the range of 10 to 80 cm )
(3) External control circuit is unnecessary.
(4) Low cost

## Applications

(1) TVs
(2) Personal computers
(3) Cars
(4) Copiers


[^1]
## SHARP

## GP2D12/GP2D15

| Specifications |
| :--- |
| GP2D12 |
| Parameter |
| Symbol |
| Supply voltage |
| Dissipation current |
| Vac |
| Measuring range |
| Output type |
| L |
| Operating temperature |

GP2D15
( $\mathrm{Ta}=25^{\circ} \mathrm{C}$ )

| Parameter | Symbol | Rating |
| :--- | :---: | :---: |
| Supply voltage | Vcc | 4.5 to 5.5 V |
| Dissipation current | Icc | MAX.35mA |
| *Judgement distance | L | TYP.24cm |
| Output type | - | Digital output |
| Operating temperature | Topr | -10 to $+60^{\circ} \mathrm{C}$ |

* Adjustable within the range of 10 to 80 cm .<Custom products>
- Output pattern




## Features

- Compatible with MCS-51 ${ }^{\text {TM }}$ Products
- 4K Bytes of In-System Reprogrammable Flash Memory
- Endurance: 1,000 Write/Erase Cycles
- Fully Static Operation: 0 Hz to 24 MHz
- Three-level Program Memory Lock
- 128 x 8-bit Internal RAM
- 32 Programmable I/O Lines
- Two 16-bit Timer/Counters
- Six Interrupt Sources
- Programmable Serial Channel
- Low-power Idle and Power-down Modes


## Description

The AT89C51 is a low-power, high-performance CMOS 8-bit microcomputer with 4K bytes of Flash programmable and erasable read only memory (PEROM). The device is manufactured using Atmel's high-density nonvolatile memory technology and is compatible with the industry-standard MCS-51 instruction set and pinout. The on-chip Flash allows the program memory to be reprogrammed in-system or by a conventional nonvolatile memory programmer. By combining a versatile 8-bit CPU with Flash on a monolithic chip, the Atmel AT89C51 is a powerful microcomputer which provides a highly-flexible and cost-effective solution to many embedded control applications.

## Pin Configurations




## Block Diagram



The AT89C51 provides the following standard features: 4 K bytes of Flash, 128 bytes of RAM, 32 I/O lines, two 16-bit timer/counters, a five vector two-level interrupt architecture, a full duplex serial port, on-chip oscillator and clock circuitry. In addition, the AT89C51 is designed with static logic for operation down to zero frequency and supports two software selectable power saving modes. The Idle Mode stops the CPU while allowing the RAM, timer/counters, serial port and interrupt system to continue functioning. The Power-down Mode saves the RAM contents but freezes the oscillator disabling all other chip functions until the next hardware reset.

## Pin Description

## VCC

Supply voltage.

## GND

Ground.

## Port 0

Port 0 is an 8 -bit open-drain bi-directional I/O port. As an output port, each pin can sink eight TTL inputs. When 1s are written to port 0 pins, the pins can be used as highimpedance inputs.
Port 0 may also be configured to be the multiplexed loworder address/data bus during accesses to external program and data memory. In this mode P0 has internal pullups.
Port 0 also receives the code bytes during Flash programming, and outputs the code bytes during program verification. External pullups are required during program verification.

## Port 1

Port 1 is an 8-bit bi-directional I/O port with internal pullups. The Port 1 output buffers can sink/source four TTL inputs. When 1s are written to Port 1 pins they are pulled high by the internal pullups and can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current $\left(l_{\mathrm{IL}}\right)$ because of the internal pullups.
Port 1 also receives the low-order address bytes during Flash programming and verification.

## Port 2

Port 2 is an 8 -bit bi-directional I/O port with internal pullups. The Port 2 output buffers can sink/source four TTL inputs. When 1s are written to Port 2 pins they are pulled high by the internal pullups and can be used as inputs. As inputs,

Port 2 pins that are externally being pulled low will source current ( $\mathrm{I}_{\mathrm{LL}}$ ) because of the internal pullups.
Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @ DPTR). In this application, it uses strong internal pullups when emitting 1 s . During accesses to external data memory that use 8-bit addresses (MOVX @ RI), Port 2 emits the contents of the P2 Special Function Register.
Port 2 also receives the high-order address bits and some control signals during Flash programming and verification.

## Port 3

Port 3 is an 8 -bit bi-directional I/O port with internal pullups. The Port 3 output buffers can sink/source four TTL inputs. When 1 s are written to Port 3 pins they are pulled high by the internal pullups and can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current ( $1_{\mathrm{LL}}$ ) because of the pullups.
Port 3 also serves the functions of various special features of the AT89C51 as listed below:

| Port Pin | Alternate Functions |
| :--- | :--- |
| P3.0 | RXD (serial input port) |
| P3.1 | TXD (serial output port) |
| P3.2 | $\overline{\mathrm{NTT}}$ (external interrupt 0) |
| P3.3 | $\overline{\mathrm{INT} 1}$ (external interrupt 1) |
| P3.4 | T0 (timer 0 external input) |
| P3.5 | T1 (timer 1 external input) |
| P3.6 | $\overline{\mathrm{WR}}$ (external data memory write strobe) |
| P3.7 | $\overline{\mathrm{RD}}$ (external data memory read strobe) |

Port 3 also receives some control signals for Flash programming and verification.

## RST

Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device.

## ALE/PROG

Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory. This pin is also the program pulse input ( $\overline{\mathrm{PROG}}$ ) during Flash programming.
In normal operation ALE is emitted at a constant rate of $1 / 6$ the oscillator frequency, and may be used for external timing or clocking purposes. Note, however, that one ALE
pulse is skipped during each access to external Data Memory.
If desired, ALE operation can be disabled by setting bit 0 of SFR location 8EH. With the bit set, ALE is active only during a MOVX or MOVC instruction. Otherwise, the pin is weakly pulled high. Setting the ALE-disable bit has no effect if the microcontroller is in external execution mode.

## PSEN

Program Store Enable is the read strobe to external program memory.
When the AT89C51 is executing code from external program memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory.

## $\overline{E A} /$ VPP

External Access Enable. EA must be strapped to GND in order to enable the device to fetch code from external program memory locations starting at 0000 H up to FFFFH. Note, however, that if lock bit 1 is programmed, $\overline{E A}$ will be internally latched on reset.
$\overline{E A}$ should be strapped to $V_{C C}$ for internal program executions.
This pin also receives the 12 -volt programming enable voltage ( $\mathrm{V}_{\mathrm{PP}}$ ) during Flash programming, for parts that require 12-volt $\mathrm{V}_{\mathrm{PP}}$.

## XTAL1

Input to the inverting oscillator amplifier and input to the internal clock operating circuit.

## XTAL2

Output from the inverting oscillator amplifier.

## Oscillator Characteristics

XTAL1 and XTAL2 are the input and output, respectively, of an inverting amplifier which can be configured for use as an on-chip oscillator, as shown in Figure 1. Either a quartz crystal or ceramic resonator may be used. To drive the device from an external clock source, XTAL2 should be left
unconnected while XTAL1 is driven as shown in Figure 2. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum voltage high and low time specifications must be observed.

## Idle Mode

In idle mode, the CPU puts itself to sleep while all the onchip peripherals remain active. The mode is invoked by software. The content of the on-chip RAM and all the special functions registers remain unchanged during this mode. The idle mode can be terminated by any enabled interrupt or by a hardware reset.
It should be noted that when idle is terminated by a hard ware reset, the device normally resumes program execution, from where it left off, up to two machine cycles before the internal reset algorithm takes control. On-chip hardware inhibits access to internal RAM in this event, but access to the port pins is not inhibited. To eliminate the possibility of an unexpected write to a port pin when Idle is terminated by reset, the instruction following the one that invokes Idle should not be one that writes to a port pin or to external memory.

Figure 1. Oscillator Connections


Note: $\quad \begin{aligned} \mathrm{C} 1, \mathrm{C} 2 & =30 \mathrm{pF} \pm 10 \mathrm{pF} \text { for Crystals } \\ & =40 \mathrm{pF} \pm 10 \mathrm{pF} \text { for Ceramic Resonators }\end{aligned}$

Status of External Pins During Idle and Power-down Modes

| Mode | Program Memory | ALE | $\overline{\text { PSEN }}$ | PORT0 | PORT1 | PORT2 | PORT3 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Idle | Internal | 1 | 1 | Data | Data | Data | Data |
| Idle | External | 1 | 1 | Float | Data | Address | Data |
| Power-down | Internal | 0 | 0 | Data | Data | Data | Data |
| Power-down | External | 0 | 0 | Float | Data | Data | Data |

Figure 2. External Clock Drive Configuration


## Power-down Mode

In the power-down mode, the oscillator is stopped, and the instruction that invokes power-down is the last instruction executed. The on-chip RAM and Special Function Regis-
ters retain their values until the power-down mode is terminated. The only exit from power-down is a hardware reset. Reset redefines the SFRs but does not change the on-chip RAM. The reset should not be activated before $\mathrm{V}_{\mathrm{CC}}$ is restored to its normal operating level and must be held active long enough to allow the oscillator to restart and stabilize.

## Program Memory Lock Bits

On the chip are three lock bits which can be left unprogrammed (U) or can be programmed (P) to obtain the additional features listed in the table below.
When lock bit 1 is programmed, the logic level at the $\overline{E A}$ pin is sampled and latched during reset. If the device is powered up without a reset, the latch initializes to a random value, and holds that value until reset is activated. It is necessary that the latched value of $\overline{E A}$ be in agreement with the current logic level at that pin in order for the device to function properly.

## Lock Bit Protection Modes

| Program Lock Bits |  |  |  |  |
| :---: | :---: | :---: | :---: | :--- |
|  | LB1 | LB2 | LB3 |  |
| 1 | U | U | U | No program lock features |
| 2 | P | U | U | MOVC instructions executed from external program memory are disabled from <br> fetching code bytes from internal memory, EA is sampled and latched on reset, <br> and further programming of the Flash is disabled |
| 3 | P | P | U | Same as mode 2, also verify is disabled |
| 4 | P | P | P | Same as mode 3, also external execution is disabled |

## Programming the Flash

The AT89C51 is normally shipped with the on-chip Flash memory array in the erased state (that is, contents = FFH) and ready to be programmed. The programming interface accepts either a high-voltage (12-volt) or a low-voltage $\left(\mathrm{V}_{\mathrm{Cc}}\right)$ program enable signal. The low-voltage programming mode provides a convenient way to program the AT89C51 inside the user's system, while the high-voltage programming mode is compatible with conventional thirdparty Flash or EPROM programmers.
The AT89C51 is shipped with either the high-voltage or low-voltage programming mode enabled. The respective top-side marking and device signature codes are listed in the following table.

|  | $\mathbf{V}_{\mathbf{P P}}=\mathbf{1 2 V}$ | $\mathbf{V}_{\mathbf{P P}}=5 \mathbf{V}$ |
| :--- | :--- | :--- |
| Top-side Mark | AT89C51 |  |
|  | xxxx |  |
| yyww | AT89C51 |  |
| xxxx-5 |  |  |
| Signature | $(030 \mathrm{H})=1 \mathrm{EH}$ | $(030 \mathrm{H})=1 \mathrm{EH}$ |
|  | $(031 \mathrm{H})=51 \mathrm{H}$ | $(031 \mathrm{H})=51 \mathrm{H}$ |
|  | $(032 \mathrm{H})=\mathrm{FFH}$ | $(032 \mathrm{H})=05 \mathrm{H}$ |

The AT89C51 code memory array is programmed byte-bybyte in either programming mode. To program any nonblank byte in the on-chip Flash Memory, the entire memory must be erased using the Chip Erase Mode.
Programming Algorithm: Before programming the AT89C51, the address, data and control signals should be set up according to the Flash programming mode table and Figure 3 and Figure 4. To program the AT89C51, take the following steps.

1. Input the desired memory location on the address lines.
2. Input the appropriate data byte on the data lines.
3. Activate the correct combination of control signals.
4. Raise $\overline{\mathrm{EA}} / \mathrm{V}_{\mathrm{PP}}$ to 12 V for the high-voltage programming mode.
5. Pulse ALE/PROG once to program a byte in the Flash array or the lock bits. The byte-write cycle is self-timed and typically takes no more than 1.5 ms . Repeat steps 1 through 5 , changing the address
and data for the entire array or until the end of the object file is reached.
Data Polling: The AT89C51 features Data Polling to indicate the end of a write cycle. During a write cycle, an attempted read of the last byte written will result in the complement of the written datum on PO .7 . Once the write cycle has been completed, true data are valid on all outputs, and the next cycle may begin. Data Polling may begin any time after a write cycle has been initiated.
Ready/Busy: The progress of byte programming can also be monitored by the RDY/BSY output signal. P3.4 is pulled low after ALE goes high during programming to indicate BUSY. P3.4 is pulled high again when programming is done to indicate READY.
Program Verify: If lock bits LB1 and LB2 have not been programmed, the programmed code data can be read back via the address and data lines for verification. The lock bits cannot be verified directly. Verification of the lock bits is achieved by observing that their features are enabled.
Chip Erase: The entire Flash array is erased electrically by using the proper combination of control signals and by holding ALE/PROG low for 10 ms . The code array is written with all " 1 "s. The chip erase operation must be executed before the code memory can be re-programmed.
Reading the Signature Bytes: The signature bytes are read by the same procedure as a normal verification of locations $030 \mathrm{H}, 031 \mathrm{H}$, and 032 H , except that P3.6 and P3.7 must be pulled to a logic low. The values returned are as follows.
$(030 \mathrm{H})=1 \mathrm{EH}$ indicates manufactured by Atmel
$(031 \mathrm{H})=51 \mathrm{H}$ indicates 89C51
$(032 \mathrm{H})=\mathrm{FFH}$ indicates 12 V programming
$(032 \mathrm{H})=05 \mathrm{H}$ indicates 5 V programming

## Programming Interface

Every code byte in the Flash array can be written and the entire array can be erased by using the appropriate combination of control signals. The write operation cycle is selftimed and once initiated, will automatically time itself to completion.
All major programming vendors offer worldwide support for the Atmel microcontroller series. Please contact your local programming vendor for the appropriate software revision.

Flash Programming Modes

| Mode |  | RST | PSEN | ALE/PROG | $\overline{E A} / V_{\text {PP }}$ | P2.6 | P2.7 | P3.6 | P3.7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Code Data |  | H | L |  | H/12V | L | H | H | H |
| Read Code Data |  | H | L | H | H | L | L | H | H |
| Write Lock | Bit - 1 | H | L |  | H/12V | H | H | H | H |
|  | Bit - 2 | H | L |  | H/12V | H | H | L | L |
|  | Bit - 3 | H | L |  | H/12V | H | L | H | L |
| Chip Erase |  | H | L | (1) | H/12V | H | L | L | L |
| Read Signature Byte |  | H | L | H | H | L | L | L | L |

Note: 1. Chip Erase requires a $10 \mathrm{~ms} \overline{\text { PROG }}$ pulse.
Figure 3. Programming the Flash


Figure 4. Verifying the Flash


Flash Programming and Verification Waveforms - High-voltage Mode ( $\mathrm{V}_{\mathrm{PP}}=12 \mathrm{~V}$ )


Flash Programming and Verification Waveforms - Low-voltage Mode ( $\mathrm{V}_{\mathrm{PP}}=5 \mathrm{~V}$ )


## Flash Programming and Verification Characteristics

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \pm 10 \%$

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $V_{P P}{ }^{(1)}$ | Programming Enable Voltage | 11.5 | 12.5 | V |
| $\mathrm{IPP}^{(1)}$ | Programming Enable Current |  | 1.0 | mA |
| 1/t ${ }_{\text {CLCL }}$ | Oscillator Frequency | 3 | 24 | MHz |
| $\mathrm{t}_{\text {AVGL }}$ | Address Setup to PROG Low | $48 \mathrm{t}_{\mathrm{CLCL}}$ |  |  |
| $\mathrm{t}_{\text {GHAX }}$ | Address Hold after PROG | $48 \mathrm{t}_{\text {CLCL }}$ |  |  |
| $\mathrm{t}_{\text {DVGL }}$ | Data Setup to $\overline{\text { PROG }}$ Low | $48 \mathrm{t}_{\text {CLCL }}$ |  |  |
| $\mathrm{t}_{\text {GHDX }}$ | Data Hold after PROG | $48 \mathrm{t}_{\text {CLCL }}$ |  |  |
| $\mathrm{t}_{\text {EHSH }}$ | P2.7 (ENABLE) High to $\mathrm{V}_{\text {PP }}$ | $48 \mathrm{t}_{\text {CLCL }}$ |  |  |
| $\mathrm{t}_{\text {SHGL }}$ | $\mathrm{V}_{\text {PP }}$ Setup to $\overline{\text { PROG }}$ Low | 10 |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {GHSL }}{ }^{(1)}$ | $V_{\text {PP }}$ Hold after PROG | 10 |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {GLGH }}$ | $\overline{\text { PROG Width }}$ | 1 | 110 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {AVQV }}$ | Address to Data Valid |  | $48 \mathrm{t}_{\text {CLCL }}$ |  |
| teLQV | ENABLE Low to Data Valid |  | $48 \mathrm{t}_{\text {CLCL }}$ |  |
| $\mathrm{t}_{\text {EHQZ }}$ | Data Float after ENABLE | 0 | $48 \mathrm{t}_{\text {CLCL }}$ |  |
| $\mathrm{t}_{\text {GHBL }}$ | $\overline{\text { PROG }}$ High to $\overline{\text { BUSY Low }}$ |  | 1.0 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {wc }}$ | Byte Write Cycle Time |  | 2.0 | ms |

Note: 1. Only used in 12-volt programming mode.

## Absolute Maximum Ratings*

Operating Temperature................................ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature ................................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
with Respect to Ground ....................................-1.0V to +7.0 V
Maximum Operating Voltage ............................................ 6.6 V
DC Output Current...................................................... 15.0 mA
*NOTICE: Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC Characteristics

$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 20 \%$ (unless otherwise noted)

| Symbol | Parameter | Condition | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low-voltage | (Except EA) | -0.5 | $0.2 \mathrm{~V}_{\mathrm{CC}}-0.1$ | V |
| $\mathrm{V}_{\text {IL-1 }}$ | Input Low-voltage ( $\overline{\mathrm{EA}}$ ) |  | -0.5 | $0.2 \mathrm{~V}_{\mathrm{CC}}-0.3$ | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High-voltage | (Except XTAL1, RST) | $0.2 V_{C C}+0.9$ | $V_{C C}+0.5$ | V |
| $\mathrm{V}_{\mathrm{HH} 1}$ | Input High-voltage | (XTAL1, RST) | $0.7 \mathrm{~V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low-voltage ${ }^{(1)}$ (Ports 1,2,3) | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | 0.45 | V |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low-voltage ${ }^{(1)}$ <br> (Port 0, ALE, PSEN) | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |  | 0.45 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High-voltage <br> (Ports 1,2,3, ALE, PSEN) | $\mathrm{I}_{\mathrm{OH}}=-60 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | 2.4 |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-25 \mu \mathrm{~A}$ | $0.75 \mathrm{~V}_{\mathrm{cc}}$ |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $0.9 \mathrm{~V}_{\mathrm{CC}}$ |  | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High-voltage <br> (Port 0 in External Bus Mode) | $\mathrm{I}_{\mathrm{OH}}=-800 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ | 2.4 |  | V |
|  |  | $\mathrm{I}_{\text {OH }}=-300 \mu \mathrm{~A}$ | $0.75 \mathrm{~V}_{\mathrm{cc}}$ |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ | 0.9 V CC |  | V |
| $\mathrm{I}_{\text {IL }}$ | Logical 0 Input Current (Ports 1,2,3) | $\mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -50 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {TL }}$ | Logical 1 to 0 Transition Current (Ports 1,2,3) | $\mathrm{V}_{\mathrm{IN}}=2 \mathrm{~V}, \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%$ |  | -650 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current (Port 0, EA) | $0.45<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| RRST | Reset Pull-down Resistor |  | 50 | 300 | $\mathrm{K} \Omega$ |
| $\mathrm{C}_{10}$ | Pin Capacitance | Test Freq. $=1 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | 10 | pF |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current | Active Mode, 12 MHz |  | 20 | mA |
|  |  | Idle Mode, 12 MHz |  | 5 | mA |
|  | Power-down Mode ${ }^{(2)}$ | $\mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=3 \mathrm{~V}$ |  | 40 | $\mu \mathrm{A}$ |

Notes: 1. Under steady state (non-transient) conditions, $\mathrm{I}_{\mathrm{OL}}$ must be externally limited as follows:
Maximum Iol per port pin: 10 mA
Maximum $\mathrm{I}_{\mathrm{OL}}$ per 8-bit port: Port 0: 26 mA
Ports 1, 2, 3: 15 mA
Maximum total $\mathrm{I}_{\mathrm{OL}}$ for all output pins: 71 mA
If $\mathrm{I}_{\mathrm{OL}}$ exceeds the test condition, $\mathrm{V}_{\mathrm{OL}}$ may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.
2. Minimum $\mathrm{V}_{\mathrm{CC}}$ for Power-down is 2 V .

## AC Characteristics

Under operating conditions, load capacitance for Port $0, A L E / \overline{\text { PROG }}$, and $\overline{\text { PSEN }}=100 \mathrm{pF}$; load capacitance for all other outputs $=80 \mathrm{pF}$.

## External Program and Data Memory Characteristics

| Symbol | Parameter | 12 MHz Oscillator |  | 16 to 24 MHz Oscillator |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 1/t ${ }_{\text {CLCL }}$ | Oscillator Frequency |  |  | 0 | 24 | MHz |
| $\mathrm{t}_{\text {LHLL }}$ | ALE Pulse Width | 127 |  | $2 \mathrm{t}_{\mathrm{CLCL}}-40$ |  | ns |
| $\mathrm{t}_{\text {AVLL }}$ | Address Valid to ALE Low | 43 |  | $\mathrm{t}_{\text {CLCL- }}{ }^{-13}$ |  | ns |
| $\mathrm{t}_{\text {LLAX }}$ | Address Hold after ALE Low | 48 |  | $\mathrm{t}_{\mathrm{CLCL}}-20$ |  | ns |
| $\mathrm{t}_{\text {LLIV }}$ | ALE Low to Valid Instruction In |  | 233 |  | $4 \mathrm{t}_{\mathrm{CLCL}}-65$ | ns |
| tLLPL | ALE Low to PSEN Low | 43 |  | $\mathrm{t}_{\mathrm{CLCL}}{ }^{-13}$ |  | ns |
| $\mathrm{t}_{\text {PLPH }}$ | $\overline{\text { PSEN Pulse Width }}$ | 205 |  | $3 \mathrm{t}_{\mathrm{CLCL}}-20$ |  | ns |
| $\mathrm{t}_{\text {PLIV }}$ | $\overline{\text { PSEN Low to Valid Instruction In }}$ |  | 145 |  | $3 \mathrm{t}_{\mathrm{CLCL}}-45$ | ns |
| $\mathrm{t}_{\text {PXIX }}$ | Input Instruction Hold after PSEN | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {PXIZ }}$ | Input Instruction Float after $\overline{\text { PSEN }}$ |  | 59 |  | $\mathrm{t}_{\mathrm{CLCL}}{ }^{-10}$ | ns |
| $\mathrm{t}_{\text {PXAV }}$ | $\overline{\text { PSEN }}$ to Address Valid | 75 |  | $\mathrm{t}_{\text {CLCL- }}$ - |  | ns |
| $\mathrm{t}_{\text {AVIV }}$ | Address to Valid Instruction In |  | 312 |  | $5 t_{\text {CLCL }}-55$ | ns |
| $\mathrm{t}_{\text {PLAZ }}$ | $\overline{\text { PSEN }}$ Low to Address Float |  | 10 |  | 10 | ns |
| $t_{\text {RLRH }}$ | $\overline{\mathrm{RD}}$ Pulse Width | 400 |  | $6 \mathrm{t}_{\text {CLCLL }}-100$ |  | ns |
| $\mathrm{t}_{\text {WLWH }}$ | $\overline{\text { WR Pulse Width }}$ | 400 |  | $6 \mathrm{t}_{\text {CLCLL }}-100$ |  | ns |
| $t_{\text {RLDV }}$ | $\overline{\mathrm{RD}}$ Low to Valid Data In |  | 252 |  | $5 t_{\text {CLCL }} 90$ | ns |
| $\mathrm{t}_{\text {RHDX }}$ | Data Hold after $\overline{\mathrm{RD}}$ | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {RHDZ }}$ | Data Float after $\overline{\mathrm{RD}}$ |  | 97 |  | $2 \mathrm{t}_{\text {CLCL }}-28$ | ns |
| tLLDV | ALE Low to Valid Data In |  | 517 |  | $8 \mathrm{t}_{\text {CLCL }}-150$ | ns |
| $\mathrm{t}_{\text {AVDV }}$ | Address to Valid Data In |  | 585 |  | $9 \mathrm{t}_{\text {CLCL }}-165$ | ns |
| $\mathrm{t}_{\text {LLWL }}$ | ALE Low to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ Low | 200 | 300 | $3 \mathrm{t}_{\mathrm{CLCL}}-50$ | $3 \mathrm{t}_{\mathrm{CLCL}+50}$ | ns |
| $\mathrm{t}_{\text {AVWL }}$ | Address to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ Low | 203 |  | $4 \mathrm{t}_{\text {CLCL }}-75$ |  | ns |
| $t_{\text {Qvwx }}$ | Data Valid to $\overline{W R}$ Transition | 23 |  | $\mathrm{t}_{\text {CLCL- }}$ 20 |  | ns |
| $\mathrm{t}_{\text {QVWH }}$ | Data Valid to $\overline{\mathrm{WR}}$ High | 433 |  | $7 \mathrm{t}_{\text {CLCLL }}-120$ |  | ns |
| $\mathrm{t}_{\text {WHQX }}$ | Data Hold after $\bar{W}$ | 33 |  | $\mathrm{t}_{\text {CLCL- }}-20$ |  | ns |
| $\mathrm{t}_{\text {RLAZ }}$ | $\overline{\mathrm{RD}}$ Low to Address Float |  | 0 |  | 0 | ns |
| $\mathrm{t}_{\text {WHLH }}$ | $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ High to ALE High | 43 | 123 | $\mathrm{t}_{\mathrm{CLCL}}-20$ | $\mathrm{t}_{\mathrm{CLCL}}+25$ | ns |

## External Program Memory Read Cycle



## External Data Memory Read Cycle



## External Data Memory Write Cycle



## External Clock Drive Waveforms



## External Clock Drive

| Symbol | Parameter | Min | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $1 / t_{\text {CLCL }}$ | Oscillator Frequency | 0 | 24 | MHz |
| $\mathrm{t}_{\mathrm{CLCL}}$ | Clock Period | 41.6 | ns |  |
| $\mathrm{t}_{\mathrm{CHCX}}$ | High Time | 15 | ns |  |
| $\mathrm{t}_{\mathrm{CLCX}}$ | Low Time | 15 | ns |  |
| $\mathrm{t}_{\mathrm{CLCH}}$ | Rise Time |  | 20 | ns |
| $\mathrm{t}_{\mathrm{CHCL}}$ | Fall Time |  | 20 | ns |

## Serial Port Timing: Shift Register Mode Test Conditions

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 20 \%\right.$; Load Capacitance $=80 \mathrm{pF}$ )

| Symbol | Parameter | 12 MHz Osc |  | Variable Oscillator |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $\mathrm{t}_{\text {XLXL }}$ | Serial Port Clock Cycle Time | 1.0 |  | $12 \mathrm{t}_{\mathrm{CLCL}}$ |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {QVXH }}$ | Output Data Setup to Clock Rising Edge | 700 |  | $10 \mathrm{CLLCL}^{-133}$ |  | ns |
| $\mathrm{t}_{\mathrm{XHQX}}$ | Output Data Hold after Clock Rising Edge | 50 |  | $2 \mathrm{t}_{\text {CLCL- }}-117$ |  | ns |
| $\mathrm{t}_{\mathrm{XHDX}}$ | Input Data Hold after Clock Rising Edge | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{XHDV}}$ | Clock Rising Edge to Input Data Valid |  | 700 |  | $10 \mathrm{t}_{\text {cLCL }}-133$ | ns |

## Shift Register Mode Timing Waveforms



## AC Testing Input/Output Waveforms ${ }^{(1)}$



Note: 1. AC Inputs during testing are driven at $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$ for a logic 1 and 0.45 V for a logic 0 . Timing measurements are made at $\mathrm{V}_{\mathrm{IH}}$ min. for a logic 1 and $\mathrm{V}_{\mathrm{IL}}$ max. for a logic 0.

Float Waveforms ${ }^{(1)}$


Note: 1. For timing purposes, a port pin is no longer floating when a 100 mV change from load voltage occurs. A port pin begins to float when 100 mV change from the loaded $\mathrm{V}_{\mathrm{OH}} / \mathrm{V}_{\mathrm{OL}}$ level occurs.

## Ordering Information

| Speed <br> (MHz) | Power Supply | Ordering Code | Package | Operation Range |
| :---: | :---: | :---: | :---: | :---: |
| 12 | $5 \mathrm{~V} \pm 20 \%$ | AT89C51-12AC | 44A | Commercial |
|  |  | AT89C51-12JC | 44J | ( $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) |
|  |  | AT89C51-12PC | 40P6 |  |
|  |  | AT89C51-12QC | 44Q |  |
|  |  | AT89C51-12AI | 44A | Industrial |
|  |  | AT89C51-12JI | 44J | ( $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ ) |
|  |  | AT89C51-12PI | 40P6 |  |
|  |  | AT89C51-12QI | 44Q |  |
| 16 | $5 \mathrm{~V} \pm 20 \%$ | AT89C51-16AC | 44A | Commercial |
|  |  | AT89C51-16JC | 44J | ( $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) |
|  |  | AT89C51-16PC | 40P6 |  |
|  |  | AT89C51-16QC | 44Q |  |
|  |  | AT89C51-16AI | 44A | Industrial |
|  |  | AT89C51-16JI | 44J | $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}\right)$ |
|  |  | AT89C51-16PI | 40P6 |  |
|  |  | AT89C51-16QI | 44Q |  |
| 20 | $5 \mathrm{~V} \pm 20 \%$ | AT89C51-20AC | 44A | Commercial |
|  |  | AT89C51-20JC | 44J | ( $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) |
|  |  | AT89C51-20PC | 40P6 |  |
|  |  | AT89C51-20QC | 44Q |  |
|  |  | AT89C51-20AI | 44A | Industrial |
|  |  | AT89C51-20JI | 44J | ( $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ ) |
|  |  | AT89C51-20PI | 40P6 |  |
|  |  | AT89C51-20QI | 44Q |  |
| 24 | $5 \mathrm{~V} \pm 20 \%$ | AT89C51-24AC | 44A | Commercial |
|  |  | AT89C51-24JC | 44J | ( $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) |
|  |  | AT89C51-24PC | 40P6 |  |
|  |  | AT89C51-24QC | 44Q |  |
|  |  | AT89C51-24AI | 44A | Industrial |
|  |  | AT89C51-24JI | 44J | $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}\right)$ |
|  |  | AT89C51-24PI | 40P6 |  |
|  |  | AT89C51-24QI | 44Q |  |


| Package Type |  |
| :--- | :--- |
| 44A | 44-lead, Thin Plastic Gull Wing Quad Flatpack (TQFP) |
| 44J | 44-lead, Plastic J-leaded Chip Carrier (PLCC) |
| 40P6 | 40-lead, 0.600" Wide, Plastic Dual Inline Package (PDIP) |
| 44Q | 44-lead, Plastic Gull Wing Quad Flatpack (PQFP) |

## Packaging Information

44A, 44-lead, Thin ( 1.0 mm ) Plastic Gull Wing Quad Flatpack (TQFP)
Dimensions in Millimeters and (Inches)*
JEDEC STANDARD MS-026 ACB


44J, 44-lead, Plastic J-leaded Chip Carrier (PLCC) Dimensions in Inches and (Millimeters) JEDEC STANDARD MS-018 AC


44Q, 44-lead, Plastic Quad Flat Package (PQFP) Dimensions in Millimeters and (Inches)* JEDEC STANDARD MS-022 AB


Controlling dimension: millimeters

## Atmel Headquarters

Corporate Headquarters 2325 Orchard Parkway San Jose, CA 95131 TEL (408) 441-0311
FAX (408) 487-2600

## Europe

Atmel U.K., Ltd.
Coliseum Business Centre Riverside Way Camberley, Surrey GU15 3YL England
TEL (44) 1276-686-677
FAX (44) 1276-686-697
Asia
Atmel Asia, Ltd.
Room 1219
Chinachem Golden Plaza
77 Mody Road Tsimhatsui
East Kowloon
Hong Kong
TEL (852) 2721-9778
FAX (852) 2722-1369

## Japan

Atmel Japan K.K.
9F, Tonetsu Shinkawa Bldg.
1-24-8 Shinkawa
Chuo-ku, Tokyo 104-0033
Japan
TEL (81) 3-3523-3551
FAX (81) 3-3523-7581

## Atmel Operations

## Atmel Colorado Springs

1150 E. Cheyenne Mtn. Blvd.
Colorado Springs, CO 80906
TEL (719) 576-3300
FAX (719) 540-1759
Atmel Rousset
Zone Industrielle
13106 Rousset Cedex
France
TEL (33) 4-4253-6000
FAX (33) 4-4253-6001

Fax-on-Demand<br>North America:<br>1-(800) 292-8635<br>International:<br>1-(408) 441-0732<br>e-mail<br>literature@atmel.com<br>Web Site http://www.atmel.com<br>\section*{BBS}<br>1-(408) 436-4309

## © Atmel Corporation 2000.

Atmel Corporation makes no warranty for the use of its products, other than those expressly contained in the Company's standard warranty which is detailed in Atmel's Terms and Conditions located on the Company's web site. The Company assumes no responsibility for any errors which may appear in this document, reserves the right to change devices or specifications detailed herein at any time without notice, and does not make any commitment to update the information contained herein. No licenses to patents or other intellectual property of Atmel are granted by the Company in connection with the sale of Atmel products, expressly or by implication. Atmel's products are not authorized for use as critical components in life support devices or systems.

Marks bearing ${ }^{\circledR}$ and/or ${ }^{\text {TM }}$ are registered trademarks and trademarks of Atmel Corporation.
Terms and product names in this document may be trademarks of others.
Printed on recycled paper.

LAMPIRAN-B

## FOTO ALAT




## LAMPIRAN-C

## PROGRAM

\$MOD51
AJMP START
DELAY: MOV R1,\#0FFH
DEL1: MOV R2,\#0FFH
DEL: DEC R2
CJNE R2,\#00H, DEL
DEC R1
CJNE R1,\#00H, DEL1
RET
DELAY1: MOV R1,\#80H
D1: MOV R2,\#0FFH
D2: $\quad$ DEC R2
CJNE R2,\#00H, D2
DEC R1
CJNE R1,\#00H, D1
DEC R3
CJNE R3,\#00H,DELAY1
RET
;SUB-RUTIN MENAIKAN JALUR TEMBAKAN
NAIK: MOV P1,\#20H
CALL DELAY1
MOV P1,\#00H
MOV R3,\#20H
CALL DELAY1
RET
;SUB-RUTIN MENURUNKAN JALUR TEMBAKAN
TURUN: MOV P1,\#02H
CALL DELAY1
MOV P1,\#00H
MOV R3,\#20H
CALL DELAY1
RET
;SUB-RUTIN MENARIK PEGAS
LEMPAR: MOV P1,\#10000000B
CALL DELAY1
MOV P1,\#00H
MOV R3,\#20H
CALL DELAY1
CALL TARIK
RET
;SUB-RUTIN MENARIK MOTOR PENARIK PEGAS
TARIK: MOV P1,\#00000100B
MOV R3,\#0AH
CALL DELAY1
MOV P1,\#00H
MOV R3,\#20H
CALL DELAY1
;SUB-RUTIN MELEPASKAN MOTOR PENARIK PEGAS
MOV P1,\#00001000B
MOV R3,\#06H
CALL DELAY1
MOV P1,\#00H
MOV R3,\#20H
CALL DELAY1
RET

START: MOV A,P3
CJNE A,\#48H,DUA0 ;JARAK 20 CM
MOV P2,\#20H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA0: CJNE A,\#47H,DUA01 ;JARAK 20 CM
MOV P2,\#20H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA01: CJNE A,\#46H,DUA1 ;JARAK 20 CM
MOV P2,\#20H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA1: CJNE A,\#45H,DUA11 ;JARAK 21 CM
MOV P2,\#21H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA11: CJNE A,\#44H,DUA12 ;JARAK 21 CM
MOV P2,\#21H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN

DUA12: CJNE A,\#43H,DUA13 ;JARAK 21 CM
MOV P2,\#21H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA13: CJNE A,\#42H,DUA2 ;JARAK 21 CM
MOV P2,\#21H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA2: CJNE A,\#41H,DUA21 ;JARAK 22 CM
MOV P2,\#22H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA21: CJNE A,\#40H,DUA22 ;JARAK 22 CM
MOV P2,\#22H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN

DUA22: CJNE A,\#3FH,DUA3 ;JARAK 22 CM
MOV P2,\#22H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN

DUA3: CJNE A,\#3EH,DUA31 ;JARAK 23 CM
MOV P2,\#23H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN
DUA31: CJNE A,\#3DH,DUA4 ;JARAK 23 CM
MOV P2,\#23H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN
DUA4: CJNE A,\#3CH,DUA41 ;JARAK 24 CM
MOV P2,\#24H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN
DUA41: CJNE A,\#3BH,DUA42 ;JARAK 24 CM
MOV P2,\#24H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN
DUA42: CJNE A,\#3AH,DUA43 ;JARAK 24 CM
MOV P2,\#24H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN

DUA43: CJNE A,\#39H,DUA44 ;JARAK 24 CM
MOV P2,\#24H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN
DUA44: CJNE A,\#38H,DUA5 ;JARAK 24 CM
MOV P2,\#24H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN
DUA5: CJNE A,\#37H,DUA51 ;JARAK 25 CM
MOV P2,\#25H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#0ACH
CALL TURUN
AJMP NN

DUA51: CJNE A,\#36H,DUA6 ;JARAK 25 CM
MOV P2,\#25H
CALL DELAY
MOV R3,\#OB0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN

DUA6: CJNE A,\#35H,DUA61 ;JARAK 26 CM
MOV P2,\#26H
CALL DELAY
MOV R3,\#0B0H
CALL NAIK
MOV R3,\#05H
CALL LEMPAR
MOV R3,\#OACH
CALL TURUN
AJMP NN

| DUA61: | CJNE A,\#34H,DUA7 <br> MOV P2,\#26H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#05H <br> CALL LEMPAR <br> MOV R3,\#OACH <br> CALL TURUN <br> AJMP NN | ;JARAK 26 CM | DUA91: | CJNE A,\#2FH,TG0 <br> MOV P2,\#29H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 29 CM |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DUA7: | CJNE A,\#33H,DUA8 <br> MOV P2,\#27H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#05H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 27 CM | TG0: | CJNE A,\#2EH,TG2 <br> MOV P2,\#30H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 30 CM |
| DUA8: | CJNE A,\#32H,DUA81 <br> MOV P2,\#28H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 28 CM | TG2: | CJNE A,\#2DH,TG3 <br> MOV P2,\#32H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 32 CM |
| DUA81: | CJNE A,\#31H,DUA9 <br> MOV P2,\#28H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 28 CM | TG3: | CJNE A,\#2CH,TG5 <br> MOV P2,\#33H <br> CALL DELAY <br> MOV R3,\#0B0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 33 CM |
| DUA9: | CJNE A,\#30H,DUA91 <br> MOV P2,\#29H <br> CALL DELAY <br> MOV R3,\#0B0H <br> CALL NAIK <br> MOV R3,\#06H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 29 CM | TG5: | CJNE A,\#2BH,TG6 <br> MOV P2,\#35H <br> CALL DELAY <br> MOV R3,\#60H <br> CALL NAIK <br> MOV R3,\#07H <br> CALL LEMPAR <br> MOV R3,\#5CH <br> CALL TURUN <br> AJMP NN | ;JARAK 35 CM |


| TG6: | CJNE A,\#2AH,TG7 | ;JARAK 36 CM | E1: | CJNE A,\#25H,E3 | ;JARAK 41 CM |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MOV P2,\#36H |  |  | MOV P2,\#41H |  |
|  | CALL DELAY |  |  | CALL DELAY |  |
|  | MOV R3,\#60H |  |  | MOV R3,\#88H |  |
|  | CALL NAIK |  |  | CALL NAIK |  |
|  | MOV R3,\#07H |  |  | MOV R3,\#08H |  |
|  | CALL LEMPAR |  |  | CALL LEMPAR |  |
|  | MOV R3,\#5CH |  |  | MOV R3,\#84H |  |
|  | CALL TURUN |  |  | CALL TURUN |  |
|  | AJMP NN |  |  | AJMP NN |  |
| TG7: | CJNE A,\#29H,TG8 | ;JARAK 37 CM | E3: | CJNE A,\#24H,E4 | ;JARAK 43 CM |
|  | MOV P2,\#37H |  |  | MOV P2,\#43H |  |
|  | CALL DELAY |  |  | CALL DELAY |  |
|  | MOV R3,\#60H |  |  | MOV R3,\#88H |  |
|  | CALL NAIK |  |  | CALL NAIK |  |
|  | MOV R3,\#07H |  |  | MOV R3,\#08H |  |
|  | CALL LEMPAR |  |  | CALL LEMPAR |  |
|  | MOV R3,\#5CH |  |  | MOV R3,\#84H |  |
|  | CALL TURUN |  |  | CALL TURUN |  |
|  | AJMP NN |  |  | AJMP NN |  |
| TG8: | CJNE A,\#28H,TG9 | ;JARAK 38 CM | E4: | CJNE A,\#23H,E5 | ;JARAK 44 CM |
|  | MOV P2,\#38H |  |  | MOV P2,\#44H |  |
|  | CALL DELAY |  |  | CALL DELAY |  |
|  | MOV R3,\#88H |  |  | MOV R3,\#0B0H |  |
|  | CALL NAIK |  |  | CALL NAIK |  |
|  | MOV R3,\#07H |  |  | MOV R3,\#08H |  |
|  | CALL LEMPAR |  |  | CALL LEMPAR |  |
|  | MOV R3,\#84H |  |  | MOV R3,\#0ACH |  |
|  | CALL TURUN |  |  | CALL TURUN |  |
|  | AJMP NN |  |  | AJMP NN |  |
| TG9: | CJNE A,\#27H,E0 | ;JARAK 39 CM | E5: | CJNE A,\#22H,E6 | ;JARAK 45 CM |
|  | MOV P2,\#39H |  |  | MOV P2,\#45H |  |
|  | CALL DELAY |  |  | CALL DELAY |  |
|  | MOV R3,\#88H |  |  | MOV R3,\#0B0H |  |
|  | CALL NAIK |  |  | CALL NAIK |  |
|  | MOV R3,\#07H |  |  | MOV R3,\#09H |  |
|  | CALL LEMPAR |  |  | CALL LEMPAR |  |
|  | MOV R3,\#84H |  |  | MOV R3,\#0ACH |  |
|  | CALL TURUN |  |  | CALL TURUN |  |
|  | AJMP NN |  |  | AJMP NN |  |
| E0: | CJNE A,\#26H,E1 | ;JARAK 40 CM | E6: | CJNE A,\#21H,E7 | ;JARAK 46 CM |
|  | MOV P2,\#40H |  |  | MOV P2,\#46H |  |
|  | CALL DELAY |  |  | CALL DELAY |  |
|  | MOV R3,\#88H |  |  | MOV R3,\#0B0H |  |
|  | CALL NAIK |  |  | CALL NAIK |  |
|  | MOV R3,\#08H |  |  | MOV R3,\#09H |  |
|  | CALL LEMPAR |  |  | CALL LEMPAR |  |
|  | MOV R3,\#84H |  |  | MOV R3,\#0ACH |  |
|  | CALL TURUN |  |  | CALL TURUN |  |
|  | AJMP NN |  |  | AJMP NN |  |


| E7: | CJNE A,\#20H,E8 <br> MOV P2,\#47H <br> CALL DELAY <br> MOV R3,\#0B0H <br> CALL NAIK <br> MOV R3,\#09H <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 47 CM | EN5: | CJNE A,\#1BH,TJ0 <br> MOV P2,\#65H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#0DH <br> CALL LEMPAR <br> MOV R3,\#0ACH <br> CALL TURUN <br> AJMP NN | ;JARAK 65 CM |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E8: | CJNE A,\#1FH,L0 <br> MOV P2,\#48H <br> CALL DELAY <br> MOV R3,\#60H <br> CALL NAIK <br> MOV R3,\#0AH <br> CALL LEMPAR <br> MOV R3,\#5CH <br> CALL TURUN <br> AJMP NN | ;JARAK 48 CM | TJ0: | CJNE A,\#1AH,TJ5 <br> MOV P2,\#70H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#OEH <br> CALL LEMPAR <br> MOV R3,\#OACH <br> CALL TURUN <br> AJMP NN | ;JARAK 70 CM |
| L0: | CJNE A,\#1EH,L5 <br> MOV P2,\#50H <br> CALL DELAY <br> MOV R3,\#60H <br> CALL NAIK <br> MOV R3,\#0AH <br> CALL LEMPAR <br> MOV R3,\#5CH <br> CALL TURUN <br> AJMP NN | ;JARAK 50 CM | TJ5: | CJNE A,\#19H,LP <br> MOV P2,\#75H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#OEH <br> CALL LEMPAR <br> MOV R3,\#OACH <br> CALL TURUN <br> AJMP NN | ;JARAK 75 CM |
| L5: | CJNE A,\#1DH,EN0 <br> MOV P2,\#55H <br> CALL DELAY <br> MOV R3,\#88H <br> CALL NAIK <br> MOV R3,\#0BH <br> CALL LEMPAR <br> MOV R3,\#84H <br> CALL TURUN <br> AJMP NN | ;JARAK 55 CM | LP: <br> NN: | MOV P2,\#80H <br> CALL DELAY <br> MOV R3,\#OB0H <br> CALL NAIK <br> MOV R3,\#OEH <br> CALL LEMPAR <br> MOV R3,\#OACH <br> CALL TURUN <br> AJMP NN <br> MOV P1,\#00H <br> MOV R3,\#0FFH | ;JARAK 80 CM |
| EN0: | CJNE A,\#1CH,EN5 <br> MOV P2,\#60H <br> CALL DELAY <br> MOV R3,\#88H <br> CALL NAIK <br> MOV R3,\#0CH <br> CALL LEMPAR <br> MOV R3,\#84H <br> CALL TURUN <br> AJMP NN | ;JARAK 60 CM | END | CALL DELAY1 |  |


[^0]:    Z-80® is a registered trademark of Zilog Corp.

[^1]:    (Notice) - In the absence of device specification sheets, SHARP takes no responsibility for any defects that may occur in equipment using any SHARP device shown in catalogs, data books, etc. Contact SHARP in order to obtain the latest device specification sheets before using any SHARP device.

    - Specifications are subject to change without notice for improvement.
    (Internet) • Data for SHARP's optoelectronic/power device is provided on internet. (Address http://www.sharp.co.jp/ecg/)

