# PHILIPS 

## Data handbook

PHIups Electronic<br>components<br>and materials

## Integrated circuits <br> Book IC14 <br> 1987



## Microcontrollers and peripherals

## Bipolar, MOS

$\frac{\bar{?}}{\square}$
2861

## MICROCONTROLLERS AND PERIPHERALS

page
Selection guide ..... 1
Functional index ..... 3
Numerical index ..... 9
Maintenance type list ..... 16
Ordering information ..... 18
Type designation ..... 20
Product status definitions ..... 22
Rating systems ..... 25
Handling MOS devices ..... 28
Single-chip 8-bit microcontroller (NMOS, CMOS)* ..... 29
Single-chip 8-bit microcontrollers (bipolar) ..... 511
Standard products ..... 513
Product support ..... 707
Software support. ..... 763
Special purpose circuits. ..... 767
Digital signal processor (DSP) ..... 853
Video display ..... 903
Speech/sound synthesizers ..... 1003
$I^{2}$ C-bus peripherals* ..... 1059
Package information ..... 1243
Package outlines ..... 1249
Soldering. ..... 1277
User Manual 1986
"Single-chip 8-bit Microcontrollers" Available on request

## DATA HANDBOOK SYSTEM

Our Data Handbook System comprises more than 60 books with specifications on electronic components, subassemblies and materials. It is made up of four series of handbooks:
ELECTRON TUBES ..... BLUE
SEMICONDUCTORS ..... RED
INTEGRATED CIRCUTTS
PURPLE
COMPONENTS AND MATERIALS
GREEN

The contents of each series are listed on pages iv to vii.
The data handbooks contain all pertinent data available at the time of publication, and each is revised and reissued periodically.
When ratings or specifications differ from those published in the preceding edition they are indicated with arrows in the page margin. Where application information is given it is advisory and does not form part of the product specification.
Condensed data on the preferred products of Philips Electronic Components and Materials Division is given in our Preferred Type Range catalogue (issued annually).
Information on current Data Handbooks and on how to obtain a subscription for future issues is available from any of the Organizations listed on the back cover.
Product specialists are at your service and enquiries will be answered promptly.

## ELECTRON TUBES (BLUE SERIES)

The blue series of data handbooks comprises:
T1 Tubes for r.f. heating
T2a Transmitting tubes for communications, glass types
T2b Transmitting tubes for communications, ceramic types
T3 Klystrons
T4 Magnetrons for microwave heating
T5 Cathode-ray tubes
Instrument tubes, monitor and display tubes, C.R. tubes for special applications
T6 Geiger-Müller tubes
T8 Colour display systems
Colour TV picture tubes, colour data graphic display tube assemblies, deflection units
T9 Photo and electron multipliers
T10 Plumbicon camera tubes and accessories
T11 Microwave semiconductors and components
T12 Vidicon and Newvicon camera tubes
T13 Image intensifiers and infrared detectors
T15 Dry reed switches
T16 Monochrome tubes and deflection units
Black and white TV picture tubes, monochrome data graphic display tubes, deflection units

## SEMICONDUCTORS (RED SERIES)

The red series of data handbooks comprises:

> S1 Diodes
> Small-signal silicon diodes, voltage regulator diodes $(<1,5 \mathrm{~W})$, voltage reference diodes, tuner diodes, rectifier diodes

## S2a Power diodes

## S2b Thyristors and triacs

S3 Small-signal transistors
S4a Low-frequency power transistors and hybrid modules
S4b High-voltage and switching power transistors
S5 Field-effect transistors
S6 R.F. power transistors and modules
S7 Surface mounted semiconductors

S8a Light-emitting diodes
S8b Devices for optoelectronics
Optocouplers, photosensitive diodes and transistors, infrared light-emitting diodes and infrared sensitive devices, laser and fibre-optic components

S9 Power MOS transistors
S10 Wideband transistors and wideband hybrid IC modules
S11 Microwave transistors

S12 Surface acoustic wave devices

S13 Semiconductor sensors
*S14 Liquid Crystal Displays
*To be issued shortly.

## INTEGRATED.CIRCUITS (PURPLE SERIES)

The NEW SERIES of handbooks is now completed. With effect from the publication date of this handbook the " N " in the handbook code number will be deleted. Handbooks to be replaced during 1986 are shown below.
The purple series of handbooks comprises:

| IC01 | Radio, audio and associated systems Bipolar, MOS | new issue 1986 IC01N 1985 |
| :---: | :---: | :---: |
| IC02a/b | Video and associated systems Bipolar, MOS | new issue 1986 <br> IC02Na/b 1985 |
| IC03 | Integrated circuits for telephony Bipolar, MOS | new issue 1986 IC03N 1985 |
| ICO4 | HE4000B logic family CMOS | $\begin{aligned} & \text { new issue } 1986 \\ & \text { IC4 } 1983 \end{aligned}$ |
| IC05N | HE4000B logic family - uncased ICs CMOS | published 1984 |
| IC06N | High-speed CMOS; PC74HC/HCT/HCU Logic family | published 1986 |
| IC08 | ECL 10 K and 100 K logic families | New issue 1986 IC08N 1984 |
| IC09N | TTL logic series | published 1986 |
| IC10 | Memories MOS, TTL, ECL | new issue 1986 <br> IC7 1982 |
| IC11N | Linear LSI | published 1985 |
| Supplement to IC11N | Linear LSI | published 1986 |
| IC12 | $1^{2} \mathrm{C}$-bus compatible ICs | not yet issued |
| IC13 | Semi-custom <br> Programmable Logic Devices (PLD) | $\begin{aligned} & \text { new issue } 1986 \\ & \text { IC13N } 1985 \end{aligned}$ |
| IC14 | Microcontrollers and peripherals Bipolar, MOS | published 1986 |
| IC15 | FAST TTL logic series | new issue 1986 IC15N 1985 |
| IC16 | CMOS integrated circuits for clocks and watches | first issue 1986 |
| IC17 | Integrated Services Digital Networks (ISDN) | not yet issued |
| IC18 | Microprocessors and peripherals | new issue 1986 |

## COMPONENTS AND MATERIALS (GREEN SERIES)

The green series of data handbooks comprises:
C2 Television tuners, coaxial aerial input assemblies, surface acoustic wave filters
C3 Loudspeakers
C4 Ferroxcube potcores, square cores and cross cores
C5 Ferroxcube for power, audio/video and accelerators
C6 Synchronous motors and gearboxes
C7 Variable capacitors
C8 Variable mains transformers
C9 Piezoelectric quartz devices
C11 Varistors, thermistors and sensors
C12 Potentiometers, encoders and switches
C13 Fixed resistors
C14 Electrolytic and solid capacitors
C15 Ceramic capacitors
C16 Permanent magnet materials
C17 Stepping motors and associated electronics
C18 Direct current motors
C19 Piezoelectric ceramics
C20 Wire-wound components for TVs and monitors
C22 Film capacitors

## SELECTION GUIDE

Functional index ..... 3
Numerical index ..... 9
Maintenance type list ..... 16

## FUNCTIONAL INDEX

type numberdescription

## SINGLE-CHIP 8-BIT MICROCONTROLLERS

NMOS

|  | RAM | ROM |  |  |
| :---: | :---: | :---: | :---: | :---: |
| MAB8035HLP; HLWP | 64 | - | ROM-less version of MAB8048H | 97 |
| MAF8035HLP | 64 | - | ROM-less version of MAB8048H; extended temperature | 97 |
| MAF80A35HLP | 64 | - | ROM-less version of MAB8048H; automotive temperature; reduced frequency | 97 |
| MAB8048HP; HWP | 64 | 1K |  | 97 |
| MAF8048HP | 64 | 1K | like MAB8048H; extended temperature | 97 |
| MAF80A48HP | 64 | 1K | like MAB8048H; automotive temperature; reduced frequency | 97 |
| MAB8411P; T | 64 | 1K | plus 8-bit LED driver | 123 |
| MAF8411P | 64 | 1K | plus 8-bit LED driver; extended temperature | 123 |
| MAF84A11P | 64 | 1K | plus 8-bit LED driver; automotive temperature; reduced frequency | 123 |
| MAB8421P; T | 64 | 2K | plus 8-bit LED driver | 123 |
| MAF8421P | 64 | 2K | plus 8-bit LED driver; extended temperature | 123 |
| MAF84A21P | 64 | 2K | plus 8-bit LED driver; automotive temperature; reduced frequency | 123 |
| MAB8422P | 64 | 2K | plus 8-bit LED driver | 155 |
| MAF8422P | 64 | 2K | plus 8-bit LED driver; extended temperature | 155 |
| MAF84A22P | 64 | 2K | plus 8-bit LED driver; automotive temperature; reduced frequency | 155 |
| MAB8031AHP; AHWP | 128 | - | ROM-less version of MAB8051AH | 31 |
| MAF8031AHP; AHWP | 128 | - | ROM-less version of MAB8051AH; extended temperature | 31 |
| MAF80A31AHP; AHWP | 128 | - | ROM-less version of MAB8051AH; automotive temperature; reduced frequency | 31 |
| MAB8039HLP; HLWP | 128 | - | ROM-less version of MAB8049H | 97 |
| MAF8039HLP | 128 | - | ROM-less version of MAB8049H; extended temperature | 97 |
| MAF80A39HLP | 128 | - | ROM-less version of MAB80A49H; automotive temperature; reduced frequency | 97 |
| MAB8401B; WP | 128 | - | bond-out version for MAB84X1 family plus 8 -bit LED-driver | 123 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$; except MAF80A31/51AH only -40 to $+100^{\circ} \mathrm{C}$.

| type number | description |  |  | page |
| :---: | :---: | :---: | :---: | :---: |
| SINGLE-CHIP 8-BIT MICROCONTROLLERS (continued) |  |  |  |  |
| NMOS (continued) |  |  |  |  |
|  | RAM | ROM |  |  |
| MAB8049HP; HWP | 128 | 2K |  | 97 |
| MAF8049HP | 128 | 2K | like MAB8049H; extended temperature | 97 |
| MAF80A49HP | 128 | 2K | like MAB8049H; automotive temperature; reduced frequency | 97 |
| MAB8051AHP; AHWP | 128 | 4K | mask-programmable ROM | 31 |
| MAF8051AHP; AHWP | 128 | 4K | like MAB8051AH; extended temperature | 31 |
| MAF80A51AHP; AHWP | 128 | 4K | like MAB8051AH; aotomotive temperature; reduced frequency | 31 |
| MAB8441P; T | 128 | 4K | plus 8-bit LED driver | 123 |
| MAF8441P | 128 | 4K | plus 8-bit LED driver; extended temperature | 123 |
| MAF84A41P | 128 | 4K | plus 8 -bit LED driver; automotive temperature; reduced frequency | 123 |
| MAB8442P | 128 | 4K | plus 8-bit LED driver | 155 |
| MAF8442P | 128 | 4K | plus 8-bit LED driver; extended temperature | 155 |
| MAF84A42P | 128 | 4K | plus 8 -bit LED driver; automotive temperature; reduced frequency | 155 |
| MAB8461P; T | 128 | 6K | plus 8-bit LED driver | 123 |
| MAF8461P | 128 | 6K | plus 8-bit LED driver; extended temperature | 123 |
| MAF84A61P | 128 | 6K | plus 8-bit LED driver; automotive temperature; reduced frequency | 123 |
| MAB8032AHP; AHWP | 256 | - | ROM-less version of MAB8052AH | 65 |
| MAB8040HLP; HLWP | 256 | - | ROM-less version of MAB8050H | 97 |
| MAF8040HLP | 256 | - | ROM-less version of MAB8050H; extended temperature | 97 |
| MAF80A40HLP | 256 | - | ROM-less version of MAB8050H; automotive temperature; reduced frequency | 97 |
| MAB8050HP; HWP | 256 | 4K |  |  |
| MAF8050HP | 256 | 4K | like MAB8050H; extended temperature | 97 |
| MAF80A50HP | 256 | 4K | like MAB8050H; automotive temperature; reduced frequency | 97 |
| MAB8052AHP | 256 | 8K | mask-programmable ROM | 65 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85{ }^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$ except MAF80A31/51AH only -40 to $+100^{\circ} \mathrm{C}$.

| type number | description |  |  | page |
| :---: | :---: | :---: | :---: | :---: |
| SINGLE-CHIP 8-BIT MICROCONTROLLERS |  |  |  |  |
| cmos |  |  |  |  |
|  | RAM | ROM |  |  |
| PCF84C12P; T | 64 | 1K |  | 395 |
| PCF84C21P; T | 64 | 2K | plus 8-bit LED driver; extended temperature | 423 |
| PCB85C51B | 128 | - | software development version of PCB80C51 | 319 |
| PCB80C31BHP; BHWP | 128 | - | ROM-less version of PCB80C51 | 175 |
| PCF80C31BHP; BHWP | 128 | - | ROM-less version of PCB80C51 | 175 |
| PCBC39P; WP | 128 | - | ROM-less version of PCB80C49 | 203 |
| PCF80C39P | 128 | - | ROM-less version of PCF80C49; extended temperature | 203 |
| PCB80C49P; WP | 128 | 2K |  | 203 |
| PCF80C49P | 128 | 2K | like PCB80C49; extended temperature | 203 |
| PCB80C51BHP; BHWP | 128 | 4K | mask-programmable ROM | 175 |
| PCF80C51BHP; BHWP | 128 | 4K | mask-programmable ROM | 175 |
| PCF84C41P; T | 128 | 4K | plus 8-bit LED driver; extended temperature | 423 |
| PCD3315CP; $T$ | 160 | 1K | telephony microcontroller | 351 |
| PCD3343D; P ; T | 224 | 3K | telephony microcontroller | 355 |
| PCB80C552WP | 256 | - | ROM-less version of PCB83C552 | 233 |
| PCB80C652WP | 256 | - | ROM-less version of PCB83C652 | 281 |
| PCF84C00B; ${ }^{\text {T }}$ | 256 | - | bond-out version of PCF84CXX family | 423 |
| PCB83C552WP | 256 | 8K | PCB80C51 plus additional functions | 233 |
| PCB83C652WP | 256 | 8K | PCB80C51 plus additional functions | 281 |
| PCF84C81P; T | 256 | 8K | plus 8-bit LED driver; extended temperature | 423 |
| PCF84C85P; T | 256 | 8K | $32 \mathrm{I} / \mathrm{O}$; extended temperature | 471 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$.
type number description page
8-BIT MICROCONTROLLERS (bipolar)
8×300 microcontroller; 250 ns cycle time ..... 515
$8 \times 305$ microcontroller; 200 ns cycle time ..... 535
$8 \times 310$ interrupt control coprocessor ..... 557
$8 \times 320$$8 \times 330$$8 \times 350$8X353bus interface register array; 2-port RAM for $8 / 16$-bitinterface between a host and peripheral processor569
floppy disk formatter/controller ..... 577
2048-bit bipolar RAM ( $256 \times 8$ ); high-speed memory with bus interface ..... 593
bipolar RAM ( $32 \times 8$ ); high-speed memory with bus interface ..... 597
LIFO stack memory ( $32 \times 8$ ); high-speed LIFO stack with bus interface ..... 605
8×360 memory address director ..... 613
$8 \times 371$ latched bidirectional I/O ports ..... 615
$8 \times 372$ addressable/bidirectional I/O ports; synchronous ..... 623
$8 \times 374$ addressable/bidirectional I/O ports; synchronous with parity ..... 633
$8 \times 376$ addressable/bidirectional I/O ports; asynchronous ..... 623
$8 \times 382$ 4-input/4-output Addressable I/O ports ..... 643
$8 \times 401$ microcontroller ..... 653
8X450 RAM (256 byte) ..... 673
8X470 I/O port ..... 681
8T31
8-bit latched bidirectional 1/O ports; synchronous ..... 695
8 T32
8-bit latched addressable bidirectional I/O ports; synchronous ..... 699
8T36 8 -bit latched addressable bidirectional I/O ports; asynchronous ..... 699
Product support
Product support 8×300 family ..... 709
8X300KT1SK 8X305 Prototyping System ..... 711
$8 \times 305$ ICEPACK ..... 731
8×300/8×305 development data I/O port programmer ..... 733
8×330
ECC application note ..... 735
Software support
8X300AS1SS MCCAP cross assembler program ..... 765
8X300AS2SS MCCAP cross assembler ..... 766
Special purpose circuits
8X01A8X02A940194038×418×6029602964B
CRC generator/checker; Synchronous Data Link Control (SDLC) ..... 769
control store sequencer ..... 775
CRC generator/checker ..... 769
64 -bit FIFO buffer memory ( $16 \times 4$ ) ..... 843
autodirectional bus transceiver ..... 783
FIFO RAM Controller (FRC) ..... 789
Error Detection and Correction (EDC) Unit ..... 797
dynamic memory controller ..... 831
type number description page
DIGITAL SIGNAL PROCESSOR (DSP)
PCB5010 digital signal processor with on-chip ROM ..... 855
PCB5011 ROM-less version of PCB5010 ..... 855
VIDEO DISPLAY
SAA5350 colour CRT controller (EUROM); CEPT standard ..... 905
SCN2670 Display Character and Graphics Generator (DCGG) ..... 933
SCN2671 Programmable keyboard \& Comm Controller (PKCC) ..... 949
App Note 401
using the 2670/71/72/73 CRT terminal chip set ..... 971
App Note 403 2670/71/72/73 CRT set application briefs ..... 987
TEA2000 PAL/NTSC colour encoder ..... 995
SPEECH/SOUND SYNTHESIZERS
MEA8000 voice synthesizer ..... 1005
PCF8200 voice synthesizer (CMOS) ..... 1029
OM8200 speech demonstration board (for PCF8200) ..... 1019
OM8201 speech demonstration box (for OM8200) ..... 1023
OM8210 speech analysis/editing system (for PCF8200) ..... 1025
SAA 1099
stereo sound generator for sound effects and music
stereo sound generator for sound effects and music synthesis ( $\mu \mathrm{C}$ controlled) ..... 1043
$1^{2} \mathrm{C}$-BUS PERIPHERALS

PCB8582P
PCF8566P; T

PCF8570P; T
PCF8571D; P; T
PCF8573P; T
PCF8574P; T
PCF8576T; U

PCF8577P; T
PCF8577AP; AT

PCF8583P; T
PCF8591P; T
$256 \times 8$ EEPROM ..... 1061
universal LCD driver for low multiplex rates
(1:1 to $1: 4$ ); max. 96 segments ..... 1069
$256 \times 8$ static RAM ..... 1099
$128 \times 8$ static RAM ..... 1111
clock calendar ..... 1123
remote 8-bit I/O enpander ..... 1141
universal LCD driver for low multiplex rates (1: 1 to $1: 4$ ); max. 160 segments ..... 1155
LCD direct driver ( 32 segments) or duplex driver ( 64 segments) ..... 1191
LCD direct driver ( 32 segments) or duplex driver ( 64 segments); different slave address ..... 1191
$256 \times 8$-bit static RAM with alarm clock /calendar and BCD-counter ..... 1207
8 -bit $A / D$ and $D / A$ converter ..... 1225

## NUMERICAL INDEX

| type number | description |  |  | package code | page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SINGLE-CHIP 8-BIT MICROCONTROLLERS |  |  |  |  |  |
|  | RAM | ROM |  |  |  |
| MAB8031AHP | 128 | - | ROM-less version of MAB8051AH | DIL-40; SOT-129 | 31 |
| MAB8031AHWP | 128 | - | ROM-less version of MAB8051AH | 44-PLCC; SOT-187A | 31 |
| MAB8032AHP | 256 | - | ROM-less version of MAB8052AH | DIL-40; SOT-129 | 65 |
| MAB8035HLP | 64 | - | ROM-less version of MAB8048H | DIL-40; SOT-129 | 97 |
| MAB8035HLWP | 64 | - | ROM-less version of MAB8048H | 44-PLCC; SOT-187A | 97 |
| MAB8039HLP | 128 | - | ROM-less version of MAB8049H | DIL-40; SOT-129 | 97 |
| MAB8039HLWP | 128 | - | ROM-less version of MAB8049H | 44-PLCC; SOT-187A | 97 |
| MAB8040HLP | 256 | - | ROM-less version of MAB8050H | DIL-40; SOT-129 | 97 |
| MAB8040HLWP | 256 | - | ROM-less version of MAB8050H | 44-PLCC; SOT-187A | 97 |
| MAB8048HP | 64 | 1K |  | DIL-40; SOT-129 | 97 |
| MAB8048HWP | 64 | 1K |  | 44-PLCC; SOT-187A | 97 |
| MAB8049HP | 128 | 2K |  | DIL-40; SOT-129 | 97 |
| MAB8049HWP | 128 | 2K |  | 44-PLCC; SOT-187A | 97 |
| MAB8050HP | 256 | 4K |  | DIL-40; SOT-129 | 97 |
| MAB8050HWP | 256 | 4K |  | 44-PLCC; SOT-187A | 97 |
| MAB8051AHP | 128 | 4K | mask-programmable ROM | DIL-40; SOT-129 | 31 |
| MAB8051AHWP | 128 | 4K | mask-programmable ROM | 44-PLCC; SOT-187A | 31 |
| MAB8052AHP | 256 | 8K | mask-programmable ROM | DIL-40; SOT-129 | 65 |
| MAB8401B | 128 | - | bond-out version for MAB84X1 family plus 8-bit LED-driver | 28/28 Piggy-back | 123 |
| MAB8401WP | 128 | - | bond-out version for MAB84X1 family plus 8-bit LED-driver | 68-PLCC; SOT-188A | 123 |
| MAB8411P | 64 | 1K | plus 8-bit LED driver | DIL-28; SOT-117 | 123 |
| MAB8411T | 64 | 1K | plus 8-bit LED driver | SO-28; SOT-136A | 123 |
| MAB8421P | 64 | 2K | plus 8-bit LED driver | DIL-28; SOT-117 | 123 |
| MAB8421T | 64 | 2K | plus 8-bit LED driver | SO-28; SOT-136A | 123 |
| MAB8422P | 64 | 2K | plus 8-bit LED driver | DIL-20; SOT-146 | 155 |
| MAB8441P | 128 | 4K | plus 8-bit LED driver | DIL-28; SOT-117 | 123 |
| MAB8441T | 128 | 4K | plus 8-bit LED driver | SO-28; SOT-136A | 123 |
| MAB8442P | 128 | 4K | plus 8-bit LED driver | DIL-20; SOT-146 | 155 |
| MAB8461P | 128 | 6K | plus 8-bit LED driver | DIL-28; SOT-117 | 123 |
| MAB8461T | 128 | 6K | plus 8-bit LED driver | SO-28; SOT-136A | 123 |


| type number | description |  |  | package code | page |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | RAM | ROM |  |  |  |
| MAF8031AHP | 128 | - | ROM-less version of MAB8051AH; extended temperature | DIL-40; SOT-129 | 31 |
| MAF8031AHWP | 128 | - | ROM-less version of MAB8051AH; extended temperature | 44-PLCC; SOT-187A | 31 |
| MAF80A31AHP | 128 | - | ROM-less version of MAB8051AH; automotive temperature; reduced frequency | DIL-40; SOT-129 | 31 |
| MAF80A31AHWP | 128 | - | ROM-less version of MAB8051AH; automotive temperature; reduced frequency | 44-PLCC; SOT-187A | 31 |
| MAF8035HLP | 64 | - | ROM-less version of MAB8048H; extended temperature | DIL-40; SOT-129 | 97 |
| MAF80A35HLP | 64 | - | ROM-less version of MAB8048H; automotive temperature; reduced frequency | DIL-40; SOT-129 | 97 |
| MAF8039HLP | 128 | - | ROM-less version of MAB8049H; extended temperature | DIL-40; SOT-129 | 97 |
| MAF80A39HLP | 128 | - | ROM-less version of MAB8049H; automotive temperature; reduced frequency | DIL-40; SOT-129 | 97 |
| MAF8040HLP | 256 | - | ROM-less version of MAB8050H; extended temperature | DIL-40; SOT-129 | 97 |
| MAF80A40HLP | 256 | - | ROM-less version of MAB8050H; automotive temperature; reduced frequency | DIL-40; SOT-129 | 97 |
| MAF8048HP | 64 | 1K | like MAB8048H; extended temperature | DIL-40; SOT-129 | 97 |
| MAF80A48HP | 64 | 1K | like MAB8048H; automotive temperature; reduced frequency | DIL-40; SOT-129 | 97 |
| MAF8049HP | 128 | 2K | like MAB8049H; extended temperature | DIL-40; SOT-129 | 97 |
| MAF80A49HP | 128 | 2K | like MAB8049H; automotive temperature; reduced frequency | DIL-40; SOT-129 | 97 |
| MAF8050HP | 256 | 4K | like MAB8050H; extended temperature | DIL-40; SOT-129 | 97 |
| MAF80A50HP | 256 | 4K | like MAB8050H; automotive temperature; reduced frequency | DIL-40; SOT-129 | 97 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$;
except MAF80A31/51AH only -40 to $+100^{\circ} \mathrm{C}$.

| type number | description |  |  | package code | page |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | RAM | ROM |  |  |  |
| MAF8051AHP | 128 | 4K | like MAB8051AH; extended temperature | DIL-40; SOT-129 | 31 |
| MAF8051AHWP | 128 | 4K | like MAB8051AH; extended temperature | 44-PLCC; SOT-187A | 31 |
| MAF80A51AHP | 128 | 4K | like MAB8051AH; automotive temperature; reduced frequency | DIL-40; SOT-129 | 31 |
| MAF80A51AHWP | 128 | 4K | like MAB8051AH; automotive temperature; reduced frequency | 44-PLCC; SOT-187A | 31 |
| MAF8411P | 64 | 1K | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 123 |
| MAF84A11P | 64 | 1K | plus 8-bit LED driver; automotive temperature; reduced frequency | DIL-28; SOT-117 | 123 |
| MAF8421P | 64 | 2K | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 123 |
| MAF84A21P | 64 | 2K | plus 8-bit LED driver; automotive temperature; reduced frequency | DIL-28; SOT-117 | 123 |
| MAF8422P | 64 | 2K | plus 8-bit LED driver; extended temperature | DIL-20; SOT-146 | 155 |
| MAF84A22P | 64 | 2K | plus 8-bit LED driver; automotive temperature; reduced frequency | DIL-20; SOT-146 | 123 |
| MAF8441P | 128 | 4K | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 123 |
| MAF84A41P | 128 | 4K | plus 8-bit LED driver; automotive temperature; reduced frequency | DIL-28; SOT-117 | 123 |
| MAF8442P | 128 | 4K | plus 8-bit LED driver; extended temperature | DIL-20; SOT-146 | 155 |
| MAF84A42P | 128 | 4K | plus 8-bit LED driver; automotive temperature; reduced frequency | DIL-20; SOT-146 | 155 |
| MAF846iP | 128 | 6K | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 123 |
| MAF84A61P | 128 | 6K | plus 8-bit LED driver; automotive temperature; reduced frequency | DIL-28; SOT-117 | 123 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$;
except MAF80A31/51AH only -40 to $+100^{\circ} \mathrm{C}$.

| type number | description | package code | page |
| :--- | :--- | :--- | ---: |
| MEA8000 | voice synthesizer | DIL-24; SOT-101A | 1005 |
| OM8200 | speech demonstration board (for PCF8200) | standard Eurocard | 1019 |
| OM8201 | speech demonstration box (for OM8200) | special pack | 1023 |
| OM8210 | speech analysis/editing system (for PCF8200) | special pack | 1025 |
| PCB5010 | digital signal processor woth on-chip ROM | 68-PLCC; SOT-188A | 855 |
| PCB5011 | ROM-less version of PCB5010 | 144-PGA | 855 |

SINGLE-CHIP 8-BIT MICROCONTROLLERS (continued)

|  | RAM | ROM |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PCB80C31BHP | 128 | - | ROM-less version of PCB80C51 | DIL-40; SOT-129 | 175 |
| PCB80C31BHWP | 128 | - | ROM-less version of PCB80C51 | 44-PLCC; SOT-187A | 175 |
| PCB80C39P | 128 | - | ROM-less version of PCB80C49 | DIL-40; SOT-129 | 203 |
| PCB80C39WP | 128 | - | ROM-less version of PCB80C49 | 44-PLCC; SOT-187A | 203 |
| PCB80C49P | 128 | 2K |  | DIL-40; SOT-129 | 203 |
| PCB80C49WP | 128 | 2K |  | 44-PLCC; SOT-187A | 203 |
| PCB80C51BHP | 128 | 4K | mask-programmable ROM | DIL-40; SOT-129 | 175 |
| PCB80C51BHWP | 128 | 4K | mask-programmable ROM | 44-PLCC; SOT-187A | 175 |
| PCB80C552WP | 256 | - | ROM-less version of PCB83C552 | 68-PLCC; SOT-188A | 233 |
| PCB80C652WP | 256 | - | ROM-less version of PCB83C652 | 44-PLCC; SOT-187A | 281 |
| PCB83C552WP | 256 | 8K | PCB80C51 plus additional functions | 68-PLCC; SOT-188A | 233 |
| PCB83C652WP | 256 | 8K | PCB80C51 plus additional functions | 44-PLCC; SOT-187A | 281 |
| PCB85C51B | 128 | - | software development version of PCB80C51 | DIL-40; SOT-215 | 319 |
| PCB8582 | $256 \times 8$ EEPROM ${ }^{\text {I }}{ }^{2} \mathrm{C}$ bus |  |  | DIL-8; SOT-97AE | 1061 |

SINGLE-CHIP 8-BIT MICROCONTROLLERS (continued)

|  | RAM | ROM |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PCD3315CP | 160 | 1,2K | telephony microcontroller | DIL-28; SOT-117 | 351 |
| PCD3315CT | 160 | 1,2K | telephony microcontroller | SO-28; SOT-136A | 351 |
| PCD3343D | 224 | 3K | telephony microcontroller | DIL-28; SOT-135A | 355 |
| PCD3343P | 224 | 3K | telephony microcontroller | DIL-28; SOT-117 | 355 |
| PCD3343T | 224 | 3K | telephony microcontroller | SO-28; SOT-136A | 355 |
| PCF80C31BHP | 128 | - | ROM-less version of PCB80C51 | DIL-40; SOT-129 | 175 |
| PCF80C31BHWP | 128 | - | ROM-less version of PCB80C51 | 44-PLCC; SOT-187A | 175 |
| PCF80C39P | 128 | - | ROM-less version of PCF80C49; extended temperature | DIL-40; SOT-129 | 203 |
| PCF80C49P | 128 | 2K | like PCB80C49; extended temperature | DIL-40; SOT-129 | 203 |
| PCF80C51BHP | 128 | 4K | mask-programmable ROM | DIL-40; SOT-129 | 175 |
| PCB80C51BHWP | 128 | 4K | mask-programmable ROM | 44-PLCC; SOT-187A | 175 |
| PCF8200 | voice synthesizer (CMOS) |  |  | DIL-24; SOT-101A | 1029 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$.

| type number | description |  |  | package code | page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SINGLE-CHIP 8-BIT MICROCONTROLLERS (continued) |  |  |  |  |  |
|  | RAM | ROM |  |  |  |
| PCF84C00B | 256 | - | bond-out version PCF84CXX family | 28/28 Piggy-back | 423 |
| PCF84C00T | 256 | - | bond-out version PCF84CXX family | VSO-56; SOT-190 | 423 |
| PCF84C12P | 64 | 1 K |  | DIL-20; SOT-146 | 395 |
| PCF84C12T | 64 | 1 K |  | SO-20; SOT-163A | 395 |
| PCF84C21P | 64 | 2K | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 423 |
| PCF84C21T | 64 | 2K | plus 8-bit LED driver; extended temperature | SO-28; SOT-136A | 423 |
| PCF84C41P | 128 | 4K | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 423 |
| PCF84C41T | 128 | 4K | plus 8 -bit LED driver; extended temperature | SO-28; SOT-136A | 423 |
| PCF84C81P | 256 |  | plus 8-bit LED driver; extended temperature | DIL-28; SOT-117 | 423 |
| PCF84C81T | 256 | 8K | plus 8 -bit LED driver; extended temperature | SO-28; SOT-136A | 423 |
| PCF84C85P | 256 | 8K | 32 I/O; extended temperature | DIL-40; SOT-129 | 471 |
| PCF84C85T | 256 | 8K | 32 1/O; extended temperature | VSO-40; SOT-158A | 471 |
| PCF8566P | universal LCD driver for low multiplex rates ( $1: 1$ to $1: 4$ ); max. 96 segments |  |  | DIL-40; SOT-129 | 1069 |
| PCF8566T | universal LCD driver for low multiplex rates (1:1 to $1: 4$ ); max. 96 segments |  |  | VSO-40; SOT-158A | 1069 |
| PCF8570P | $256 \times 8$ static RAM; ${ }^{2} \mathrm{C}$ bus |  |  | DIL-8; SOT-97AE | 1099 |
| PCF8570T | $256 \times 8$ static RAM; $1^{2} \mathrm{C}$ bus |  |  | SO-8L; SOT-176 | 1099 |
| PCF8571D | $128 \times 8$ static RAM; $1^{2} \mathrm{C}$ bus |  |  | DIL-8; SOT-151A | 1111 |
| PCF8571P | $128 \times 8$ static RAM; $1^{2} \mathrm{C}$ bus |  |  | DIL-8; SOT-97AE | 1111 |
| PCF8571T | $128 \times 8$ static RAM; $1^{2} \mathrm{C}$ bus |  |  | SO-8L; SOT-176 | 1111 |
| PCF8573P | clock calendar with serial 1/Oclock calendar with serial I/O |  |  | DIL-16; SOT-38 | 1123 |
| PCF8573T |  |  |  | SO-16L; SOT-162A | 1123 |
| PCF8574P | remote 8-bit I/O expander |  |  | DIL-16; SOT-38 | 1141 |
| PCF8574T | remote 8-bit 1/O expender |  |  | SO-16L; SOT-162A | 1141 |
| PCF8576T | universal LCD driver for low multiplex rates (1:1 to $1: 4$ ); max. 160 segments |  |  | VSO-56; SOT-190 | 1155 |
| PCF8576U | universal LCD driver for low multiplex rates (1:1 to $1: 4$ ); max. 160 segments |  |  | uncased chip | 1155 |

Operating temperature range: 0 to $70^{\circ} \mathrm{C}$.
Extended temperature range: -40 to $+85^{\circ} \mathrm{C}$.
Automotive temperature range: -40 to $+110^{\circ} \mathrm{C}$.

| type number | description | package code | page |
| :---: | :---: | :---: | :---: |
| PCF8577P | LCD direct driver ( 32 segments) or duplex driver (64 segments) | DIL-40; SOT-129 | 1191 |
| PCF8577T | LCD direct driver ( 32 segments) or duplex driver ( 64 segments) | VSO-40; SOT-158A | 1191 |
| PCF8577AP | LCD direct driver ( 32 segments) or duplex driver (64 segments); different slave address | DIL-40; SOT-129 | 1191 |
| PCF8577AT | LCD direct driver ( 32 segments) or duplex driver (64 segments); different slave address | VSO-40; SOT-158A | 1191 |
| PCF8583P | $256 \times 8$-bit static RAM with alarm clock/calendar and BCD-counter | DIL-8; SOT-97AE | 1207 |
| PCF8583T | $256 \times 8$-bit static RAM with alarm clock/calendar and BCD-counter | SO-8L; SOT-176 | 1207 |
| PCF8591P | 8-bit $A / D$ and D/A converter | DIL-16; SOT-38 | 1225 |
| PCF8591T | 8 -bit $A / D$ and D/A converter | SO-16L; SOT-162A | 1225 |
| SAA1099 | stereo sound generator for sound effects and music synthesis ( $\mu \mathrm{C}$ controlled) | DIL-18; SOT-102ME | 1043 |
| SAA5350 | Colour CRT controller (EUROM) ; CEPT standard | DIL-40; SOT-129 | 905 |
| SCN2670 | Display Character and Graphics Generator (DCGG) | N, I (28-DIL) | 933 |
| SCN2671 | Programmable Keyboard \& Comm Controller (PKCC) | N, I (40-DIL) | 949 |
| TEA2000 | PAL/NTSC colour encoder | DIL-18; SOT-102HE | 995 |
| 8T31 | 8-bit Latched Bidirectional I/O ports; synchronous | N (24-DIL) |  |
| 8 T32 | 8-bit Latched Addressable Bidirectional I/O ports; synchronous | N, F (24-DIL) | 695 699 |
| 8 T 36 | 8-bit Latched Addressable Bidirectional I/O ports; asynchronous | N, F (24-DIL) | 699 |
| 8X01A | CRC Generator/Checker; Synchronous Data Link Control (SDLC) | N, F (14-DIL) | 769 |
| 8X02A | Control Store Sequencer | N (28-DIL) | 775 |
| $8 \times 41$ | Autodirectional Bus Transceiver | N (24-DIL) | 783 |
| $8 \times 60$ | FIFO RAM Controller (FRC) | N, FQ (28-DIL) | 789 |
| $8 \times 300$ | Microcontroller; 250 ns cycle time | 1 (50-DIL) | 515 |
| $8 \times 305$ | Microcontroller; 200 ns cycle time | N, I (50-DIL) | 535 |
| $8 \times 310$ | Interrupt Control Coprocessor | N, I (40-DIL) | 557 |
| $8 \times 320$ | Bus Interface Register Array; 2-port RAM for 8/16-bit interface between a host and peripheral processor | N, I (40-DIL) | 569 |
| $8 \times 330$ | Floppy Disk Formatter/Controller | N (40-DIL) | 577 |
| 8×350 | 2048-bit Bipolar RAM ( $256 \times 8$ ); high-speed memory with bus interface | N, F (22-DIL) | 593 |
| $8 \times 353$ | Bipolar RAM (32 $\times 8$ ); high-speed memory with bus interface | N, F (20-DIL) | 597 |
| $8 \times 355$ | LIFO Stack Memory ( $32 \times 8$ ); high-speed LIFO stack with bus interface | N, F (20-DIL) | 605 |
| $8 \times 360$ | Memory Address Director | N, I (40-DIL) | 613 |
| $8 \times 371$ | Latched Bidirectional I/O ports | N, I (24-DIL) | 615 |
| $8 \times 372$ | Addressable/Bidirectional I/O ports; synchronous | N, I (24-DIL) | 623 |


| type number | description | package code | page |
| :--- | :--- | :--- | :--- |
| $8 \times 374$ | Addressable/Bidirectional I/O ports; synchronous <br> with parity |  |  |
| $8 \times 376$ | Addressable/Bidirectional I/O ports; asynchronous | $\mathrm{N}, \mathrm{F}, \mathrm{I}(28-\mathrm{DIL})$ | 633 |
| $8 \times 382$ | 4-input/4-output Addressable I/O ports | $\mathrm{N}, \mathrm{I}(24-\mathrm{DIL})$ | 623 |
| $8 \times 401$ | Microcontroller | $\mathrm{N}, \mathrm{I}(64-\mathrm{DIL})$ | 643 |
| $8 \times 450$ | RAM (256 byte) | $\mathrm{N}, \mathrm{I}(24-\mathrm{DIL})$ | 653 |
| $8 \times 470$ | I/O port | $\mathrm{N}, \mathrm{I}(24-\mathrm{DIL})$ | 673 |
| 2960 | Error Detection and Correction (EDC) Unit | $\mathrm{N}, \mathrm{I}(48-\mathrm{DIL})$ | 681 |
| 2964 B | Dynamic Memory Controller | -- | 797 |
| 9401 | CRC Generator/Checker | $\mathrm{N}, \mathrm{F}(14-\mathrm{DIL})$ | 831 |
| 9403 | 64-bit FIFO Buffer Memory $(16 \times 4)$ | $\mathrm{N}(24-\mathrm{DIL})$ | 769 |
|  |  |  |  |



Purchase of Philips $1^{2} \mathrm{C}$ components conveys a license under the Philips ${ }^{\prime} 1^{2} \mathrm{C}$ patent to use the components in the $1^{2} \mathrm{C}$ system provided the system conforms to the $I^{2} \mathrm{C}$ specification defined by Philips.

## MAINTENANCE TYPE LIST

The types listed below are not included in this handbook. Detailed information will be supplied on request.

| MAB8021 | single-chip 8-bit microcomputer |  |
| :--- | :--- | ---: |
| single-chip 8-bit microcontroller |  |  |
| MAB8041A | single-chip 8-bit microcontroller | successor type: MAB84X1 |
| MAF84XX |  | MAF84X1 |
| MAF84AX1 |  | MAF84AX1 |
| FAMILY | FAMILY |  |
| PCB80C31 | single-chip 8-bit microcontroller | successor type: PCB80C31B |
| PCB80C51 |  | PCB80C51BH |
| TEA1002 | PAL colour encoder and video summer | successor type: TEA2000 |

## ORDERING INFORMATION

## TYPE DESIGNATION

## PRODUCT STATUS DEFINITIONS

PART NUMBERING SYSTEM

Example: SCN2661AC1N28


## BIPOLAR LSI ORDERING INFORMATION

## 3X300 I/O Peripheral Components

Various 8X300/8X305 MicroController I/O parts and bus expanders can be ordered with an address preprogrammed at the factory or unprogrammed to permit feild address assignment. Addresses in range indicated as STOCK in the table below may be ordered in any quantity. Addresses outside of the STOCK range but indicated as AVAILABLE require a minimum order of 250 pieces per line item per part type. To order, use the part number indicated in the table, substituting the desired address of $x x$ or $x x x$ when ordering preprogrammed parts.

| PART <br> NUMBER | ADDRESSES |  | ORDER NUMBER |  |
| :---: | :---: | :---: | :---: | :---: |
|  | AVAILABLE | STOCK | UNPROGRAMMED | PREPROGRAMMED |
| N8T32F | $000-255$ | None | N8T32F | N8T32F-xxx |
| N8T32N | $000-255$ | $000-015$ | N8T32N | N8T32N-xxx |
| N8T36F | $000-255$ | None | N8T36F | N8T36F-xxx |
| N8T36N | $000-255$ | $000-015$ | N8T36N | N8T36N-xxx |
| N8X372N | $000-255$ | $000-015$ | N8X372N | N8X372N-xxx |
| N8X374N | $000-255$ | $000-015$ | N8X374N | N8X374-xxx |
| N8X376N | $000-255$ | $000-015$ | N8X376N | N8X376N-xxx |
| N8X382N | $000-255$ | $000-015$ | N8X382N | N8X382N-xxx |

## MCCAP 8X300/8X305 CROSSASSEMBLER PROGRAM

MCCAP, the crossassembler program for the $8 \times 300$ and $8 \times 305$ Micro-Controllers, is supplied as a 9 -track magnetic tape containing FORTRAN IV source code for the crossassembler program. For compatibility with various computer systems, the tape is available in various combinations of density and data encoding. To order, use the following part numbers.

| NUMBER | DENSITY | ENCODING |
| :---: | :---: | :---: |
| $8 \times 300$ AS1-1 SS | 800 | ASCII |
| $8 \times 300$ AS1-2 SS | 800 | EBCDIC |
| $8 \times 300$ AS1-3 SS | 1600 | ASCII |
| $8 \times 300$ AS1-4 SS | 1600 | EBCDIC |
| $8 \times 300$ AS2SS | SINGLEI | FLOPPY |
|  | DOUBLE | DISK |

## PRO ELECTRON TYPE DESIGNATION CODE FOR INTEGRATED CIRCUITS

This type nomenclature applies to semiconductor monolithic, semiconductor multi-chip, thin-film, thick-film and hybrid integrated circuits.
A basic number consists of:
THREE LETTERS FOLLOWED BY A SERIAL NUMBER

## FIRST AND SECOND LETTER

1. DIGITAL FAMILY CIRCUITS

The FIRST TWO LETTERS identify the FAMILY (see note 1).
2. SOLITARY CIRCUITS

The FIRST LETTER divides the solitary circuits into:
S: Solitary digital circuits
T : Analogue circuits
U : Mixed analogue/digital circuits
The SECOND LETTER is a serial letter without any further significance except ' H ' which stands for hybrid circuits.
3. MICROPROCESSORS

The FIRST TWO LETTERS identify microprocessors and correlated circuits as follows:
MA : $\left\{\begin{array}{l}\text { Microcomputer } \\ \text { Central processing unit }\end{array}\right.$
MB : Slice processor (see note 2)
MD : Correlated memories
ME : Other correlated circuits (interface, clock, peripheral controller, etc.)
4. CHARGE-TRANSFER DEVICES AND SWITCHED CAPACITORS

The FIRST TWO LETTERS identify the following:
NH: Hybrid circuits
NL : Logic circuits
NM: Memories
NS : Analogue signal processing, using switched capacitors
NT : Analogue signal processing, using CTDs
NX: Imaging devices
NY: Other correlated circuits

## Notes

1. A logic family is an assembly of digital circuits designed to be interconnected and defined by its basic electrical characteristics (such as: supply voltage, power consumption, propagation delay, noise immunity).
2. By 'slice processor' is meant: a functional slice of microproc' sor.

## THIRD LETTER

It indicates the operating ambient temperature range.
The letters $A$ to $G$ give information about the temperature:
A : temperature range not specified
B : 0 to $+70^{\circ} \mathrm{C}$
C : -55 to $+125^{\circ} \mathrm{C}$
D : -25 to $+70^{\circ} \mathrm{C}$
E : -25 to $+85^{\circ} \mathrm{C}$
F : -40 to $+85^{\circ} \mathrm{C}$
G: -55 to $+85^{\circ} \mathrm{C}$

If a circuit is published for another temperature range, the letter indicating a narrower temperature range may be used or the letter ' A '.
Example: the range 0 to $+75^{\circ} \mathrm{C}$ can be indicated by ' $\mathrm{B}^{\prime}$ or ' A '.

## SERIAL NUMBER

This may be either a 4-digit number assigned by Pro Electron, or the serial number (which may be a combination of figures and letters) of an existing company type designation of the manufacturer.

To the basic type number may be added:

## A VERSION LETTER

Indicates a minor variant of the basic type or the package. Exgept for ' $Z$ ', which means customized wiring, the letter has no fixed meaning. The following letters are recommended for package variants:
C : for cylindrical
D : for ceramic DIL
F: for flat pack
$L$ : for chip on tape
P : for plastic DIL
Q : for OIL
$T$ : for miniature plastic (mini-pack)
$U$ : for uncased chip
Alternatively a TWO LETTER SUFFIX may be used instead of a single package version letter, if the manufacturer (sponsor) wishes to give more information.
FIRST LETTER: General shape SECOND LETTER: Material
C : Cylindrical
D : Dual-in-line (DIL)
E : Power DIL (with external heatsink)
C : Metal-ceramic

F: Flat (leads on 2 sides)
G : Glass-ceramic (cerdip)

G: Flat (leads on 4 sides)
K : Diamond (TO-3 family)
$M$ : Multiple-in-line (except Dual-, Triple-,' Quadruple-in-line)
Q : Quadruple-in-line ( $\mathrm{O} \mid \mathrm{L}$ )
R : Power QIL (with external heatsink)
$S$ : Single-in-line
T : Triple-in-line
A hyphen precedes the suffix to avoid confusion with a version letter.

## DEFINITION OF TERMS

| Data Sheet Identification | Product Status | Definition |
| :--- | :--- | :--- |
| Preview | Formative or <br> In Design | This data sheet contains the design <br> specifications for product develop- <br> ment. Specifications may change in <br> any manner without notice. |
| Advance Information | Sampling or <br> Pre-Production | This data sheet contains advance <br> information and specifications are <br> subject to change without notice. |
| Preliminary | First <br> Production | This data sheet contains preliminary <br> data and supplementary data will be <br> published at a later date. Signetics <br> reserves theright to make changes at <br> anytime without notice inorder to im- <br> prove design and supply the best <br> possible product. |
| No | Full | This data sheet contains final |
| Idenfification |  | Specifications. Signetics reserves <br> the right to make changes at any <br> time without notice in order to im- <br> prove design and supply the best <br> possible product. |
| Noied |  |  |

## RATING SYSTEMS

## RATING SYSTEMS

The rating systems described are those recommended by the International Electrotechnical Commission (IEC) in its Publication 134.

## DEFINITIONS OF TERMS USED

Electronic device. An electronic tube or valve, transistor or other semiconductor device.

## Note

This definition excludes inductors, capacitors, resistors and similar components.

Characteristic. A characteristic is an inherent and measurable property of a device. Such a property may be electrical, mechanical, thermal, hydraulic, electro-magnetic, or nuclear, and can be expressed as a value for stated or recognized conditions. A characteristic may also be a set of related values, usually shown in graphical form.

Bogey electronic device. An electronic device whose characteristics have the published nominal values for the type. A bogey electronic device for any particular application can be obtained by considering only those characteristics which are directly related to the application.

Rating. A value which establishes either a limiting capability or a limiting condition for an electronic device. It is determined for specified values of environment and operation, and may be stated in any suitable terms.
Note
Limiting conditions may be either maxima or minima.
Rating system. The set of principles upon which ratings are established and which determine their interpretation.

Note
The rating system indicates the division of responsibility between the device manufacturer and the circuit designer, with the object of ensuring that the working conditions do not exceed the ratings.

## ABSOLUTE MAXIMUM RATING SYSTEM

Absolute maximum ratings are limiting values of operating and environmental conditions applicable to any electronic device of a specified type as defined by its published data, which should not be exceeded under the worst probable conditions.
These values are choser, by the device manufacturer to provide acceptable serviceability of the device, taking no responsibility for equipment variations, environmental variations, and the effects of changes in operating conditions due to variations in the characteristics of the device under consideration and of all other electronic devices in the equipment.

The equipment manufacturer should design so that, initially and throughout life, no absolute maximum value for the intended service is exceeded with any device under the worst probable operating conditions with respect to supply voltage variation, equipment component variation, equipment control adjustment, load variations, signal variation, environmental conditions, and variations in characteristics of the device under consideration and of all other electronic devices in the equipment.

## DESIGN MAXIMUM RATING SYSTEM

Design maximum ratings are limiting values of operating and environmental conditions applicable to a bogey electronic device of a specified type as defined by its published data, and should not be exceeded under the worst probable conditions.

These values are chosen by the device manufacturer to provide acceptable serviceability of the device, taking responsibility for the effects of changes in operating conditions due to variations in the characteristics of the electronic device under consideration.
The equipment manufacturer should design so that, initially and throughout life, no design maximum value for the intended service is exceeded with a bogey device under the worst probable operating conditions with respect to supply voltage variation, equipment component variation, variation in characteristics of all other devices in the equipment, equipment control adjustment, load variation, signal variation and environmental conditions.

## DESIGN CENTRE RATING SYSTEM

Design centre ratings are limiting values of operating and environmental conditions applicable to a bogey electronic device of a specified type as defined by its published data, and should not be exceeded under normal conditions.
These values are chosen by the device manufacturer to provide acceptable serviceability of the device in average applications, taking responsibility for normal changes in operating conditions due to rated supply voltage variation, equipment component variation, equipment control adjustment, load variation, signal variation, environmental conditions, and variations in the characteristics of all electronic devices.
The equipment manufacturer should design so that, initially, no design centre value for the intended service is exceeded with a bogey electronic device in equipment operating at the stated normal supply voltage.

HANDLING MOS DEVICES

## HANDLING MOS DEVICES

Though all our MOS integrated circuits incorporate protection against electrostatic discharges, they can nevertheless be damaged by accidental over-voltages. In storing and handling them, the following precautions are recommended.

## Caution

Testing or handling and mounting call for special attention to personal safety. Personnel handling MOS devices should normally be connected to ground via a resistor.

## Storage and transport

Store and transport the circuits in their original packing. Alternatively, use may be made of a conductive material or special IC carrier that either short-circuits all leads or insulates them from external contact.

## Testing or handling

Work on a conductive surface (e.g. metal table top) when testing the circuits or transferring them from one carrier to another. Electrically connect the person doing the testing or handling to the conductive surface, for example by a metal bracelet and a conductive cord or chain. Connect all testing and handling equipment to the same surface.
Signals should not be applied to the inputs while the device power supply is off. All unused input leads should be connected to either the supply voltage or ground.

## Mounting

Mount MOS integrated circuits on printed circuit boards after all other components have been mounted. Take care that the circuits themselves, metal parts of the board, mounting tools, and the person doing the mounting are kept at the same electric (ground) potential. If it is impossible to ground the printedcircuit board the person mounting the circuits should touch the board before bringing MOS circuits into contact with it.

## Soldering

Soldering iron tips, including those of low-voltage irons, or soldering baths should also be kept at the same potential as the MOS circuits and the board.

## Static charges

Dress personnel in clothing of non-electrostatic material (no wool, silk or synthetic fibres). After the MOS circuits have been mounted on the board proper handling precautions should still be observed. Until the sub-assemblies are inserted into a complete system in which the proper voltages are supplied, the board is no more than an extension of the leads of the devices mounted on the board. To prevent static charges from being transmitted through the board wiring to the device it is recommended that conductive clips or conductive tape be put on the circuit board terminals.

## Transient voltages

To prevent permanent damage due to transient voltages, do not insert or remove MOS devices, or printed-circuit boards with MOS devices, from test sockets or systems with power on.

## Voltage surges

Beware of voltage surges due to switching electrical equipment on or off, relays and d.c. lines.

## SINGLE-CHIP 8-BIT MICROCONTROLLERS (NMOS, CMOS)*

MAB8031AH; MAB8051AH ..... 31
MAB8031AH; MAB8052AH ..... 65
MAB8048H/35HL; MAB8049H/39HL; MAB8050H/40HL ..... 97
MAB84X1; MAF84X1; MAF84AX1 family ..... 123
MAB8422/42; MAF8422/42; MAF84A22/42 ..... 155
PCB80C31BH; PCB80C51BH ..... 175
PCB80C39; PCB80C49 ..... 203
PCB83C552; PCB80C552 ..... 233
PCB83C652; PCB80C652 ..... 281
PCB85C51 ..... 319
PCD3315C ..... 351
PCD3343. ..... 355
PCF84C12 ..... 395
PCF84CXX family ..... 423
PCF84C85 ..... 471

[^0]
# SINGLE-CHIP 8-BIT MICROCONTROLLER 

## DESCRIPTION

The MAB8051AH family of single-chip 8-bit microcontrollers is manufactured in an advanced $2 \mu$ NMOS process. The family consists of the following members:

- MAB8031AH: ROM-less version of the MAB8051AH
- MAB8051AH: 4 K bytes mask-programmable ROM, 128 bytes RAM

Both types are available in 8,10 and 12 MHz versions and 15 MHz for the MAB8031AH. In the following, the generic term "MAB8051AH" is used to refer to both family members.
The device provides hardware features, architectural enhancements and new instructions to function as a controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.
The MAB8051AH contains a non-volatile $4 \mathrm{~K} \times 8$ read-only program memory (not ROM-less version); a volatile $128 \times 8 \mathrm{read} / \mathrm{write}$ data memory; $32 \mathrm{I} / \mathrm{O}$ lines; two 16 -bit timer/event counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O power for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and timing circuits. For systems that require extra capability, the MAB8051AH can be expanded using standard TTL compatible memories and logic.
The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of 255 instructions; $44 \%$ one-byte, $41 \%$ two-byte and $15 \%$ three-byte. With a 12 MHz crystal, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ and $40 \%$ in $2 \mu \mathrm{~s}$. Multiply and divide instructions require $4 \mu \mathrm{~s}$. Multiply, divide, subtract and compare are among the many instructions added to the standard MAB8048H instruction set.
For further detailed information see users manual 'Single-chip 8-bit microcontrollers'.

## Features

- $4 \mathrm{~K} \times 8$ ROM ( 8051 AH only), $128 \times 8$ RAM
- Four 8 -bit ports, 32 I/O lines
- Two 16 -bit timer/event counters
- Full duplex serial port
- External memory expandable to 128 K
- Boolean processing
- 218 bit-addressable locations
- On-chip oscillator
- Five-source interrupt structure with two priority levels
- $58 \%$ of instructions executed in $1 \mu \mathrm{~s}$; multiply and divide in $4 \mu \mathrm{~s}$ (at 12 MHz clock)
- Enhanced architecture with:
non-page-oreinted instructions
direct addressing
four 8 -bit register banks
stack depth up to 128 -bytes
multiply, divide, subtract and compare
- Available with extended temperature range: -40 to $+85^{\circ} \mathrm{C}$ (MAF8031/51AH)
- Available with automotive temperature range: -40 to $+100^{\circ} \mathrm{C}$ (MAF80A31/51AH)


## PACKAGE OUTLINES

MAB8031/51AHP; MAF8031/51AHP; MAF80A31/51AHP: 40-lead DIL; plastic (SOT-129). MAB8031/51AHWP; MAF8031/51AHWP; MAF80A31/51AHWP: 44-lead, plastic leaded-chip-carrier (PLCC); SOT-187A.



Fig. 2 Functional diagram.


Fig. 3a Pinning diagram for MAB8031/51AHP; MAF8031/51AHP; MAF80A31/51AHP.

Fig. 3b Pinning diagram for MAB8031/51AHWP; MAF8031/51AHWP; MAF80A31/51AHWP.

* $\mathrm{V}_{\mathrm{PD}}$ option available on request.

PINNING (DIL package)

| 1-8 |  |
| :--- | :--- |
| P1.0-P1.7 | Port 1: 8-bit quasi-bidirectional I/O port. It receives the low-order address <br> byte during program verification. Port 1 can sink/source one TTL (= 4 LS TTL) <br> input. It can drive MOS inputs without external pull-ups. |
| RST/VPD RESET/POWER DOWN: a high level on this pin for two machine |  |
| cycles while the oscillator is running resets the device. An internal pulldown |  |
| permits Power-On reset using only a capacitor connected to VCC. As an |  |
| available option, this pin also supplies standby power to the RAM: VPD should |  |
| be held within its specified limit while VCC drops below its specified limit. |  |
| When VPD is LOW the RAM current is drawn from V CC. |  |

PINNING (continued)

$31 \quad$| $\overline{E A}$ | When $\overline{E A}$ is held at a TTL high level the CPU executes out of the internal <br> Program Memory (ROM), provided the Program Counter is less than 4096. <br> When $\overline{E A}$ is held at a TTL low level the CPU executes out of external <br> Program Memory. $\overline{E A}$ does not float. |
| :--- | :--- |
| $32-39 \quad$ P0.7-P0.0 $\quad$Port 0: 8-bit open drain bidirectional I/O port. It is also the multiplexed <br> low-order address and data bus during accesses to external memory (during <br> these accesses it activates internal pull-ups). It also outputs instruction bytes <br> during program verification. (External pull-ups are required during program <br> verification). Port 0 can sink/source two TTL inputs. |  |
| 40 | $V_{C C} \quad$Power Supply: + 5 V power supply pin during normal operation. |

Power Supply: + 5 V power supply pin during normal operation.

## FUNCTIONAL DESCRIPTION

## General

The MAB8051AH is a stand-alone high-performance microcontroller designed for use in real-time applications such as instrumentation, industrial control and intelligent computer peripherals.
The device provides hardware features, architectural enhancements and new instructions to function as a controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.

The MAB8031AH is a control-oriented CPU without on-chip program memory. It can address 64 K bytes of external program memory in addition to 64 K bytes of external data memory. The MAB8051AH is a MAB8031AH with the lower 4 K bytes of program memory filled with on-chip mask programmable ROM. For systems requiring extra capability, the MAB8051AH can be expanded using standard TTL memories and peripherals.
The two pin-compatible versions of this component reduce development problems to a minimum and provide maximum flexibility. The MAB8051AH is for low-cost, high volume production; and the MAB8031AH for applications requiring the flexibility of external program memory which can be easily modified and updated in the field.

The MAB8051AH contains a non-volatile $4 \mathrm{~K} \times 8$ read-only program memory; a volatile $128 \times 8$ read/ write data memory; 32 I/O lines; two 16 -bit timer/event counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and timing circuits.

## Central processing unit

The central processing unit (CPU) manipulates operands in four memory spaces. These are the 64 K-byte external data memory, 256 -byte internal data memory and 16 -bit program counter spaces. The internal data memory address space is sub-divided into the 128 -byte internal data RAM and 128 -byte special function register (SFR) address spaces, as shown in Fig. 4a. See also Figures 4b to 4f.


## Where:

The internal data memory locations are addressable direct/indirect as follows:

| location | addressed |
| :--- | :--- |
| RAM 0 to 127 | direct and indirect |
| SFR 128 to 255 | direct only |

## FUNCTIONAL DESCRIPTION (continued)

The internal data RAM contains four register banks (each with eight registers), 128 addressable bits, and the stack. The stack depth is limited by the available internal data RAM and its location is determined by the 8 -bit stack pointer. All registers except the program counter and the four 8 -register banks reside in the special function register (SFR) address space. These memory mapped registers include arithmetic registers, pointers, $1 / O$ ports, interrupt system registers, timers and serial port. There are 128 addressable bit locations in the SFR address space.

The MAB8051AH contains 128 bytes of internal data RAM and 20 special function registers. It provides a non-paged program memory address space to accommodate relocatable code. Conditional branches are performed relative to the program counter. The register-indirect jump permits branching relative to a 16 -bit base register with an offset provided by an 8 -bit index register. 16 -bit jumps and calls permit branching to any location in the contiguous 64 K program memory address space.
The MAB8051AH has five methods for addressing source operands:

- Register
- Direct
- Register-Indirect
- Immediate
- Base-Register-plus Index-Register-Indirect

The first three methods can be used for addressing destination operands. Most instructions have a "destination source" field that specifies the data type, addressing methods and operands involved. For operations other than moves, the destination operand is also a source operand.
Access addressing is as follows:

- Registers in the four 8-register banks through Register, Direct, or Register-Indirect.
- 128 bytes of internal data RAM through Direct or Register-Indirect.
- Special function registers through Direct.
- External data memory through Register-Indirect.
- Program memory look-up tables through Base-Register-plus Index-Register-Indirect.

The MAB8051AH is classified as an 8-bit device since the internal ROM, RAM, Special Function Registers (SFR), Arithmetic Logic Unit (ALU), and external data bus are each 8-bits wide. It performs operations on bit, nibble, byte and double-byte data types.

Facilities are available for byte transfer, logic, and integer arithmetic operations. Data transfer, logic, and conditional branch operations can be performed directly on Boolean variables to provide excellent bit handling.


Fig. 4b Internal data memory address space.


Fig. 4c Mapping of special function registers.


STACK-POINTER REGISTER-INDIRECT AND REGISTER-INDIRECT ADDRESSING

Fig. 4d Special function register bit addresses.


Fig. 4e RAM bit addresses.


Fig. 4f Addressing operands in internal data memory.

## FUNCTIONAL DESCRIPTION (continued)

## I/O facilities

The MAB8051AH has 32 I/O lines treated as 32 individual addressable bits and as four parallel 8-bit addressable ports. Ports $0,1,2$ and 3 perform the following alternate functions:

- Port 0; provides the multiplexed low-order address and data bus used for expanding the MAB8051AH with standard memories and peripherals
- Port 2; provides the high-order address bus when expanding the MAB8051 with external program memory or more than 256 bytes of external data memory
- Port 3; pins can be configured individually to provide:-
external interrupt requests inputs counter inputs serial port receiver input and transmitter output control signals to READ and WRITE to external data memory
The generation or use of a Port 3 pin as an alternate function is carried out automatically by the MAB8051AH provided the pin is configured as an output.


## Timer/event counters

The MAB8051AH contains two 16 -bit registers, Timer 0 and Timer 1 , that can be used as timers or event counters to carry out the following functions:

- Measure time intervals and pulse durations
- Count events
- Generate interrupt requests

Each timer/event counter can be programmed independently to operate in three modes:

- Mode $0 ; 8$-bit timer or 8 -bit counter each with divide by 32 prescaler
- Mode 1; 16-bit time-interval or event counter
- Mode 2; 8-bit time-interval or event counter with automatic reload upon overflow

Counter 0 can be programmed to operate in an additional mode as follows:

- Mode 3; one 8-bit time-interval or event counter and one 8-bit time-interval counter

When counter 0 is in Mode 3, counter 1 can be programmed to operate in Modes 0,1 or 2 but cannot set an interrupt request flag or generate an interrupt. However the overflow from counter 1 can be used to pulse the serial Port transmission-rate generator.
The frequency handling range of these counters with a 3,5 to 12 MHz crystal is as follows:

- 0,3 to 1 MHz when programmed for an input that is a division by 12 of the oscillator frequency
- 0 Hz to an upper limit of 150 kHz to $0,5 \mathrm{MHz}$ when programmed for external inputs

Both internal and external inputs can be gated to the counter by a second external source for directly measuring pulse durations.
The counters are started and stopped under software control. Each one sets its interrupt request flag when it overflows from all 1 's to all 0 's (or automatic reload value).

## On-chip peripheral functions

In addition to the CPU and memories, an interrupt system, extensive I/O facilities, and several peripheral functions are integrated on-chip to relieve the CPU of repetitious, complicated or time-critical tasks and to permit stringent real-time control of external system interfaces. The I/O facilities include the I/O pins, parallel ports, bidirectional address/data bus and the serial port for I/O expansion. The CPU peripheral functions integrated on-chip are the two 16 -bit timer/event counters and the serial port.

## Interrupt system (see Fig. 5)

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, two-priority-level, nested interrupt system is provided. Interrupt response latency is from $3 \mu \mathrm{~s}$ to $7 \mu \mathrm{~s}$ when using a 12 MHz crystal.
The MAB8051AH acknowledge interrupt requests from five sources as follows:

- $\overline{\text { INTO }}$ and $\overline{\text { INT1 }}$; externally via pins 12 and 13 respectively
- Timer 0 and Timer 1 ; from the two internal counters
- Serial Port; from the internal serial I/O port

Each interrupt vectors to a separate location in program memory for its service program. Each source can be individually enabled or disabled and can be programmed to a high or low priority level. Also all enabled sources can be globally disabled or enabled. Both external interrupts can be programmed to be level-activated or transition-activated and is active LOW to allow "wireORing" of several interrupt sources to the input pin.


## OSCILLATOR CIRCUITRY

The oscillator circuitry of the MAB8051AH is a single-stage inverting amplifier in a Pierce oscillator configuration. The circuitry has a combination of depletion and enhancement mode MOS FETs to produce the inverting characteristics, and not passive components. Either a crystal or ceramic resonator can be used as the feedback element to complete the oscillator circuitry. XTAL1, pin 19, is the high gain amplifier input, and XTAL2, pin 18, is the output (see Fig. 6).
To drive the MAB8051AH externally, XTAL1 should be connected to ground and XTAL2 driven from an external source (see Fig. 7).


Fig. 6 MAB8051AH oscillator circuit.


Fig. 7 Driving the MAB8051AH from an external source.

## RESET CIRCUITRY

The reset circuitry for the MAB8051AH is connected to the reset pin, RST, as shown in Fig. 8. A Schmitt trigger is used th the input for noise rejection. The output of the Schmitt trigger is sampled by the reset circuitry every machine cycle.


Fig. 8 Reset configuration at RST.
A reset is accomplished by holding the RST pin HIGH for at least two machine cycles ( 24 oscillator periods), while the oscillator is running. The CPU responds by executing an internal reset. It also configures the ALE and PSEN pins as inputs. (They are quasi-bidirectional.) The internal reset is executed during the second cycle in which RST is high and is repeated every cycle until RST goes LOW. It leaves the internal registers as follows:

| REGISTER | CONTENT |
| :--- | :--- |
| PC | 0000 H |
| ACC | 00 H |
| B | 00 H |
| PSW | 00 H |
| SP | 07 H |
| DPTR | 0000 H |
| PO -- P3 | 0 FFH |
| IP | XXXOOOOOB |
| IE | XXXOOOOOB |
| TMOD | 00 H |
| TCON | 00 H |
| TH0 | 00 H |
| TLO | 00 H |
| TH1 | 00 H |
| TL1 | 00 H |
| SCON | 00 H |
| SBUF | Indeterminate |
| PCON | $0 X X X X X X X B$ |

## Where

$H=$ Hexadecimal
$B=B i n a r y$
The internal RAM is not affected by reset. When VCC is turned on, the RAM content is determinate.

## RESET CIRCUITRY (continued)

## Power-on reset

An automatic reset when $V_{\text {CC }}$ is turned on can be obtained by connecting the RST pin to $V_{C C}$ through a $10 \mu \mathrm{~F}$ capacitor, as long as the $\mathrm{V}_{\text {CC }}$ rise-time does not exceed 10 milliseconds. This poweron reset circuit is shown in Fig. 9. When the power is switched on, the current drawn by RST is the difference between $V_{C C}$ and the capacitor voltage, and decreases from $V_{C C}$ as the capacitor charges. The larger the capacitor, the more slowly $\mathrm{V}_{\text {RST }}$ decreases. $\mathrm{V}_{\text {RST }}$ must remain above the lower threshold of the Schmitt trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles.


Fig. 9 Power-on reset.

## INSTRUCTION SET

The MAB8051AH uses a powerful instruction set to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Reassigned opcodes add new high-power operations and permit new addressing modes to make old operations more orthogonal. The instruction set consists of 49 single-byte, 45 two-byte and 17 three-byte instructions. When using a 12 MHz oscillator, 64 instructions execute in $1 \mu \mathrm{~s}$ and 45 instructions execute in $2 \mu \mathrm{~s}$. Multiply and divide instructions execute in $4 \mu$ s.

Table 1 Instruction set description

| mnemonic | description | bytes/ <br> cycles | opcode <br> (hex.) |  |
| :--- | :--- | :--- | :--- | :--- |
| Arithmetic operation |  |  |  |  |
| ADD | A,Rr | Add register to A | 1 | 1 |
| ADD | A,direct | Add direct byte to A | $2^{*}$ |  |
| ADD | A,@Ri | Add indirect RAM to A | 2 | 1 |
| ADD | A,\#data | Add immediate data to A | 25 |  |
| ADDC | A,Rr | Add register to A with carry flag | 1 | 26,27 |
| ADDC | A,direct | Add direct byte to A with carry flag | 2 | 1 |
| ADDC | A,@Ri | Add indirect RAM to A with carry flag | 24 |  |
| ADDC | A,\#data | Add immediate data to A with carry flag | 1 | $3^{*}$ |
| SUBB | A,Rr | Subtract register from A with borrow | 1 | 35 |
| SUBB | A,direct | Subtract direct byte from A with borrow | 1 | 36,37 |
| SUBB | A,@Ri | Subtract indirect RAM from A with borrow | 1 | $9^{*}$ |
| SUBB | A,\#data | 1 | 1 | 1 |
| INC | A | Subtract immediate data from A with borrow | 2 | 1 |
| INC | Rr | Increment A | 96,97 |  |
| INC | direct | Increment register | 1 | 1 |
| INC | @Ri | Increment direct byte | 04 |  |
| DEC | A | Increment indirect RAM | 1 | 1 |
| DEC | Rr | Decrement A | $0^{*}$ |  |
| DEC | direct | Decrement register | 2 | 1 |
| DEC | @Ri | Decrement direct byte | 05 |  |
| INC | DPTR | Decrement indirect RAM | 1 | 1 |
| MUL | AB | Increment data pointer | 06,07 |  |
| DIV | AB | Multiply A \& B | 1 | 14 |
| DA | A | Divide A by B | 1 | 1 |


| mnemonic |  | description | bytes/ cycles | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Logic operations |  |  |  |  |
| ANL | A, Rr | AND register to A | 11 | 5* |
| ANL | A,direct | AND direct byte to $A$ |  | 55 |
| ANL | A,@Ri | AND indirect RAM to $A$ |  | 56, 57 |
| ANL | A,\#data | AND immediate data to $A$ |  | 54 |
| ANL | direct, A | AND A to direct byte |  | 52 |
| ANL | direct,\#data | AND immediate data to direct byte | 32 | 53 |
| ORL | A, Rr | OR register to $A$ |  | 4* |
| ORL | A,direct | OR direct byte to $A$ |  | 45 |
| ORL | A,@Ri | OR indirect RAM to $A$ | 11 | 46,47 |
| ORL | A, \#data | OR immediate data to $A$ | 21 | 44 |
| ORL | direct,A | OR A to direct byte |  | 42 |
| ORL | direct,\#data | OR immediate data to direct byte | 32 | 43 |
| XRL | A, Rr | Exclusive-OR register to $A$ |  | 6* |
| XRL | A, direct | Exclusive-OR direct byte to $A$ |  | 65 |
| XRL | A,@Ri | Exclusive-OR indirect RAM to $A$ |  | 66, 67 |
| XRL | A,\#data | Exclusive-OR immediate data to $A$ |  | 64 |
| XRL | direct, A | Exclusive-OR to direct byte |  | 62 |
| XRL | direct,\#data | Exclusive-OR immediate data to direct byte | 32 | 63 |
| CLR | A | Clear A |  | E4 |
| CPL | A | Complement A |  | F4 |
| RL | A | Rotate A left | 11 | 23 |
| RLC | A | Rotate A left through the carry flag |  | 33 |
| RR | A | Rotate A right | 11 | 03 |
| RRC | A | Rotate A right through the carry flag | 11 | 13 |
| SWAP | A | Swap nibbles within A | 11 | C4 |

INSTRUCTION SET (continued)

| mnemonic |  | description | bytes/ cycles | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Data transfer |  |  |  |  |
| MOV** | A, Rr | Move register to $A$ | 1 | E* |
| MOV | A, direct | Move direct byte to $A$ | 21 | E5 |
| MOV | A,@Ri | Move indirect RAM to A | 1 | E6, E7 |
| MOV | A,\#data | Move immediate data to $A$ |  | 74 |
| MOV | $\mathrm{Rr}, \mathrm{A}$ | Move A to register | 11 | F* |
| MOV | Rr,direct | Move direct byte to register | 22 | A* |
| MOV | Rr,\#data | Move immediate data to register |  | 7* |
| MOV | direct, A | Move A to direct byte | 21 | F5 |
| MOV | direct, Rr | Move register to direct byte | 22 | 8* |
| MOV | direct, direct | Move direct byte to direct | 32 | 85 |
| MOV | direct,@Ri | Move indirect RAM to direct byte | 22 | 86, 87 |
| MOV | direct,\#data | Move immediate data to direct byte | 32 | 75 |
| MOV | @Ri,A | Move A to indirect RAM | 11 | F6, F7 |
| MOV | @Ri,direct | Move direct byte to indirect RAM |  | A6, A7 |
| MOV | @Ri,\#data | Move immediate data to indirect RAM | 2 | 76, 77 |
| MOV | DPTR,\#data 16 | Load data pointer with a 16-bit constant | 32 | 90 |
| MOVC | A,@A+DPTR | Move code byte relative to DPTR to A | 12 | 93 |
| MOVC | A, @A+PC | Move code byte relative to PC to A | 12 | 83 |
| MOVX | A,@Ri | Move external RAM (8-bit address) to A | 12 | E2, E3 |
| MOVX | A,@DPTR | Move external RAM (16-bit address) to A | 12 | E0 |
| MOVX | @Ri,A | Move A to external RAM (8-bit address) | 12 | F2, F3 |
| MOVX | @DPTR,A | Move A to external RAM (16-bit address) | 12 | F0 |
| PUSH | direct | Push direct byte onto stack | 22 | C0 |
| POP | direct | Pop direct byte from stack | 22 | D0 |
| XCH | A, Rr | Exchange register with A | 11 | C* |
| XCH | A, direct | Exchange direct byte with $A$ | 21 | C5 |
| XCH | A,@Ri | Exchange indirect RAM with A | 11 | C6, C7 |
| XCHD | A,@Ri | Exchange LOW-order digit indirect RAM with A | 11 | D6, D7 |

MOV A,ACC not valid instruction.

| mnemonic |  | description | bytes/ cycles | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Boolean variable manipulation |  |  |  |  |
| CLR | C | Clear carry flag | 11 | C3 |
| CLR | bit | Clear direct bit | 21 | C2 |
| SETB | C | Set carry flag | 11 | D3 |
| SETB | bit | Set direct bit | 21 | D2 |
| CPL | C | Complement carry flag | 11 | B3 |
| CPL | bit | Complement direct bit | 21 | B2 |
| ANL | C, bit | AND direct bit to carry flag | 22 | 82 |
| ANL | C,/bit | AND complement of direct bit to carry flag | 22 | B0 |
| ORL | C,bit | OR direct bit to carry flag | 22 | 72 |
| ORL | C,/bit | OR complement of direct bit to carry flag | $2 \quad 2$ | A0 |
| MOV | C,bit | Move direct bit to carry flag | 21 | A2 |
| MOV | bit, C | Move carry flag to direct bit | 22 | 92 |
| Program and machine control |  |  |  |  |
| ACALL | addr11 | Absolute subroutine call | 22 | -1addr |
| LCALL | addr16 | Long subroutine call | 32 | 12 |
| RET |  | Return from subroutine | 12 | 22 |
| RET1 |  | Return from interrupt | 12 | 32 |
| AJMP | addr 11 | Absolute jump | 22 | 41addr |
| LJMP | addr16 | Long jump | $3 \quad 2$ | 02 |
| SJMP | rel | Short jump (relative address) | 22 | 80 |
| JMP | @A+DPTR | Jump indirect relative to the DPTR | 12 | 73 |
| JZ | rel | Jump if $A$ is zero | 22 | 60 |
| JNZ | rel | Jump if $A$ is not zero | 22 | 70 |
| JC | rel | Jump if carry flag is set | 22 | 40 |
| JNC | rel | Jump if no carry flag | 22 | 50 |
| JB | bit,rel | Jump if direct bit is set | 32 | 20 |
| JNB | bit,rel | Jump if direct bit is not set | 32 | 30 |
| JBC | bit,rel | Jump if direct bit is set and clear bit | 31 | 10 |
| CJNE | A,direct, rel | Compare direct to $A$ and jump if not equal | 32 | B5 |
| CJNE | A,\#data,rel | Compare immediate to $A$ and jump if not equal | 31 | B4 |
| CJNE | Rr,\#data, rel | Compare immed. to reg. and jump if not equal | 3 | B* |
| CJNE | @Ri,\#data,rel | Compare immed. to ind. and jump if not equal | 3 | B6, B7 |
| DJNZ | Rr,rel | Decrement register and jump if not aro | 22 | D* |
| DJNZ | direct, rel | Decrement direct and jump if ne: 2 :ro | $3 \quad 2$ | D5 |
| NOP |  | No operation |  | 00 |

## Notes to Table 1

Data addressing modes
$\mathrm{Rr} \quad$ Working register RO-R7.
direct $\quad 128$ internal RAM locations and any special function register (SFR).
@Ri Indirect internal RAM location addressed by register RO or R1.
\#data $\quad 8$-bit constant included in instruction.
\#data16 16-bit constant included as bytes 2 and 3 of instruction.
bit Direct addressed bit in internal RAM or SFR.
addr16 16-bit destination address. Used by LCALL and LJMP. The branch will be anywhere within the 64 K -byte program memory address space.
addr11 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 K -byte page of program memory as the first byte of the following instruction.
rel Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is $\mathbf{- 1 2 8}$ to +127 bytes relative to first byte of the following instruction.

## Hexadecimal opcode cross-reference to Table 2

*: 8, 9, A, B, C, D, E, F.
-: 11, 31, 51, 71, 91, B1, D1, F1.
4: 01, 21, 41, 61, 81, A1, C1, E1.

Table 2 Instruction map

|  | _ first hexadecimal chacter of opcode |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\checkmark$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 |  | 8 | 9 | A | B | C | D | E | F |
|  | 0 | NOP | AJMP page 0 | LJMP addr16 | RR A | INC A | INC dir | $\begin{aligned} & \text { INC @Ri } \\ & 0 \end{aligned}$ |  | $\left.\begin{aligned} & \text { INC Rr } \\ & 0 \\ & 0 \end{aligned} 1 \right\rvert\, \begin{aligned} & \text { IN } \end{aligned}$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 1 | JBC bit, addr8 | ACALL page 0 | LCALL addr16 | RRC A | DEC A | DEC <br> dir | $\begin{aligned} & \text { DEC @Ri } \\ & 0 \end{aligned}$ |  | $\begin{aligned} & \text { DEC Rr } \\ & 0 \\ & 0 \end{aligned} 1$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 2 | JB <br> bit, addr8 | AJMP page 1 | RET | RLA | ADD <br> A, \#data | $\begin{aligned} & \text { ADD } \\ & \text { A, dir } \end{aligned}$ | $\begin{aligned} & \text { ADD A,@Ri } \\ & 0 \end{aligned}$ |  | $$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 3 | JNB bit, addr8 | ACALL page 1 | RET1 | RLC A | ADDC <br> A, \#data | ADDC <br> A, dir | $\begin{aligned} & \text { ADDC A,@Ri } \\ & 0 \end{aligned}$ |  |    <br> ADDC A, Rr   <br> 0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 4 | JC addr8 | AJMP page 2 | ORL <br> dir,A | ORL dir,\#data | ORL <br> A, \#data | ORL <br> A,dir | ORL A, @Ri 0 |  | $$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 5 | JNC addr8 | ACALL page 2 | ANL <br> dir,A | ANL <br> dir,\#data | ANL <br> A,\#data | ANL A, dir | ANL A,@Ri 0 |  | $\begin{array}{l\|l\|l} \text { ANL } & \text { R } \\ \hline 0 & 1 & 2 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 6 | JZ addr8 | AJMP page 3 | $\begin{aligned} & \text { XRL } \\ & \text { dir,A } \end{aligned}$ | XRL dir,\#data | XRL <br> A, \#data | XRL <br> A, dir | $\begin{aligned} & \text { XRL A,@Ri } \\ & 0 \end{aligned}$ |  | $\begin{array}{l\|r} X R L A, R r \\ 0 & 1 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 7 | JNZ <br> addr8 | ACALL page 3 | ORL <br> C, bit | JMP <br> @A+DPTR | MOV <br> A, \#data | MOV dir,\#data | MOV @Ri,\#data$\square$ |  | MOV Rr,\#data0 1 2 3 |  |  |  | 4 | 5 | 6 | 7 |
|  | 8 | SJMP addr8 | AJMP page 4 | ANL <br> C,bit | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+PC } \end{aligned}$ | $\begin{aligned} & \text { DIV } \\ & \text { AB } \end{aligned}$ | MOV dir,dir | MOV dir,@Ri 0 |  |    <br> MOV dir, Rr   <br> 0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
|  | 9 | MOV DPTR, \#data 16 | ACALL page 4 | MOV <br> bit,C | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+DPTR } \end{aligned}$ | SUBB <br> A,\#data | SUBB <br> A,dir | $\begin{aligned} & \text { SUBB A,@Ri } \\ & 0 \end{aligned}$ |  |    <br> SUBB $A, R r$   <br> 0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
|  | A | ORL <br> C,/bit | AJMP page 5 | $\begin{aligned} & \text { MOV } \\ & \text { C,bit } \end{aligned}$ | INC DPTR | $\begin{aligned} & \text { MUL } \\ & \text { AB } \end{aligned}$ |  | MOV @Ri,dir 0 |  | $$ |  |  | 3 | 4 | 5 | 6 | 7 |
| $\int$ | B | ANL C,/bit | ACALL page 5 | $\begin{aligned} & \text { CPL } \\ & \text { bit } \end{aligned}$ | CPL C | CJNE A, \#data, addr8 | CJNE <br> A,dir, addr8 | CJNE @Ri,\#data, addr8 0 1 |  | CJNE Rr,\#data, addr80 1 2 3 4 |  |  |  |  | 5 | 6 | 7 |
| $\underset{\substack{2}}{ }$ | C | PUSH dir | AJMP page 6 | $\begin{aligned} & \text { CLR } \\ & \text { bit } \end{aligned}$ | CLR C | $\begin{aligned} & \text { SWAP } \\ & \text { A } \end{aligned}$ | XCH <br> A,dir | $\begin{aligned} & \text { XCH A,@Ri } \\ & 0 \end{aligned}$ |  | $\begin{array}{l\|l\|r} \hline X C H & A \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
|  | D | $\begin{aligned} & \mathrm{POP} \\ & \text { dir } \end{aligned}$ | ACALL page 6 | SETB <br> bit | $\begin{aligned} & \text { SETB } \\ & \mathrm{C} \end{aligned}$ | DA A | DJNZ dir, addr8 | $\begin{aligned} & \text { XCHD A,@Ri } \\ & 0 \end{aligned}$ |  | DJNZ Rr, addr80 1 2 3 |  |  |  | 4 | 5 | 6 | 7 |
| $\stackrel{\rightharpoonup}{\infty}$ | E | MOVX A,@DPTR | AMMP page 7 | Moyx $0$ | $@ R i$ | CLR A | MOV <br> A, dir | $\begin{aligned} & \text { MOV A,@Ri } \\ & 0 \end{aligned}$ |  | MOV $A, R r$   <br> 0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
|  | F | MOVX @DPTR,A | ACALL page 7 | $\begin{aligned} & \text { MOVX } \\ & 0 \end{aligned}$ | $\begin{aligned} & n_{1, A} \\ & 1 \end{aligned}$ | CPL A | $\begin{aligned} & \text { MOV } \\ & \text { dir,A } \end{aligned}$ | $\begin{aligned} & \text { MOV @Ri,A } \\ & 0 \end{aligned}$ |  | MOV Rr,A |  |  | 3 | 4 | 5 | 6 | 7 |

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Input voltage on any pin with respect to ground ( $\mathrm{V}_{\mathrm{SS}}$ )

| $\mathrm{V}_{\mathrm{I}}$ | $-0,5$ to +7 V |
| :--- | :--- | ---: |
| $\mathrm{P}_{\text {tot }}$ | max. 1 W |
| $\pm I_{\mathrm{I}}, \mathrm{I}_{\mathrm{O}}$ | $\max . \quad 10 \mathrm{~mA}$ |
| $\mathrm{~T}_{\mathrm{stg}}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |
|  |  |
| $\mathrm{T}_{\mathrm{amb}}$ | 0 to $+70{ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{amb}}$ | -40 to $+85{ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{amb}}$ | -40 to $+100{ }^{\circ} \mathrm{C}$ |

## D.C. CHARACTERISTICS (MAB8031/51AH)

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current | ${ }^{1} \mathrm{CC}$ | - | 160 | mA |  |
| Supply current (optional) | ${ }^{\text {IPD }}$ | - | 20 | mA |  |
| Inputs |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IL }}$ | -0,5 | 0,8 | V |  |
| inputs except RST and XTAL 2 | $\mathrm{V}_{\text {IH }}$ | 2 | $\mathrm{V}_{\mathrm{CC}}+0,5$ | V |  |
| Input voltage HIGH to RST and XTAL 2 | $\mathrm{V}_{1+1}$ | 2,5 |  | V | XTAL 1 to $\mathrm{V}_{\text {SS }}$ |
| Outputs |  |  |  |  |  |
| Output voltage LOW (Ports 1, 2, 3) (note 1) | $\mathrm{V}_{\mathrm{OL}}$ |  | 0,45 | V | $\mathrm{I}_{\mathrm{OL}}=1,6 \mathrm{~mA}$ |
| Output voltage LOW (Port 0, ALE, PSEN) (note 1) | $\mathrm{v}_{\text {OL1 }}$ |  | 0,45 | V | $\mathrm{I}_{\mathrm{OL} 1}=3,2 \mathrm{~mA}$ |
| Output voltage HIGH (Port 1, 2, 3) | $\mathrm{v}_{\text {OH }}$ | 2,4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ |
| Output voltage HIGH (Port 0, ALE, PSEN) | $\mathrm{V}_{\mathrm{OH} 1}$ | 2,4 |  | V | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| Input leakage current (Port 0, EA) | $\pm \mathrm{I}_{\mathrm{LI}}$ |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ |
| Input current HIGH (RST) current logic 0 | IIH1 |  | 500 | $\mu \mathrm{A}$ | $V_{1}=V_{C C}-1,5 \mathrm{~V}$ |
| (Ports 1, 2, 3) | IIL |  | -800 | $\mu \mathrm{A}$ | $V_{\text {IL }}=0,45 \mathrm{~V}$ |
| Input current logic 0 (XTAL 2) | IIL2 |  | -2,5 | mA | $\begin{aligned} & \mathrm{V}_{\text {IL }}=0,45 \mathrm{~V} \\ & \text { XTAL } 1 \text { to } \mathrm{V}_{\mathrm{SS}} \end{aligned}$ |
| Capacitance of I/O buffer | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 10 | pF | $\begin{aligned} & \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ |

D.C. CHARACTERISTICS (MAF8031/51AH; MAF80A31/51AH)
$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}(\mathrm{MAF} 8031 / 51 \mathrm{AH}),-40$ to $+100{ }^{\circ} \mathrm{C}$
(MAF80A31/51AH); all voltages with respect to $\mathrm{V}_{\text {SS }}$ unless otherwise specified

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current | ${ }^{1} \mathrm{CC}$ | - | 175 | mA |  |
| Inputs |  |  |  |  |  |
| Input voltage LOW Input voltage HIGH all | $V_{\text {IL }}$ | -0,5 | 0,8 | V |  |
| inputs except and XTAL 2 | $\mathrm{V}_{\text {IH }}$ | 2,2 | $\mathrm{V}_{\mathrm{CC}}+0,5$ | V |  |
| Input voltage HIGH to RST and XTAL 2 | $\mathrm{V}_{1 \mathrm{H} 1}$ | 2,7 |  | V | XTAL 1 to $\mathrm{V}_{\mathrm{SS}}$ |
| Outputs |  |  |  |  |  |
| Output voltage LOW (Ports 1, 2, 3) (note 1) | $\mathrm{V}_{\text {OL }}$ |  | 0,45 | V | ${ }^{1} \mathrm{OL}=1,2 \mathrm{~mA}$ |
| Output voltage LOW (Port 0, ALE, PSEN) (note 1) | $\mathrm{V}_{\mathrm{OL} 1}$ |  | 0,45 | V | ${ }^{\prime}{ }_{\text {OL1 }}=2,4 \mathrm{~mA}$ |
| Output voltage HIGH (Port 1, 2, 3) | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| Output voltage HIGH (Port 0, ALE PSEN) | $\mathrm{V}_{\mathrm{OH} 1}$ | 2,4 |  | V | $\mathrm{I}_{\mathrm{OH} 1}=-360 \mu \mathrm{~A}$ |
| Input leakage current (Port 0, EA) | $\pm \mathrm{I}_{\mathrm{LI}}$ |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\mathrm{CC}}$ |
| Input current HIGH (RST) current logic 0 | $\mathrm{I}_{1} \mathrm{H} 1$ |  | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}-1,5 \mathrm{~V}$ |
| (Ports 1, 2, 3) | IIL |  | -800 | $\mu \mathrm{A}$ | $V_{\text {IL }}=0,45 \mathrm{~V}$ |
| Input current logic 0 (XTAL 2) | IIL2 |  | $-3,0$ | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0,45 \mathrm{~V} ; \\ & \text { XTAL } 1 \text { to } \mathrm{V}_{\mathrm{SS}} \end{aligned}$ |
| Capacitance of I/O buffer | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 10 | pF | $\begin{aligned} & \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ |

## Note 1

$\mathrm{V}_{\mathrm{OL}}$ is degraded when the MAB8051AH rapidly discharges external capacitance.
This a.c. noise is most pronounced during emission of address data. When using external memory, locate the latch or buffer as close to the MAB8051AH as possible.

| datum | emitting <br> ports | time slot <br> interval | degraded <br> I/O lines | VOL <br> (max.) |
| :--- | :--- | :--- | :--- | :--- |
| address | P2, P0 | TS3, TS9 | P1, P3 | $0,8 \mathrm{~V}$ |
| write data | P0 | TS6 | P1, P3, ALE | $0,8 \mathrm{~V}$ |

## A.C. CHARACTERISTICS (note 1)

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}\left(\right.$ Port $0, \mathrm{ALE}$ and $\overline{\text { PSEN }}$ ); $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ all other outputs unless otherwise specified (see waveforms Figs 7, 8 and 9).

| parameter | symbol | 8 MHz |  | 10 MHz |  | 12 MHz |  | variable clock (note 2) |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. | min. | max. |  |
| Program memory <br> ALE pulse duration | ${ }^{\text {t }}$ LL | 127 | - | 160 | - | 127 | - | ${ }^{2 t} \mathrm{CK}-40$ | - | ns |
| Address set-up time to ALE | ${ }^{\text {t }}$ AL | 85 | - | 60 | - | 43 | - | ${ }^{\text {t }}$ CK -40 | - | ns |
| Address hold time after ALE | ${ }^{\text {t }}$ LA | 90 | - | 65 | - | 48 | - | ${ }^{\text {t }}$ CK -35 | - | ns |
| Time from ALE to valid instruction input | t LIV | - | 400 | - | 300 | - | 233 | - | ${ }^{4 t} \mathrm{CK}-100$ | ns |
| Time from ALE to control pulse PSEN | ${ }^{\text {t }}$ C | 100 | - | 75 | - | 58 | - | ${ }^{\mathrm{t}} \mathrm{CK}-25$ | - | ns |
| Control pulse duration PSEN | ${ }^{\mathrm{t}} \mathrm{C}$ | 340 | - | 265 | - | 215 | - | ${ }^{3 t} \mathbf{C K}-35$ | - | ns |
| Time from $\overline{\text { PSEN }}$ to valid instruction input | ${ }^{\text {t CIV }}$ | - | 250 | - | 175 | - | 125 | - | ${ }^{3} \mathrm{t}$ CK-125 | ns |
| Input instruction hold time after $\overline{\text { PSEN }}$ | ${ }^{\mathrm{t}} \mathrm{Cl}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Input instruction float delay after PSEN (note 3) | ${ }^{\text {t }} \mathrm{CIF}$ | - | 105 | - | 80 | - | 63 | - | ${ }^{\text {t }}$ CK-20 | ns |
| Address valid after $\overline{\text { PSEN }}$ (note 3) | ${ }^{t} A C$ | 117 | - | 92 | - | 75 | - | ${ }^{\text {t }} \mathrm{CK}-8$ |  | ns |
| Address to valid instruction input | ${ }^{\text {t }}$ AIV | - | 510 | - | 385 | - | 302 | - | ${ }^{51} \mathrm{CK} \mathbf{- 1 1 5}$ | ns |
| Address float time to $\overline{\text { PSEN }}$ | ${ }^{\text {t }}$ AFC | -12 | - | -12 | - | -12 | - | -12 | - | ns |


| parameter | symbol | 8 MHz |  | 10 MHz |  | 12 MHz |  | variable clock (note 2) |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. | min. | max. |  |
| External data memory |  |  |  |  |  |  |  |  |  |  |
| $\overline{\mathrm{RD}}$ pulse duration | ${ }^{\text {t } R R}$ | 650 | - | 500 | - | 400 | - | 6 t CK-100 | - | ns |
| $\overline{W R}$ pulse duration | tww | 650 | - | 500 | - | 400 | - | $6 \mathrm{C}_{\text {CK }}-100$ | - | ns |
| Address hold time after ALE |  | 90 | - | 65 | - | 48 | - | ${ }^{\text {t }}$ CK -35 | - | ns |
| RD to valid data input | ${ }^{\text {t }} \mathrm{RD}$ | - | 460 | - | 335 | - | 250 | - | ${ }^{51} \mathrm{CK}^{-165}$ | ns |
| Data hold time after $\overline{R D}$ | ${ }^{t} \mathrm{DR}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Data float delay after $\overline{R D}$ | ${ }^{\text {t DFR }}$ | - | 180 | - | 130 | - | 97 | - | $2 \mathrm{C} \mathrm{CK}^{-70}$ | ns |
| Time from ALE to valid data input | ${ }^{\text {t }}$ LD | - | 850 | - | 650 | - | 517 | - | $8 \mathrm{CtK}^{-150}$ | ns |
| Address to valid data input | ${ }^{t} A D$ | - | 960 | - | 735 | - | 585 | - | ${ }^{9} \mathrm{t} \mathrm{CK}^{-165}$ | ns |
| Time from ALE to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ LW | 325 | 425 | 250 | 350 | 200 | 300 | ${ }^{3} \mathrm{t} \mathrm{CK}^{-50}$ | ${ }^{3} \mathrm{C} C \mathrm{~K}+50$ | ns |
| Time from address to $\overline{R D}$ or $\overline{W R}$ | ${ }^{\text {t }}$ AW | 370 | - | 270 | - | 203 | - | ${ }^{4 t} \mathrm{CKK}^{-130}$ | - | ns |
| Time from $\overline{R D}$ or $\overline{W R}$ HIGH to ALE HIGH | ${ }^{\text {tWHLH }}$ | 85 | 165 | 60 | 140 | 43 | 123 | ${ }^{\text {t }} \mathrm{CK}-40$ | ${ }^{\text {t }} \mathrm{CK}^{+40}$ | ns |
| Data valid to $\overline{W R}$ transition | ${ }^{\text {t DWX }}$ | 65 | - | 40 | - | 23 | - | ${ }^{\text {t }} \mathrm{CK}^{-60}$ | - | ns |
| Data set-up time before WR | ${ }^{\text {t }}$ W | 725 | - | 550 | - | 433 | - | ${ }^{7 t} \mathrm{CK}^{-150}$ | - | ns |
| Data hold time after $\overline{W R}$ | twD | 75 | - | 50 | - | 33 | - | $\mathrm{t}_{\mathrm{CK}}-50$ | - | ns |
| Address float delay after $\overline{R D}$ | ${ }^{\text {t AFR }}$ | - | 12 | - | 12 | - | 12 | - | 12 | ns |

## Notes to the a.c. characteristics

1. $\mathrm{T}_{\text {amb }}$ for MAF8031AH/MAF8051AH is -40 to $85^{\circ} \mathrm{C}$;
for MAF80A31AH/MAF80A51AH is -40 to $100^{\circ} \mathrm{C}$.
The clock frequencies applicable to each device are as follows:

| device | clock frequency (MHz) |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
|  | 8 | 10 | 12 | 15 |
| MAB8031AH | yes | yes | yes | yes |
| MAB8051AH | yes | yes | yes | no |
| MAF8031AH | yes | yes | yes | no |
| MAF8051AH | yes | yes | yes | no |
| MAF80A31AH | yes | yes | no | no |
| MAF80A51AH | yes | yes | no | no |

2. $1 / \mathrm{t} \mathrm{CK}=3,5$ to 15 MHz (see Fig. 11 and Table 3).
3. Interfacing the MAB8051AH to devices with float times up to 75 ns is permitted. This limited bus contention will not cause damage to port 0 drivers.

(a)

A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 . Timing measurements are taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for logic 0 . The float state is defined as the point at which a Port 0 pin sinks 3,2 mA or sources $400 \mu \mathrm{~A}$ at the voltage test levels.

Fig. 10 A.C. testing input, output waveform (a) and float waveform (b).


Fig. 11 External clock drive XTAL 2 (see Table 3).
Table 3 External clock drive XTAL 2 (see Fig. 11)

| parameter | symbol | variable clock ( $\mathrm{f}=3,5$ to 15 MHz ) |  | unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| oscillator clock period | ${ }^{\text {t }} \mathrm{CK}$ | 66,6 | 286 | ns |
| HIGH time | ${ }_{\text {thigh }}$ | 20 | ${ }^{\text {t }}$ CK ${ }^{\text {t }}$ LOW | ns |
| LOW time | ${ }^{\text {t LOW }}$ | 20 | ${ }^{\text {t }} \mathrm{CK}{ }^{-t} \mathrm{HIGH}$ | ns |
| rise time | $\mathrm{t}_{\mathrm{r}}$ | - | 20 | ns |
| fall time | $\mathrm{t}_{\mathrm{f}}$ | - | 20 | ns |



Fig. 12 Read from program memory.

$`$ Fig. 13 Read from data memory.


Fig. 14 Write to data memory.


Fig. 15 Instruction cycle timing.

## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The MAB8052AH is a member of the MAB8051AH family with a higher performance. This single-chip 8-bit microcontroller is manufactured in an advanced $2 \mu$ NMOS process. For this version the following members exist:

- MAB8032AH: ROM-less version of the MAB8052AH
- MAB8052AH: 8 K bytes mask programmable ROM, 256 bytes RAM

Both types are available in 12 MHz versions. In the following, the generic term "MAB8052AH" is used to refer to both family members.
The device provides hardware features, architectural enhancements and new instructions to function as a controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.

The MAB8052AH contains a non-volatile $8 \mathrm{~K} \times 8$ read-only program memory (not ROM-less version); a volatile $256 \times 8$ read/write data memory; 32 I/O lines; three 16-bit timer/event counters; a six-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and timing circuits. For systems that require extra capability, the MAB8052AH can be expanded using standard TTL compatible memories and logic.
The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of 255 instructions; $44 \%$ one-byte, $41 \%$ twobyte and $15 \%$ three-byte. With a 12 MHz crystal, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ and $40 \%$ in $2 \mu \mathrm{~s}$. Multiply and divide instructions require $4 \mu \mathrm{~s}$.
For furthe detailed information see users manual 'single-chip 8-bit microcontrollers'.

## Features

- $8 \mathrm{~K} \times 8$ ROM (8052AH only), $256 \times 8$ RAM
- Four 8 -bit ports, 32 I/O lines
- Three 16 -bit timer/event counters
- Full-duplex serial port
- External memory expandable to 128 K
- Boolean processing
- 218 bit-addressable locations
- On-chip oscillator
- Six-source interrupt structure with two priority levels
- $58 \%$ of instructions executed in $1 \mu \mathrm{~s}$; multiply and divide in $4 \mu \mathrm{~s}$
- Enhanced architecture with:
non-page-oriented instructions
direct addressing
four 8-bit register banks
stack depth up to 128 -bytes
multiply, divide, substract and compare
- Upward compatible with MAB8031AH/8051AH
- Extended temperature range ( -40 to $+100{ }^{\circ} \mathrm{C}$ ) in preparation


## PACKAGE OUTLINE

MAB8032/52AHP: 40-lead DIL, plastic (SOT-129).


Fig. 1 Block diagram.


Fig. 2 Functional diagram.


Fig. 3 Pinning diagram.

## PINNING

1-8 P1.0-P1.7 Port 1: 8-bit quasi-bidirectional I/O port. It receives the low-order address byte during program verification. Port 1 can sink/source four LS TTL (= 1TTL) inputs. It can drive MOS inputs without external pull-ups. Pins 1 and 2 also supply alternative functions T2 and T2EX. T2 is the counter trigger input for timer 2; T2EX the external input to timer 2. Operation of the alternative functions is determined by the relevant output latch programmed to logic 1.
9 RST: a high level on this pin for two machine cycles while the oscillator is running resets the device. An internal pulldown permits Power-On reset using only a capacitor connected to $\mathrm{V}_{\mathrm{CC}}$ (see Fig. 18).
10-17 P3.0-P3.7 Port 3: 8-bit quasi-bidirectional I/O port with internal pull-ups. It also serves the following alternative functions:
Port pin Alternative function
P3.0 RXD/data: serial port receiver data input (asynchronous) or data input/output (synchronous)
P3.1 TXD/clock: serial port transmitter data output (asynchronous) or clock output (synchronous)
P3.2 $\overline{\text { INTO }}$ : external interrupt 0 or gate control input for timer/event
P3.3 counter 0

P3.4 counter 1

P3.5
TO : external input for timer/event counter 0

P3.6 $\overline{\text { WR }}$ : external data memory write strobe
P3.7 $\overline{\mathbf{R D}}$ : external data memory read strobe
Operation of an alternative function is determined by the relevant output latch programmed to logic 1. Port 3 can sink/source four LS TTL inputs. It can drive MOS inputs without external pull-ups.
18 XTAL 2 Crystal input 2: output of the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external oscillator signal when an external oscillator is used (see figures 15 and 16).
19 XTAL 1 Crystal input 1: input to the inverting amplifier that forms the oscillator. Connected to $\mathrm{V}_{\mathrm{SS}}$ when an external oscillator is used.
$20 \quad V_{S S} \quad$ Ground: circuit earth potential.
21-28 P2.0-P2.7 Port 2: 8-bit quais-bidirectional I/O port with internal pull-ups. It emits the high-order address byte when accessing external memory. It also receives the high-order address bits and control signals during program verification. Port 2 can sink/source four LS TTL inputs. It can drive MOS inputs without external pull-ups.
29 PSEN Program Store Enable output: read strobe to the external Program Memory. It is activated twice each machine cycle during fetches from external Program Memory. When executing out of external Program Memory two activations of $\overline{\text { PSEN }}$ are skipped during each access to external Data Memory. $\overline{\text { PSEN }}$ is not activated (remains HIGH) during fetches from internal Program Memory.

PINNING (continued)
30 ALE Address Latch Enable output: latches the low byte of the address during accesses to external memory in normal operation. It is activated every six oscillator periods except during an external data memory addess.
31 EA
When $\overline{E A}$ is held at a TTL high level the CPU executes out of the internal Program Memory (ROM), provided the Program Counter is less than 8192. When $\overline{E A}$ is held at a TTL low level the CPU executes out of external Program Memory. EA does not float.
32-39 P0.7-P0.0 Port 0: 8-bit open drain bidirectional I/O port. It is also the multiplexed loworder address and data bus during accesses to external memory (during these accesses it activates internall pull-ups). It also outputs instruction bytes during program verification. (External pull-ups are required during program verification). Port 0 can sink (and in bus operations can source) eight LS TTL inputs.
$40 \quad V_{C C} \quad$ Power Supply: +5 V power supply pin during normal operation.

As the MAB8052AH is based on the MAB8051 the following pages are a description of the additional features.

MEMORIES (see Fig. 4)
ROM: 8 K bytes mask programmable. An external ROM is accessed up to 64 K to accommodate an address higher than 8191.
RAM: 256 bytes (on-chip) plus special function registers detailed in Table 1.


7296495


## Where:

The internal data memory locations are addressable direct/indirect as follows:

| location | addressed |
| :--- | :--- |
| RAM 0 to 127 | direct and indirect |
| RAM 128 to 255 | indirect only |
| SFR 128 to 255 | direct only |

Fig. 4 Memory map.

## SPECIAL FUNCTION REGISTERS

Table 1 Special Function Registers (SFR)

| symbol | name | address | contents after reset |
| :---: | :---: | :---: | :---: |
| ACC* | accumulator | OEOH | OOH |
| B* | B register | OFOH | OOH |
| PSW* | program status word | ODOH | OOH |
| SP | stack pointer | 81H | 07H |
| DPTR | data pointer |  |  |
|  | DPH | 83H | 0000H |
|  | DPL | 82H | 0000H |
| P0* | port 0 | 80 H | OFFH |
| P1* | port 1 | 90 H | OFFH |
| P2* | port 2 | OAOH | OFFH |
| P3* | port 3 | OBOH | OFFH |
| IP* | interrupt priority control | OB8H | XX000000B |
| IE* | interrupt enable control | OA8H | 0X000000B |
| TMOD | timer/counter mode control | 89H | 00 H |
| T2CON* | timer/counter 2 control | OC8H | OOH |
| TCON | timer/counter control | 88H | OOH |
| TH0 | timer/counter 0 (high byte) | 8CH | OOH |
| TLO | timer/counter 0 (low byte) | 8AH | OOH |
| TH1 | timer/counter 1 (high byte) | 8DH | OOH |
| TL1 | timer/counter 1 (low byte) | 8BH | 00 H |
| TH2 | timer/counter 2 (high byte) | OCDH | OOH |
| TL2 | timer/counter 2 (low byte) | OCCH | OOH |
| RCAP2H | timer/counter 2 capture register (high byte) | OCBH | OOH |
| RCAP2L | timer/counter 2 capture register (low byte) | OCAH | OOH |
| SCON* | serial control | 98H | OOH |
| SBUF | serial data buffer | 99H | indeterminate |
| PCON | power control | 87H | OXXXXXXXB |

## Where

$H=$ Hexadecimal
$B=B$ inary

[^1]
## T2CON

Special Function Register T2CON is the timer/counter 2 control register. T2CON contains the control and status bits shown in Fig. 5 and described in Table 2.


Fig. 5 Timer/counter 2 control register (T2CON).
Table 2 T2CON: Control and status bits

| symbol | position | name | operation |
| :---: | :---: | :---: | :---: |
| TF2 | T2CON. 7 | Timer 2 overflow flag | Set by a Timer 2 overflow and must be cleared by software. TF2 will not be set when either RCLK $=1$ or TCLK $=1$. |
| EXF2 | T2CON. 6 | Timer 2 external flag | Set when either a capture or reload is caused by a negative transition on T2EX and EXEN2 $=1$. When Timer 2 interrupt is enabled, EXF2 $=1$ will cause the CPU to vector to the Timer 2 interrupt routine. EXF2 must be cleared by software. |
| RCLK | T2CON. 5 | Receive clock flag | When set, causes the serial port to use Timer 2 overflow pulses for its receive clock in modes 1 and 3. RCLK $=0$ causes Timer 1 overflow to be used for the receive clock. |
| TCLK | T2CON. 4 | Transmit clock flag | When set causes the serial port to use Timer 2 overflow pulses for its transmit clock in modes 1 and 3. TCLK = $\mathbf{0}$ causes Timer 1 overflows to be used for the transmit clock. |
| EXEN2 | T2CON. 3 | Timer 2 external enable flag | When set allows a capture or reload to occur as a result of a negative transition on T2EX if Timer 2 is not being used to clock the serial port. EXEN2 $=0$ causes Timer 2 to ignore events at T2EX. |
| TR2 | T2CON. 2 | Start/stop control for timer 2 | A logic 1 starts the timer. |
| C/T2 | T2CON. 1 | Time or counter select (timer 2) | $0=$ internal timer (OSC/12) $1=$ external event counter (falling edge triggered) |
| CP/RL2 | T2CON. 0 | Capture/reload flag | When set capture will occur on negative transitions at T2EX if EXEN2 $=1$. When cleared automatic reloads will occur either with Timer 2 overflows or negative transitions at T2EX when EXEN2 $=1$. When either RCLK $=1$ or TCLK $=1$, this bit is ignored and the timer is forced to automatic-reload on Timer 2 overflow. |

## SPECIAL FUNCTION REGISTERS (continued)

## TH2; TL2

Timer/counter 2 (high byte); Timer/counter 2 (low byte) are the register pair for the 16 -bit counting of timer/counter 2.

## RCAP2H; RCAP2L

Timer/counter 2 capture (high byte); Timer/counter 2 capture (low byte) are the register pair for the "capture mode" of Timer 2. In this mode, a signal at T2EX initiates a copy of TH2 and TL2 into RCAP2H and RCAP2L. Timer 2 also has an automatic-reload mode. RCAP2H and RCAP2L hold the reload value for this mode.

## T2CON

Timer 2 is 16 -bit and operates the same as Timer 0 and Timer 1 . The operating mode is selected by the T2CON register. Table 3 shows the operating modes of Timer 2.

Table 3 Timer 2 operating modes.

| RCLK + TCLK | CP/RL2 | TR2 | mode |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 16-bit automatic-reload |
| 0 | 1 | 1 | 16-bit capture |
| 1 | $X$ | 1 | baud rate generator |
| $X$ | $X$ | 0 | off |

## Where

$X=$ don't care.

## Capture mode (see Fig. 6)

In the capture mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2 $=0$, then Timer 2 is a 16 -bit timer or counter which on overflow will set bit TF2 (Timer 2 overflow bit). TF2 can be used to generate an interrupt. If EXEN2 $=1$, Timer 2 operates as for EXEN2 $=0$ with the added feature that a 1 -to- 0 transition at the external input T2EX causes the current value in the Timer 2 registers (TL2 and TH2) to be captured into registers RCAP2L and RCAP2H respectively. The 1 -to-0 transition of T2EX also causes bit EXF2 in T2CON to be set. EXF2 can be used to generate an interrupt.

## Automatic-reload mode (see Fig. 7)

In the automatic-reload mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2 $=0$, when Timer 2 overflows it sets TF2 and causes the Timer 2 registers to be reloaded with the 16 -bit value in registers RCAP2L and RCAP2H, which are preset by software. If EXEN2 $=1$, Timer 2 operates as for EXEN2 $=0$ with the added feature that a 1 -to- 0 transition at the external input T2EX triggers the 16 -bit reload and sets EXF2.

## Baud rate generator mode (see Fig. 8)

The baud rate generator mode is selected by RCLK = 1 and/or TCLK = 1 in T2CON. Thus baud rates for transmit and receive can be simultaneously different. This mode is described in conjunction with the serial port.


Fig. 6 Timer 2 in capture mode.

$\angle$ NOTE AVALLABILITY OF ADDITIONAL EXTERNAL INTERRUPT


Fig. 9 The serial port in mode 1.


Fig. 10 The serial port in mode 3.

## INTERRUPTS

The MAB8052AH has 6 interrupts as shown in Fig. 11.

## $\overline{\text { INTO }} \overline{\text { INT1 }}$

The external interrupts $\overline{\mathrm{NTO}}$ and $\overline{\mathrm{INT} 1}$ can be level-activated or transition-activated dependent on bits ITO and IT1 in register TCON. The flags that generate these interrupts are bits IE0 and IE1.
When a transition-activated external interrupt is generated, the interrupt flag is cleared by the on-chip hardware when the CPU transfers control to the service routine. If the interrupt is level-activated, the request flag is controlled by the external requesting source.

## Timer 0; Timer 1

The Timer 0 and Timer 1 interrupts are generated by TF0 and TF1, which are set by an overflow in their respective timer/counter registers. This is not applicable for Timer 0 in mode 3. When a timer interrupt is generated, the interrupt flag is cleared by the on-chip hardware when the CPU transfers control to the service routine.

## Timer 2

The interrupt of Timer 2 is generated by the logical OR of TF2 and EXF2. The service routine determines whether it was TF2 or EXF2 that generated the interrupt, and the bits are cleared by software.

## Serial port interrupt

The serial port interrupt is generated by the logical OR of R1 and T1 flags. These flags are not cleared by the on-chip hardware when the CPU transfers control to the service routine. The service routine determines whether it was R1 or T1 that generated the interrupt, and the bit is cleared by software.
All of the bits that generate interrupts can be set or cleared by software, with the same result as being set or cleared by hardware. Thus interrupts can be generated, or pending interrupts cancelled, by software.
Each of the interrupt sources can be individually enabled or disabled by setting or clearing a bit in Special Function Register IE (see Fig. 12 and Table 4).
Register IE contains a global disable bit (EA) which disables all interrupts simultaneously.


Fig. 11 Interrupt sources.


Fig. 12 Interrupt enable register (IE).
Table 4 IE: Control and status bits

| symbol | position | function |
| :---: | :---: | :---: |
| EA | IE. 7 | Disables all interrupts. If $\mathrm{EA}=0$ no interrupt will be acknowledged. If $E A=1$ each interrupt source is individually enabled or disabled by setting or clearing its enable bit. |
| - | IE. 6 | Reserved. |
| ET2 | IE. 5 | Enables or disables the Timer 2 overflow or capture interrupt. If ET2 $=0$ the Timer 2 interrupt is disabled. |
| ES | IE. 4 | Enables or disables the Serial Port interrupt. If ES $=0$ the Serial Port interrupt is disabled. |
| ET1 | IE. 3 | Enables or disables the Timer 1 overflow interrupt. If ET1 $=0$ the Timer 1 interrupt is disabled. |
| EX1 | IE. 2 | Enables or disables external interrupt 1 . If EX1 $=0$ the external interrupt is disabled. |
| ETO | IE. 1 | Enables or disables the Timer 0 overflow interrupt. If ETO $=0$ the Timer 0 interrupt is disabled. |
| EXO | IE. 0 | Enables or disables external interrupt. 0 . If EXO $=0$ the external interrupt is disabled. |

## INTERRUPTS (continued)

## Priority level structure (see Fig. 13 and Table 5)

Each interrupt source can be programmed to one of two priority levels by setting or clearing a bit in Special Function Register IP. A low-priority interrupt can be interrupted by a high-priority interrupt, but not by another low-priority interrupt. A high-priority interrupt cannot be interrupted by any other interrupt source.


Fig. 13 Interrupt priority register (IP).
Table 5 IP: Control and status bits

| symbol | position | function |
| :--- | :--- | :--- |
| - | IP. 7 | Reserved. <br> - |
| PT2 6 | IP. 5 | Reserved. <br> Defines the Timer 2 interrupt priority level. PT2 $=1$ programs it to the <br> higher priority level. <br> Defines the Serial Port interrupt priority level. $\mathrm{PS} 1=1$ programs it to the <br> higher priority level. <br> Defines the Timer 1 interrupt priority level. PT1 $=1$ programs it to the <br> higher priority level. <br> PS |
| PT1 | IP. 3 |  |
| PX1 | IP. 2 | Defines the external interrupt 1 priority level. $\mathrm{PX} 1=1$ programs it to the <br> higher priority level. <br> Defines the Timer 0 interrupt priority level. PT0 $=1$ programs it to the <br> higher priority level. <br> Defines the external interrupt 0 priority level. $\mathrm{PX} 0=1$ programs it to the <br> higher priority level. |
| PT0 | IP. 1 | IP. 0 |

The interrupt response timing is shown in Fig. 14. The fastest possible response occurs when C2 is the final cycle of an instruction other than "return from interrupt" instruction (RET1), or an access to registers IE or IP.


Fig. 14 Interrupt response timing diagram.

## Priority level structure (continued)

If two requests of different priority levels are received simultaneously, the higher priority request is serviced. If requests of the same priority level are received simultaneously, an internal polling sequence determines which request is serviced. This second priority structure determined by the polling sequence is detailed in Table 6.

Table 6 Vector addresses by interrupt depending on interrupt source and priority

| number | source | priority within level | vector address |
| :--- | :--- | :--- | :--- |
| 1 | IE0 | (highest) | 0003 H |
| 2 | TF0 |  | 000 BH |
| 3 | IE1 |  | 0013 H |
| 4 | TF1 |  | 001 BH |
| 5 | R1 + T1 |  | 0023 H |
| 6 | TF2 + EXF2 | (lowest) | 002 BH |

## OSCILLATOR CIRCUITRY

The oscillator circuitry of the MAB8052AH is a single-stage inverting amplifier in a Pierce oscillator configuration. The circuitry has a combination of depletion and enhancement mode MOS FETs to produce the inverting characteristics, and passive components. Either a crystal or ceramic resonator can be used as the feedback element to complete the oscillator circuitry. XTAL.1, pin 19, is the high gain amplifier input, and XTAL2, pin 18, is the output (see Fig. 15).
To drive the MAB8052AH externally, XTAL1 should be connected to ground and XTAL2 driven from an external source (see Fig. 16).


Fig. 15 MAB8052AH oscillator circuit.


Fig. 16 Driving the MAB8052AH from an external source.

## RESET CIRCUITRY

The reset circuitry for the MAB8052AH is connected to the reset pin, RST, as shown in Fig. 17. A Schmitt trigger is used at the input for noise rejection. The output of the Schmitt trigger is sampled by the reset circuitry every machine cycle.


Fig. 17 Reset configuration at RST.
A reset is accomplished by holding the RST pin HIGH for at least two machine cycles (24 oscillator periods), while the oscillator is running. The CPU responds by executing an internal reset. It also configures the ALE and PSEN pins as inputs. (They are quasi-bidirectional.) The internal reset is executed during the second cycle in which RST is HIGH and is repeated every cycle until RST goes LOW. It leaves the internal registers as shown in Table 1.
The internal RAM is not affected by reset. When $V_{C C}$ is turned on, the RAM content is indeterminate.

## Power-on reset (see Fig. 18)

When $V_{\text {CC }}$ is turned on, and provided its rise-time does not exceed 10 ms , an automatic reset can be obtained by connecting the RST pin to $\mathrm{V}_{\mathrm{CC}}$ via a $10 \mu \mathrm{~F}$ capacitor. When the power is switched on, the current drawn by RST is the difference between $\mathrm{V}_{\mathrm{CC}}$ and the capacitor voltage, and decreases from $V_{C C}$ as the capacitor charges through the internal resistor ( $R_{R S T}$ ) to ground. The larger the capacitor, the more slowly $\mathrm{V}_{\text {RST }}$ decreases. $\mathrm{V}_{\text {RST }}$ must remain above the lower threshold of the Schmitt trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles.


Fig. 18 Power-on reset.

## INSTRUCTION SET

The MAB8052AH uses a powerful instruction set to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Reassigned opcodes add new high-power operations and permit new addressing modes to make old operations more orthogonal. The instruction set consists of 49 single-byte, 45 two-byte and 17 three-byte instructions. When using a 12 MHz oscillator, 64 instructions execute in $1 \mu \mathrm{~s}$ and 45 instructions execute in $2 \mu \mathrm{~s}$. Multiply and divide instructions execute in $4 \mu$ s.

Table 7 Instruction set description

| mnemonic | description | bytes/ <br> cycles | opcode <br> (hex.) |  |
| :--- | :--- | :--- | :--- | :--- |
| Arithmetic operation |  |  |  |  |
| ADD | A,Rr | Add register to A | 1 | 1 |
| ADD | A,direct | Add direct byte to A | $2^{*}$ |  |
| ADD | A,@Ri | Add indirect RAM to A | 2 | 1 |
| ADD | A,\#data | Add immediate data to A | 25 |  |
| ADDC | A,Rr | Add register to A with carry flag | 1 | 26,27 |
| ADDC | A,direct | Add direct byte to A with carry flag | 2 | 1 |
| ADDC | A,@Ri | Add indirect RAM to A with carry flag | 24 |  |
| ADDC | A,\#data | Add immediate data to A with carry flag | 1 | $3^{*}$ |
| SUBB | A,Rr | Subtract register from A with borrow | 1 | 35 |
| SUBB | A,direct | Subtract direct byte from A with borrow | 1 | 36,37 |
| SUBB | A,@Ri | Subtract indirect RAM from A with borrow | 1 | 1 |
| SUBB | A,\#data | Subtract immediate data from A with borrow | 1 | 1 |
| INC | A | 2 | 1 | 95 |
| INC | Rr | Increment A | 96,97 |  |
| INC | direct | Increment register | 1 | 1 |
| INC | $@ R:$ | Increment direct byte | 04 |  |
| DEC | A | Increment indirect RAM | 1 | 1 |
| DEC | Rr | Decrement A | $0^{*}$ |  |
| DEC | direct | Decrement register | 2 | 1 |
| DEC | @Ri | Decrement direct byte | 05 |  |
| INC | DPTR | Decrement indirect RAM | 1 | 1 |
| MUL | AB | Increment data pointer | 06,07 |  |
| DIV | AB | Multiply A \& B | 1 | 1 |
| DA | A | Divide A by B | 14 |  |

INSTRUCTION SET (continued)

| mnemonic |  | description | bytes/ cycles | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Logic operations |  |  |  |  |
| ANL | A, Rr | AND register to A | 11 | 5* |
| ANL | A,direct | AND direct byte to $A$ | 21 | 55 |
| ANL | A,@Ri | AND indirect RAM to $A$ | $1 \begin{array}{ll}1 & 1\end{array}$ | 56, 57 |
| ANL | A, \#data | AND immediate data to $A$ | 21 | 54 |
| ANL | direct, $A$ | AND A to direct byte | 21 | 52 |
| ANL | direct,\#data | AND immediate data to direct byte | 32 | 53 |
| ORL | A, Rr | OR register to $A$ |  | 4* |
| ORL | A, direct | OR direct byte to $A$ | 21 | 45 |
| ORL | A,@Ri | $O R$ indirect RAM to $A$ | 11 | 46, 47 |
| ORL | A, \#data | OR immediate data to $A$ | 21 | 44 |
| ORL | direct, A | OR A to direct byte |  | 42 |
| ORL | direct,\#data | OR immediate data to direct byte | 32 | 43 |
| XRL | A, Rr | Exclusive-OR register to $A$ | 11 | 6* |
| XRL | A,direct | Exclusive-OR direct byte to $A$ | 21 | 65 |
| XRL | A,@Ri | Exclusive-OR indirect RAM to $A$ | 11 | 66, 67 |
| XRL | A,\#data | Exclusive-OR immediate data to $A$ | 21 | 64 |
| XRL | direct, A | Exclusive-OR to direct byte | 21 | 62 |
| XRL | direct,\#data | Exclusive-OR immediate data to direct byte | 32 | 63 |
| CLR | A | Clear A | 11 | E4 |
| CPL | A | Complement A | 11 | F4 |
| RL | A | Rotate A left | 11 | 23 |
| RLC | A | Rotate A left through the carry flag | 11 | 33 |
| RR | A | Rotate A right | 11 | 03 |
| RRC | A | Rotate A right through the carry flag | 11 | 13 |
| SWAP | A | Swap nibbles within A | 11 | C4 |


| mnemonic |  | description | bytes/ cycles | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Data transfer |  |  |  |  |
| MOV | A, Rr | Move register to A | 11 | E* |
| MOV | A, direct ** | Move direct byte to A | 21 | E5 |
| MOV | A,@Ri | Move indirect RAM to $A$ | 11 | E6, E7 |
| MOV | A,\#data | Move immediate data to $A$ | 21 | 74 |
| MOV | Rr,A | Move A to register | $1 \begin{array}{ll}1 & 1\end{array}$ | F* |
| MOV | Rr,direct | Move direct byte to register | 22 | A* |
| MOV | Rr,\#data | Move immediate data to register | 21 | 7* |
| MOV | direct, $A$ | Move A to direct byte | 21 | F5 |
| MOV | direct, Rr | Move register to direct byte | 22 | 8* |
| MOV | direct, direct | Move direct byte to direct | $3 \quad 2$ | 85 |
| MOV | direct,@Ri | Move indirect RAM to direct byte | 22 | 86, 87 |
| MOV | direct,\#data | Move immediate data to direct byte | $3 \quad 2$ | 75 |
| MOV | @Ri,A | Move A to indirect RAM | $1 \begin{array}{ll}1 & 1\end{array}$ | F6, F7 |
| MOV | @Ri, direct | Move direct byte to indirect RAM | 22 | A6, A7 |
| MOV | @Ri,\#data | Move immediate data to indirect RAM | 2 | 76, 77 |
| MOV | DPTR,\#data 16 | Load data pointer with a 16-bit constant | $3 \quad 2$ | 90 |
| MOVC | A,@A+DPTR | Move code byte relative to DPTR to A | 12 | 93 |
| MOVC | A,@A+PC | Move code byte relative to PC to A | 12 | 83 |
| MOVX | A,@Ri | Move external RAM (8-bit address) to A | 12 | E2, E3 |
| MOVX | A,@DPTR | Move external RAM (16-bit address) to A | 12 | E0 |
| MOVX | @ $\mathrm{Ri}, \mathrm{A}$ | Move A to external RAM (8-bit address) | 12 | F2, F3 |
| MOVX | @DPTR,A | Move A to external RAM (16-bit address) | 12 | F0 |
| PUSH | direct | Push direct byte onto stack | 22 | C0 |
| POP | direct | Pop direct byte from stack |  | D0 |
| XCH | A, Rr | Exchange register with A | 11 | C* |
| XCH | A,direct | Exchange direct byte with A | 21 | C5 |
| XCH | A,@Ri | Exchange indirect RAM with A | $1 \begin{array}{ll}1 & 1\end{array}$ | C6, C7 |
| XCHD | A,@Ri | Exchange LOW-order digit indirect RAM with A | 11 | D6, D7 |

[^2]INSTRUCTION SET (continued)

| mnemonic |  | description | bytes/ cycles | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Boolean variable manipulation |  |  |  |  |
| CLR | C | Clear carry flag | 11 | C3 |
| CLR | bit | Clear direct bit | 21 | C2 |
| SETB | C | Set carry flag | 11 | D3 |
| SETB | bit | Set direct bit | 21 | D2 |
| CPL | C | Complement carry flag | 11 | B3 |
| CPL | bit | Complement direct bit | 21 | B2 |
| ANL | C, bit | AND direct bit to carry flag | 22 | 82 |
| ANL | C,/bit | AND complement of direct bit to carry flag | 22 | B0 |
| ORL | C,bit | OR direct bit to carry flag | 22 | 72 |
| ORL | C,/bit | OR complement of direct bit to carry flag | 22 | A0 |
| MOV | C,bit | Move direct bit to carry flag | 21 | A2 |
| MOV | bit, C | Move carry flag to direct bit | 22 | 92 |
| Program and machine control |  |  |  |  |
| ACALL | addr11 | Absolute subroutine call | 22 | -1addr |
| LCALL | addr16 | Long subroutine call | 32 | 12 |
| RET |  | Return from subroutine | 12 | 22 |
| RET1 |  | Return from interrupt | 12 | 32 |
| AJMP | addr11 | Absolute jump | 22 | 41addr |
| LJMP | addr16 | Long jump | 32 | 02 |
| SJMP | rel | Short jump (relative address) | 22 | 80 |
| JMP | @A+DPTR | Jump indirect relative to the DPTR | $1 \begin{array}{ll}1 & 2\end{array}$ | 73 |
| JZ | rel | Jump if $A$ is zero | 22 | 60 |
| JNZ | rel | Jump if $A$ is not zero | 22 | 70 |
| JC | rel | Jump if carry flag is set | 22 | 40 |
| JNC | rel | Jump if no carry flag | 22 | 50 |
| JB | bit,rel | Jump if direct bit is set | 32 | 20 |
| JNB | bit,rel | Jump if direct bit is not set | 32 | 30 |
| JBC | bit,rel | Jump if direct bit is set and clear bit | 32 | 10 |
| CJNE | A, direct, rel | Compare direct to $A$ and jump if not equal | $\begin{array}{ll}3 & 2\end{array}$ | B5 |
| CJNE | A, \#data, rel | Compare immediate to $A$ and jump if not equal | 32 | B4 |
| CJNE | Rr,\#data, rel | Compare immed. to reg. and jump if not equal | 3 | B* |
| CJNE | @Ri,\#data,rel | Compare immed. to ind. and jump if not equal | 3 | B6, B7 |
| DJNZ | Rr,rel | Decrement register and jump if not zero | 2 | D* |
| DJNZ | direct, rel | Decrement direct and jump if not zero | 3 | D5 |
| NOP |  | No operation | 11 | 00 |

## Notes to Table 7

Data addressing modes
$\mathrm{Rr} \quad$ Working register RO-R7.
direct 128 internal RAM locations and any special function register (SFR).
@Ri Indirect internal RAM location addressed by register RO or R1.
\#data $\quad 8$-bit constant included in instruction.
\#data16 16-bit constant included as bytes 2 and 3 of instruction.
bit Direct addressed bit in internal RAM or SFR.
addr16 16-bit destination address. Used by LCALL and LJMP. The branch will be anywhere within the 64 K -byte program memory address space.
addr11 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 K -byte page of program memory as the first byte of the following instruction.
rel Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is -128 to +127 bytes relative to first byte of the following instruction.

## Hexadecimal opcode cross-reference to Table 8

*: 8, 9, A, B, C, D, E, F.

- : 11, 31, 51, 71, 91, B1, D1, F1.

A: $01,21,41,61,81$, A1, C1, E1.

Table 8 Instruction map

| - first hexadecimal chacter of opcode |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\downarrow$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| 0 | NOP | AJMP page 0 | LJMP <br> addr16 | RR A | INC A | INC dir | INC@Ri $0$ | 1 | $\begin{aligned} & \text { INC Rr } \\ & 0\|1\| \end{aligned}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 1 | $\begin{aligned} & \text { JBC } \\ & \text { bit, addr8 } \end{aligned}$ | ACALL page 0 | LCALL addr16 | RRC A | DEC A | $\begin{aligned} & \text { DEC } \\ & \text { dir } \end{aligned}$ | DEC @Ri $10$ | 1 |  |  |  | 3 | 4 | 5 | 6 | 7 |
| 2 | JB <br> bit, addr8 | AJMP page 1 | RET | RLA | ADD <br> A,\#data | ADD <br> A, dir | $\begin{aligned} & \text { ADD A,@Ri } \\ & 0 \end{aligned}$ | 1 | $\begin{array}{l\|l\|l\|} \hline \text { ADD } & \mathrm{Rr} \\ 0 & 1 & 2 \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 3 | JNB bit, addr8 | ACALL page 1 | RET1 | RLC A | ADDC <br> A, \#data | ADDC <br> A, dir | $\begin{aligned} & \text { ADDC A,@Ri } \\ & 0 \end{aligned}$ | 1 | $\begin{array}{l\|l\|l} \text { ADC } & \mathrm{A}, \mathrm{Rr} \\ 0 & 1 & 2 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 4 | JC addr8 | AJMP page 2 | ORL <br> dir,A | ORL <br> dir,\#data | ORL <br> A, \#data | ORL <br> A, dir | $\begin{aligned} & \text { ORLA, @Ri } \\ & 0 \end{aligned}$ | 1 | $$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 5 | JNC addr8 | ACALL page 2 | ANL dir,A | ANL <br> dir,\#data | ANL <br> A, \#data | ANL <br> A, dir | ANL A,@Ri 0 | 1 |  |  |  | 3 | 4 | 5 | 6 | 7 |
| 6 | JZ addr8 | AJMP page 3 | XRL <br> dir,A | XRL dir,\#data | XRL <br> A,\#data | XRL <br> A, dir | $\begin{aligned} & \text { XRL A,@Ri } \\ & 0 \end{aligned}$ | 1 | $\begin{array}{l\|l\|l} X R L A, R r \\ 0 & 1 & 2 \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 7 | JNZ <br> addr8 | ACALL page 3 | ORL <br> C,bit | JMP <br> @A+DPTR | MOV <br> A, \#data | MOV <br> dir,\#data | MOV @Ri,\#data 0 |  | MOV Rr,\#data <br> 0 1 2 3 |  |  |  | 4 | 5 | 6 | 7 |
| 8 | SJMP <br> addr8 | AJMP page 4 | ANL C,bit | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+PC } \end{aligned}$ | $\begin{aligned} & \text { DIV } \\ & \text { AB } \end{aligned}$ | MOV <br> dir,dir | MOV dir,@Ri <br> 0 |  | MOV dir, Rr0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
| 9 | MOV DPTR, \#data 16 | ACALL page 4 | $\begin{align*} & \text { MOV } \\ & \text { bit,C } \tag{1} \end{align*}$ | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+DPTR } \end{aligned}$ | SUBB <br> A,\#data | SUBB <br> A,dir | $\begin{aligned} & \text { SUBB A,@Ri } \\ & 0 \end{aligned}$ |  | SUBB A, Rr <br> $0\|\|l\| l\|$ |  |  | 3 | 4 | 5 | 6 | 7 |
| A | ORL <br> C,/bit | AJMP page 5 | MOV <br> C,bit | INC DPTR | $\begin{aligned} & M U L \\ & A B \end{aligned}$ |  | MOV @Ri,dir 0 | $1$ | MOV Rr,dir0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
| B | ANL C,/bit | ACALL page 5 | $\begin{aligned} & \text { CPL } \\ & \text { bit } \end{aligned}$ | CPL C | CJNE A, \#data, addr8 | CJNE <br> A,dir,addr8 | CJNE @Ri,\#data, addr80 1 |  | CJNE Rr,\#data, addr80 1 2 3 4 |  |  |  |  | 5 | 6 | 7 |
| C | $\begin{aligned} & \text { PUSH } \\ & \text { dir } \end{aligned}$ | AJMP page 6 | CLR bit | CLR C | $\begin{aligned} & \text { SWAP } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{dir} \end{aligned}$ | $\begin{aligned} & \text { XCH A, @Ri } \\ & 0 \end{aligned}$ | $1$ | $\begin{array}{l\|l\|l} \mathrm{XCH} & \mathrm{~A}, \mathrm{Rr} \\ 0 & 1 & 2 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| D | $\begin{aligned} & \text { POP } \\ & \text { dir } \end{aligned}$ | ACALL page 6 | SETB bit | $\begin{aligned} & \text { SETB } \\ & \text { C } \end{aligned}$ | DA A | DJNZ dir, addr8 | $\begin{aligned} & \text { XCHD A,@Ri } \\ & 0 \end{aligned}$ | 1 | DJNZ Rr, addr80 1 2 3 |  |  |  | 4 | 5 | 6 | 7 |
| E | MOVX <br> A,@DPTR | AJMP page 7 | $\begin{aligned} & \text { MOVX A } \\ & 0 \end{aligned}$ | $\begin{aligned} & @ R i \\ & 1 \end{aligned}$ | CLR A | $\begin{aligned} & \text { MOV } \\ & \text { A,dir } \end{aligned}$ | $\begin{aligned} & \text { MOV A,@Ri } \\ & 0 \end{aligned}$ | 1 | MOV $A, R r$   <br> 0 1 2 |  |  | 3 | 4 | 5 | 6 | 7 |
| F | MOVX @DPTR,A | ACALL page 7 | $\begin{aligned} & \text { MOVX © } \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{Ri}, \mathrm{~A} \\ & 1 \end{aligned}$ | CPL A | $\begin{aligned} & \text { MOV } \\ & \text { dir,A } \end{aligned}$ | $\begin{aligned} & \text { MOV @Ri,A } \\ & 0 \end{aligned}$ | $1$ | MOV Rr,A |  |  | 3 | 4 | 5 | 6 | 7 |

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Input voltage on any pin with respect to ground ( $\mathrm{V}_{\mathrm{SS}}$ )
Total power dissipation
Input, output current
Storage temperature range
Operating ambient temperature range

| $\mathrm{V}_{\mathrm{l}}$ | $-0,5$ to $+7 \mathrm{~V}$ |  |
| :--- | ---: | ---: |
| $\mathrm{P}_{\text {tot }}$ | max. | 2 W |
| $\pm \mathrm{I}_{1}, \mathrm{I}_{\mathrm{O}}$ | max. | 10 mA |
| $\mathrm{~T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |  |
| $\mathrm{T}_{\text {amb }}$ | 0 to $+70^{\circ} \mathrm{C}$ |  |

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current | ${ }^{\text {I CC }}$ | - | 175 | mA | all outputs disconnected; $\overline{\mathrm{EA}}=\mathrm{V}_{\mathrm{CC}}$ |
| Inputs |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IL }}$ | -0,5 | 0,8 | V |  |
| Input voltage HIGH all inputs except RST and XTAL 2 | $\mathrm{V}_{\text {IH }}$ | 2 | $\mathrm{V}_{\mathrm{CC}}+0,5$ | V |  |
| Input voltage HIGH to RST and XTAL 2 | $\mathrm{V}_{1 \mathrm{H} 1}$ | 2,5 | $\mathrm{V}_{\mathrm{CC}}+0,5 \mathrm{~V}$ | V | XTAL 1 to $\mathrm{V}_{\text {SS }}$ |
| Outputs |  |  |  |  |  |
| Output voltage LOW (Ports 1, 2, 3) (note 1) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,45 | V | $\mathrm{I}_{\mathrm{OL}}=1,6 \mathrm{~mA}$ |
| Output voltage LOW (Port 0, ALE, PSEN) (note 1) | $\mathrm{V}_{\text {OL1 }}$ | - | 0,45 | V | $\mathrm{I}_{\mathrm{OL1}}=3,2 \mathrm{~mA}$ |
| Output voltage HIGH (Ports 1, 2, 3) | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | V | ${ }^{\prime} \mathrm{OH}=-80 \mu \mathrm{~A}$ |
| Output voltage HIGH (Port 0, ALE, $\overline{\text { PSEN }}$ ) | $\mathrm{V}_{\mathrm{OH} 1}$ | 2,4 | - | V | ${ }^{1} \mathrm{OH} 1=-400 \mu \mathrm{~A}$ |
| Input leakage current (Port 0, EA) | $\pm 1 \mathrm{LI}$ | - | 10 | $\mu \mathrm{A}$ | $0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ |
| Input current HIGH (RST) | ${ }_{1 / H 1}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}-1,5 \mathrm{~V}$ |
| current logic 0 <br> (Ports 1, 2, 3) | IIL | - | -800 | $\mu \mathrm{A}$ | $V_{\text {IL }}=0,45 \mathrm{~V}$; |
| Input current logic 0 (XTAL 2) | IIL2 | - | -3,2 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0,45 \mathrm{~V} \\ & \mathrm{XTAL} 1 \text { to } \mathrm{V}_{\mathrm{SS}} \end{aligned}$ |
| Capacitance of I/O buffer | $\mathrm{Cl}_{1 / \mathrm{O}}$ | - | 10 | pF | $\begin{aligned} & \mathrm{f}_{\mathrm{C}}=1 \mathrm{MHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ |

## Note 1

$\mathrm{V}_{\text {OL }}$ is degraded when the MAB8052AH rapidly discharges external capacitance.
This a.c. noise is most pronounced during emission of address data. When using external memory, locate the latch or buffer as close to the MAB8052AH as possible.

| datum | emitting <br> ports | time slot <br> interval | degraded <br> I/O lines | $\mathrm{V}_{\mathrm{OL}}$ <br> (max.) |
| :--- | :--- | :--- | :--- | :--- |
| address | P2, P0 | TS3, TS9 | P1, P3 | $0,8 \mathrm{~V}$ |
| write data | P0 | TS6 | P1, P3, ALE | $0,8 \mathrm{~V}$ |

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}($ Port $0, A L E$ and $\overline{\text { PSEN }}) ; \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ all other outputs unless otherwise specified (see waveforms Figs 21, 22 and 23).

A.C. CHARACTERISTICS (continued)

| parameter | symbol | 12 MHz |  | variable clock (note 1) |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. |  |
| External data memory |  |  |  |  |  |  |
| $\overline{\mathrm{RD}}$ pulse duration | ${ }^{\text {t }}$ RR | 400 | - | ${ }^{6} \mathrm{t} \mathrm{CK}^{-100}$ | - | ns |
| $\overline{\text { WR }}$ pulse duration | tww | 400 | - | $6 \mathrm{tcK}-100$ | - | ns |
| Address hold time after ALE | ${ }^{\text {t L A }}$ | 48 | - | ${ }^{\mathrm{t}} \mathrm{CK}-35$ | - | ns |
| RD to valid data input | ${ }^{\text {t } R D}$ | - | 250 | - | ${ }^{5} \mathrm{t}$ CK-165 | ns |
| Data hold time after $\overline{\mathrm{RD}}$ | ${ }^{\text {t }} \mathrm{DR}$ | 0 | - | 0 | - | ns |
| Data float delay after $\overline{\mathrm{RD}}$ | ${ }^{\text {t }}$ DFR | - | 97 | - | ${ }^{2} \mathrm{t} \mathrm{CK}-70$ | ns |
| Time from ALE to valid data input | ${ }^{\text {t }}$ D | - | 517 | - | $8{ }^{\text {ctek }}$-150 | ns |
| Address to valid data input | ${ }^{t} A D$ | - | 585 | - | $9{ }^{\text {ctek }}$ - 165 | ns |
| Time from ALE to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ LW | 200 | 300 | ${ }^{3} \mathrm{t} C K-50$ | ${ }^{3} \mathrm{t} \mathrm{CK}^{+50}$ | ns |
| Time from address to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ AW | 203 | - | ${ }^{4 t} \mathrm{CK}-130$ | - | ns |
| Time from $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ HIGH to ALE HIGH | ${ }^{\text {twhin }}$ | 43 | 123 | ${ }^{\text {t }}$ CK -40 | ${ }^{\text {t }} \mathrm{CK}{ }^{+40}$ | ns |
| Data valid to $\overline{\mathrm{WR}}$ transition | ${ }^{\text {t DWX }}$ | 23 | - | ${ }^{\text {t }}$ CK -60 | - | ns |
| Data set-up time before $\overline{W R}$ | ${ }^{\text {t }}$ W | 433 | - | $7 \mathrm{tcK}-150$ | - | ns |
| Data hold time after $\overline{W R}$ | ${ }^{t} W \mathrm{D}$ | 33 | - | ${ }^{t} \mathrm{CK}-50$ | 0 | ns |
| Address float delay after $\overline{R D}$ | ${ }^{\text {t }}$ AFR | - | + 12 | - | + 12 | ns |

## Notes to the a.c. characteristics

1. $1 / \mathrm{t}_{\mathrm{CK}}=3,5$ to 12 MHz (see Fig. 20 and Table 9).
2. Interfacing the MAB8052AH to devices with float times up to 75 ns is permitted. This limited bus contention will cause damage to port 0 drivers.

(a)

A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 . Timing measurements are taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for logic 0 . The float state is defined as the point at which a Port 0 pin sinks $3,2 \mathrm{~mA}$ or sources $400 \mu \mathrm{~A}$ at the voltage test levels.

Fig. 19 A.C. testing input, output waveform (a) and float waveform (b).


Fig. 20 External clock drive XTAL 2 (see Table 9).
Table 9 External clock drive XTAL 2 (see Fig. 20)

| parameter | symbol | variable clock$\text { (f = 3,5 to } 12 \mathrm{MHz} \text { ) }$ |  | unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| oscillator clock period | ${ }^{\text {t }} \mathrm{CK}$ | 83,3 | 286 | ns |
| HIGH time | ${ }^{\text {t HIGH }}$ | 20 | ${ }^{\text {t }}$ CK-t ${ }^{\text {LOW }}$ | ns |
| LOW time | ${ }^{\text {t LOW }}$ | 20 | ${ }^{\text {t }}$ CK ${ }^{-t} \mathrm{HIGH}$ | ns |
| rise time | $\mathrm{t}_{\mathrm{r}}$ | - | 20 | ns |
| fall time | $\mathrm{t}_{\mathrm{f}}$ | - | 20 | ns |



Fig. 21 Read from program memory.


Fig. 22 Read from data memory.


Fig. 23 Write to data memory.


Fig. 24 Instruction cycle timing.

## SINGLE-CHIP. 8-BIT MICROCONTROLLER

## GENERAL DESCRIPTION

The MAB80XXH family of single-chip 8-bit microcontrollers are fabricated in NMOS.
Three interchangeable (pin compatible) versions are available:

- MAB8048H with resident mask-programmed $1 \mathrm{~K} \times 8$ ROM, $64 \times 8$ RAM
- MAB8035HL without resident program memory for use with external EPROM/ROM, $64 \times 8$ RAM.
- MAB8049H with resident mask-programmed $2 \mathrm{~K} \times 8$ ROM, $128 \times 8$ RAM
- MAB8039HL without resident program memory for use with external EPROM/ROM, $128 \times 8$ RAM.
- MAB8050H with resident mask-programmed $4 \mathrm{~K} \times 8$ ROM, $256 \times 8$ RAM
- MAB8040HL without resident program memory for use with external EPROM/ROM, $256 \times 8$ RAM.

The MAB80XXH family are designed to be efficient control processors as well as arithmetic processors. Their instruction set allows the user to directly set and reset individual I/O lines as well as test individual bits within the accumulator. A large variety of branch and table look-up instructions enable efficient implementation of standard logic functions. Code efficiency is high; over $70 \%$ of the instructions are single byte; all others are two byte.
An on-chip 8-bit counter is provided, which can count either machine cycles ( $\div 32$ ) or external events. The counter can be programmed to cause an interrupt to the processor. Program and data memories plus input/output capabilities can be expanded using standard devices. For further detailed information see users manual 'single-chip 8 -bit microcontrollers'.

## Features

- 8 -bit CPU, ROM, RAM and I/O
- Internal counter/timer
- Internal oscillator, clock driver
- Single-level interrupts: external and counter/timer
- 17 internal registers: accumulator, 16 addressable registers
- Over 90 instructions: $70 \%$ single byte
- All instructions 1 or 2 cycles
- Easily expandable memory and 27 I/O lines
- TTL compatible inputs and outputs
- Single 5 V supply
- Standard and extended temperature range (see Table 1)


## Applications

- Peripheral interfaces and controllers
- Test and measuring instruments
- Sequencers
- Modems and data enciphering
- Environmental control systems
- Audio/video systems


## PACKAGE OUTLINES

All versions: with type no. suffix P (see Table 1): 40-lead DIL; plastic (SOT-129).
MAB80XXH/HLWP: 44-lead plastic leaded chip-carrier (PLCC); SOT-187A.

Table 1 MAB80XXH versions

| version | internal memory |  | RAM <br> st/by. | frequency (MHz) |  | temperature range <br> ( ${ }^{\circ} \mathrm{C}$ ) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| MAB8048H | $1 \mathrm{~K} \times 8 \mathrm{ROM}$ | 64 byte RAM |  | yes | 1,0 | 11,0 | 0 to +70 |
| MAB8035HL | none | 64 byte RAM | yes | 1,0 | 11,0 | 0 to +70 |
| MAF8048H | $1 \mathrm{~K} \times 8 \mathrm{ROM}$ | 64 byte RAM | yes | 1,0 | 11,0 | -40 to +85 |
| MAF8035HL | none | 64 byte RAM | yes | 1,0 | 11,0 | -40 to +85 |
| MAF80A48H | $1 \mathrm{~K} \times 8 \mathrm{ROM}$ | 64 byte RAM | yes | 1,0 | 10,0 | -40 to +110 |
| MAF80A35HL | none | 64 byte RAM | yes | 1,0 | 10,0 | -40 to +110 |
| MAB8049H | $2 \mathrm{~K} \times 8 \mathrm{ROM}$ | 128 byte RAM | yes | 1,0 | 11,0 | 0 to +70 |
| MAB8039HL | none | 128 byte RAM | yes | 1,0 | 11,0 | 0 to +70 |
| MAF8049H | $2 \mathrm{~K} \times 8 \mathrm{ROM}$ | 128 byte RAM | yes | 1,0 | 11,0 | -40 to +85 |
| MAF8039 HL | none | 128 byte RAM | yes | 1,0 | 11,0 | -40 to +85 |
| MAF80A49H | $2 \mathrm{~K} \times 8 \mathrm{ROM}$ | 128 byte RAM | yes | 1,0 | 10,0 | -40 to +110 |
| MAF80A39HL | none | 128 byte RAM | yes | 1,0 | 10,0 | -40 to +110 |
| MAB8050H | $4 \mathrm{~K} \times 8 \mathrm{ROM}$ | 256 byte RAM | yes | 1,0 | 6,0 | 0 to +70 |
| MAB8040HL | none | 256 byte RAM | yes | 1,0 | 6,0 | 0 to +70 |
| MAF8050H | $4 \mathrm{~K} \times 8 \mathrm{ROM}$ | 256 byte RAM | yes | 1,0 | 6,0 | -40 to +85 |
| MAF8040HL | none | 256 byte RAM | yes | 1,0 | 6,0 | -40 to +85 |
| MAF80A50H | $4 \mathrm{~K} \times 8 \mathrm{ROM}$ | 256 byte RAM | yes | 1,0 | 6,0 | -40 to +110 |
| MAF80A40HL | none | 256 byte RAM | yes | 1,0 | 6,0 | -40 to +110 |



Fig. 1 Block diagram.
12-19 DB0-DB7

XTAL 1
$\overline{\text { PROG }}$
T0

T1
$\overline{\text { RESET }}$

ALE
$\overline{R D}$
$\overline{W R}$

XTAL 2
$V_{S S}$
$V_{C C}$
$V_{D D}$

Data Bus: bidirectional I/O port which can write or read using the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ strobes. This port can also be statically latched. It contains the 8 lower order address bits during external memory access and receives the addressed instruction under control of $\overline{\text { PSEN }}$. $\overline{\text { PSEN }}, ~ A L E, \overline{R D}$ and $\overline{W R}$ determine whether the access is an instruction fetch or a read/write access to external RAM.

Port 1: 8 -bit quasi-bidirectional I/O port (note 1).
Port 2: 8 -bit quasi-bidirectional I/O port (note 1).
P20-P23 contain the 4 higher order address bits during an access of external program memory.
Output strobe: active LOW for 8243 I/O expander.
Test 0 : test input pin sensed using the JTO and JNTO instructions. Clock: clock output pin when designated by the ENTO CLK instructions.
Test 1: test input pin sensed using the JT1 and JNT1 instructions. Can be designated as the timer/counter input by the STRT CNT instruction.
Interrupt: interrupt input pin, which causes an interrupt in the current program, provided that the external interrupt is enabled.
Can also be used as an input, testable using the JNI instruction. Interrupt is disabled during and after RESET.
Reset: active LOW input used to initialize the microcontroller. During program verification the address is latched by a ' 0 ' to ' 1 ' transition on RESET and the data at the addressed location is output on BUS (note 2).
Address latch enable: occurs each cycle and is used for timing and sampling. During external program or data memory access, ALE is used to strobe the address information multiplexed on the DB0 to DB7 outputs.
Read BUS: active LOW strobe used to gate data onto BUS lines when reading from an external source.

Write BUS: active LOW strobe used to write data from BUS lines to an external designation.
External access input: when HIGH, forces instruction fetch from external memory.
Program store enable: active LOW strobe that occurs only during a fetch from external memory.
Single step: active LOW input used with ALE to cause the microcontroller to execute a single instruction.
Crystal inputs: inputs for a crystal, LC-network or an external timing signal to determine the internal oscillator frequency (note 2).
Ground: circuit earth potential.
Power supply: +5 V main supply pin.
Power supply: + 5 V RAM standby power supply; low power standby pin.

## Notes

1. Each port line can be designated as an input or an output. A line is designated as an input by first writing a logic 1 to the line. $\overline{\operatorname{RESET}}$ sets all lines to logic 1.
2. Non-standard TTL $\mathrm{V}_{\mathrm{IH}}$.

## FUNCTIONAL DESCRIPTION

The following sections provide a detailed functional description of the MAB80XXH microcontroller as shown in Fig. 1. The generic term "MAB80XXH" is used to refer collectively to the MAB8048H/35HL, MAB8049H/39HL and MAB8050H/40HL.

## Program memory (see Fig. 3)

The resident program memory consists of a 1024,2048 or 4096 byte ROM (MAB8048H/49H/50H); the MAB8035HL/39HL/40HL versions do not have a resident program memory. The total addressing capability is 4096 bytes.
The program memory address space is divided into two 2048 -byte banks MBO and MB1. These two 2048 byte banks are divided into 8 pages of 256 bytes for conditional branches.
There are three locations in program memory which contain the first instruction to be executed after one of three events:

- Location 0 - if $\overline{\text { RESET }}$ is activated (LOW) then location 0 is activated
- Location 3 - if the external interrupt is enabled and the $\overline{\text { INT }}$ line is activated (LOW)
- Location 7 - if the T/C interrupt is enabled and the timer/counter has an overflow.


Fig. 3 Program memory map.

## FUNCTIONAL DESCRIPTION (continued)

## Data memory (see Fig. 4)

The resident data memory consists of a 64, 128 or 256 byte RAM. All locations are indirectly addressable using two RAM pointer registers R0, R1 or R0', R1'. The first 8 RAM locations ( 0 to 7) are designated as working registers bank 0 and are directly addressable. By selecting register bank 1, RAM locations 24 to 31 become the working registers, replacing those in register bank 0. RAM locations 8 to 23 are designated as the stack. Two bytes are used per CALL allowing up to 8 levels of subroutine nesting.
An extra 256 bytes of RAM may be added and addressed directly using the MOVX instructions. If the required extra RAM is greater than 320 bytes, additional ( 256 byte) banks of external memory can be selected, one at a time, by an I/O port.

## Program counter and stack

The program counter ( PC ) is a 12 -bit counter/register that points to the location from which the next instruction is to be fetched. When EA is logic 0 the PC can address locations 0 to $1023(8048 \mathrm{H}), 2047$ $(8049 \mathrm{H})$ or $4095(8050 \mathrm{H})$ of internal program memory. At the $1 \mathrm{~K}(8048 \mathrm{H}), 2 \mathrm{~K}(8049 \mathrm{H})$ boundary, an automatic switch-over to external memory occurs. When EA is logic 1 all the program is fetched from external ROM/EPROM. The total address space is 4 K bytes. An interrupt or CALL to a subroutine causes the contents of the program counter to be stored in one of the 8 register pairs of the program stack. The pair to be used is determined by a 3-bit stack pointer which is part of the program status word (PSW). Data RAM locations 8 to 23 are available as stack registers and are used to store the program counter and 4 bits of PSW. The stack pointer, when initialized to 000 B , points to RAM locations 8 and 9 . The first subroutine jump or interrupt results in the program counter contents being transferred to locations 8 and 9 of the RAM array. The stack pointer is then incremented by one to point to locations 10 and 11 in anticipation of another CALL. Nesting of subroutines within subroutines can continue up to 8 times without overflowing the stack. If overflow does occur the deepest address stored (locations 8 and 9 ) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111 . The end of a subroutine, which is signalled by a return instruction (RET or RETR), causes the stack pointer to be decremented and the contents of the resulting register pair to be transferred to the program counter.

## Oscillator and clock (see Figs 5, 6 and 7)

The MAB80XXH contains its own internal oscillator and clock driver. A crystal, LC-network or external timing signal (pulse generator) determines the oscillator frequency. The output of the oscillator is divided-by-three and is available at T0 (pin 1) by executing the ENTO CLK instruction. This clock signal (CLK) is divided-by-five to define a machine (instruction) cycle. It is available at ALE (pin 11).

(1) Including crystal-socket stray capacities.

Fig. 5 Crystal oscillator mode. Crystal series impedance should be $<75 \Omega$ at 6 MHz and $<180 \Omega$ at $3,6 \mathrm{MHz}$. When using a ceramic oscillator both capacitors should be 30 pF .


Fig. 6 Driving from external source. Both XTAL 1 and XTAL 2 should be driven. Resistors to $\mathrm{V}_{\mathrm{CC}}(+5 \mathrm{~V})$ are required to ensure $\mathrm{V}_{I H}=3,8 \mathrm{~V}$ if TTL circuitry is used. The minimum HIGH and LOW times are $45 \%$.

| L <br> $(\mu \mathrm{H})$ | C <br> $(\mathrm{pF})$ | nom. f <br> $(\mathrm{MHz})$ |
| :---: | :---: | :---: |
| 45 | 20 | 5,2 |
| 120 | 20 | 3,2 |

$$
f \approx \frac{1}{2 \pi \sqrt{L 一 ⿻^{\prime}}} ; C^{\prime}=\frac{C+3 C_{p p}}{2}
$$

Fig. 7 LC oscillator mode. Each C should be $\approx 20 \mathrm{pF}$ including stray capacitance $\mathrm{C}_{\mathrm{pp}} \approx 5$ to 10 pF (pin-to-pin capacitance).

## Timer/event counter

An internal counter is available which can count either external events or machine cycles ( $\div 32$ ). The machine cycles are divided-by- 32 before they are applied to the input of the 8 -bit counter. External events are applied directly to the input of the counter. The maximum frequency that can be counted is one third of the machine cycle frequency. The minimum positive duty cycle that can be detected is 0,2 times the cycle period. The counter is under program control and can be made to generate an interrupt to the processor when it overflows.

## Interrupt

An interrupt may be generated by:

- An external input $\overline{\mathrm{INT}}$ (pin 6)
or
- Overflow of the internal counter, when enabled.

In either, the processor completes execution of the present instruction followed by a CALL to the interrupt service routine.
After service, a RETR instruction restores the machine to the state it was prior to the interrupt. The external interrupt has priority over the internal interrupt.

## Input/output

The MAB80XXH has 27 I/O lines. They are arranged as three 8 -line ports which serve as either inputs, outputs or bidirectional ports and 3 'test' inputs that can alter program sequences when tested by conditional jump instructions.

## FUNCTIONAL DESCRIPTION (continued)

## Ports 1 and 2 (see Fig. 8)

Ports 1 and 2 are both 8 -bits wide and have identical characteristics. Data written to these ports is statically latched and remains unchanged until rewritten. As input lines these ports are non-latching, i.e. inputs must be present until read by an input instruction. Inputs are fully TTL compatible and outputs will drive one standard TTL load.
The lines of ports 1 and 2 are called quasi-bidirectional because of a special output circuit structure which allows each line to serve as an input, an output, or both even through outputs are statically latched. Each line is continuously pulled up to +5 V through a resistor ( $\approx 50 \Omega$ ). Thus pull-up provides sufficient source current for a TTL HIGH level, yet can be pulled LOW by a standard TTL gate, thus allowing the pin to be used both as an input and an output. To provide fast switching times during a logic 0 to 1 transition, transistor TR 2 is switched on for one fifth of a machine cycle when a logic 1 is written to the line. When a logic 0 is written transistor TR 1 overcomes the pull-up and provides TTL current sinking capability. Since the pull-down transistor is low impedance, a logic 1 must first be written to any line which is to used as an input. $\overline{\text { RESET initializes all lines to the high }}$ impedance logic 1 state. This structure allows input and output on the same pin plus a mixture of input and output lines on the same port. The quasi-bidirectional port in combination with the ANL and ORL logical instructions facilitates the handling of single line inputs and outputs within an 8-bit microcontroller.

## BUS (DB0-DB7)

Bus is a true bidirectional 8 -bit port with associated input and output strobes. If the bidirectional feature is not required, BUS can serve as a statically latched output port or non-latching input port. Input and output lines on this port cannot be mixed.
As a static port, data is written and latched using the OUTL instruction and input using the INS instruction. These instructions generate pulses on the corresponding $\overline{R D}$ and $\overline{W R}$ output strobe lines, but in the static port mode they are not used. As a bidirectional port, the MOVX instructions are used to read from and write to the port. A write generates a pulse on the $\overline{W R}$ output line and output data is valid at the trailing edge of $\overline{W R}$. A read generates a pulse on the $\overline{R D}$ output line and input data must be valid at the trailing edge of $\overline{\mathrm{RD}}$. When the BUS lines are not being written to or read from they are high impedance.


Fig. 8 Quasi-bidirectional port structure.

## Test (TO, T1) and $\overline{\mathrm{INT}}$

These three pins serve as inputs and are testable with the conditional jump instruction. They allow inputs to cause program branches without the necessity of loading an input port into the accumulator.

## $\overline{\text { RESET }}$ (see Fig. 9)

This active LOW input is used to initialize the microcontroller.
This Schmitt-trigger input has an internal pull-up resistor which, in combination with an internal $1 \mu \mathrm{~F}$ capacitor, provides an internal reset pulse of sufficient duration to reset all circuitry. If the reset pulse is generated externally, the reset pin must be held at ground $(0,45 \mathrm{~V})$ for at least 10 ms after the power supply is within tolerance. Only 5 machine cycles ( $12,5 \mu \mathrm{~s}$ at 6 MHz ) are required if power is already on and the oscillator has stabilized.


Fig. 9 An external reset is shown in (a) and power-on reset in (b).

## Single step ( $\overline{\mathrm{SS}}$ )

This active LOW input when used in combination with ALE will cause the microcontroller to execute a single instruction, then wait until $\overline{\mathrm{SS}}$ is reactivated.

## Power-down mode (see Fig. 10)

In the MAB80XXH, power can be removed from all but the data RAM array, for low power standby operation. In the power-down mode the contents of the data RAM can be maintained while drawing typically $10 \%$ to $15 \%$ of the normal operating supply voltage. $\mathrm{V}_{\mathrm{CC}}$ serves as the +5 V supply pin for the bulk of the circuitry, while the $V_{D D}$ pin supplies only the RAM array. In normal operation, both pins are at +5 V . In the standby mode, $\mathrm{V}_{\mathrm{CC}}$ is at ground and only $\mathrm{V}_{\mathrm{DD}}$ is maintained at +5 V . Applying RESET to the microcontroller through the reset pin inhibits any access to the RAM and ensures that the RAM cannot be inadvertently altered as power is removed from $\mathrm{V}_{\mathrm{CC}}$.


Fig. 10 Power down sequence.

## FUNCTIONAL DESCRIPTION (continued)

## Instruction set (see Tables 1,2,3 and 4)

The MAB80XXH instruction set consists of over 90 one and two-byte instructions. Program code efficiency is high because:

- Working registers and program variables are stored in the RAM locations 0 to 127 , which require only a single byte to address
- Program memory is divided into pages of 256 bytes, which means that branch destination addresses require only one byte
The instruction set performs logical, arithmetic and test operations on bytes. It also manipulates and tests bits. A set of MOVE instructions operate indirectly on either RAM or ROM, which permits efficient access of pointers and data tables. The indirect jump instruction performs a multi-way branch (up to 256) on the contents of the accumulator to addresses stored in a look-up table. The 'decrement register and jump if not zero' instruction saves a bit each time it is used as opposed to using separate increment and test instructions. The on-chip counter provides the facility for external events or time to be counted off-line from the main program. The MAB80XXH can either test the counter (under program control) or cause its overflow to generate an interrupt. These features are essential for real-time applications.

Table 1 Symbols and definitions used in Table 2.

| symbol | definition description |
| :--- | :--- |
| A | accumulator |
| addr | program memory address |
| Bb | bit designation (b $=0-7$ ) |
| RBS | register bank select |
| C | carry (bit CY) |
| CNT | event counter |
| D | mnemonic for 4-bit digit (nibble) |
| data | 8-bit number or expression |
| I | interrupt |
| MB | memory bank |
| MBFF | memory bank flip-flop |
| P | mnemonic for 'in-page' operation |
| PC | program counter |
| Pp | port designation (p $=0,1,2$ ) |
| PSW | program status word |
| RB | register bank |
| Rr | register designation ( $r=0-7$ ) |
| Sn | serial I/O register |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| TO | test 0 input |
| T1 | test 1 input |
| $\#$ | immediate data prefix |
| $@$ | indirect address prefix |
| (X) | contents of $X$ |
| ((X)) | contents of location addressed by $X$ |
| $\leftarrow$ | is replaced by |
| $\leftrightarrow$ | is exchanged with |

Table 2 Instruction set

|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { ADD A, Rr } \\ & \text { ADD A, @Rr } \end{aligned}$ | $\begin{array}{\|l\|} \hline 6^{*} \\ 60 \\ 61 \end{array}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | Add register contents to $A$ <br> Add RAM data, addressed by Rr, to A | $\begin{aligned} & (A) \leftarrow(A)+(R r) \\ & (A) \leftarrow(A)+((R 0)) \\ & (A) \leftarrow(A)+((R 1)) \end{aligned}$ | $r=0-7$ | 11 |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  | ADD A, \#data |  | 2/2 | Add immediate data to A | $(A) \leftarrow(A)+$ data |  | 1 |
|  | ADDC A, Rr | 7* | 1/1 | Add carry and register contents to $A$ | $(A) \leftarrow(A)+(R r)+(C)$ | $r=0-7$ | 1 |
|  | ADDC A, @Rr | 70 | 1/1 | Add carry and RAM data, addresses | $(\mathrm{A}) \leftarrow(\mathrm{A})+((\mathrm{RO}))+(\mathrm{C})$ |  | 1 |
|  |  | 71 |  | by Rr, to A | $(A) \leftarrow(A)+((R 1))+(C)$ |  |  |
|  | ADDC A, \#data | 13 data | 2/2 | Add carry and immediate data to $A$ | $(\mathrm{A}) \leftarrow(\mathrm{A})+$ data $+(\mathrm{C})$ |  | 1 |
|  | ANL A, Rr | 5* | 1/1 | 'AND' Rr with A | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{AND}(\mathrm{Rr})$ | $r=0-7$ |  |
|  | ANL A, @Rr | 50 | 1/1 | 'AND' RAM data, addressed by Rr, with A | $(\mathrm{A}) \leftarrow(\mathrm{A})$ AND ( $(\mathrm{RO}))$ |  |  |
|  |  | 51 |  |  | $(A) \leftarrow(A)$ AND ( $(\mathrm{R} 1))$ |  |  |
|  | ANL À, \#data | 53 data | 2/2 | 'AND' immediate data with A | $(A) \leftarrow(A)$ AND data |  |  |
|  | ORL A, Rr | 4* | 1/1 | 'OR' Rr with $A$ | $(A) \leftarrow(A) O R(R r)$ | $r=0-7$ |  |
|  | ORL A, @Rr | 40 | 1/1 | 'OR' RAM data, addressed by Rr, with A | $(A) \leftarrow(A) O R((R 0))$ |  |  |
|  |  | 41 |  |  | $(A) \leftarrow(A) O R((R 1))$ |  |  |
|  | ORL A, \#data | 43 data | 2/2 | 'OR' immediate data with A | $(A) \leftarrow(A) O R$ data |  |  |
|  | XRL A, Rr | D* | 1/1 | 'XOR' Rr with A | $(A) \leftarrow(A) X O R(R r)$ | $r=0--7$ |  |
|  | XRL A, @Rr | D0 | 1/1 | 'XOR' RAM, addressed by Rr, with A | $(A) \leftarrow(A) X O R((R O))$ |  |  |
|  |  | D1 |  |  | $(A) \leftarrow(A) X O R((R 1))$ |  |  |
|  | XRL A, \#data | D3 data | 2/2 | 'XOR' immediate data with $A$ | $(\mathrm{A}) \leftarrow(\mathrm{A}) \times O R$ data |  |  |
|  | INC A | 17 | 1/1 | increment A by 1 | $(A) \leftarrow(A)+1$ |  |  |
|  | DEC A | 07 | 1/1 | decrement $A$ by 1 | $(A) \leftarrow(A)-1$ |  |  |
|  | CLR A | 27 | 1/1 | clear A to zero | $(\mathrm{A}) \leftarrow 0$ |  |  |
|  | CPL A | 37 | 1/1 | one's complement A | $(A) \leftarrow \operatorname{NOT}(\mathrm{A})$ |  |  |
|  | RL A | E7 | $1 / 1$ | rotate A left | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow\left(A_{n}\right) \\ & \left(A_{0}\right) \leftarrow\left(A_{7}\right) \end{aligned}$ | $\mathrm{n}=0-6$ |  |


|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RLC A | F7 | 1/1 | rotate A left through carry | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow\left(A_{n}\right) \\ & \left(A_{0}\right) \leftarrow(C),(C) \leftarrow\left(A_{7}\right) \end{aligned}$ | $n=0-6$ | 2 |
|  | RR A | 77 | 1/1 | rotate A right | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow\left(A_{0}\right) \end{aligned}$ | $n=0-6$ |  |
|  | RRC A | 67 | 1/1 | rotate A right through carry | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow(C),(C) \leftarrow\left(A_{0}\right) \end{aligned}$ | $n=0-6$ | 2 |
|  | DA A | 57 | 1/1 | decimal adjust A |  |  | 2 |
|  | SWAP A | 47 | 1/1 | swap nibbles of A | $\left(A_{4-7}\right) \leftrightarrow\left(A_{0-3}\right)$ |  |  |
|  | MOV A, Rr | F* | 1/1 | move register contents to $A$ | $(\mathrm{A}) \leftarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | MOV A, @Rr | $\begin{aligned} & \text { F0 } \\ & \text { F1 } \end{aligned}$ | 1/1 | move RAM data, addressed by Rr , to A | $\begin{aligned} & (A) \leftarrow((R 0)) \\ & (A) \leftarrow((R 1)) \end{aligned}$ |  |  |
|  | MOV A, \#data | 23 data | 2/2 | move immediate data to A | (A) - data |  |  |
|  | MOV Rr, A | A* | 1/1 | move accumulator contents to register | $(\mathrm{Rr}) \leftarrow(\mathrm{A})$ | $r=0-7$ |  |
|  | MOV @Rr, A |  | 1/1 | move accumulator contents to RAM location addressed by Rr | $\begin{aligned} & ((R O)) \leftarrow(A) \\ & ((R 1)) \leftarrow(A) \end{aligned}$ |  |  |
|  | MOV Rr, \#data | B* data | 2/2 | move immediate data to Rr | $(\mathrm{Rr}) \leftarrow$ data | $r=0-7$ |  |
|  | MOV @rR, \#data | BO data B1 data | 2/2 | move immediate data to RAM location addressed by Rr | $\begin{aligned} & ((\mathrm{RO})) \leftarrow \text { data } \\ & ((\mathrm{R} 1)) \leftarrow \text { data } \end{aligned}$ |  |  |
|  | XCH A, Rr | 2* | 1/1 | exchange accumulator contents with Rr | $(\mathrm{A}) \leftrightarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | XCH A, @Rr | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | 1/1 | exchange accumulator contents with RAM data addressed by Rr | $\begin{aligned} & (A) \leftrightarrow((R 0)) \\ & (A) \leftrightarrow((R 1)) \end{aligned}$ |  |  |
|  | XCHD A, @Rr | $\begin{aligned} & 30 \\ & 31 \end{aligned}$ | 1/1 | exchange lower nibbles of A and RAM data addressed by Rr | $\begin{aligned} & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 0_{0-3}\right)\right) \\ & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 1_{0-3}\right)\right) \end{aligned}$ |  |  |
|  | MOV A, PSW | C7 | 1/1 | move PSW contents to accumulator | $(\mathrm{A}) \leftarrow$ (PSW) |  |  |
|  | MOV PSW, A | D7 | 1/1 | move accumulator contents to PSW | (PSW) $\leftarrow(A)$ |  | 3 |
|  | MOVP A, @A | A3 | 1/2 | move indirectly addressed data in current page to $A$ | $(\mathrm{A}) \leftarrow((\mathrm{A}))$ |  |  |
|  | MOVP3 A,@A | E3 | 1/2 | move data in page 3 to $A$ | $(\mathrm{A}) \leftarrow((\mathrm{A}))$ | in page 3 |  |


|  | MOVX A,@Rr <br> MOVX @Rr,A | $\begin{array}{\|l} 80 \\ 81 \\ 90 \\ 91 \end{array}$ | $\begin{array}{\|l\|} 1 / 2 \\ 1 / 2 \end{array}$ | move indirect the contents of external memory to $A$ move indirect the contents of $A$ to external memory | $\left\lvert\, \begin{aligned} & (A) \leftarrow((R)) \\ & ((R)) \leftarrow(A) \end{aligned}\right.$ | $\begin{aligned} & r=0-1 \\ & r=0-1 \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| O | $\begin{array}{\|l\|l\|} \hline \text { CLR C } \\ \text { CPL C } \end{array}$ | $\begin{array}{\|l\|} 97 \\ \text { A7 } \end{array}$ | $\begin{array}{\|l} \hline 1 / 1 \\ 1 / 1 \end{array}$ | clear carry bit complement carry bit | $\begin{aligned} & \text { (C) } \leftarrow 0 \\ & \text { (C) } \leftarrow \text { NOT }(C) \end{aligned}$ |  | 2 |
|  | INC Rr INC @Rr DEC Rr | $\begin{aligned} & \hline 1^{*} \\ & 10 \\ & 11 \\ & C^{*} \end{aligned}$ | $\begin{array}{\|l\|} \hline 1 / 1 \\ 1 / 1 \\ 1 / 1 \end{array}$ | increment register by 1 <br> increment RAM data, addressed by Rr, by 1 <br> decrement register by 1 | $\begin{aligned} & (R r) \leftarrow(R r)+1 \\ & ((R 0)) \leftarrow((R 0))+1 \\ & ((R 1)) \leftarrow((R 1))+1 \\ & (R r) \leftarrow(R r)-1 \end{aligned}$ | $\begin{aligned} & r=0-7 \\ & r=0-7 \end{aligned}$ |  |
|  | JMP addr <br> JMPP @A <br> DJNZ Rr, addr <br> JFO addr <br> JF1 addr <br> JNI addr <br> JBb addr <br> JC addr <br> JNC addr <br> JZ addr <br> JNZ addr <br> JTO addr <br> JNTO addr <br> JT1 addr <br> JNT1 addr <br> JTF addr | - 4 address <br> B3 <br> E* address <br> B6 address <br> 76 address <br> 86 address <br> 4 2 address <br> F6 address <br> E6 address <br> C6 address <br> 96 address <br> 36 address <br> 26 address <br> 56 address <br> 46 address <br> 16 address | $\begin{aligned} & 2 / 2 \\ & 1 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \end{aligned}$ | unconditional jump within a 2 K bank <br> indirect jump within a page <br> decrement Rr by 1 and jump if not <br> zero to addr <br> jump to addr if F0 = 1 <br> jump to addr if F1 = 1 <br> jump to addr if $\overline{I N T}=0$ <br> jump to addr if Acc. bit $\mathrm{b}=1$ <br> jump to addr if $\mathrm{C}=1$ <br> jump to addr if $\mathrm{C}=0$ <br> jump to addr if $A=0$ <br> jump to addr if $A$ is NOT zero <br> jump to addr if $\mathrm{TO}=1$ <br> jump to addr if T0 $=0$ <br> jump to addr if T1 $=1$ <br> jump to addr if $\mathrm{T} 1=0$ <br> jump to addr if Timer Flag $=1$ | ( $\mathrm{PC}_{8}-10$ ) $\leftarrow$ addr $8-10$ <br> ( $\mathrm{PC}_{0-7}$ ) -addro-7 <br> ( $\mathrm{PC}_{11-12}$ ) ${ }^{-}$MBFF 0-1 <br> $\left(\mathrm{PC}_{0-7}\right) \leftarrow((\mathrm{A}))$ <br> $(\operatorname{Rr}) \leftarrow(\operatorname{Rr})-1$ <br> if ( Rr ) not zero $\left(\mathrm{PC}_{0-7}\right)$ <addr $\begin{aligned} & \text { if } \mathrm{FO}=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{F} 1=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow a d d r \\ & \text { if } \overline{\text { INT }}=0:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{b}=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow a d d r \\ & \text { if } \mathrm{C}=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{C}=0:\left(\mathrm{PC}_{0-7}\right) \leftarrow a d d r \\ & \text { if } \mathrm{A}=0:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{A} \neq 0:\left(\mathrm{PC}_{0-7}\right) \leftarrow a d d r \\ & \text { if } \mathrm{TO}=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{TO}=0:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{T} 1=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow a d d r \\ & \text { if } \mathrm{T} 1=0:\left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } \\ & \text { if } \mathrm{TF}=1:\left(\mathrm{PC}_{0-7}\right) \leftarrow a d d r \end{aligned}$ | $r=0-7$ $b=0-7$ | 4 |




Table 3 Instruction timing (see also Figs 11 and 12)

|  |  | cycle 1 |  |  |  |  | cycle 2 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | instruction | S1. | S2 | S3 | S4 | S5 | S1 | S2 | S3 | S4 | S5 |
|  | IN A,P | fetch instruction | increment program counter | - | increment timer | - | - | read port | * | - | - |
|  | OUTLP,A | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | - | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | output to port | - | - | * | - | - |
|  | ANL P,\#data | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{array}{ll} * & 1 \\ & 1 \\ & 1 \\ & 1 \\ \hline \end{array}$ | - | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | read port | fetch immediate data | - | *increment program counter | output to port | - |
|  | ORL P,\#data | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |  | - | $\begin{aligned} & i \\ & i \\ & i \\ & i \end{aligned}$ | read port | fetch immediate data | - | *increment program counter | output to port | - |
|  | INS A,BUS | $1$ | 1 | - | 1 | - | - | read port | * | - | - |
|  | OUTL BUS,A | 1 | 1 | - | 1 | output to port | - | - | * | - | - |
|  | ANL BUS,\#data | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |  | - | 1 | read port | fetch immediate data | - | *increment program counter | output to port | - |
|  | ORL BUS,\#data | i | * $\begin{aligned} & 1 \\ & \\ & \\ & \\ & \\ & \\ & 1\end{aligned}$ | - | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | read port | fetch immediate data | - | *increment program counter | output to port | - |
|  | MOVX @R,A | $1$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | output RAM address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | output data to RAM | - | - | * | - | - |
|  | MOVX A,@R | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | 1 | output RAM address | 1 | - | - | read <br> data | * | - | - |
|  | MOVD A,P | fetch instruction | increment program counter | output opcode/ address | increment timer | - | - | read P2 lower | * | - | - |




Fig. 11 Instruction cycle.


Fig. 12 Instruction cycle timing.

Table 4 Instruction map.

- first hexadicimal character of opcode

| [ first hexadicimal character of opcode |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $0 \quad 1$ | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| 0 | NOP | OUTL <br> BUS,A | ADD <br> A, \#data | JMP <br> page 0 | EN I |  | DEC A | INS A,BUS | $\begin{array}{l\|l} \begin{array}{l} \text { IN A, Pp } \\ 1 \end{array} & \\ \hline \end{array}$ |  |  | $\begin{array}{l\|l\|l} \text { MOVD A, Pp } \\ 4 & 5 & 6 \\ \hline \end{array}$ |  |  | 7 |
| 1 | $\begin{array}{ll} \text { INC @Rr } & \\ 0 & 1 \end{array}$ | JB0 addr | ADDC <br> A, \#data | CALL page 0 | DIS I | JTF addr | INC A | $\begin{aligned} & \text { INC Rr } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 2 | $\begin{aligned} & \text { XCH A, @Rr } \\ & 0 \end{aligned}$ |  | $\begin{aligned} & \text { MOV } \\ & \text { A, \#data } \end{aligned}$ | JMP page 1 | EN TCNTI | JNTO addr | CLR A | $\begin{aligned} & \mathrm{XCH} A, R r \\ & 0 \end{aligned}$ | 1 |  | 3 | 4 | 5 |  |  |
| 3 | $\begin{aligned} & \text { XCHD A, @Rr } \\ & 0 \end{aligned}$ | JB1 addr |  | CALL page 1 | $\begin{aligned} & \hline \text { DIS } \\ & \text { TCNTI } \end{aligned}$ | JTO addr | CPLA |  |  | 2 |  | 4 | 5 | $\begin{gathered} 0, A \\ 6 \end{gathered}$ | 7 |
| 4 | $\begin{aligned} & \text { ORL A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~A}, \mathrm{~T} \end{aligned}$ | ORL <br> A, \#data | JMP page 2 | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 addr | SWAP A | $\begin{aligned} & \text { ORL A, Rr } \\ & 0 \end{aligned}$ | 1 | $2$ | 3 | 4 | 5 | 6 7 |  |
| 5 | $\begin{aligned} & \text { ANL A, @Rr } \\ & 0 \end{aligned}$ | JB2 <br> addr | ANL <br> A, \#data | CALL page 2 | $\begin{aligned} & \text { STRT } \\ & \mathrm{T} \end{aligned}$ | JT1 addr | DA, A | $\begin{aligned} & \text { ANL } A, R r \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 6 | $\begin{aligned} & \text { ADD A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \mathrm{T}, \mathrm{~A} \end{aligned}$ |  | JMP page 3 | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | RRC A | $\begin{aligned} & \text { ADD A, Rr } \\ & 0 \end{aligned}$ | 1 |  | 3 | 4 | 5 | 6 | 7 |
| 7 | $\begin{aligned} & \text { ADDC A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB3 } \\ & \text { addr } \end{aligned}$ |  | CALL page 3 | ENTO CLK | JF1 addr | RR A | $\begin{aligned} & \text { ADDC } \mathrm{A}, \mathrm{Rr} \\ & 0 \end{aligned}$ | 1 12 <br> ORL Pp, \#data  <br> 1 2 |  | 3 | 4 | 5 | 6 | 7 |
| 8 | $\begin{aligned} & \text { MOVXA, } @ R r \\ & 0 \end{aligned}$ |  | RET | JMP page 4 | $\begin{aligned} & \text { CLR } \\ & \text { FO } \end{aligned}$ | JN1 addr |  | $\begin{aligned} & \text { ORL BUS, } \\ & \text { \#data } \end{aligned}$ |  |  |  | $$ |  |  | 17 |
| 9 | $\begin{aligned} & \mathrm{MOVX} @ R \mathrm{r}, \mathrm{~A} \\ & 0 \end{aligned}$ | JB4 <br> addr | RETR | CALL page 4 | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{FO} \end{aligned}$ | JNZ addr | CLR C | ANL BUS, \#data | ANP Pp, \#data <br> $1 \mid 2$ |  |  | $\begin{array}{l\|l\|l} \text { ANLD Pp, A } \\ 4 & 5 & 6 \\ \hline \end{array}$ |  |  | 17 |
| A | $\begin{aligned} & \text { MOV @Rr, A } \\ & 0 \end{aligned}$ |  | MOVP <br> A, @A | JMP page 5 | $\begin{aligned} & \text { CLR } \\ & \text { F1 } \end{aligned}$ |  | CPL C | $\begin{aligned} & \text { MOV Rr,A } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| B | $\begin{aligned} & \text { MOV @Rr, \# data } \\ & 0 \end{aligned}$ | JB5 <br> addr | $\begin{aligned} & \text { JMPP } \\ & \text { @A } \end{aligned}$ | CALL page 5 | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{~F} 1 \end{aligned}$ | JFO addr |  | MOV R, \#data 0 |  | $12$ | 3 | 4 | 5 | 6 | 7 |
| C |  |  |  | JMP page 6 | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | $\begin{aligned} & \mathrm{JZ} \\ & \mathrm{addr} \end{aligned}$ | MOV <br> A, PSW | $\begin{aligned} & \mathrm{DEC} \mathrm{Rr} \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| D | $\begin{aligned} & \text { XRL A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB6 } \\ & \text { addr } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, \#data } \end{aligned}$ | CALL page 6 | $\begin{aligned} & \mathrm{SEL} \\ & \mathrm{RB} 1 \end{aligned}$ |  | MOV PSW, A | $\begin{aligned} & X R L A, R r \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| E |  |  | MOVP3 <br> A @A | JMP page 7 | SEL <br> MBO | JNC addr | RL A | DJNZ Rr, addr$\begin{array}{l\|l} 0 & 1 \\ \hline \end{array}$ |  | 2 | 3 | 4 | 5 | 6 | 7 |
| F | $\begin{array}{ll} \text { MOV A, @Rr } \\ 0 \end{array}$ | $\begin{aligned} & \text { JB7 } \\ & \text { addr } \end{aligned}$ |  | CALL page 7 | SEL MB1 | JC addr | RLCA | $\begin{aligned} & \text { MOV } A, R r \\ & 0 \end{aligned}$ | $1$ | 2 | 3 | 4 | 5 |  | 7 |

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Input voltage with respect to $\mathrm{V}_{\mathrm{SS}}$ except input EA
input EA
D.C. current into any input or output

Total power dissipation
Storage temperature range
Operating ambient temperature range

| $V_{1}$ | $-0,5$ to +7 V |
| :--- | :--- |
| $\mathrm{~V}_{\mathrm{I}}$ | $-0,5$ to +12 V |
| $\pm I_{1} \pm \mathrm{I}_{\mathrm{O}}$ | max. $\quad 10 \mathrm{~mA}$ |
| $\mathrm{P}_{\text {tot }}$ | max. $\quad 1 \mathrm{~W}$ |
| $\mathrm{~T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {amb }}$ | see Table 5 |

D.C. CHARACTERISTICS (MAB8048H/35HL; MAB8049H/39HL; MAB8050H/40HL)
$\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{S S}=V_{C C}=0 \mathrm{~V}$ |  |  |  |  |  |
| MAB8048H/35HL | IDD | - | - | 6 | mA |
| MAB8049H/39HL | IDD | - | - | 8 | mA |
| MAB8050H/40HL | IDD | - | - | 15 | mA |
| $\begin{aligned} & \text { Supply current (total) } \\ & \text { at } \mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} \end{aligned}$ |  |  |  |  |  |
| MAB8048H/35HL | $I_{D D}+I^{\prime} C$ | - | - | 80 | mA |
| MAB8049H/39HL | $I_{D D}+I_{C C}$ | - | - | 90 | mA |
| MAB8050H/40HL | ${ }^{\prime} \mathrm{DD}+{ }^{\text {I }} \mathrm{CC}$ | - | - | 100 | mA |
| Inputs |  |  |  |  |  |
| Input voltage LOW all inputs except XTAL 1, XTAL 2, $\overline{\operatorname{RESET}}$ | $V_{\text {IL }}$ | -0,5 | - | 0,8 | V |
| Input voltage LOW XTAL 1, XTAL 2, $\overline{\operatorname{RESET}}$ | VILI | -0,5 | - | 0,6 | V |
| Input voltage HIGH all inputs except XTAL 1, XTAL 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input voltage HIGH XTAL 1, XTAL 2, $\overline{\operatorname{RESET}}$ | $\mathrm{V}_{\mathrm{IH} 1}$ | 3,8 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Outputs |  |  |  |  |  |
| Output voltage LOW (DB0 to DB7) at $I_{\mathrm{OL}}=2 \mathrm{~mA}$ | VOL | - | - | 0,45 | V |
| Output voltage LOW ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE}$ ) at $\mathrm{I}_{\mathrm{OL} 1}=1,8 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL1 }}$ | - | - | 0,45 | V |
| Output voltage LOW ( $\overline{\mathrm{PROG}}$ ) at $\mathrm{l}_{\mathrm{OL2}}=1 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL2 }}$ | - | - | 0,45 | V |
| Output voltage LOW (all other outputs) at $\mathrm{I}_{\mathrm{OL} 3}=1,6 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL3 }}$ | - | - | 0,45 | V |
| Output voltage HIGH (DB0 to DB7) at $-\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | - | V |
| Output voltage HIGH ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE}$ ) at $-\mathrm{I}_{\mathrm{OH} 1}=100 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH} 1}$ | 2,4 | - | - | V |
| Output voltage HIGH (all other outputs) $\text { at }-\mathrm{I}_{\mathrm{OH}}=40 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {OL2 }}$ | 2,4 | - | - | V |

D.C. CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input leakage current (T1, $\overline{\mathrm{INT}}$ ) at $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ | $\pm 1 \mathrm{IL}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output leakage current (DB0 to DB7; high impedance) $\text { at } \mathrm{V}_{\mathrm{SS}}+0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ | $\pm I_{O Z}$ | - | - | 10 | $\mu \mathrm{A}$ |
| LOW input load current (P10 to P17, P20 to P27 EA, $\overline{\text { SS }}$ ) at $\mathrm{V}_{\mathrm{SS}}+0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ | $I_{\text {LI }}$ | - | - | -0,5 | mA |
| LOW input load current ( $\overline{\mathrm{RESET}})$ at $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{I}_{\text {LII }}$ | 0,02 | - | -0,3 | mA |

## D.C. CHARACTERISTICS

MAF $8048 \mathrm{H} / 35 \mathrm{HL}$; MAF8049H/39HL; MAF8050H $/ 40 \mathrm{HL} \quad$ (at $\mathrm{T}_{\mathrm{amb}}=-40$ to $+85{ }^{\circ} \mathrm{C}$ ) MAF80A48H/A35HL; MAF80A49H/A39HL; MAF80A50H/A40HL (at Tamb $=-40$ to $+110^{\circ} \mathrm{C}$ )
$V_{C C}=V_{D D}=5 \mathrm{~V}( \pm 10 \%) ; V_{S S}=0 \mathrm{~V} ; T_{a m b}$ as above; all voltages with respect to $V_{S S}$ unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current <br> at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{S S}=V_{C C}=0 \mathrm{~V}$ |  |  |  |  |  |
| MAF8048H/35HL; MAF80A48H/A35HL | ${ }^{\text {I D D }}$ | - | - | 8 | mA |
| MAF8049H/39HL; MAF80A49H/A39HL | IDD | - | - | 10 | mA |
| MAF8050H/40HL; MAF80A50H/A40HL | IDD | - | - | 18 | mA |
| Supply current (total) <br> at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{S S}=V_{C C}=0 \mathrm{~V}$ |  |  |  |  |  |
| MAF8048H/35HL; MAF80A48H/A35HL | ${ }^{\text {I }} \mathrm{DD}+{ }^{\text {I }} \mathrm{CC}$ | - | - | 90 | mA |
| MAF8049H/39HL; MAF80A49H/A39HL | ${ }^{1} \mathrm{DD}+\mathrm{I}_{\text {CC }}$ | - | - | 100 | mA |
| MAF8050H/40HL; MAF80A50H/A40HL | ${ }^{\prime} \mathrm{DD}+{ }^{\text {I }} \mathrm{CC}$ | - | - | 120 | mA |
| Inputs |  |  |  |  |  |
| Input voltage HIGH all inputs except XTAL 1, XTAL 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\text {IH }}$ | 2,2 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |
| LOW input load current (P10 to P17, P20 to P27 EA, $\overline{\mathrm{SS}}$ ) at $\mathrm{V}_{\mathrm{SS}}+0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ | ${ }^{-1} \mathrm{LI}$ | - | - | 0,6 | mA |

A.C. CHARACTERISTICS (MAB8048H/35HL; MAB8049H/39HL; MAB8050H/40HL)
$\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; note 1.
See waveforms Figs 14, 15, 16, 17 and 18

| parameter | symbol | $f(t C L)$ <br> (note 2) | 11 MHz |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Clock period (note 2) | ${ }^{t} \mathrm{CL}$ | 1/(f XTAL ) | 90,9 | 1000 | ns |
| ALE pulse duration | ${ }^{\text {t LL }}$ | 3,5t CL -170 | 150 | - | ns |
| Address set-up time to ALE (note 3) | ${ }^{\text {t }}$ AL | 2 t CL-110 | 70 | - | ns |
| Address hold time after ALE | ${ }^{\text {t }}$ LA | ${ }^{\mathrm{t}} \mathrm{CL}$-40 | 50 | - | ns |
| Control pulse duration $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | ${ }^{\text {t }} \mathrm{CC} 1$ | 7,5t ${ }^{\text {CL-200 }}$ | 480 | - | ns |
| Control pulse duration $\overline{\text { PSEN }}$ | ${ }^{\text {t CC2 }}$ | 6 t CL-200 | 350 | - | ns |
| Data set-up time before $\overline{W R}$ | ${ }^{\text {t }}$ W | 6,5tCL-200 | 390 | - | ns |
| Data set-up time after $\overline{W R}$ | ${ }^{\text {tw }}$ W | ${ }^{\mathrm{t}} \mathrm{CL}-50$ | 40 | - | ns |
| $\frac{\text { Data hold time }}{\text { RD }}$ | ${ }^{\text {t }}$ R | 1,5tCL-30 | 0 | 110 | ns |
| $\overline{\mathrm{RD}}$ to data input | $t_{\text {R }}$ 1 | $6_{\text {tCL }}-170$ | - | 375 | ns |
| $\overline{\text { PSEN }}$ to data input | ${ }^{\text {t RD2 }}$ | 4,5tCL-170 | - | 240 | ns |
| Address set-up time to $\overline{W R}$ | ${ }^{t}$ AW | ${ }^{5} \mathrm{t}$ CL-150 | 300 | - | ns |
| Address set-up time to data input ( $\overline{\mathrm{RD}}$ ) | ${ }^{\text {t }}$ AD1 | 10,5t CL-220 | - | 730 | ns |
| Address set-up time to data input (PSEN) | ${ }^{t}$ AD2 | 7,5t CL -200 | - | 460 | ns |
| Address floating to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ AFC1 | 2 t CL-40 | 140 | - | ns |
| Address floating to $\overline{\text { PSEN }}$ (note 3) | ${ }^{\text {t }}$ AFC2 | $5 \mathrm{C}_{\mathrm{CL}}-40$ | 10 | - | ns |
| ALE to control pulse $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | ${ }_{\text {t }}$ LAFC1 | ${ }^{3} \mathrm{CL}$ L-75 | 200 | - | ns |
| ALE to control pulse $\overline{\text { PSEN }}$ | ${ }^{\text {t }}$ LAFC2 | 1,5t CL-75 | 60 | - | ns |
| Control pulse to ALE $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ | ${ }^{\text {t }}$ CA1 | ${ }^{\text {t }} \mathrm{CL}-40$ | 50 | - | ns |
| $\frac{\text { Control pulse to ALE }}{\overline{\text { PSEN }}}$ | ${ }^{\text {t }}$ CA2 | ${ }^{4 t} \mathrm{CL}-40$ | 320 | - | ns |
| Port control set-up to $\overline{\text { PROG }}$ | ${ }^{\text {t }}$ CP | 1,5t CL-80 | 50 | - | ns |
| Port control hold to $\overline{\text { PROG }}$ | ${ }_{\text {tPC }}$ | ${ }^{4 t} \mathrm{CL}-260$ | 100 | - | ns |
| $\overline{\text { PROG }}$ to Port 2 input must be valid | ${ }^{\text {tPR }}$ | 8,5t CL-120 | - | 650 | ns |
| Input data hold time from $\overline{\text { PROG }}$ | tPF | $1,5 \mathrm{t}$ CL | 0 | 150 | ns |
| Output data set-up time | ${ }^{t} \mathrm{DP}$ | ${ }^{6 t} \mathrm{CL}^{-290}$ | 250 | - | ns |
| Output data hold time | ${ }_{\text {tPD }}$ | 1,5t CL-90 | 40 | - | ns |
| $\overline{\text { PROG }}$ pulse duration | tpp | 10,5t CL-250 | 700 | - | ns |
| Port 2 I/O data set-up time to ALE | ${ }^{\text {PPL }}$ | ${ }^{4 t} \mathrm{CL}-200$ | 160 | - | ns |
| Port 2 I/O data hold time to ALE | ${ }_{\text {t }}$ P | 1,5t $\mathrm{CL}^{-120}$ | 15 | - | ns |

A.C. CHARACTERISTICS (continued)

| parameter | symbol | $\mathrm{f}(\mathrm{t} \mathrm{CL})$ (note 2) | 11 MHz |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Port output from ALE | tPV | $4,5 \mathrm{t} \mathrm{CL}^{+}+100$ | - | 510 | ns |
| T0 repetition rate | toprR | ${ }^{3 t} \mathrm{CL}$ | 270 | - | ns |
| Cycle time | ${ }^{\text {t }} \mathrm{C} Y$ | 1/(fXTAL $\times 15$ ) | 1,36 | 15 | $\mu \mathrm{s}$ |
| MAF80A48H/A35HL; MAF80A49H/A39HL; MAF80A50H/A40HL |  |  |  |  |  |
| Clock period (note 2) | ${ }^{\text {t }} \mathrm{CL}$ | 1/(fXTAL) | 90,9 | 1000 | ns |

## Notes to A.C. characteristics

1. Control outputs: $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$.

Bus outputs: $\quad C_{L}=150 \mathrm{pF}$.
2. $\mathrm{f}(\mathrm{t} \mathrm{CL})$ assumes $50 \%$ duty cycle on XTAL 1 and XTAL 2 ; minimum frequency $=1 \mathrm{MHz}$.
3. Bus high-impedance load: 20 pF .

A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 . Output timing measurements are taken $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for a logic 0 .

Fig. 13 A.C. testing input, output waveform.


Fig. 14 Read from external data memory.


Fig. 15 Write to external memory.


Fig. 16 Instruction fetch from program memory.


Fig. 17 Port 2 timing.


Fig. 18 I/O port timing.

MAB84X1
MAF84X1 MAF84AX1 FAMILY

## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The MAB84X1 family of microcontrollers is fabricated in NMOS. The family consists of 5 devices:

- MAB8401 - 128 bytes RAM, external program memory, with 8-bit LED-driver (10mA), emulation of $\mathrm{MAB} / \mathrm{F} 8422 / 42^{*}$ possible
- MAB/MAF8411 - 1 K byte ROM/64 bytes RAM plus 8-bit LED-driver
- MAB/MAF8421 - 2K bytes ROM/64 bytes RAM plus 8-bit LED-driver
- MAB/MAF8441 - 4K bytes ROM/128 bytes RAM plus 8-bit LED-driver
- MAB/MAF8461 - 6K bytes ROM/128 bytes RAM plus 8-bit LED-driver

Each version has 20 quasi-bidirectional I/O port lines, one serial I/O line, one single-level vectored interrupt, an 8-bit timer event counter and on-board clock oscillator and clock circuits. Two 20-pin versions, MAB/F8422 and MAB/F8442* are also available.

This microcontroller family is designed to be an efficient controller as well as an arithmetic processor. The instruction set is based on that of the MAB8048. The microcontrollers have extensive bit handling abilities and facilities for both binary and BCD arithmetic.
For detailed information see the " 8 -bit Single-chip Microcontrollers user manual".

* See data sheet on MAB/F8422/42.


## Features

- 8-bit: CPU, ROM, RAM and I/O in a single 28-lead DIL package
- $1 \mathrm{~K}, 2 \mathrm{~K}, 4 \mathrm{~K}$ or 6 K ROM bytes plus a ROM-less version
- 64 or 128 RAM bytes
- 20 quasi-bidirectional I/O port lines
- Two testable inputs: one of which can be used to detect zero cross-over, the other is also the external interrupt input
- Single level vectored interrupts: external, timer/event counter, serial I/O
- Serial I/O that can be used in single or multi-master systems (serial I/O data via an existing port line and clock via a dedicated line)
- 8-bit programmable timer/event counter
- Internal oscillator, generated with inductor, crystal, ceramic resonator or external source
- Over 80 instructions (based on MAB8048) all of 1 or 2 cycles
- Single 5 V power supply ( $\pm 10 \%$ )
- Operating temperature ranges: 0 to $+70^{\circ} \mathrm{C} \quad$ MAB84X1 family

$$
\begin{array}{ll}
-40 \text { to }+85^{\circ} \mathrm{C} & \text { MAF84X1 family only } \\
-40 \text { to }+110^{\circ} \mathrm{C} & \text { MAF84AX1 family only }
\end{array}
$$

## PACKAGE OUTLINES

MAB8401B: 28-lead 'Piggy-back' package (with up to 28-pin EPROM on top). MAB8401WP: 68-lead plastic leaded chip-carrier (PLCC) (SOT-188A).
MAB/MAF8411/21/41/61P: 28-lead DIL; plastic (SOT-117).
MAF84A11/21/41/61P: 28-lead DIL; plastic (SOT-117).
MAB8411/21/41/61T: 28-lead mini-pack; plastic (SO-28; SOT-136A).

## PINNING



Fig. 1 Pinning diagram for mask-programmable devices MAB8411, MAB8421, MAB8441, MAB8461 and for MAB8401 'Piggy-back' version bottom pinning (for top pinning see Fig. 2).

## PINNING DESIGNATION

| $\mathrm{V}_{\text {SS }}$ | 14 | Ground |
| :---: | :---: | :---: |
| $V_{\text {cc }}$ | 28 | Power supply, + 5 V |
| P00-P07 | 4-11 | Port 0, 8-bit quasi-bidirectional I/O port |
| P10-P17 | 18-25 | Port 1, 8 -bit quasi-bidirectional I/O port with 8 -bit LED driver |
| P20-P23 | 26, 27, 1, 2 | Port 2, 4-bit quasi-bidirectional I/O port, P23 is the serial data I/O in serial I/O mode |
| SCLK | 3 | Bidirectional clock for serial I/O |
| INT/T0 | 12 | External interrupt input (sensitive to a negative-going edge min LOW $>7$ clock pulses, min HIGH $>4$ clock pulses), testable using the JTO or JNT0 instructions. |
| T1 | 13 | Input pin, testable using the JT1 or JNT1 instructions. It can be designated as event counter input using the STRT CNT instruction. It can also be used to detect zero cross-over of slowly moving a.c. inputs. |
| RESET | 17 | Input to initialize the processor (active HIGH). |
| XTAL1 | 15 | Connection to timing component (crystal) that determines the frequency of the internal oscillator. It is also the input for an external clock source. |
| XTAL2 | 16 | Connection to other side of the timing component. |

## MAB8401B (top pinning)



Fig. 2a Connection of EPROM to 'Piggy-back' package MAB8401B.

## PIN DESIGNATION

| designation | pin | function |
| :--- | :--- | :--- |
| V SS | 14,22 | Ground |
| V CC $^{\text {CO }}$ | $1,26-28$ | Power supply, +5 V |
|  | $10-3,25$, |  |
|  | $24,21,23,2$ | Address outputs |
| D0-D7 | $11-13$, |  |
| $\overline{\text { PSEN }}$ | $15-19$ | Data inputs |
|  | 20 | Program store enable |

Fig. 2 Pinning diagram for MAB8401B 'Piggy-back' version top pinning (for bottom pinning see Fig. 1); to access a 2732 or 2764 EPROM.

## Note

Access times for ROMS/EPROMS to be below $1 \mu \mathrm{~s}$.



Fig. 3 Pinning diagram; PLCC.
CHIP CARRIER DESIGNATION
designation pad no.

| VSS | 35 | Ground |
| :--- | :--- | :--- |
| $V_{C C}$ | 68 | Power supply, +5 V |
| POO-PO7 | $4-5,12-17$ | Port 0, 8-bit quasi-bidirectional I/O port |
| P10-P17 | $56-59,62-65$ | Port 1, 8-bit quasi-bidirectional I/O port |
| P20-P22 | $66,67,1$ | Port 2, 4-bit quasi-bidirectional I/O port; P23 is the serial |
| P23/SDA | 2 | data 1/O in series I/O mode |
| SCLK | 3 | Bidirectional clock for serial I/O <br> INT/TO |
|  | 20 | External interrupt input (sensitive to a negative-going edge), <br> testable using the JTO or JNTO instructions |


| T1 | 21 | Input pin, testable using the JT1 or JNT1 instructions. It can be designated as event counter input using the STRT CNT inctruction. It can also be used to detect zero cross-over of slowly moving a.c. inputs. |
| :---: | :---: | :---: |
| RESET | 55 | Input to initialize the processor (active HIGH) |
| XTAL1 | 53 | Connection to timing component (e.g. crystal) that determines the frequency of the internal oscillator. It is also the input for an external clock source. |
| XTAL2 | 54 | Connection to other side of the timing component |
| EXSI | 34 | External serial I/O interrupt (active-LOW) for emulation of MAB/F8422/42. |
| A0-A12 | $\begin{aligned} & 41-36,33-28 \\ & 25 \end{aligned}$ | Program memory address outputs (active HIGH); AO = LSB, A 12 = MSB. Address output change after begin Phi3 of TS8. |
| D0-D7 | 22-24, 45-49 | Data input lines (active HIGH) used for reading external program memory. DO = LSB, D7 = MSB. |
| CLK | 51 | Clock output buffered from XTAL2. On the positive-going edge the (internal) Phi clock goes HIGH. |
| $\overline{\text { PSEN }}$ | 50 | Program store enable. This signal is used for enabling the external EPROM (e.g. on the 'Piggy-back' version). For emulation, it enables the emulation memory and it indicates machine cycles. Active LOW during TS9, TS10 of each machine cycle and TS1 of the following machine cycle. |
| $\overline{\mathrm{C} 1}$ | 18 | Cycle 1 indication output (active LOW). During emulation, this signal indicates the opcode fetch cycle (useful for external instruction decoding, real-time trace). Active from start of TS10 of the cycle preceding cycle 1 , until the start of TS10 of cycle 1. |
| $\overline{\text { HALT }}$ | 52 | Halt input (active LOW). If activated, the current instruction is finished and the microcontroller stops execution (HALT mode). The next program counter address is available on the address bus. Program counter and timer/event counter are no longer updated. The serial I/O finishes the current transmit/receive action and goes into the idle state. Interrupts are not sampled in the HALT mode, they are only sampled when the microcontroller is running. Interrupt routines can be single-stepped as a normal program. |
| $\overline{\text { INTA }}$ | 19 | Interrupt acknowledge output (active LOW). It indicates any interrupt acception. Active from start of TS8 of the interrupted cycle, until start of TS7 of the second cycle of the (internally forced 'CALL vector address' instruction. During INTA active, the address bus shows the address that has been saved in the stack (return address); the C1 output indicates opcode fetch cycles as if a user CALL was executed. |
| $\overline{\text { EMU20 }}$ | 6 | Emulate 20-pin version MAB/F8422/42 (active-LOW). |



Fig. 4a Block diagram of the MAB84X1 family.


Fig. 4b Replacement for dotted part in Fig. 4a for the MAB8401WP bond-out version.


Fig. 4c Replacement of dotted part in Fig. 4a for the MAB8401B 'Piggy-back' version.

FUNCTIONAL DESCRIPTION (for more detail see Microcontroller Users Manual)

## Bond-out version MAB8401WP

The bond-out version is a microcontroller that contains no on-board ROM, but has all address and data lines brought out to access an external ROM or EPROM. So, this version has more pins than the standard microcontrollers with on-board ROM. It has all the features of the other members of the MAB84X1-family, including emulation facilities for the MAB/F8422/42 (20-pin version). It can address 8 K bytes of external ROM. The RAM has 128 bytes.

## Piggy-back version MAB8401B

The Piggy-back version is a special package that has standard pinning to the bottom which facilitates insertion as a mask-programmed device. An EPROM is mounted on top in an additional socket. Thus, the total package height is greater than the standard DIL package. Emulation of the 8422/42 is not possible.

## Program and data memory

The program memory (ROM) is mask-programmed at our factory. Because the MAB84X1-family offers a range of ROM capacities to suit the application, ROM expansion is not required. Figure 5 shows the program memory map. Program memory is arranged in banks of 2 K bytes, that are selected by SEL MB instructions.



Fig. 6 The data memory map.

Fig. 5 The program memory map.

## FUNCTIONAL DESCRIPTION (continued)

The data memory (RAM) consists of 64 or 128 bytes ( 8 -bit words). All locations are indirectly addressable using RAM pointer registers and up to 16 designated location can be addressed directly. The memory also includes an 8 -level program counter stack addressed by a 3 -bit stack pointer. Figure 6 shows the data memory map.

## On-chip peripheral functions

In addition to the CPU and memories, an interrupt system, I/O facilities, and an 8-bit timer/event counter are integrated on-chip to assist the CPU in repetitions, complicated or time-critical tasks. The I/O facilities include the I/O pins, parallel ports and a serial I/O port, consisting of a data line SDA shared with a parallel port line (P23), and a dedicated clock line SCLK.

## I/O facilities

The MAB84XX family has 23 I/O lines arranged as:

- Two parallel ports of 8 lines (P00-P07, P10-P17). Each line of Port 1 can sink 10 mA .
- A parallel port of 4 lines (P20-P23)
- A serial I/O consisting of a data line shared with a parallel port line (P23) and a separate clock line SCLK;
- An external interrupt and test input $\overline{\mathrm{NT}} / \mathrm{TO}$, which when used as a test input can be tested by the conditional jump instructions JTO or JNTO;
- A test input T1, which can alter program sequences when tested by conditional jump instructions JT1 or JNT1. T1 can also be used as an input to the timer/event counter or to detect zero cross-over of slowly moving a.c. signals.
All parallel port lines are available in three optional output configurations (except P23 - option 1 only):
- Option 1; open drain output without pull-up transistor (Fig. 7(a))
- Option 2; open drain output with pull-up transistor (Fig. 7(b))
- Option 3; push-pull output with pull-up transistor (Fig. 7(c))

If the inputs and outputs on a port are mixed (mixed-mode), the inputs should be options 1 or 2 but not option 3. This prevents cross-currents via TR2 and an external connection to ground, while switching the output on the same port and in parallel, masking the inputs with logic ' 1 ' s .
The MAB84X1 family serial I/O interface has been designed to eliminate the heavy processing load imposed upon a normal microcontroller performing serial data transfer. Whereas a normal microcontroller must regularly monitor the serial data bus for the presence of data, the serial I/O interface detects, receives and converts the serial data stream into a parallel format without interrupting the execution of the current program. An interrupt is sent to the microcontroller only when a complete byte is received. Then, the microcontroller reads the data byte in one instruction. Likewise, for transmission, the serial I/O interface performs parallel to serial conversion and subsequent serial output of the data and the microcontroller is only interrupted in the execution of its programmed tasks when a complete byte has been transmitted. The design of the serial I/O interface allows any number of MAB84X1 family devices and peripheral circuits with $I^{2} \mathrm{C}$ bus compatibility to be interconnected by the two-line serial bus. This is achieved by allocating a specific 7 -bit address to each device and ensuring that a device reacts only to a message preceded by its own address or the 'general call' address.
Address recognition is performed by the interface hardware so that the microcontroller need only be interrupted when a valid address is received. This saves significant processing time and memory space compared to a conventional microcontroller with a software serial interface. When the address facility is not required, for instance in a system with only two microcontrollers, direct data transfer is possible. In multi-master systems, an automatically invoked arbitration procedure prevents two or more devices transmitting simultaneously.

(b)

(c)

Fig. 7 Quasi-bidirectional I/O interface with (a) open drain output without pull-up transistor, (b) open drain output with pull-up transistor, (c) push-pull output with pull-up transistor.

## Serial I/O interface

Figure 8 shows the serial I/O interface. The clock line of the serial bus has exclusive use of pin 3 (SCLK) while the data line shares pin 2 (serial data) with the I/O line P23 of port 2. When the serial 1/O is enabled, P23 is disabled as a parallel port line (P23 and SCLK only open drain).
The microcontroller and interface communicate via the internal microcontroller bus and the Serial Interrupt Request line. Data and information controlling the operation of the interface are stored in four registers:

- data shift register SO,
- serial I/O interface status word S1,
- serial clock control word S2,
- address register.


## FUNCTIONAL DESCRIPTION (continued)

## Serial I/O interface (continued)

## Data shift register S0

SO is the shift register that converts serial data to parallel format and vice versa. A pending interrupt is generated only after a complete byte has been transmitted, or after a complete data byte, specific or general call address has been received. The most significant bit is transmitted first.

## Status word S1

S1 provides information about the state of the interface and stores interface control information from the microcontroller. The four most significant bits are common to both read and write instructions, with a separate 4 read-only control bits and 4 write-only interface status bits.

## MST and TRX

These bits determine the operating mode of the serial I/O interface (Table 2).
Table 1 Operating modes of the serial I/O interface.

| MST | TRX | mode |
| :---: | :---: | :--- |
| 0 | 0 | slave receiver |
| 1 | 0 | master receiver |
| 0 | 1 | slave transmitter |
| 1 | 1 | master transmitter |

## BB: Bus Busy

This bit indicates the status of the bus.

## PIN: Pending Interrupt Not

PIN = ' 0 ' indicates that there is an interrupt pending. This causes a Serial Interrupt Request when the serial interrupt mechanism is enabled.

ESO: Enable Serial Output
The ESO flag enables/disables the serial I/O interface: ESO = ' 1 ' enables
ESO = ‘0' disables
$\mathrm{BCO}, \mathrm{BC} 1$ and BC 2
These bits indicate the number of bits received or transmitted in a serial data stream.
Bits $E S O, B C O, B C 1$ and $B C 2$ can only be written via software.
AL: Arbitration Lost
The AL flag is set via the hardware when the serial I/O interface, as a master transmitter, loses the bus arbitration procedure.

## ASS: Addressed As Slave

This flag is set via the hardware when the interface detects either its own address or the 'general call' address as the first byte of a transfer and if the interface has been programmed to operate in the address recognition mode.

## ADO: Address Zero

This flag is set via the hardware after the general call address is detected when the interface is operating in the address recognition mode.

## LRB: Last Received Bit

This contains either the last data bit received or, for a transmitting device in the acknowledge mode, the acknowledge from the receiving device.

Bits AL, AAS, ADO and LRB can only be read via software.

## Clock control register S2

Bits 0 to 4 of S 2 are used to set the frequency of the serial clock signal. When a $4,43 \mathrm{MHz}$ crystal is used, the frequency of the serial clock can be varied between 100 kHz and 720 Hz . An asymmetrical clock with a HIGH to LOW ratio of 3 to 1 is produced by setting bit 5 . The asymmetrical clock allows a microcontroller more time per clock period for sampling the data line, making the timing of this action less critical. Bit 6 is used to activate the acknowledge mode of the serial I/O. S2 is a write-only register.

## Address register

The address register contains the 7-bit address back-up latches and the bit (ALS) used to enable/disable the address recognition mode. Only when ESO = 0 can the address register be written using the MOV SO,A and MOV SO,\#data instructions.

## Serial I/O interrupt logic

The interrupt logic is enabled by the EN SI instruction and disabled by DIS SI. When the interrupt logic is enabled, a pending interrupt results in a serial I/O interrupt to the controller, causing a jump to location 5 in the ROM. When the logic is disabled, the presence of an interrupt is still indicated by the PIN bit in register S1. Therefore, an interrupt can still be serviced but a vectored interrupt will not occur.

## Interrupt system

External events and real-time on-chip peripherals require servicing by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution, three single-level nested interrupts are provided.
Each interrupt vectors to a separate location in the program memory for its service program. Each source can be individually enabled or disabled. When more than one interrupt occurs simultaneously, their priority will be: (1) external, (2) serial I/O and, (3) timer/event counter. An additional external interrupt can be created using the timer/event counter interrupt.


Fig. 8 The serial I/O interface.

## Test input T1

The T1 input line can be used as:

- a test input for branch instructions,
- an input for zero voltage cross-over detection,
- an external input to the event counter.

An internal pull-up transistor is provided as a ROM mask option. This is useful when the input is from a switch or standard TTL output.

When T1 is used as a test input, the JT1 or JNT1 instructions test for a HIGHi or a LOW respectiveiy.
When used for zero-cross detection purposes, the T1 input must be coupled through a capacitor of typical value $1 \mu \mathrm{~F}$ and operation carried out using the T1 input without the pull-up transistor. The maximum input voltage amplitude is 3 V (peak-to-peak), with a maximum operational frequency of 1 kHz . The T1 input has an on-chip d.c. offset circuit which self-biases the input to its exact switching level of 1 V . As a consequence a small change will cause a digital transition to occur. The switching level of the T1 input circuit is within the bias voltage of $\pm 135 \mathrm{mV}$. Upon each positive cycle on the pin, the event counter is incremented and an overflow will set the timer flag TF. Zero cross-over detection used in conjunction with the timer/event counter interrupt, is useful in thyristor control of power equipment. Figure 9 illustrates, (a) the input waveform, (b) the input diagram and (c) the on-chip self-stabilized bias.


Fig. 9 Zero-cross detection circuitry.
The operation of T1 as an input to the timer/event counter is described under the heading Timer/ event counter.

## High current outputs

Ten pins are provided that can sink high currents:

- P23 (serial data), pin 2
- SCLK, pin 3
- P10 - P17 4

5 mA at $0,45 \mathrm{~V}$ (open drain), 5 mA at $0,45 \mathrm{~V}$ (open drain), 10 mA at 1 V
$\Delta \mathrm{P} 10$ to P 17 may be connected in parallel if their logic outputs are always the same.


Purchase of Philips' $I^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specifications defined by Philips.

FUNCTIONAL DESCRIPTION (continued)
Timer/event counter
An 8 -bit binary up-counter is provided. This can count external events, machine cycles divided by 32, or machine cycles directly. When used as a timer, the input to the counter is either the overflow or input of a 5-bit prescaler. When used as an event counter, LOW to HIGH transitions on T1 (pin 13) are counted. The maximum rate at which the counter may be incremented is once every machine cycle ( 200 kHz for a $5 \mu \mathrm{~s}$ machine cycle). Figure 10 illustrates the timer/event counter.


Fig. 10 The timer/event counter.
Differences between the MAB8021 and MAB8048 microcontrollers, and the MAB84X1 family.

|  | 8021 | 8048 | $\begin{aligned} & 8401,8411 \\ & 8421,8441,8461 \end{aligned}$ |
| :---: | :---: | :---: | :---: |
| ROM capacity (bytes) | 1K | 1K | ROMless, $1 \mathrm{~K}, 2 \mathrm{~K}, 4 \mathrm{~K}, 6 \mathrm{~K}$ |
| RAM capacity (bytes) | 64 | 64 | 64, 64, 128, 128 |
| paralel I/O lines | $8+8+4$ | $8+8+8$ | $8+8+4$ |
| single inputs | 1 | 3 |  |
| serial I/O | no | no | yes, 2-line multi-transmitter |
| timer | 8 bit | 8 bit | 8 bit |
| prescaler | mod. 32 | mod. 32 | mod. $1 \&$ mod. 32 |
| machine cycle time ( $\mu \mathrm{s}$ ) for clock (MHz) instruction set | 10 | 2,5 |  |
|  |  | 6 | 6 |
|  | 8021 | 8048 | 8048 with omissions; 5 new serial I/O instructions: |
|  |  |  | 2 new register instructions; 2 new control instructions; 1 new cond. branch instruction |
| interrupts | none |  |  |
|  |  | external timer/ | external serial I/O |
|  |  | event counter | timer/event counter |
| no. of pins (DIL) | 28 |  | (PLCC-68) 28 |

## OSCILLATOR CIRCUITRY

Clock frequency is determined by using the internal oscillator or by connecting an external clock to XTAL1. Where the internal oscillator is used, the frequency is set by a crystal between XTAL1 and XTAL2, or by a ceramic resonator or an inductor, each with two associated capacitors, between XTAL1 and XTAL2 (see Fig. 11a). A machine cycle consists of 10 states, each state being 3 oscillator periods. The common 6 MHz crystal gives a $5 \mu$ s machine cycle. The MAB84X1 family has dynamic logic, and therefore, for adequate refreshing the oscillator frequency must be at least 1 MHz .


1. Crystal - AT-cut
2. Ceramic resonator
$\mathrm{C} 1=\mathrm{C} 2=27 \mathrm{pF}$
C1 may be trimmed
$\mathrm{C}_{\mathrm{p}} \leqslant 6,75 \mathrm{pF}$ (parasitic capacitance)

Fig. 11a Quartz crystal or ceramic resonator mode.


Fig. 11b LC pi-network.


Drive XTAL1
Leave XTAL2 open
Driver may be high-speed CMOS or any TTL $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}<10 \mathrm{~ns}$

Fig. 11c External drive.

## PROGRAM STATUS WORD

The program status word (PSW) is an 8-bit word in the CPU which stores information about the current status of the microcontroller (Fig. 12). The PSW bits are:
bits 0,1 and $2-$ stack pointer bits ( $\mathrm{SP}_{\mathrm{0}}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ );
bit $3-$ prescaler select (PS); $0=$ divide-by-32; $1=$ no prescaling;
bit 4 - working register bank select (RBS):
$0=$ register bank 0 1 = register bank 1;
bit $5-$ not used (1);
bit 6 - auxiliary carry (AC): half-carry bit is generated by an ADD instruction and used by the decimal adjust instruction DA A;
bit 7 - carry (CY): the carry flag indicates that the previous operation has resulted in an overflow of the accumulator.


Fig. 12 Program status word.
All bits can be read using MOV A, PSW and bit 3 can be written with MOV PSW, A.
Bits 6 and 7 can be set and cleared by CPU operation. Bit 4 is changed by the SEL RB instruction, bit 3 by the MOV PSW, A instruction, and bits 0,1 and 2 by the CALL, RET or RETR instructions and when an interrupt occurs. Bits 4,6 and 7 are stored in the program counter stack during subroutine and interrupt calls. These bits are restored to the PSW with RETR (return and restore) instruction.

Note: The RET instruction has no restore feature and should not be used at the end of an interfupt because this would leave any further interrupts disabled.

The MAB84X1 family has arithmetic, logical and branching capabilities. The DA A, SWAP A, and XCHD instructions simplify BCD arithmetic and the handling of nibbles. The MOVP A,@A instruction permits efficient table look up from the current ROM page.
The conditional branch logic within the processor enables several conditions, internal and external to the processor, to be tested by the user's program. Table 2 lists the conditional branch instructions used to change the program execution sequence. The DJNZ instruction decrements a designated register and branches if the contents are not zero. This instruction makes the register an efficient program loop counter. The JMPP @A instruction allows multiway branches to destinations indirectly addressed by the contents of the accumulator.

Table 2 Conditional branches

| TEST | JUMP CONDITION | JUMP INSTRUCTION |
| :--- | :--- | :--- |
| accumulator | 0 or non-zero | JZ, JNZ |
| accumulator bit test | 1 | JBO to JB7 |
| carry flag | 0 or 1 | JNC, JC |
| timer overflow flag | 1 | JTF |
| test input INT | 0 or 1 | JNTO, JTO |
| test input T1 | 0 or 1 | JNT1, JT1 |
| test flag 0 | 1 | JFO |
| test flag 1 | 1 | JF1 |
| register | non-zero | DJNZ |

## RESET

A positive-going signal on the RESET input:

- sets the program counter to zero,
- selects location 0 of memory bank 0, and register bank 0,
- sets the stack pointer to zero ( ${ }^{\prime} 000^{\prime} \mathrm{B}$ ); pointing to RAM address 8,
- disable the interrupts (external, timer and serial I/O),
- stops the timer/event counter, then sets it to zero,
- sets the timer prescaler to divide-by-32,
- resets the timer flag,
- sets all ports to logic '1' (input mode),
- sets the serial I/O to slave receiver mode and disables serial I/O.

Automatic reset at power-up may be obtained by connecting the RESET pin to $V_{C C}$ through a $1 \mu \mathrm{~F}$ capacitor C , together with a diode to $\mathrm{V}_{\mathrm{SS}}$ (cathode to RESET pin). This arrangement is satisfactory, if both the voltage $\left(V_{C C}\right)$ rise time and the oscillator start-up time do not exceed either 1 or 10 ms respectively.
The power-on reset circuit is shown in figure 13. At power-on the current drawn by RESET commences to charge the capacitor $C$. The difference between this increasing capacitor voltage and $V_{\text {CC }}$ is known as $V_{\text {RESET }}$. The charging circuit is designed to hold $V_{\text {RESET }}$ above the lower threshold of a Schmitt trigger arrangement long enough to effect a complete reset. The minimum time required; is the oscillator start-up time plus two machine cycles.


Fig. 13 Typical power-on reset circuitry.

## INSTRUCTION SET

The instruction set consists of over 80 one and two byte instructions and is based on the MAB8048 instruction set. New instructions include those for serial I/O operation and memory bank selection. Program code efficiency is high because all ROM locations on a 256 byte page require only a single byte address.
Table 3 gives the instruction set of the MAB84XX family and Table 4 shows the instruction map. The following symbols and abbreviations are used.

Note: During development of software on a PMDS or similar system, it is important to ensure that no jump instruction (direct or indirect), outreaches the final address range of the device.

| symbol | description |
| :---: | :---: |
| A | the accumulator |
| AC | the auxiliary carry flag |
| addr | program memory address (11-bits) |
| Bb | bit designation ( $\mathrm{b}=0-7$ ) |
| BS | the bank switch |
| C | carry flag |
| CLK | clock signal |
| CNT | event counter |
| D | nibble designation (4-bits) |
| DBF | program memory bank flip-flop |
| data | number or expression (8-bits) |
| F0, F1 | flags 0 and 1 |
| $\underline{1}$ | interrupt |
| $\overline{\text { INT }}$ | external interrupt |
| P | 'in-page' operation designation |
| Pp | port designation ( $\mathrm{p}=1,2$ or $4-7$ ) |
| PSW | program status word |
| Rr | register designation ( $r=0,1$ or $0-7$ ) |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| T0, T1 | test 0 and 1 inputs |
| \# | immediate data prefix |
| @ | indirect address prefix |
| \$ | current value of program counter |
| $\leftarrow$ | is replaced by |
| $\leftrightarrow$ | is exchanged with |

Table 3 MAB84XX family instruction set

## 9861 ıəquəлоN

## ACCUMULATOR

|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\frac{a}{5}$055325000 | ADD A, Rr | 6* | 1/1 | Add register contents to A | $(A) \leftarrow(A)+(R r)$ | $r=0-7$ | 1 |
|  | ADD A, @Rr | 60 61 | 1/1 | Add RAM data, addressed by Rr, to A | $\begin{aligned} & (A) \leftarrow(A)+((R 0)) \\ & (A) \leftarrow(A)+((R 1)) \end{aligned}$ |  | 1 |
|  | ADD A, \#data | 03 data | 2/2 | Add immediate data to $A$ | $(A) \leftarrow(A)+$ data |  | 1 |
|  | ADDC A, Rr | $7{ }^{*}$ | 1/1 | Add carry and register contents to $A$ | $(A) \leftarrow(A)+(R r)+(C)$ | $r=0-7$ | 1 |
|  | ADDC A, @Rr | 70 | 1/1 | Add carry and RAM data, addressed | $\begin{aligned} & (A) \leftarrow(A)+((R 0))+(C) \\ & (A) \leftarrow(A)+((R 1))+(C) \end{aligned}$ |  | 1 |
|  |  |  |  | Add carry and immediate data to A |  |  |  |
|  | ADDC A, \#data | 13 data | 2/2 | Add carry and immediate data to $A$ | $(A) \leftarrow(A)+$ data $+(C)$ |  | 1 |
|  | ANL A, Rr | 5* | 1/1 | 'AND' Rr with A | $(A) \leftarrow(A) A N D(\operatorname{Rr})$ | $r=0-7$ |  |
|  | ANL A, @Rr | 50 | $1 / 1$ | 'AND' RAM data, addressed by $\operatorname{Rr}$, with A | $(A) \leftarrow(A) \text { AND }((R O))$ |  |  |
|  |  | 51 |  |  | $(A) \leftarrow(A)$ AND ( $(\mathrm{R} 1)$ ) |  |  |
|  | ANL A, \#data | 53 data | 2/2 | 'AND' immediate data with A | $(A) \leftarrow(A)$ AND data |  |  |
|  | ORL A, Rr | 4* | 1/1 | 'OR' Rr with A | $(A) \leftarrow(A) O R(R r)$ | $r=0-7$ |  |
|  | ORL A, @Rr | 40 41 | 1/1 | 'OR' RAM data, addressed by Rr, with A | $\begin{aligned} & (A) \leftarrow(A) \text { OR }((R 0)) \\ & (A) \leftarrow(A) \text { OR }((R 1)) \end{aligned}$ |  |  |
|  | ORL A, \#data | 43 data | 2/2 | 'OR' immediate data with A | $(A) \leftarrow(A) O R$ data |  |  |
|  | XRL A, Rr | D* | 1/1 | 'XOR' Rr with A | $(A) \leftarrow(A) X O R(R r)$ | $r=0-7$ |  |
|  | XRL A, @Rr | D0 | 1/1 | 'XOR' RAM, addressed by Rr, with A | $(A) \leftarrow(A) \text { XOR }((R 0))$ |  |  |
|  |  | D1 |  |  | $(A) \leftarrow(A) \text { XOR }((R 1))$ |  |  |
|  | XRL A, \#data | D3 data | 2/2 | 'XOR' immediate data with A | $(A) \leftarrow(A) \times O R$ data |  |  |
|  | INC A | 17 | 1/1 | increment A by 1 | $(A) \leftarrow(A)+1$ |  |  |
|  | DEC A | 07 | 1/1 | decrement A by 1 | $(A) \leftarrow(A)-1$ |  |  |
|  | CLR A | 27 | 1/1 | clear A to zero | $(\mathrm{A}) \leftarrow 0$ |  |  |
|  | CPL A | 37 | 1/1 | one's complement A | $(A) \leftarrow \operatorname{NOT}(\mathrm{A})$ |  |  |
|  | RLA | E7 | 1/1 | rotate A left | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow\left(A_{n}\right) \\ & \left(A_{0}\right) \leftarrow\left(A_{7}\right) \end{aligned}$ | $n=0-6$ |  |


|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RLC A <br> RR A <br> RRC A <br> DA A <br> SWAP A | F7 77 67 57 47 | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | rotate A left through carry <br> rotate A right <br> rotate A right through carry <br> decimal adjust $A$ <br> swap nibbles of $A$ | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow A_{n} \\ & \left(A_{0}\right) \leftarrow(C),(C) \leftarrow\left(A_{7}\right) \\ & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow\left(A_{0}\right) \\ & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow(C),(C) \leftarrow\left(A_{0}\right) \end{aligned}$ $\left(A_{4-7}\right) \leftrightarrow\left(A_{0-3}\right)$ | $\begin{aligned} & n=0-6 \\ & n=0-6 \\ & n=0-6 \end{aligned}$ | $2$ <br> 2 <br> 2 |
|  | MOV A, Rr MOV A, @Rr <br> MOV A, \#data MOV Rr, A MOV @Rr, A <br> MOV Rr, \#data MOV @Rr, \#data <br> XCH A, Rr <br> XCH A, @Rr <br> XCHD A, @Rr <br> MOV A, PSW <br> MOV PSW, A <br> MOVP A, @A | $F^{*}$ F0 F1 23 data A* $^{*}$ A0 A1 B* data $^{\text {B }}$ data B1 data $2^{*}$ 20 21 30 31 C7 D7 A3 | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 2 / 2 \\ & 1 / 1 \\ & 1 / 1 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & \\ & 1 / 1 \\ & 1 / 1 \\ & \\ & 1 / 1 \\ & \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 2 \end{aligned}$ | move register contents to $A$ move RAM data, addressed by $R r$, to $A$ <br> move immediate data to $A$ move accumulator contents to register move accumulator contents to RAM location addressed by Rr move immediate data to Rr move immediate data to RAM location addressed by Rr <br> exchange accumulator contents with Rr exchange accumulator contents with RAM data addressed by Rr <br> exchange !ower nibbles of A and RAM data addressed by Rr move PSW contents to accumulator move accumulator bit 3 to $\mathrm{PSW}_{3}$ move indirectly addressed data in current page to $A$ | $\begin{aligned} & (A) \leftarrow(R r) \\ & (A) \leftarrow((R 0)) \\ & (A) \leftarrow((R 1)) \\ & (A) \leftarrow \text { data } \\ & (R r) \leftarrow(A) \\ & ((R 0)) \leftarrow(A) \\ & ((R 1)) \leftarrow(A) \\ & (R r) \leftarrow \text { data } \\ & ((R 0)) \leftarrow \text { data } \\ & ((R 1)) \leftarrow \text { data } \\ & (A) \leftrightarrow(R r) \\ & (A) \leftrightarrow((R 0)) \\ & (A) \leftrightarrow((R 1)) \\ & (A 0-3) \leftrightarrow\left(\left(R 0_{0}-3\right)\right) \\ & \left(A_{0}-3\right) \leftrightarrow\left(\left(R 1_{0-3}\right)\right) \\ & (A) \leftarrow(P S W) \\ & \left(P S W_{3}\right) \leftarrow\left(A_{3}\right) \\ & \left(P C_{0}-7\right) \leftarrow(A),(A) \leftarrow((P C)) \end{aligned}$ | $\begin{aligned} & r=0-7 \\ & r=0-7 \\ & r=0-7 \end{aligned}$ | 3 |




\begin{tabular}{|c|c|c|c|c|c|c|}
\hline  \& \begin{tabular}{l}
IN A, Pp \\
OUTL Pp, A \\
ANL Pp, \#data \\
ORL Pp, \#data \\
OUTL PO,A
\end{tabular} \& \begin{tabular}{l}
08 \\
09 \\
OA \\
38 \\
39 \\
3A \\
98 data \\
99 data \\
9A data \\
88 data \\
89 data \\
8A data \\
90
\end{tabular} \& \begin{tabular}{l}
\(1 / 2\) \\
\(1 / 2\) \\
\(2 / 2\) \\
\(2 / 2\) \\
\(1 / 2\)
\end{tabular} \& \begin{tabular}{l}
input port p data to accumulator \\
output accumulator data to port \(p\) \\
AND port p data with immediate data \\
OR port p data with immediate data \\
Output accumulator data to port \(\phi\)
\end{tabular} \&  \& 7

9 <br>

\hline  \& | MOV A, $S_{n}$ |
| :--- |
| MOV S $n, A$ |
| MOV $S_{n}$, \#data |
| EN SI |
| DIS SI | \& \[

$$
\begin{aligned}
& 0 C \\
& 0 D \\
& 3 C \\
& 3 D \\
& 3 E \\
& 9 C \\
& 9 D \\
& 9 E \\
& 85 \\
& 95
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 / 2 \\
& 1 / 2 \\
& 2 / 2 \\
& \\
& 1 / 1 \\
& 1 / 1
\end{aligned}
$$

\] \& | move serial I/O register contents to accumulator |
| :--- |
| move accumulator contents to serial I/O register |
| move immeidate date to serial I/O register |
| enable serial I/O interrupt |
| disable serial I/O interrupt | \& \[

$$
\begin{aligned}
& (A) \leftarrow(S 0) \\
& (A) \leftarrow(S 1) \\
& (S 0) \leftarrow(A) \\
& (S 1) \leftarrow(A) \\
& (S 2) \leftarrow(A) \\
& (S 0) \leftarrow \text { data } \\
& (S 1) \leftarrow \text { data } \\
& (S 2) \leftarrow \text { data }
\end{aligned}
$$
\] \& 8 <br>

\hline \& NOP \& 00 \& 1/1 \& no operation \& \& <br>
\hline
\end{tabular}

Notes to Table 3.

| 1. PSW CY, AC | affected |
| :--- | :--- |
| 2. PSW CY | affected |
| 3. PSW PS | affected |

4. Execution of JTF and JNTF instructions resets the Timer Flag (TF).

## 5. PSW RBS affected

6. $\mathrm{PSW} \mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ affected
7. $(A)=1111$ P23, P22, P21, P20.
8. (S1) has a different meaning for read and write operation, see serial I/O interface.
9. Only for software-transfer from the MAB8021.

Table 4 MAB84X1 family instruction set


Table 5 shows the additional MAB84X1 family instructions (including the five for serial I/O operation) that are not part of the MAB8048 instruction set.

Table 5 MAB84X1 family instructions not in the MAB8048 instruction set

| serial I/O | register | control | conditional branch |
| :--- | :--- | :--- | :--- |
| MOV A, S | MEC @Rr | SEL MB2 | JNTF addr |
| MOV S $n_{n}$ A | DEC | DJNZ @Rr, addr | SEL MB3 |

Table 6 shows the MAB8048 instructions omitted from the MAB84X1 family instruction set.
Table 6 MAB8048 instructions not in the MAB84X1 family instruction set

| data moves | flags | branch | control |
| :--- | :--- | :--- | :--- |
| MOVX A, @R | CLR F0 | * JNI addr | ENTO CLK |
| MOVX @R, A | CPL FO | JFO addr |  |
| MOVP3 A, @A | CLR F1 | JF1 addr |  |
| MOVD A, P | CPL F1 |  |  |
| MOVD P, A |  | * replaced by |  |
| ANLD P, A |  | JTO JNTO. |  |
| ORLD P, A |  |  |  |

## ABSOLUTE MAXIMUM RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Stress above 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 above 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.
Input voltage on any pin
with respect to ground ( $\mathrm{V}_{\mathrm{SS}}$ )
Total power dissipation
Input/output for all pins except port 1
Input/output current for port 1
Storage temperature
Operating temperature


## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current |  |  |  |  |  |
| MAB | ${ }^{\text {I CC }}$ | - | 85 | mA | 0 to $+70{ }^{\circ} \mathrm{C}$ |
| MAF | ICC | - | 100 | mA | -40 to $+85{ }^{\circ} \mathrm{C}$ |
| MAF84A | ICC | - | 100 | mA | -40 to $+110^{\circ} \mathrm{C}$ |
| Inputs |  |  |  |  |  |
| Input voltage LOW (except P23 and SCLK) | $V_{\text {IL }}$ | -0,5 | 0,8 | V |  |
| Input voltage LOW (P23 and SCLK) | VIL1 | -0,5 | 1,5 | V |  |
| Input voltage HIGH (all inputs except XTAL1, P23 and SCLK) | $\mathrm{V}_{\text {IH }}$ | 2 | $\begin{aligned} & V_{C C} \\ & +0,5 \end{aligned}$ | V |  |
| Input voltage HIGH <br> (XTAL1, P23 and SCLK) | $\mathrm{V}_{1+1}$ | 3,0 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \\ & +0,5 \end{aligned}$ | V |  |
| Outputs |  |  |  |  |  |
| Output voltage LOW (P00-P07) | $\mathrm{V}_{\text {OL }}$ | - | 0,45 | V | ${ }^{\prime} \mathrm{OL}=1,6 \mathrm{~mA}$ |
| Output voltage LOW (P10-P17 for 8401/11/21/41/61) | $\mathrm{V}_{\text {OL12 }}$ | - | 1,0 | V | $\mathrm{I}^{\mathrm{OL} 12}=10 \mathrm{~mA}$ |
| Output voltage LOW (P20-P22) | $\mathrm{V}_{\text {OL2 }}$ | - | 0,45 | V | $\mathrm{I}_{\mathrm{OL2}}=1,6 \mathrm{~mA}$ |
| Output voltage LOW (P23, SCLK) | VOL3 | - | 0,45 | V | ${ }^{1} \mathrm{OLS}=5 \mathrm{~mA}$ |
| Output voltage LOW (non-standard pins of bond-out versions) | $\mathrm{V}_{\text {OL4 }}$ | - | 0,45 | V | ${ }^{\mathrm{OL4}}=0,4 \mathrm{~mA}$ |
| Output voltage HIGH (all outputs unless (open drain) | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | 1 - | V | $\mathrm{I}^{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| Output leak age current | $\pm \mathrm{I}_{\mathrm{OL}}$ | - | 10 | $\mu \mathrm{A}$ | $\mathrm{v}_{\mathrm{SS}}<\mathrm{v}_{1}<\mathrm{v}_{\mathrm{CC}}$ |

A.C. CHARACTERISTICS (all versions except bond-out)
$V_{C C}=5 \mathrm{~V} \pm 10 \% ; V_{S S}=0 \mathrm{~V}$.

| parameter | symbol |  | $\min$. | $\max$. | unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Frequency | fXTAL | MAB/MAF84X1 | 1 | 6 | MHz |
| Cycle time | t (Y | MAF84AX1 | 1 | 5 | MHz |
|  |  | MAB/MAF84X1 | 5 | 30 | $\mu \mathrm{~s}$ |
|  |  | MAF84AX1 | 6 | 30 | $\mu \mathrm{~s}$ |

A.C. CHARACTERISTICS (bond-out versions)
$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$.

| parameter | symbol | min. | max. | unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{CL}}=6 \mathrm{MHz}$ |  |  |  |  |
| Control pulse duration $\overline{\text { PSEN }}$ (9CP) | ${ }^{\mathrm{t}} \mathrm{CC}$ | 1,5 | 9 | $\mu \mathrm{s}$ |
| Address to $\overline{\text { PSEN }} \mathrm{L}$ set-up (1CP) | ${ }^{t} A$ S | 167 | - | ns |
| Data to $\overline{\text { PSEN }} \mathrm{H}$ set-up (1CP + 120 ns ) | ${ }^{t}$ DS | 600 | - | ns |
| Data hold time | ${ }^{\text {t }}$ DR | 0 | - | ns |
| Address to data-in ( $10 \mathrm{CP}-\mathrm{t}_{\mathrm{DS}}$ ) | ${ }^{t} A D$ | - | 1,07 | $\mu \mathrm{s}$ |
| Time from $\overline{\text { PSEN }} \mathrm{L}$ to C 1 (3CP) | ${ }^{\text {tPC }}$ | 500 | - | ns |
| Time from INTA $L$ to $\overline{\text { PSEN }}$ (3CP) | tipo | 500 | - | ns |
| Time from $\overline{\text { INTA }} \mathrm{H}$ to $\overline{\text { PSEN }}$ (6CP) | $t_{\text {IP1 }}$ | 1 | - | $\mu \mathrm{s}$ |
| $\overline{\text { HALT }}$ set-up to $\overline{\text { PSEN }}$ (15CP) | ${ }_{\text {thS }}$ | 2,5 | - | $\mu \mathrm{s}$ |
| $\overline{\text { HALT }}$ hold time from $\overline{\text { PSEN }}$ (3CP) | ${ }^{\text {thH }}$ | 500 | - | ns |

Note: CP = clock pulse.

## T1 ZERO-CROSS CHARACTERISTICS

$\mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$

| parameter | symbol | $\min$. | max. | unit | conditions |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Zero-cross detection <br> input (T1) peak-to-peak | $\mathrm{V}_{\mathrm{ZX}}(\mathrm{p}-\mathrm{p})$ | 1 | 3 | V | a.c. coupled, $\mathrm{C}=1,0 \mu \mathrm{~F}$ |
| Zero-cross accuracy | $\mathrm{A}_{\mathrm{ZX}}$ | - | $\pm 135$ | mV | 50 Hz sine wave |
| Zero-cross detection <br> input frequency (T1) | $\mathrm{F}_{\mathrm{ZX}}$ | 0,05 | 1 | kHz |  |



Fig. 14 Memory access timing MAB8401B/WP and I/O voltage parameters.


Fig. $15 \overline{\mathrm{INTA}}$ and $\overline{\mathrm{HALT}}$ timing MAB8401 and I/O voltage parameters.

## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The MAB8422/8442 is a high-performance microcontroller incorporating dedicated hardware, memory capacity and I/O lines. This dedication means a microcontroller can be economically installed in high-volume products where its main function is control.

The MAB8422/8442 is a 20 pin, single-chip 8 -bit microcontroller that has been developed from the 28 pin MAB8421/8441 microcontrollers. The versions are:

- MAB8422-2K $\times 8$ ROM/ 64 bytes RAM
- MAB8442-4K $\times 8$ ROM/ 128 bytes RAM

Each version has $15 \mathrm{I} / \mathrm{O}$ port lines comprising one 8-bit parallel port (P0), one 2-bit parallel port (P10 and P11 that are shared with the serial I/O lines SDA and SCL), one 3-bit parallel port (P20-P22) and two input lines (INT/T0 and T1).
The serial I/O interface is $I^{2} \mathrm{C}$ compatible and therefore the MAB8422/8442 can operate as a slave or a master in single and multi-master systems. Conversion from parallel to serial data when transmitting, and vice versa when receiving, is done mainly in software. There is a minimum of hardware for the serial I/O implemented. This hardware is controlled by the status of the SDA and SCL lines and can be read or written under software control. Standard software for $I^{2} \mathrm{C}$-bus control is available upon request. For detailed information see the user manual 'Single-chip 8-bit microcontrollers'.

## Features

- 8-bit: CPU, ROM, RAM and I/O
- 20 pin package
- MAB8422: $2 \mathrm{~K} \times 8$ ROM/ 64 bytes RAM
- MAB8442: $4 \mathrm{~K} \times 8 \mathrm{ROM} / 128$ bytes RAM
- 13 quasi-bidirectional I/O port lines
- Two testable inputs T1 and INT/T0
- High current output on $\mathrm{PO}\left(\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}\right.$ at $\left.\mathrm{V}_{\mathrm{OL}}=1 \mathrm{~V}\right)$
- One interrupt line combined with the testable input line INT/TO
- Single-level interrupts: external, timer/event counter, serial I/O
- $I^{2} \mathrm{C}$-compatible serial I/O that can be used in single or multi-master systems (serial I/O data and clock via P10 and P11 port lines, respectively)
- 8-bit programmable timer/event counter
- Internal oscillator, generated with inductor, crystal, ceramic resonator or external source
- Over 80 instructions (based on MAB8048)
- All instructions 1 or 2 cycles, cycle time dependent on oscillator frequency
- Single power supply
- Operating temperature ranges: 0 to $+70^{\circ} \mathrm{C}$ (MAB84X2)
-40 to $+85^{\circ} \mathrm{C}$ (MAF84X2)
-40 to $+10^{\circ} \mathrm{C}$ (MAF84AX2)


## PACKAGE OUTLINES

MAB/MAF84X2, MAF84AX2: 20-lead DIL; plastic (SOT-146)


Fig. 1 Block diagram of the MAB8422/8442.


Fig. 2 Pinning diagram.

## PINNING

\(\left.$$
\begin{array}{lll}\begin{array}{ll}\text { Designation } \\
\text { P00-P07 }\end{array} & \begin{array}{l}\text { Pin number } \\
\text { INT/TO }\end{array} & 9\end{array}
$$ \begin{array}{l}Function <br>
8-bit quasi-bidirectional I/O port (Port 0 high current output). <br>
External interrupt input (sensitive to a negative going edge) <br>
and/or input, testable using the JTO or JNTO instructions. <br>

Ground.\end{array}\right]\)| Input pin, testable using the JT1 or JNT1 instructions. It can be |
| :--- |
| designated as event counter input using the STRT CNT instruction. |
| It can also be used to detect zero cross-over of slowly moving a.c. |
| inputs. |
| Connection to timing component that determines the frequency of |
| the internal oscillator. It is also the input for an external clock |
| source. |
| XTAL1 |

## FUNCTIONAL DESCRIPTION

## Program and data memory

The non-volatile program memory (ROM), as shown in Fig. 3, is arranged in two banks of 2K bytes, that are selected by SEL MB instructions, and each bank is further divided into 256-byte pages.
Only the unconditional jump instructions (JMP and CALL) can be used to cross page boundaries. Memory bank boundaries can also be crossed using these instructions provided that the appropriate memory bank has been selected.


Fig. 3 Program memory map.

In the volatile data memory (RAM), all locations are indirectly addressable using RAM pointer registers and up to 16 designated locations can be addressed directly. The memory also includes an 8 -level program counter stack addressed by a 3 -bit stack pointer and two register banks, each with 8 registers. The data memory is shown in Fig. 4.


Fig. 4 Data memory map.

## Instruction set

The instruction set consists of over 80 one and two byte instructions. It is identical to the MAB84X1 instruction set except that the instructions MOV Sn, A, MOV A, Sn and MOV Sn, \#data are not used. Program code efficiency is high because all RAM locations on a 256 byte page require only a single byte address.

## On-chip peripheral functions

In addition to the CPU and memories, an interrupt system, I/O facilities, and an 8-bit timer/event counter are integrated on-chip to assist the CPU in repetitious, complicated or time-critical tasks. The I/O facilities include the I/O pins, parallel ports and a serial I/O port sharing the two pins of the parallel port P1.

## FUNCTIONAL DESCRIPTION (continued)

## I/O facilities (see Fig. 5)

The MAB8422/8442 has 13 I/O lines and 2 testable inputs arranged as:

- An 8 line parallel port P00-P07, high current outputs with three optional output configurations:
- A push-pull output with pull-up (Fig. 5 (a))
- Open drain with pull-up (Fig. 5 (b))
- Open drain without pull-up (Fig. 5 (c))
- A 2 line parallel/serial port P10/SDA and P11/SCL, open-drain without pull-up, as output configuration. Schmitt-trigger input. After RESET, P10/SDA and P11/SCL will be in the parallel port mode. To stay in this mode the internal port latches, P14 and P13, must be kept in the logic ' 1 ' state. Inputs P12-P17 are not valid in the parallel port mode. After a RESET, the microcontroller remains in the parallel port mode until the serial I/O mode is enabled.
- A 3 line parallel port P20-P22 with the same output configurations as P00-P07 but without high--current output;
- An external interrupt and test input INT/TO, which when used as a test input can be tested by the conditional jump instructions JTO and JNTO;
- A test input T1, tested by the conditional jump instructions JT1 and JNT1. T1 can also be used as an input to the timer/event counter or to detect zero cross-over of slowly moving a.c. signals.

(a)

(b)


Fig. 5 Port option configurations.

## Test input T1

The T1 input line can be used as:

- a test input for branch instructions,
- an input for zero voltage cross-over detection,
- an external input to the event counter.

An internal pull-up transistor is provided as a ROM mask option. This is useful when the input is from a switch or standard TTL output.
When T 1 is used as a test input, the JTi or JNTI instructions test for a HIGH or a LOW respectively.

## Zero cross-over detection

When used for zero-cross detection purposes, the T1 input must be coupled through a capacitor of typical value $1 \mu \mathrm{~F}$ and operation carried out using the T 1 input without the pull-up transistor. The maximum input voltage amplitude is 3 V (peak-to-peak), with a maximum operational frequency of 1 kHz . The T1 input has an on-chip d.c. offset circuit which self-biases the input near to its exact switching level of 1 V . As a consequence a small change will cause a digital transition to occur. The switching level of the T1 input circuit is within the bias voltage of $\pm 135 \mathrm{mV}$. Upon each positive cycle on the pin, the event counter is incremented and an overflow will set the timer flag TF. Zero cross-over detection used in conjunction with the timer/event counter interrupt, is useful in thyristor control of power equipment. Figure 6 illustrates, (a) the input waveform, (b) the input diagram and (c) the on-chip self-stabilized bias.

## 



Fig. 6 Zero-cross voltage detection circuitry.

## FUNCTIONAL DESCRIPTION (continued)

## Timer/event counter

An 8-bit binary up-counter is provided. This can count external events, modulo- 32 machine cycles, or machine cycles directly. When used as a timer, the input to the counter is either the overflow or input of a 5 -bit prescaler. When used as an event counter, LOW to HIGH transitions on T1 (pin 13) are counted. The maximum rate at which the counter may be incremented is once every machine cycle ( 200 kHz for a $5 \mu \mathrm{~s}$ machine cycle). Fig. 7 illustrates the timer/event counter.


Fig. 7 Timer/event counter.

## Interrupt system

External events and real-time on-chip peripherals require servicing by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, single-level nested interrupt system is provided.
The MAB8422/8442 handles interrupts from three sources as follows:

- $\overline{\mathrm{INT} / \mathrm{TO} \text {; externally via pin } 9}$
- $\overline{\text { SIOINT; }}$; from the internal serial I/O port
- TCNT interrupt; from the internal timer/event counter.

Each interrupt vectors to a separate location in the program memory for its service program. Each source can be individually enabled or disabled. When more than one interrupt occurs simultaneously, their priority will be: (1) external, (2) serial I/O and, (3) timer/event counter. An additional external interrupt can be created using the timer/event counter interrupt.

## OSCILLATOR CIRCUITRY (see Fig. 8)

The clock frequency is determined by using the internal oscillator or by connecting an external clock to XTAL1. Where the internal oscillator is used the frequency is set by a crystal, a ceramic resonator or an inductor (each with associated capacitors) between XTAL1 and XTAL2. A machine cycle consists of 10 states, each state being 3 oscillator periods. The MAB8422/8442 has a dynamic logic, and therefore, for adequate refreshing the oscillator frequency must be at least 1 MHz .


1. Crystal-AT-cut
2. Ceramic resonator
$\mathrm{C}_{1}=\mathrm{C}_{2}=27 \mathrm{pF}$
$\mathrm{C}_{\mathrm{t}}$ is optional
$\mathrm{C}_{\mathrm{p}}<6,75 \mathrm{pF}$ (parasitic capacitance)

Fig. 8(a) Quartz crystal or ceramic resonator mode.
If the frequency has to be trimmed, then a trimmer capacitor $C_{t}$ should be connected in parallel with the fixed capacitor $\mathrm{C}_{\boldsymbol{1}}$.
Table 1 shows the LC values for timing generation with the LC oscillator.
Table 1 LC oscillator timing


Fig. 8(b) LC pi-network.


Drive XTAL1
Leave XTAL2 open
Driver may be high-speed CMOS or any TTL $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}<10 \mathrm{~ns}$

Fig. 9 External drive.

## RESET

A positive-going signal on the RESET input:

- sets the program counter to zero,
- selects location 0 of memory bank 0 , and register bank 0 ,
- sets the stack pointer to zero (000); pointing to RAM address 8,
- disables the interrupts (external), timer and serial I/O),
- stops the timer/event counter, then sets it to zero,
- sets the timer prescaler to modulo-32,
- resets the timer flag,
- sets all ports to logic ' 1 ' (input mode),
- sets ports P10/SDA and P11/SCL to the parallel part mode and disables the serial I/O.

Automatic reset at power-up may be obtained by connecting the RESET pin to $\mathrm{V}_{\mathrm{CC}}$ through a $1 \mu \mathrm{~F}$ capacitor C 1 , together with a diode to $\mathrm{V}_{\text {SS }}$ (cathode to RESET pin). This arrangement is satisfactory, if both the voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) rise time and the oscillator start-up time do not exceed either 1 or 10 ms respectively.
The power-on reset circuit is shown in Fig. 11; the input characteristics are shown in Fig. 12. At power-on the current drawn by RESET commences to charge the capacitor C 1 . The difference between this increasing capacitor voltage and $\mathrm{V}_{\text {CC }}$ is known as $\mathrm{V}_{\text {RESET }}$. The charging circuit is designed to hold $V_{\text {RESET }}$ above the lower threshold of a schmitt trigger arrangement, long enough to effect a complete reset. The minimum time required is the oscillator start-up time, plus two machine cycles.


Fig. 10 External reset.


Fig. 11 Power-on reset circuitry.


Fig. 12 Power-on reset input characteristics.

## INSTRUCTION SET

The instruction set consists of over 80 one and two byte instructions and is based on the MAB8048 instruction set. New instructions include those for serial I/O operation and memory bank selection. Program code efficiency is high because all ROM locations on a 256 byte page require only a single byte address.

Table 2 gives the instruction set of the MAB84X2 family and Table 3 shows the instruction map. The following symbols and abbreviations are used.



## DEVELOPMENT DATA



Table 2 Instruction set (continued)

| $\begin{aligned} & 0 \\ & 0 \\ & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & \text { CLR C } \\ & \text { CPL C } \end{aligned}$ | $\begin{array}{\|l\|} 97 \\ \text { A7 } \end{array}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | clear carry bit complement carry bit | $\begin{aligned} & \text { (C) } \leftarrow 0 \\ & \text { (C) } \leftarrow \text { NOT }(C) \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | INC Rr INC @Rr <br> DEC Rr DEC @Rr | $\begin{aligned} & 1^{*} \\ & 10 \\ & 11 \\ & C^{*} \\ & \mathrm{Co} \\ & \mathrm{C} 1 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | increment register by 1 increment RAM data, addressed by Rr, by 1 <br> decrement register by 1 <br> decrement RAM data, addressed by Rr, by 1 | $\begin{array}{ll} (R r) \leftarrow(R r)+1 & r=0-7 \\ ((R 0)) \leftarrow((R 0))+1 & \\ ((R 1)) \leftarrow((R 1))+1 & \\ (R r) \leftarrow(R r)-1 & \\ ((R O)) \leftarrow((R O))-1 & \\ ((R 1)) \leftarrow((R 1))-1 & \\ \hline \end{array}$ |  |
|  | JMP addr <br> JMPP @A <br> DJNZ Rr, addr <br> DJNZ @Rr, addr <br> JBb addr <br> JC addr <br> JNC addr <br> JZ addr <br> JNZ addr <br> JTO addr <br> JNTO addr <br> JT1 addr <br> JNT1 addr <br> JTF addr <br> JNTF addr | - 4 address <br> B3 <br> E* address <br> EO address <br> E1 address <br> - 2 address <br> F6 address <br> E6 address <br> C6 address <br> 96 address <br> 36 address <br> 26 address <br> 56 address <br> 46 address <br> 16 address <br> 06 address | $\begin{aligned} & 2 / 2 \\ & 1 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & \\ & \\ & \\ & \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \\ & 2 / 2 \end{aligned}$ | unconditional jump within a 2 K bank <br> indirect jump within a page decrement Rr by 1 and jump if not zero to addr decrement RAM data, addressed by Rr by 1 and jump if not zero to addr <br> jump to addr if Acc. bit $\mathrm{b}=1$ <br> jump to addr if $\mathrm{C}=1$ <br> jump to addr if $\mathrm{C}=0$ <br> jump to addr if $A=0$ <br> jump to addr if A is NOT zero <br> jump to addr if $\mathrm{TO}=1$ <br> jump to addr if $\mathrm{TO}=0$ <br> jump to addr if $\mathrm{T} 1=1$ <br> jump to addr if $\mathrm{T} 1=0$ <br> jump to addr if Timer Flag $=1$ <br> jump to addr if Timer Flag $=0$ |  | 4 |

## DEVELOPMENT DATA

|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MOV A, T <br> MOV T, A <br> STRT CNT <br> STRT T <br> STOP TCNT <br> EN TCNTI <br> DIS TCNTI | 42 <br> 62 <br> 45 <br> 55 <br> 65 <br> 25 <br> 35 | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | move timer/event counter contents to accumulator <br> move accumulator contents to timer/event counter <br> start event counter <br> start timer <br> stop timer/event counter <br> enable timer/event counter interrupt <br> disable timer/event counter interrupt | $\begin{aligned} & (A) \leftarrow(T) \\ & (T) \leftarrow(A) \end{aligned}$ |  |
| $\begin{aligned} & \text { 1 } \\ & 0 \\ & \text { ry } \\ & 2 \\ & 0 \\ & 0 \end{aligned}$ | EN I <br> DIS I <br> SEL RBO <br> SEL RB1 <br> SEL MBO <br> SEL MB1 <br> SEL MB2 <br> SEL MB3 | $\begin{aligned} & \text { O5 } \\ & 15 \\ & \text { C5 } \\ & \text { D5 } \\ & \text { E5 } \\ & \text { F5 } \\ & \text { A5 } \\ & \text { B5 } \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | enable external interrupt disable external interrupt select register bank 0 select register bank 1 select program memory bank 0 select program memory bank 1 select program memory bank 2 select program memory bank 3 | $\begin{aligned} & (\text { RBS }) \leftarrow 0 \\ & (\text { RBS }) \leftarrow 1 \\ & (M B F F 0) \leftarrow 0,(\text { MBFF1 }) \leftarrow 0 \\ & (M B F F 0) \leftarrow 1,(\text { MBFF1 }) \leftarrow 0 \\ & (M B F F 0) \leftarrow 0,(\text { MBFF1 }) \leftarrow 1 \\ & (M B F F 0) \leftarrow 1,(\text { MBFF1 } 1 \leftarrow 1 \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ |
|  | CALL addr <br> RET <br> RETR | $\triangle 4$ address <br> 83 <br> 93 | $2 / 2$ <br> $1 / 2$ $1 / 2$ | jump to subroutine <br> return from subroutine <br> return from interrupt and restore bits 4, 6, 7 of PSW |  | 6 6 6 |

Table 2 Instruction set (continued)

| 5 | IN A, Pp | $\begin{aligned} & 08 \\ & 09 \\ & 0 A \end{aligned}$ | 1/2 | input port p data to accumulator | $\begin{aligned} & (\mathrm{A}) \leftarrow(\mathrm{PO}) \\ & (\mathrm{A}) \leftarrow(\mathrm{P} 1) \\ & (\mathrm{A}) \leftarrow(\mathrm{P} 2) \end{aligned}$ | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \stackrel{\rightharpoonup}{5} \\ & \stackrel{2}{5} \\ & 5 \end{aligned}$ | OUTL Pp, A | $\begin{aligned} & 38 \\ & 39 \\ & 3 A \end{aligned}$ | 1/2 | output accumulator data to port $p$ | $\begin{aligned} & (P 0) \leftarrow(A) \\ & (P 1) \leftarrow(A) \\ & (P 2) \leftarrow(A) \end{aligned}$ |  |
| $\begin{aligned} & \stackrel{0}{3} \\ & \underset{د}{山} \end{aligned}$ | ANL Pp, \#data | 98 data <br> 99 data <br> 9 A data | $2 / 2$ | AND port $p$ data with immediate data | $(\mathrm{PO}) \leftarrow(\mathrm{PO})$ AND data $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1)$ AND data $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2)$ AND data |  |
| $$ | ORL Pp, \#data | 88 data <br> 89 data <br> 8A data | $2 / 2$ | OR port p data with immediate data | $(\mathrm{PO}) \leftarrow(\mathrm{PO})$ OR data $(P 1) \leftarrow(P 1)$ OR data $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2)$ OR data |  |
|  | OUTLPO,A | 90 | 1/2 | Output accumulator data to port $\phi$ | $(\mathrm{PO}) \leftarrow(\mathrm{A})$ | 8 |
|  | $\begin{aligned} & \text { EN SI } \\ & \text { DIS SI } \end{aligned}$ | $\begin{aligned} & 85 \\ & 95 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | enable serial I/O interrupt disable serial I/O interrupt |  |  |
|  | NOP | 00 | 1/1 | no operation |  |  |

Notes to Table 2.

1. PSW CY, AC
affected

* : 8, 9, A, B, C, D, E, F

2. PSW CY affected

- : 0, 2, 4, 6, 8, A, C, E

3. PSW PS affected

- : $1,3,5,7,9, B, D, F$

4. Execution of JTF and JNTF instructions resets the Timer Flag (TF).
5. PSW RBS
affected
6. PSW SP $0, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ affected
7. $(A)=1111$ P23, P22, P21, P20.
8. Only for software-transfer from the MAB8021.

## DEVELOPMENT DATA



## ABSOLUTE MAXIMUM RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Input voltage on any pin with respect to ground ( $\mathrm{V}_{\mathrm{SS}}$ )
Total power dissipation
Input/output current for all pins except port 0
Input/output current for port 0
Storage temperature
Operating temperature


## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current |  |  |  |  |  |
| MAB8422/42 | ICC | - | 70 | mA | at $0^{\circ} \mathrm{C}$ |
| MAF8422/42 | ${ }^{\text {I C C }}$ | - | 90 | mA | at $-40^{\circ} \mathrm{C}$ |
| MAF84A22/42 | ${ }^{\text {ICC }}$ | - | 90 | mA | at $-40^{\circ} \mathrm{C}$ |
| Inputs |  |  |  |  |  |
| Input voltage LOW (except P10/SDA and P11/SCL) | $\mathrm{V}_{\text {IL }}$ | -0,5 | 0,8 | V |  |
| Input voltage LOW (P10/SDA and P11/SCL) | VIL1 | -0,5 | 1,5 | V |  |
| Input voltage HIGH all inputs except XTAL 1, P10/SDA and P11/SCL | $\mathrm{V}_{\text {IH }}$ | 2,0 | $\left\lvert\, \begin{aligned} & V_{\mathrm{CC}} \\ & +0,5 \end{aligned}\right.$ | V |  |
| Input voltage HIGH to XTAL 1, P10/SDA and P11/SCL | $\mathrm{V}_{\mathrm{IH} 1}$ | 3,0 | $\begin{aligned} & V_{c c} \\ & +0,5 \end{aligned}$ | $V$ |  |
| Outputs |  |  |  |  |  |
| Output voltage LOW (PO only) | VOL |  | 1,0 | V | $\mathrm{I}^{\mathrm{OL}}=10 \mathrm{~mA}$ |
| Output voltage LOW (P10/SDA and P11/SCL) | Vol1 |  | 0,45 | V | $\mathrm{I}^{\mathrm{OL}}=5 \mathrm{~mA}$ |
| Output voltage LOW (P0 and P2) | $\mathrm{V}_{\text {OL2 }}$ |  | 0,45 | V | $\mathrm{I}_{\mathrm{OL}}=1,6 \mathrm{~mA}$ |
| Output voltage HIGH (all outputs unless open-drain) | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| Output leakage current | $\pm{ }^{1} \mathrm{OL}$ |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}>\mathrm{V}_{1}>\mathrm{V}_{\text {SS }}$ |

## A.C. CHARACTERISTICS

| parameter | symbol | min. | max. | unit |
| :--- | :--- | :--- | :--- | :--- |
| Frequency |  |  |  |  |
| MAB/MAF8422/42 | ${ }^{\text {YXTAL }}$ | 1 | 6 | MHz |
| MAF84A22/42 | ${ }^{\text {XXTAL }}$ | 1 | 5 | MHz |
| Cycle time | ${ }^{\text {TCY }}$ | 5 | 30 | $\mu \mathrm{~s}$ |
| MAB/MAF8422/42 | ${ }^{\text {C }} \mathrm{CY}$ | 6 | 30 | $\mu \mathrm{~s}$ |
| MAF84A22/42 |  |  |  |  |

T1 ZERO-CROSS CHARACTERISTICS
$\mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$

| parameter | symbol | $\min$. | $\max$. | unit | conditions |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Zero-cross detection <br> input (T1) peak-to-peak <br> Zero-cross accuracy <br> Zero-cross detection <br> input frequency (T1) | $\mathrm{V}_{\mathrm{ZX}}(\mathrm{p}-\mathrm{p})$ | 1 | 3 | V | a.c. coupled, $\mathrm{C}=1 \mu \mathrm{~F}$ |

Purchase of Philips' $\left.\right|^{2} \mathrm{C}$ components conveys a license under the Philips $\left.\right|^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specification defined by Philips.

## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The PCB80C51 family of single-chip 8-bit microcontrollers is manufactured in an advanced CMOS process. The family consists of the following members:

- PCB80C31BH: ROM-less version of the PCB80C51BH
- PCB80C51BH: 4 K bytes mask-programmable ROM, 128 bytes RAM

In the following, the generic term "PCB80C51BH" is used to refer to both family members.
The device provides hardware features, architectural enhancements and new instructions to function as a controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.
The PCB80C51BH contains a non-volatile $4 \mathrm{~K} \times 8$ read-only program memory (not ROM-less version); a volatile $128 \times 8$ read/write data memory; 32 I/O lines; two 16 -bit timer/event counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and timing circuits. For systems that require extra capability, the PCB80C51BH can be expanded using standard TTL compatible memories and logic.
The PCB80C31BH/80C51BH has two software selectable modes of reduced activity for further power reduction - Idle and Power Down.
The Idle modes freezes the CPU while allowing the RAM, timers, serial port and interrupt system to continue functioning.
The Power Down mode saves the RAM contents but freezes the oscillator causing all other chip functions to be inoperative.

The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of 255 instructions; $44 \%$ one-byte, $41 \%$ two-byte and $15 \%$ three-byte. With a 12 MHz crystal for example, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ and $40 \%$ in $2 \mu \mathrm{~s}$. Multiply and divide instructions require $4 \mu \mathrm{~s}$. Multiply, divide, subtract and compare are among the many instructions added to the standard PCB80C48 instruction set. Software development to be announced: PCB85C51 in piggy-back.

## Features

- $4 \mathrm{~K} \times 8$ ROM (80C51BH only), $128 \times 8$ RAM
- Four 8-bit ports, 32 I/O lines
- Two 16-bit timer/event counters
- Full-duplex serial port
- External memory expandable to 128 K , external ROM up to 64 K and/or external RAM up to 64 K
- Boolean processing
- 218 bit-addressable locations
- On-chip oscillator
- Five-source interrupt structure with two priority levels
- 58\% of instructions executed in $1 \mu \mathrm{~s}$; multiply and divide in $4 \mu \mathrm{~s}$; all others executed in $2 \mu$ s (at 12 MHz clock)
- Enhanced architecture with: non-page-oriented-instructions direct addressing four 8-byte +1 -byte register banks stack depth up to 128-bytes multiply, divide, subtract and compare instructions.
- Available as

PCB80C31/51BH with 1,2 to 16 MHz
PCF80C31/51BH with 1,2 to 12 MHz

## PACKAGE OUTLINES

PCB/PCF80C31/51BHP: 40-lead DIL; plastic (SOT-129).
PCB/PCF80C31/51BHWP: 44-lead PLCC; plastic, leaded-chip-carrier (SOT-187A).


Fig. 1 Block diagram.

| type | temp. range | frequency range | ICC max at 5,5 V |
| :--- | :--- | :--- | :--- |
| PCB80C51BH <br> PCB80C31BH | $0-70^{\circ} \mathrm{C}$ | $1,2-16 \mathrm{MHz}$ | $23 \mathrm{~mA}^{*}$ |
| PCF80C51BH <br> PCF80C31BH | $-40-+85^{\circ} \mathrm{C}$ | $1,2-12 \mathrm{MHz}$ | $18 \mathrm{~mA}^{*}$ |

[^3]

Fig. 2 Functional diagram.


Fig. 3a Pinning diagram for PCB80C31BH/51BHP.
Fig. 3b Pinning diagram for PCB80C31BH/51BHWP.

## PINNING (PCB80C31BH/51BHP)

1-8 P1.0-P1.7 Port 1: 8-bit quasi-bidirectional I/O port.
Port 1 can sink/source one TTL ( $=4$ LS TTL) input. It can drive CMOS inputs without external pull-ups.
$9 \quad$ RST

10-17 P3.0-P3.7 Port 3: 8-bit quasi-bidirectional I/O port with internal pull-ups. It also serves the following alternative functions:

Port pin
P3.0 RXD/data: serial port receiver data input (asynchronous) or data input/output (synchronous)
P3.1 TXD/clock: serial port transmitter data output (asynchronous) or clock output (synchronous)
P3.2 $\overline{\text { INTO }}$ external interrupt 0 or gate control input for timer/event counter 0
P3.3 $\overline{\text { INT1 }}$ : external interrupt 1 or gate control input for timer/event counter 1

P3.4 T0 : external input for timer/event counter 0
P3.5 T1 : external input for timer/event counter 1
P3.6 $\overline{\text { WR }}$ : external data memory write strobe
P3.7 $\overline{\mathbf{R D}}$ : external data memory read strobe
Operation of an alternative function is determined by the relevant output latch programmed to logic 1 . Port 3 can sink/source one TTL input. It can drive CMOS inputs without external pull-ups.
18 XTAL 2 Crystal input 2: output of the inverting amplifier that forms the oscillator. Left open-circuit when an external oscillator is used (see figures 8 and 9 ).
19 XTAL 1 Crystal input 1: input to the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external oscillator signal when an external oscillator is used (see figures 8 and 9 ).
$\overline{E A} \quad$ External Access input: When $\overline{E A}$ is held at a TTL high level the CPU executes out of the internal Program Memory (ROM), provided the Program Counter is less than 4096. When $\overline{E A}$ is held at a TTL low level, the CPU executes out of external Program Memory. $\overline{E A}$ is not allowed to float.
32-39 P0.7-P0.0 Port 0:8-bit open drain bidirectional I/O port. It is also the multiplexed low-order address and data bus during accesses to external memory (during these accesses it activates internal pull-ups). Port 0 can sink/source eight TTL inputs.
$40 \quad V_{C C}$
Power supply: +5 V power supply pin during normal operation, Idle mode and Power Down mode.

## FUNCTIONAL DESCRIPTION

## General

The PCB80C51BH is a stand-alone high-performance microcontroller designed for use in real-time applications such as instrumentation, industrial control and intelligent computer peripherals.
The device provides hardware features, architectural enhancements and new instructions to function as a controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.
The PCB80C31BH is a control-oriented CPU without on-chip program memory. It can address 64 K bytes of external program memory in addition to 64 K bytes of external data memory. The PCB80C51BH is a PCB80C31BH with the lower 4 K bytes of program memory filled with on-chip mask programmable ROM. For systems requiring extra capability, the PCB80C51BH can be expanded using standard memories and peripherals.
The two pin-compatible versions of this component reduce development problems to a minimum and provide maximum flexibility. The PCB80C51BH is for low-cost, high volume production and the PCB80C31BH for applications requiring the flexibility of external program memory which can be easily modified and updated in the field.
The PCB80C51BH contains a non-volatile $4 \mathrm{~K} \times 8$ read-only program memory; a volatile $128 \times 8$ read/write data memory; 32 I/O lines; two 16 -bit timer/event counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and timing circuits.

## Central processing unit

The central processing unit (CPU) manipulates operands in four memory spaces. These are the 64 K byte external data memory, 384 -byte internal data memory, the 64 K -byte internal and external program memory and 16 -bit program counter spaces. The internal data memory address space is sub-divided into the 256 -byte internal data RAM and 128 -byte special function register (SFR) address spaces, as shown in Fig. 4.


Fig. 4 Memory map.

The internal data RAM contains four register banks (each with eight registers), 128 addressable bits, and the stack. The stack depth is limited by the available internal data RAM and its location is determined by the 8 -bit stack pointer. All registers except the program counter and the four 8 -register banks reside in the special function register address space. These memory mapped registers include arithmetic registers, pointers, I/O ports, interrupt system registers, timers and serial port. There are 128 addressable bite locations in the SFR address space.
The PCB80C51BH contains 128 bytes of internal data RAM and 20 special function registers. It provides a non-paged program memory address space to accommodate relocatable code. Conditiona! branches are performed relative to the program counter. The register-indirect jump permits branching relative to a 16 -bit base register with an offset provided by an 8 -bit index register. 16 -bit jumps and calls permit branching to any location in the contiguous 64 K program memory address space.
The PCB80C51BH has five methods for addressing source operands:

- Register.
- Direct.
- Register-Indirect.
- Immediate.
- Base-Register-plus Index-Register-Indirect.

The first three methods can be used for addressing destination operands. Most instructions have a "destination/source" field that specifies the data type, addressing methods and operands involved. For operations other than moves, the destination operand is also a source operand.
Access addressing is as follows:

- Registers in the four 8-register banks through Register, Direct, or Register-Indirect.
- 128 bytes of internal data RAM through Direct or Register-Indirect.
- Special function registers through Direct.
- External data memory through Register-Indirect.
- Program memory look-up tables through Base-Register-plus Index-Register-Indirect.

The PCB80C51BH is classified as an 8-bit device since the internal ROM, RAM, Special Function Registers (SFR), Arithmetic Logic Unit (ALU), and external data bus are each 8 -bits wide. It performs operations on bit, nibble, byte and double-byte data types.
Facilities are available for byte transfer, logic, and integer arithmetic operations, Data transfer, logic, and conditional branch operations can be performed directly on Boolean variables to provide excellent bit handling.

## I/O facilities

The PCB80C51BH has 32 I/O lines treated as 32 individual addressable bits and as four parallel 8 -bit addressable ports. Ports $0,1,2$ and 3 perform the following alternate functions:

- Port 0; provides the multiplexed low-order address and data bus used for expanding the PCB80C51BH with standard memories and peripherals.
- Port 2; provides the high-order address bus when expanding the PCB80C51BH with external program memory or more than 256 bytes of external data memory.
- Port 3; pins can be configured individually to provide:
external interrupt requests inputs
counter inputs
serial port receiver input and transmitter output
control signals to READ and WRITE to external data memory
The generation or use of a Port 3 pin as an alternate function is carried out automatically by the PCB80C51BH provided the pin is loaded with a HIGH content.


Fig. 5 I/O buffers in the PCB80C51BH (Ports 1, 2 and 3).

## Timer/event counters

The PCB80C51BH contains two 16 -bit registers, Timer 0 and Timer 1 , that can be used as timers or event counters to carry out the following functions:

- Measure time intervals and pulse durations.
- Count events.
- Generate interrupt requests.

Each timer/event counter can be programmed independently to operate in three modes:

- Mode 0; 8-bit timer or 8-bit counter each with divide by 32 prescaler.
- Mode 1; 16-bit time-interval or event counter.
- Mode 2; 8-bit time-interval or event counter with automatic reload upon overflow.

Counter 0 can be programmed to operate in an additional mode as follows:

- Mode 3; one 8 -bit time-interval or event counter and one 8 -bit time-interval counter.

When counter 0 is in Mode 3, counter 1 can be programmed to operate in Modes 0,1 or 2 but cannot set an interrupt request flag or generate an interrupt. However the overflow from counter 1 can be used to pulse the serial Port transmission-rate generator.
The frequency handling range of these counters with a 12 MHz crystal for example is as follows:

- Up to 1 MHz when programmed for an input that is a division by 12 of the oscillator frequency.
- 0 Hz to an upper limit of 150 kHz to $0,5 \mathrm{MHz}$ when programmed for external inputs.

Both internal and external inputs can be gated to the counter by a second external source for directly measuring pulse durations.
The counters are started and stopped under software control. Each one sets its interrupt request flag when it overflows from all 1 's to all 0 's (or automatic reload value).

## On-chip peripheral functions

In addition to the CPU and memories, an interrupt system, extensive I/O facilities, and several peripheral functions are integrated on-chip to relieve the CPU of repetitious, complicated or time-critical tasks and to permit stringent real-time control of external system interfaces. The 1/O facilities include the I/O pins, parallel ports, bidirectional address/data bus and the serial port for I/O expansion. The CPU peripheral functions integrated on-chip are the two 16 -bit timer/event counters and the serial port.

## Idle and Power-down operation (see Fig. 6)

The Power-down operation freezed the oscillator. The Idle mode operation allows the interrupt, serial port and timer blocks to continue to function while the clock to the CPU is halted.


Fig. 6 Internal Idle and Power-down clock configuration.

## Power control register (PCON)

These special modes are activated by software via the Special Function Register PCON. Its hardware address is 87 H . PCON is not bit addressable.


| SMOD | - | - | - | GF1 | GFO | PD | IDL |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| symbol | position | name and function |
| :--- | :--- | :--- |
| SMOD | PCON.7 | Double Baud rate bit <br> when set to logic 1 the baud rate is doubled when the serial port is <br> being used in either modes 1, 2 or 3 |
| - | PCON.6 | (reserved) |
| - | PCON.5 | (reserved) |
| (reserved) |  |  |
| GF1 | PCON.4 | PCON.3 |
| general-purpose flag bit |  |  |
| GF0 | PCON.2 | general-purpose flag bit <br> Power-down bit <br> setting this bit activates power-down operation |
| PD | PCON.1 | Idle mode bit <br> setting this bit activates the idle mode operation |
| IDL | PCON.0 |  |

If logic 1s are written to PD and IDL at the same time, PD takes precedence. The reset value of PCON is ( $0 \times X \times 0000$ ).

## Idle mode

The instruction that sets PCON. 0 is the last instruction executed in the normal operating mode before Idle mode is activated. Once in the Idle mode, the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM and all other registers maintain their data during Idle mode. The status of the external pins during Idle mode is shown in Table 1.
There are two ways to terminate the Idle mode:-
Activation of any enabled interrupt will cause PCON. 0 to be cleared by hardware terminating Idle mode. The interrupt is serviced, and following return from interrupt instruction RETI, the next instruction to be executed will be the one which follows the instruction that wrote a logic 1 to PCON.0. The flag bits GF0 and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the instruction that writes the PCON. 0 can also set or clear one or both flag bits. When Idle mode is terminated by an interrupt, the service routine can examine the status of the flags bits.
The second way of terminating the Idle mode is with a hardware reset. Since the oscillator is still running, the hardware reset is required to be active for two machine cycles ( 24 oscillator periods) to complete the reset operation.

## Power-down mode

The instruction that sets PCON. 1 is the last executed prior to going into the Power-down mode. Once in Power-down mode, the oscillator is stopped. Only the contents of the on-chip RAM are preserved. The Special Function Registers are not saved. A hardware reset is the only way of exiting the Powerdown mode.

In the Power-down mode, $V_{\text {CC }}$ may be reduced to minimize circuit power consumption. The voltage must not be reduced until the Power-down mode is entered, but must be restored before the hardware reset is applied which will free the oscillator. Reset should not be released until the oscillator has restarted and stabilized.
The status of the external pins during Power-down mode is shown in Table 1. If the Power-down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a logic 1, the port pin is held HIGH during the Powerdown mode by the strong pull-up transistor p1(see Fig. 5).

Table 1 Status of the external pins during Idle and Power-down modes.

| mode | memory | ALE | $\overline{\text { PSEN }}$ | Port 0 | Port 1 | Port 2 | Port 3 |
| :--- | :--- | :---: | :---: | :--- | :--- | :--- | :--- |
| Idle | internal | 1 | 1 | port data | port data | port data | port data |
| Idle | external | 1 | 1 | floating | port data | address | port data |
| Power-down | internal | 0 | 0 | port data | port data | port data | port data |
| Power-down | external | 0 | 0 | floating | port data | port data | port data |



Fig. 7 Interrupt system.

## Interrupt system (see Fig. 7)

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, two-priority-level, nested interrupt system is provided. Interrupt response latency is from $3 \mu$ s to $7 \mu$ s when using a 12 MHz crystal.

The PCB80C51BH acknowledges interrupt requests from five sources as follows:

- $\overline{\mathrm{INTO}}$ and $\overline{\mathrm{INT}}$; externally via pins 12 and 13 respectively.
- Timer 0 and Timer 1; from the two internal counters.
- Serial Port; from the internal serial I/O port.

Each interrupt vectors to a separate location in program memory for its service program.
Each source can be individually enabled or disabled and can be programmed to a high or low priority level. Also all enabled sources can be globally disabled or enabled. Both external interrupts can be programmed to be level-activated or transition-activated and is active LOW to allow "wire-ORing" of several interrupt sources to the input pin.

## Oscillator circuitry

The oscillator circuitry of the PCB80C51BH is a single-stage inverting amplifier in a Pierce oscillator configuration. The circuitry between XTAL 1 and XTAL 2 is basically an inverter biased to the transfer point. Either a crystal or ceramic resonator can be used as the feedback element to complete the oscillator circuitry. Both are operated in parallel resonance. XTAL 1 ( pin 19 ) is the high gain amplifier input, and XTAL 2 (pin 18) is the output (see Fig. 8).

To drive the PCB80C51BH externally, XTAL 1 is driven from an external source and XTAL 2 left open-circuit (see Fig. 9).


Fig. 8 PCB80C51BH oscillator circuit.


Fig. 9 Driving the PCB80C51BH from an external source.

## Reset circuitry

The reset circuitry for the PCB80C51BH is connected to the reset pin, RST, as shown in Fig. 10. A Schmitt trigger is used at the input for noise rejection. The output of the Schmitt trigger is sampled by the reset circuitry every machine cycle.


Fig. 10 Reset configuration at RST.
A reset is accomplished by holding the RST pin HIGH for at least two machine cycles ( 24 oscillator periods), while the oscillator is running. The CPU responds by executing an internal reset. It also configures the ALE and $\overline{\text { PSEN }}$ pins as inputs. (They are quasi-bidirectional.)

The internal reset is executed during the second cycle in which RST is HIGH and is repeated every cycle until RST goes LOW. It leaves the internal registers as follows:

|  | Register | Content |
| :---: | :---: | :---: |
|  | PC | OOOH |
|  | ACC | OOH |
|  | B | OOH |
|  | PSW | OOH |
|  | SP | 07H |
|  | DPTR | 0000 H |
|  | PO - P3 | OFFH |
|  | IP | ( $\mathrm{XX000000}$ ) |
|  | IE | (0X000000) |
|  | TMOD | OOH |
|  | TCON | OOH |
|  | THO | OOH |
|  | TLO | OOH |
|  | TH1 | OOH |
|  | TL1 | OOH |
|  | SCON | OOH |
| ¢ | SBUF | Intermediate |
| $\stackrel{E}{6}$ | PCON | (0XXX0000) |

The internal RAM is not affected by reset. When $V_{C C}$ is turned on, the RAM content is indeterminate.

## Power-on reset (see Fig. 11)

When $\mathrm{V}_{\mathrm{CC}}$ is turned on, and provided its rise-time does not exceed 10 ms , an automatic reset can be obtained by connecting the RST pin to $\mathrm{V}_{\mathrm{CC}}$ via a $10 \mu \mathrm{~F}$ capacitor. When the power is switched on, the current drawn by RST is the difference between $\mathrm{V}_{\mathrm{C}}$ and the capacitor voltage, and decreases from $V_{\mathrm{CC}}$ as the capacitor charges through the internal resistor ( $\mathrm{R}_{\mathrm{RST}}$ ) to ground. The larger the capacitor, the more slowly $\mathrm{V}_{\text {RST }}$ decreases. $\mathrm{V}_{\text {RST }}$ must remain above the lower threshold of the Schmitt trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles.


Fig. 11 Power-on reset.

To ensure a correct start-up at power-on, the voltage $V_{C C}$ and RST must come up at the same time.

## INSTRUCTION SET

The PCB80C51BH uses a powerful instruction set to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Reassigned opcodes add new high-power operations and permit new addressing modes to make old operations more orthogonal when compared to the 8048 family.
The instruction set consists of 49 single-byte, 45 two-byte and 17 three-byte instructions. When using a 16 MHz oscillator, 64 instructions execute in 750 ns and 45 instructions execute in $15 \mu \mathrm{~s}$. Multiply and divide instructions execute in $3 \mu$ s.

Table 2 Instruction set description.

| mnemonic |  | description | bytes/ cycles | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Arithmetic operation |  |  |  |  |
| ADD | A, Rr | Add register to A | 1 | 2* |
| ADD | A, direct | Add direct byte to A | 2 | 25 |
| ADD | A,@Ri | Add indirect RAM to $A$ |  | 26, 27 |
| ADD | A, \#data | Add immediate data to A | 2 | 24 |
| ADDC | A, Rr | Add register to A with carry flag | 1 | 3* |
| ADDC | A, direct | Add direct byte to A with carry flag |  | 35 |
| ADDC | A,@Ri | Add indirect RAM to A with carry flag | 1 | 36, 37 |
| ADDC | A,\#data | Add immediate data to A with carry flag | 2 | 34 |
| SUBB | A, Rr | Subtract register from A with borrow |  | 9* |
| SUBB | A, direct | Subtract direct byte from A with borrow |  | 95 |
| SUBB | A,@Ri | Subtract indirect RAM from $A$ with borrow |  | 96, 97 |
| SUBB | A, \#data | Subtract immediate data from A with borrow | 2 | 94 |
| INC | A | Increment A |  | 04 |
| INC | Rr | Increment register | 1 | 0* |
| INC | direct | Increment direct byte |  | 05 |
| INC | @Ri | Increment indirect RAM |  | 06, 07 |
| DEC | A | Decrement A | 1 | 14 |
| DEC | Rr | Decrement register |  | 1* |
| DEC | direct | Decrement direct byte | 21 | 15 |
| DEC | @Ri | Decrement indirect RAM | 11 | 16, 17 |
| INC | DPTR | Increment data pointer |  | A3 |
| MUL | $A B$ | Multiply A \& B |  | A4 |
| DIV | $A B$ | Divide A by B |  | 84 |
| DA | A | Decimal adjust A |  | D4 |


| mnemonic |  | description | bytes/ cycles | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Logic operations |  |  |  |  |
| ANL | A, Rr | AND register to $A$ | 11 | 5* |
| ANL | A,direct | AND direct byte to $A$ | 21 | 55 |
| ANL | A,@Ri | AND indirect RAM to A |  | 56,57 |
| ANL | A, \#data | AND immediate data to $A$ |  | 54 |
| ANL | direct,A | AND A to direct byte |  | 52 |
| ANL | direct,\#data | AND immediate data to direct byte | 32 | 53 |
| ORL | A, Rr | OR register to A |  | 4* |
| GRL | A,direct | OR direct byte to $A$ |  | 45 |
| ORL | A,@Ri | OR indirect RAM to $A$ | 11 | 46, 47 |
| ORL | A, \#data | OR immediate data to $A$ |  | 44 |
| ORL | direct, A | OR A to direct byte |  | 42 |
| ORL | direct,\#data | OR immediate data to direct byte | 32 | 43 |
| XRL | A, Rr | Exclusive-OR register to $A$ |  | 6* |
| XRL | A, direct | Exclusive-OR direct byte to $A$ |  | 65 |
| XRL | A,@Ri | Exclusive-OR indirect RAM to $A$ |  | 66, 67 |
| XRL | A,\#data | Exclusive-OR immediate data to $A$ | 21 | 64 |
| XRL | direct, A | Exclusive-OR to direct byte |  | 62 |
| XRL | direct,\#data | Exclusive-OR immediate data to direct byte |  | 63 |
| CLR | A | Clear A | 11 | E4 |
| CPL | A | Complement A | 11 | F4 |
| RL | A | Rotate A left | 11 | 23 |
| RLC | A | Rotate A left through the carry flag |  | 33 |
| RR | A | Rotate A right | 11 | 03 |
| RRC | A | Rotate A right through the carry flag | 11 | 13 |
| SWAP | A | Swap nibbles within A |  | C4 |

INSTRUCTION SET (continued)

| mnemonic |  | description | bytes/ cycles | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Data transfer |  |  |  |  |
| MOV | A, Rr | Move register to $A$ | 11 | E* |
| MOV | A,direct ** | Move direct byte to $A$ |  | E5 |
| MOV | A,@Ri | Move indirect RAM to $A$ | $1 \begin{array}{ll}1 & 1\end{array}$ | E6, E7 |
| MOV | A, \#data | Move immediate data to $A$ |  | 74 |
| MOV | Rr,A | Move A to register |  | F* |
| MOV | Rr,direct | Move direct byte to register | 22 | A* |
| MOV | Rr,\#data | Move immediate data to register |  | 7* |
| MOV | direct, A | Move A to direct byte | 2 | F5 |
| MOV | direct, Rr | Move register to direct byte | 22 | 8* |
| MOV | direct, direct | Move direct byte to direct |  | 85 |
| MOV | direct,@Ri | Move indirect RAM to direct byte | 2 | 86, 87 |
| MOV | direct,\#data | Move immediate data to direct byte | 32 | 75 |
| MOV | @Ri,A | Move A to indirect RAM | $\begin{array}{ll}1 & 1\end{array}$ | F6, F7 |
| MOV | @Ri, direct | Move direct byte to indirect RAM |  | A6, A7 |
| MOV | @Ri,\#data | Move immediate data to indirect RAM | 21 | 76, 77 |
| MOV | DPTR,\#data 16 | Load data pointer with a 16-bit constant | 32 | 90 |
| MOVC | A,@A+DPTR | Move code byte relative to DPTR to A | 12 | 93 |
| MOVC | A,@A+PC | Move code byte relative to PC to A | 12 | 83 |
| movx | A,@Ri | Move external RAM (8-bit address) to A | 12 | E2, E3 |
| MOVX | A,@DPTR | Move external RAM (16-bit address) to A | 12 | E0 |
| MOVX | @Ri,A | Move A to external RAM (8-bit address) | 12 | F2, F3 |
| MOVX | @DPTR,A | Move A to external RAM (16-bit address) | 12 | F0 |
| PUSH | direct | Push direct byte onto stack | 22 | C0 |
| POP | direct | Pop direct byte from stack | 22 | D0 |
| XCH | A, Rr | Exchange register with A | 1 | C* |
| XCH | A, direct | Exchange direct byte with $A$ | 21 | C5 |
| XCH | A,@Ri | Exchange indirect RAM with $A$ | 11 | C6, C7 |
| XCHD | A,@Ri | Exchange LOW-order digit indirect RAM with A | 11 | D6, D7 |

[^4]| mnemon |  | description | bytes/ <br> cycles | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Boolean variable manipulation |  |  |  |  |
| CLR | C | Clear carry flag | 11 | C3 |
| CLR | bit | Clear direct bit | 21 | C2 |
| SETB | C | Set carry flag | 11 | D3 |
| SETB | bit | Set direct bit | 21 | D2 |
| CPL | C | Complement carry flag | 11 | B3 |
| CPL | bit | Complement direct bit | 21 | B2 |
| ANL | C,bit | AND direct bit to carry flag | 22 | 82 |
| ANL | C,/bit | AND complement of direct bit to carry flag | 22 | B0 |
| ORL | C,bit | OR direct bit to carry flag | 22 | 72 |
| ORL | C,/bit | OR complement of direct bit to carry flag | 22 | A0 |
| MOV | C,bit | Move direct bit to carry flag | 21 | A2 |
| MOV | bit, C | Move carry flag to direct bit | 22 | 92 |
| Program and machine control |  |  |  |  |
| ACALL | addr11 | Absolute subroutine call | 22 | -1addr |
| I_CALL | addr16 | Long subroutine call | 32 | 12 |
| RET |  | Return from subroutine | 12 | 22 |
| RETI |  | Return from interrupt | 12 | 32 |
| AJMP | addr 11 | Absolute jump | 22 | 41addr |
| LJMP | addr16 | Long jump | 32 | 02 |
| SJMP | rel | Short jump (relative address) | 22 | 80 |
| JMP | @A+DPTR | Jump indirect relative to the DPTR | 12 | 73 |
| JZ | rel | Jump if $A$ is zero | 22 | 60 |
| JNZ | rel | Jump if $A$ is not zero | 22 | 70 |
| JC | rel | Jump if carry flag is set | 22 | 40 |
| JNC | rel | Jump if no carry flag | 22 | 50 |
| JB | bit,rel | Jump if direct bit is set | 32 | 20 |
| JNB | bit,rel | Jump if direct bit is not set | 32 | 30 |
| JBC | bit,rel | Jump if direct bit is set and clear bit | 32 | 10 |
| CJNE | A, direct,rel | Compare direct to $A$ and jump if not equal | 32 | B5 |
| CJNE | A,\#data,rel | Compare immediate to $A$ and jump if not equal | 32 | B4 |
| CJNE | Rr,\#data, rel | Compare immed. to reg. and jump if not equal | 32 | B* |
| CJNE | @Ri,\#data, rel | Compare immed. to ind. and jump if not equal | 32 | B6, B7 |
| DJNZ | Rr,rel | Decrement register and jump if not zero | 22 | D* |
| DJNZ | direct,rel | Decrement direct and jump if not zero | 32 | D5 |
| NOP |  | No operation | 11 | 00 |

## Notes to Table 2

Data addressing modes
$\mathrm{Rr} \quad$ Working register R0-R7.
direct $\quad 128$ internal RAM locations and any special function register (SFR).
@Ri Indirect internal RAM location addressed by register R0 or R1 of the actual register bank.
\#data 8-bit constant included in instruction.
\#data16 16-bit constant included as bytes 2 and 3 of instruction.
bit direct addressed bit in internal RAM or SFR.
addr16 16-bit destination address. Used by LCALL and LJMP. The branch will be anywhere within the 64 K-byte program memory address space.
addr11 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 K-byte page of program memory as the first byte of the following instruction.
re1 Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is -128 to +127 bytes relative to first byte of the following instruction.

Hexadecimal opcode cross-reference to Table 3

* : 8, 9, A, B, C, D, E, F.
- : 11, 31, 51, 71, 91, B1, D1, F1.

A: $01,21,41,61,81, A 1, C 1, E 1$.

Table 3 Instruction map

- first hexadecimal chacter of opcode



## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134) Input voltage on any pin with respect to ground ( $V_{\mathrm{SS}}$ )
Input, output current
Total power dissipation
Storage temperature range
Operating ambient temperature range

| $V_{1}$ | $-0,5$ to $+6,5$ |  |
| :---: | :---: | :---: |
| $\pm 1.10$ | max. | 5 |
| $\mathrm{P}_{\text {tot }}$ | max. |  |
| $\mathrm{T}_{\text {stg }}$ | -65 to +150 |  |
| Tamb | 70 |  |

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}, 0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified

| parameter | symbol | min . | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4,5 | 5,5 | V |  |
| Supply current |  |  |  |  |  |
| operating (note 1) | ${ }^{\text {ICC }}$ | - | 18* | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz} \mathrm{PCF80C51BH}$ |
|  | ${ }^{\text {I CC }}$ | - | 23* | mA | $\mathrm{f}_{\mathrm{CLK}}=16 \mathrm{MHz} \mathrm{PCB80C51BH}$ |
| idle mode (note 2) | ${ }^{\text {ICC }}$ | - | 10* | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz}$ |
| Power-down current | IPD | - | 100* | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=2 \mathrm{~V}$ (note 3 ) |
| Inputs |  |  |  |  |  |
| LOW level input voltage (except $\overline{E A}$ ) | $V_{\text {IL }}$ | -0,5 | $0,2 V_{C C}-0,1$ | V |  |
| LOW level input voltage (EA) | VIL1 | -0,5 | $0,2 V_{C C}-0,3$ | V |  |
| HIGH level input voltage (except XTAL 1, RST | $\mathrm{V}_{\text {IH }}$ | $0,2 V_{C C}+0,9$ | $\mathrm{V}_{\text {CC }}+0,5$ | V |  |
| HIGH level input voltage (XTAL 1, RST) | $\mathrm{V}_{1 \mathrm{H} 1}$ | $0,7 \mathrm{~V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}+0,5$ | V |  |
| Input current logic 0 <br> (Ports 1, 2 and 3) | $-\mathrm{ILL}$ | - | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=0,45 \mathrm{~V}$ |
| Input current logic 1 to 0 transition (Ports 1, 2 and 3) | ${ }^{-1} \mathrm{TL}$ | - | 650 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=2 \mathrm{~V}$ |
| Input leakage current (Port 0, EA) | $\pm \mathrm{l}_{\mathrm{L}}$ | - | 10 | $\mu \mathrm{A}$ | $0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ |

[^5]

## Notes to the d.c. characteristics

1. The operating supply current is measured with all output pins disconnected;

XTAL 1 driven with $t_{r}=t_{f}=10 \mathrm{~ns}, V_{I L}=V_{S S}+0,5 \mathrm{~V}, \mathrm{~V}_{1 H}=\mathrm{V}_{\mathrm{CC}}-0,5 \mathrm{~V}$;
XTAL 2 not connected; $\overline{E A}=R S T=$ Port $0=V_{C C}$.
2. The idle mode supply current is measured with all output pins disconnected;

XTAL 1 driven with $t_{r}=t_{f}=10 \mathrm{~ns}, V_{I L}=V_{S S}+0,5 \mathrm{~V}, V_{I H}=V_{C C}-0,5 \mathrm{~V}$;
XTAL 2 not connected; $\overline{E A}=$ Pori $0=\mathrm{V}_{\mathrm{CC}} ; \mathrm{RST}=\mathrm{V}_{\mathrm{SS}}$.
3. The power-down current is measured with all output pins disconnected;

XTAL 2 not connected; $\overline{E A}=$ Port $0=V_{C C} ; R S T=V_{S S}$.
4. Capacitive loading on Port 0 and Port 2 may cause spurious noise pulses to be superimposed on the LOW level output voltage of ALE, Port 1 and Port 3. The noise is due to external Bus capacitance discharging into the Port 0 and Port 2 pins when these pins make a 1 -to- 0 transition during Bus operations. In the most adverse condition (capacitive loading $>100 \mathrm{pF}$ ) the noise pulse on ALE line may exceed $0,8 \mathrm{~V}$. In this event it may be required to qualify ALE with a Schmitt trigger, or use an address latch with a Schmitt trigger STROBE input.
5. Capacitive loading on Port 0 and Port 2 may cause the HIGH level output voltage on ALE and PSEN to momentarily fall below the $0,9 \vee_{\mathrm{CC}}$ specification when the address bits are stabilizing.

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}($ Port $0, A L E$ and $\overline{\text { PSEN }}) ; \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ (all other outputs); unless otherwise specified (see waveforms Figs 14, 15 and 16)

| parameter | symbol | 16 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. |  |
| Program memory |  |  |  |  |  |  |  |  |
| ALE pulse duration | tLL | 85 | - | 127 | - | 2tcK-40 | - | ns |
| Address set-up time to ALE | ${ }^{\text {t }} \mathrm{AL}$ | 23 | - | 43 | - | tck-40 | - | ns |
| Address hold time after ALE | tLA | 28 | - | 48 | - | tck-35 | - | ns |
| Time from ALE to valid instruction input | t LIV | - | 150 | - | 233 | - | 4 t CK-100 | ns |
| Time from ALE to control pulse $\overline{\text { PSEN }}$ | ${ }^{\text {t }} \mathrm{C}$ | 38 | - | 58 | - | ${ }^{\text {t }}$ CK-25 | - - | ns |
| Control pulse duration PSEN | ${ }^{\mathrm{t}} \mathrm{C}$ | 153 | - | 215 | - | 3 t CK-35 | - | ns |
| Time from $\overline{\text { PSEN }}$ to valid instruction input | ${ }^{\text {t CIV }}$ | - | 63 | - | 125 | - - | $3 \mathrm{tcK}-125$ | ns |
| Input instruction hold time after $\overline{\text { PSEN }}$ | ${ }^{\mathrm{t}} \mathrm{Cl}$ | 0 | - | 0 | - | 0 | - | ns |
| Input instruction float delay after $\overline{\text { PSEN }}$ * | ${ }^{\text {t }}$ IF | - | 43 | - | 63 | - | ${ }^{\text {t }}$ CK-20 | ns |
| Address to valid instruction input | ${ }^{\text {t A IV }}$ | - | 198 | - | 302 | - | ${ }^{5} \mathrm{t} \mathrm{CK}-115$ | ns |
| Address float time to $\overline{\text { PSEN }}$ | ${ }^{\text {t }} \mathrm{AFC}$ | 0 | - | 0 | - | 0 | - | ns |

* Interfacing the PCB80C51BH to devices with float times up to 75 ns is permitted. This limited bus contention will not cause damage to port 0 drivers.

| parameter | symbol | 16 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. |  |
| External data memory |  |  |  |  |  |  |  |  |
| $\overline{\mathrm{RD}}$ pulse duration | $\mathrm{t}_{\mathrm{R} R}$ | 275 | - | 400 | - | $6 \mathrm{Ct}-100$ | - | ns |
| $\overline{W R}$ pulse duration | ${ }^{\text {tWW }}$ | 275 | - | 400 | - | 6tck-100 | - | ns |
| Address hold time after ALE | $t$ LA | 28 | - | 48 | - | ${ }^{\text {t }}$ CK-35 | - | ns |
| $\overline{\mathrm{RD}}$ to valid data input | ${ }^{\text {t R D }}$ | - | 148 | - | 250 | - | $5 \mathrm{CK}-165$ | ns |
| Data hold time after $\overline{\mathrm{RD}}$ | ${ }^{t} \mathrm{DR}$ | 0 | - | 0 | - | 0 | - | ns |
| Data float delay after $\overline{R D}$ | ${ }^{t}$ DFR | - | 55 | - | 97 | - | 2tCK-70 | ns |
| Time from ALE to valid data input | tLD | - | 350 | - | 517 | - | 8tCK-150 | ns |
| Address to valid data input | ${ }^{\text {t }} \mathrm{AD}$ | - | 398 | - | 585 | - | $9 \mathrm{t}_{\text {CK }}-165$ | ns |
| Time from ALE to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | tLW | 138 | 238 | 200 | 300 | $3 \mathrm{tcK}-50$ | $3 \mathrm{tcK}+50$ | ns |
| Time from address to $\overline{R D}$ or $\overline{W R}$ | ${ }^{\text {t }}$ AW | 120 | - | 203 | - | 4tCK-130 | - | ns |
| Time from $\overline{R D}$ or $\overline{W R}$ HIGH to ALE HIGH | tWHLH | 23 | 103 | 43 | 123 | ${ }^{\text {t }}$ CK-40 | ${ }^{\text {t }} \mathrm{CK}^{+40}$ | ns |
| Data valid to $\overline{W R}$ transition | tDWX | 3 | - | 23 | - | ${ }^{\text {t }} \mathrm{CK}-60$ | - | ns |
| Data set-up time before $\overline{W R}$ | ${ }^{\text {t }}$ DW | 288 | - | 433 | - | 7tck-150 | - | ns |
| Data hold time after $\overline{W R}$ | tWD | 13 | - | 33 | - | tck-50 | - | ns |
| Address float delay after $\overline{\mathrm{RD}}$ | tAFR | - | 0 | - | 0 | - | 0 | ns |

Where:
$1 / \mathrm{t} \mathrm{CK}=1,2$ to 16 MHz (see Fig. 13 and Table 4).
A.C. CHARACTERISTICS (continued)

(a)

A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 .

Timing measurements are taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for logic 0 .
The float state is defined as the point at which a Port 0 pin sinks $3,2 \mathrm{~mA}$ or sources $400 \mu \mathrm{~A}$ at the voltage test levels.

Fig. 12 A.C. testing input, output waveform (a) and float waveform (b).


Fig. 13 External clock drive XTAL 1 (see Table 4).
Table 4 External clock drive XTAL 1 (see Fig. 13)

| parameter. | symbol | $\begin{gathered} \text { variable clock } \\ (f=1,2 \text { to } 16 \mathrm{MHz})^{*} \end{gathered}$ |  | unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min . | max. |  |
| oscillator clock period | ${ }^{\text {t }}$ CK | 63 | 833,3 | ns |
| HIGH time | thigh | 20 | tek-tlow | ns |
| LOW time | t Low | 20 | $\mathrm{t}_{\text {ck- }}-\mathrm{tHIGH}$ | ns |
| rise time | $\mathrm{tr}_{r}$ | - | 20 | ns |
| fall time | $\mathrm{tf}_{f}$ | - | 20 | ns |

* PCF80C51BH: 1,2-12 MHz only.


Fig. 15 Read from data memory.


Fig. 16 Write to data memory.

DEVELOPMENT DATA


Fig. 17 Instruction cycle timing.

## SINGLE-CHIP 8-BIT CMOS MICROCONTROLLER

## DESCRIPTION

The PCB80CXX family of single-chip 8-bit CMOS microcontrollers consists of:

- The PCB80C49 with resident mask programmed $2 \mathrm{~K} \times 8$ ROM, $128 \times 8$ RAM.
- The PCB80C39 without resident program memory for use with external EPROM/ROM, $128 \times 8$ RAM. All versions are pin and function compatible to their NMOS counter parts but with additional features and high performance.
The PCB80CXX family are desgined to be both efficient control and arithmetic processors.
The instruction set allows the user to directly set and reset individual I/O lines, and to test individual bits within the accumulator. A large variety of branch and table look-up instructions enable efficient implementation of standard logic functions. Code efficiency is high; over $70 \%$ of the instructions are single byte; all others are two byte.
An on-chip 8-bit counter is provided, which can count either machine cycles $(\div 32)$ or external events. The counter can be programmed to cause an interrupt to the processor.
Program and data memories can be expanded using standard devices. Input/output capabilities can be expanded using standard devices.
The family has low power consumption and in addition a power down mode is provided.
For further detailed information see users manual 'single-chip 8 -bit microcontrollers'.


## FEATURES

- 8-bit CPU, ROM, RAM, I/O in a single 40-pin package
- PCB80C49: $2 \mathrm{~K} \times 8$ ROM, $128 \times 8$ RAM
- PCB80C39: $128 \times 8$ RAM
- Internal counter/timer
- Internal oscillator, clock driver
- Single-level interrupts: external and counter/timer
- 17 internal registers: accumulator, 16 addressable registers
- Over 90 instructions: $70 \%$ single byte
- All instructions: 1 or 2 cycles
- Easily expandable memory and I/O
- TTL compatible inputs and outputs
- Single 5 V supply
- Wide frequency operation range
- Low current consumption
- Also available with extended temperature range; $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$


## APPLICATIONS

- Peripheral interfaces and controllers
- Test and measurement instruments
- Sequencers
- Audio/video systems
- Environmental control systems
- Modems and data enciphering


## PACKAGES

PCB/F80C39/C49P: 40-lead DIL; plastic (SOT-129).
PCB/F80C39/C49WP: 44-lead plastic leaded chip carrier (PLCC); SOT-187A.



Fig. 2(a) Pinning diagram, DIL; for pin designation see next page.

Fig. 2(b) Pinning diagram, PLCC; for pin designation see next page.

Where: n.c. = not connected.

## PIN DESIGNATION

| designation | pin no. | function |
| :---: | :---: | :---: |
| DB0-DB7 | 12-19 | BUS. Bidirectional I/O port that can be read or written using the $\overline{R D}$ and $\overline{W R}$ strobes. This port can also be statically latched. Contains the 8 lower order address bits during external memory access and receives the addressed instruction under control of $\overline{P S E N}$. $\overline{P S E N}, A L E, \overline{R D}$ and $\overline{W R}$ determine whether the access is an instruction fetch or a read/write access to external RAM. |
| P10-P17 | 27-34 | Port 1. 8 -bit quasi-bidirectional I/O port (note 1). |
| P20-P27 | $\begin{aligned} & 21-24, \\ & 35-38 \end{aligned}$ | Port 2. 8 -bit quasi-bidirectional I/O port (note 1). P20-P23 contain the 4 higher order address bits during an access of external program memory. |
| $\overline{\text { PROG }}$ | 25 | Output strobe (active LOW) for 1/O expander. |
| T0 | 1 | Input pin sensed using the JT0 and JNTO instructions. |
|  |  | Clock output pin when designated as such by the ENTO CLK instruction. |
| T1 | 39 | Input pin sensed using the JT1 and JNT1 instructions. Can be designated as the timer/counter input by the STRT CNT instruction. |
| $\overline{\text { INT }}$ | 6 | Interrupt input pin. When LOW causes an interrupt in the current program if external interrupt is enabled. Can also be used as an input, testable using the JNI instruction. Interrupt is disabled during and after a RESET. |
| RESET | 4 | Reset input pin used to initialize the microcontroller. <br> Active LOW. <br> During program verification the address is latched by a ' 0 ' to ' 1 ' transition on $\overline{\text { RESET }}$ and the data at the addressed location is output on BUS (note 2). |
| ALE | 11 | Address latch enable. Occurs once each machine cycle and is useful for timing and sampling. During external program or data memory access, ALE is used to strobe the address information multiplexed on the DB0 to DB7 outputs. |
| $\overline{R D}$ | 8 | Read BUS. Active LOW strobe used to gate data onto BUS lines when reading from an external source. |
| $\overline{W R}$ | 10 | Write BUS. Active LOW strobe used to write data from BUS lines to an external designation. |
| EA | 7 | External access input. When HIGH, forces instruction fetch from external memory. |
| $\overline{\text { PSEN }}$ | 9 | Program store enable. Active LOW strobe that occurs only during a fetch from external program memory. |
| $\overline{\mathrm{SS}}$ | 5 | Single step input. Active LOW which is used with ALE to cause the microcontroller to execute a single instruction. |
| VDD | 26 | RAM power supply, +5 V during normal operation and power-down mode. |


| designation | pin no. | function |
| :--- | :--- | :--- |
| XTAL1 | 2 | One side of crystal (or inductor) input for internal oscillator. Can <br> also be used as an input for an external timing source (note 2). |
| XTAL2 | 3 | Other side of crystal. |
| $V_{\text {SS }}$ | 20 | Ground. |
| $V_{\text {CC }}$ | 40 | Main power supply, +5 V during normal operation. |

## Notes

1. Each port line can be designated as an input or an output. A line is designated as an input by first writing a logic 1 to the line. $\overline{\text { RESET }}$ sets all lines to logic 1.
2. Non-standard TTL $V_{I H}$.

## FUNCTIONAL DESCRIPTION

Program memory (see Fig. 3)
The resident program memory is:
2048 byte ROM
The PCB80C39 has no resident program memory.
The total addressing capability is 4096 bytes.
The program memory address space is divided into two 2048-bytes banks MBO and MB1.
The program memory is also divided into pages of 256 bytes for conditional branches.
There are three locations in program memory of special importance. These locations contain the first instruction to be executed after one of three events.
The three locations and their contents are:
location 0 - activation, then deactivation of the $\overline{\mathrm{RESET}}$ line,
location 3 - activation of the $\overline{\mathrm{NT}}$ line when the external interrupt is enabled,
location 7 - an overflow of the timer/counter if the T/C interrupt is enabled.

## Data memory (see Fig. 4)

The resident data memory is: 128 byte RAM.
All locations are indirectly addressable by either of two RAM pointer registers at locations 0 and 1 . The first eight locations of RAM ( 0 to 7 ) are designated as working registers and are directly addressable by several instructions. By selecting register bank 1, RAM locations 24 to 31 become the working registers, replacing those in register bank 0 ( 0 to 7 ).
RAM locations 8 to 23 are designated as the stack. Two locations (bytes) are used per CALL, allowing up to eight levels of subroutine nesting.
If additional RAM is required, up to 256 bytes may be added and addressed directly using the MOVX instructions. If more RAM is required, an I/O port can be used to select one ( 256 byte) bank of external memory at a time.


Fig. 3 Program memory map.

## Program counter and stack

The program counter (PC) is a 12 -bit counter/register that points to the location from which the next instruction is to be fetched. When EA is ' 0 ', the PC addresses an internal program memory. At the boundary of the internal program memory an automatic switch over to external memory is made. When EA is ' 1 ', all the program is fetched from external ROM/EPROM. The total address space is 4 K bytes. An interrupt or CALL to a subroutine causes the contents of the program counter to be stored in one of the 8 register pairs of the program counter stack. The pair to be used is determined by a 3-bit stack pointer which is part of the program status word (PSW). Data RAM locations 8 to 23 are available as stack registers and are used to store the program counter and 4 bits of PSW. The stack pointer, when initialized to 000B, points to RAM locations 8 and 9 . The first subroutine jump or interrupt results in the program counter contents being transferred to locations 8 and 9 of the RAM array. The stack pointer is then incremented by one to point to locations 10 and 11 in anticipation of another CALL. Nesting of subroutines within subroutines can continue up to 8 times without overflowing the stack. If overflow does occur the deepest address stored (location 8 and 9 ) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111. The end of a subroutine, which is signalled by a return instruction (RET or RETR), causes the stack pointer to be decremented and the contents of the resulting register pair to be transferred to the program counter.

## Oscillator and clock

The PCB80C49 contains its own internal oscillator and clock driver.
A crystal, inductor or external pulse generator determines the oscillator frequency (see Figs 5, 6 and 7). The output of the oscillator is divided-by-three and is available at TO (pin 1) by executing the ENTO CLK instruction. This CLK signal is divided-by-five to define a machine (instruction) cycle. It is available at ALE (pin 11).


For quartz crystal
1 to 11 MHz : C1 = C2 = 15 to 25 pF
For ceramic resonators
1 to 11 MHz :

$$
\begin{aligned}
& \text { resonators } \\
& \mathrm{C} 1=\mathrm{C} 2=30_{-10}^{+5} \mathrm{pF}
\end{aligned}
$$


(1) Including crystal-socket stray capacitance.

Fig. 5 Crystal oscillator mode. Typical values are given. Crystal serial impedance should be $<75 \Omega$ at 6 MHz and $<180 \Omega$ at $3,6 \mathrm{MHz}$.

Fig. 6 Driving from an external source. Test conditions at XTAL1; Minimum HIGH ( $>0,7$ of $\mathrm{V}_{\mathrm{CC}}$ ) and LOW $\left(<0,13\right.$ of $\left.\mathrm{V}_{\mathrm{CC}}\right)$ times, should be at least $45 \%$ of a clock period.


Fig. 7 LC oscillator mode.

## FUNCTIONAL DESCRIPTION (continued)

## Timer/event counter

An internal counter is available which can count either external events or machine cycles ( $\div 32$ ). The machine cycles are divided-by- 32 before they are applied to the input of the 8 -bit counter. External events are applied directly to the input of the counter. The maximum frequency that can be counted is one third of the machine cycle frequency. The minimum positive duty cycle that can be detected is 0,2 times the cycle period. The counter is under program control and can be made to generate an interrupt to the processor when it overflows.

## Interrupt

An interrupt may be generated by either an external input (INT, pin 6) or the overflow of the internal timer/event counter, when enabled. In either case, the processor completes execution of the present instruction and then does a CALL to the interrupt service routine, After service, a RETR instruction restores the machine to the state it was prior to the interrupt. The external interrupt has priority over the internal interrupt.

## Input/output

The PCB80CXX family has 27 I/O lines. These lines are arranged as three 8 -line ports, which serve individually as either inputs, outputs or together as bidirectional ports, plus 3 'test' inputs which can alter program sequences when tested by conditional jump instructions.

## Ports 1 and 2

Ports 1 and 2 are each 8 -bits wide and have identical characteristics. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, e.g., inputs must be present until read by an input instruction. Inputs are fully TTL compatible and outputs will drive one standard TTL load.
The lines of ports 1 and 2 are called quasi-bidirectional because of a special output circuit structure which allows each line to serve as an input, an output, or both even though outputs are statically latched. The circuit configuration is shown in Fig. 8. Each line has a unique high-impedance pull-up transistor TR3, this is turned on when the line is pulled above 2 V by an external source or by writing a logic 1 to the port. This pull-up is sufficient to provide the source current for a TTL HIGH level, yet can be pulled LOW by a standard TTL gate, thus allowing the same pin to used for both input and output. When a logic 1 is written to a line, a second high impedance transistor TR2, pulls the line up to 5 V . To provide fast switching during a ' 0 ' to ' 1 ' transition, a relatively low-impedance transistor TR1 (approx. $750 \Omega$ ) is switched on for $1 / 5$ of a machine cycle whenever a ' 1 ' is written to the line. Whenever a ' 0 ' is written to the line, a low-impedance (approx. $250 \Omega$ ) transistor TR4, overcomes the weak light pull-up and provides TTL current sinking capability.
Since the pull-down transistor TR4 is a low-impedance device, a ' 1 ' must first be written to any line which is to be used as an input. RESET initializes all lines to the high impedance ' 1 ' state. This structure allows input and output on the same pin and also allows a mixture of input lines and output lines on the same port. The quasi-bidirectional port in combination with the ANL and ORL logical instructions provide an efficient means for handling single line inputs and outputs within an 8-bit processor.

## BUS

BUS is also an 8-bit port which is a true bidirectional port with associated input and output strobes. If the bidirectional feature is not needed, BUS can serve as either a statically latched output port or non-latching input port. Input and output lines on this port cannot be mixed.
As a static port, data is written and latched using the OUTL instruction and input using the INS instruction. The INS and OUTL instructions generate pulses on the corresponding $\overline{R D}$ and $\overline{W R}$ output strobe lines; however, in the static port mode they are generally not used. As a bidirectional port, the MOVX instructions are used to read and write the port. A write to the port generates a pulse on the $\overline{W R}$ output line and output data is valid at the trailing-edge of $\overline{W R}$. A read of the port generates a pulse on the $\overline{R D}$ output line and input data must be valid the trailing-edge of $\overline{R D}$. When not being written or read, the BUS lines are high impedance.

## Test (TO, T1) and $\overline{I N T}$ inputs

Three pins serve as inputs and are testable with the conditional jump instruction. These pins are T0, T1, and $\overline{\mathrm{INT}}$ and they allow inputs to cause program branches without the necessity to load an input port into the accumulator. The T0, T1 and INT pins have other possible functions as well.


Fig. 8 Quasi-bidirectional port structure.
RESET input (see Fig. 10)
The $\overline{R E S E T}$ input provides a means to initialize the processor. This Schmitt-trigger input has an internal pull-up resistor. The combination of an external $47 \mathrm{k} \Omega$ resistor and a $1 \mu \mathrm{~F}$ capacitor provides a reset pulse of sufficient duration to guarantee that all circuitry is reset. If the reset puise is generated otherwise, the $\overline{\text { RESET }}$ pin must be held at ground for at least 10 ms after the ( $0,13 \mathrm{~V}_{\mathrm{CC}}$ ) power supply is within tolerance. Only five machine cycles $(2,5 \mu \mathrm{~s}$ at 6 MHz$)$ are required if power is already on and the oscillator has stabilized.

## Single step input ( $\overline{\mathrm{SS}}$ )

Under control of the $\overline{\mathrm{S}} \overline{\mathrm{S}}$ line, the processor can be forced to execute one instruction and then to wait until the single step switch is activated again.

## FUNCTIONAL DESCRIPTION (continued)

## IDLE mode

The PCB80CXX family is provided with a IDLE mode in which the internal oscillator, the internal timer and the external interrupt and counter are still functioning, while the status of following parts is maintained: RAM and register/Port 1 and 2/Bus. The IDLE mode is entered after execution of the IDLE instruction (opcode 1 H ). The IDLE mode is terminated by one of the two possible interrupts, if enabled, or a RESET signal. If an external interrupt terminates the IDLE mode, the next instruction that is executed is at location 3 of the program store. If a timer/counter interrupt terminates the IDLE mode, the next instruction is at location 7. The reset signal will terminate the IDLE mode, and also initialize the processor.

## Power-down mode

In the PCB80CXX family, power can be removed from all but the $64 \times 8$ bit and $128 \times 8$ bit data RAM array, for low power standby operation. In the power-down mode the contents of the data RAM are maintained. $\mathrm{V}_{\mathrm{CC}}$ serves as the +5 V supply pin for most of the circuitry, while the $\mathrm{V}_{\mathrm{DD}}$ pin supplies only the RAM array. In normal operation, both pins are at +5 V . In standby, $\mathrm{V}_{\mathrm{CC}}$ is at ground and $V_{D D}$ is maintained at +5 V .
Applying $\overline{\operatorname{RESET}}$ to the processor through the $\overline{\operatorname{RESET}}$ pin inhibits any access to the RAM by the processor and guarantees that the RAM cannot be inadvertently altered when power is removed from $V_{\text {CC. }}$ Fig. 9 shows a typical power-down sequence.


Fig. 9 Power-down sequence.


Fig. 10(a) External reset circuit; (b) power-on reset.

## Instruction set

The PCB80CXX instruction set consists of over 90 one and two-byte instructions (see Table 2). Program code efficiency is high because:

- working registers and program variables are stored in the RAM, which require only a single byte to address,
- program memory is divided into pages of 256 bytes, which means that branch destination addresses require one byte.
In addition to performing logical and arithmetic operations, the instruction set manipulates and tests both bits and bytes. A set of MOVE instructions operates indirectly upon either RAM or ROM, which permits efficient access of pointers and data tables. The indirect jump instruction performs a multi-way branch (up to 256) upon the content of the accumulator to addresses stored in a look-up table. The 'decrement register and jump if not zero' DJNZ instruction saves a byte every time it is used as opposed to using separate increment and test instructions.
The on-chip counter enables either external events or time to be counted off-line from the main program. The PCB80CXX can either test the counter (under program control) or cause its overflow to generate an interrupt. These features are required for real-time applications. Instruction timing is shown in Table 3.


## Table 1

Symbol definitions used in Table 2.

| symbol | description |
| :---: | :---: |
| A | the accumulator |
| AC | the auxiliary carry flag |
| addr | program memory address (11-bits) |
| Bb | bit designation ( $\mathrm{b}=0-7$ ) |
| BS | the bank switch |
| C | carry flag |
| CLK | clock signal |
| CNT | event counter |
| D | nibble designation (4-bits) |
| DBF | program memory bank flip-flop |
| data | number or expression (8-bits) |
| F0, F1 | flags 0 and 1 |
| 7 | interrupt |
| INT | external interrupt |
| P | 'in-page' operation designation |
| Pp | port designation ( $\mathrm{p}=1,2$ or 4-7) |
| PSW | program status word |
| Rr | register designation ( $\mathrm{r}=0,1$ or $0-7$ ) |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| T0, T1, | test 0 and 1 inputs |
| \# | immediate data prefix |
| @ | indirect address prefix |
| \$ | current value of program counter |
| $\leftarrow$ | is replaced by |
| $\leftrightarrow$ | is exchanged with |

Notes to Table 2.

1. Instruction code designations $r$ and $p$ form the binary representation of the registers and ports involved.
2. The dot under the appropriate flag bit indicates that its content is subject to change by the instruction it appears in.
3. Numerical subscripts appearing in the FUNCTION column reference the specific bits affected.

Table 2 Instruction set



Table 2 (continued)

| mnemonic |  | function | description | instruction code | cycles | bytes | flags |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | C |  |  | AC | F0 | F1 | BS |
| $\left\|\begin{array}{l} I \\ U \\ 2 \\ \mathbb{u} \\ \underset{\sim}{\infty} \end{array}\right\|$ | DJNZ Rr, addr |  | $(R r) \leftarrow(R r)-1$ <br> if ( Rr ) not zero: $\left(\mathrm{PC}_{0-7}\right) \leftarrow \mathrm{addr}$ | Decrement the specified register and test contents | $\left\lvert\, \begin{array}{cccccccc} 1 & 1 & 1 & 0 & 1 & r & r & r \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}\right.$ | 2 | 2 |  |  |  |  |  |
|  | JBb addr | $\begin{aligned} & \left(\mathrm{PC}_{0}-7\right) \leftarrow \mathrm{addr} \text { if } \\ & \mathrm{Bb}=1 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \text { if } \mathrm{Bb}=0 \end{aligned}$ | Jump to specified address if accumulator bit is set | $\begin{array}{lllccccc} b_{2} & b_{1} & b_{0} & 1 & 0 & 0 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}$ | 2 | 2 |  |  |  |  |  |
|  | JC addr | $\begin{aligned} & \left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr if } \\ & \mathrm{C}=1 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \text { if } \mathrm{C}=0 \end{aligned}$ | Jump to specified address if carry flag is set | $\begin{array}{cccccccc} 1 & 1 & 1 & 1 & 0 & 1 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}$ | 2 | 2 |  |  |  |  |  |
|  | JF0 addr | $\begin{aligned} & \left(\mathrm{PC}_{0}-7\right) \leftarrow \text { addr if } \\ & (\mathrm{FO}=1 ;(\mathrm{PC}) \leftarrow(P C)+2 \\ & \text { if } F 0=0 \end{aligned}$ | Jump to specified address if flag FO is set | $\begin{array}{cccccccc} 1 & 0 & 1 & 1 & 0 & 1 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}$ | 2 | 2 |  |  |  |  |  |
|  | JF1 addr | $\begin{aligned} & \left(\mathrm{PC}_{0}-7\right) \text { 世addr if } \\ & \mathrm{F} 1=1 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \text { if } \mathrm{F} 1=0 \end{aligned}$ | Jump to specified address if flag F1 is set | 0 1 1 1 0 1 1 0 <br> $a_{7}$ $a_{6}$ $a_{5}$ $a_{4}$ $a_{3}$ $a_{2}$ $a_{1}$ $a_{0}$ | 2 | 2 |  |  |  |  |  |
|  | JMP addr | $\begin{aligned} & \left(\mathrm{PC}_{8}-10\right) \leftarrow \text { addr } 8-10 \\ & \left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addr } 0-7 \\ & \left(\mathrm{PC}_{11}\right) \leftarrow(\mathrm{DBF}) \end{aligned}$ | Direct jump to specified address within the 2 K address block | $\begin{array}{ccccccc} a_{10} a_{9} & a_{8} & 0 & 0 & 1 & 0 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} \end{array} a_{0}$ | 2 | 2 |  |  |  |  |  |
|  | JMPP @A | $\left(\mathrm{PC}_{0-7}\right) \leftarrow((A))$ | Jump indirect to specified address within address page | $\begin{array}{llllllll}1 & 0 & 1 & 1 & 0 & 0 & 1 & 1\end{array}$ | 2 | 1 |  |  |  |  |  |
|  | JNC addr | $\begin{aligned} & \left(\mathrm{PC}_{0}-7\right) \leftarrow \text { addr if } \\ & \mathrm{C}=0 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \text { if } \mathrm{C}=1 \end{aligned}$ | Jump to specified address if carry flag is LOW | $\begin{array}{cccccccc} 1 & 1 & 1 & 0 & 0 & 1 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}$ | 2 | 2 |  |  |  |  |  |
|  | JNI | $\begin{aligned} & \left(\mathrm{PC}_{0}-7\right) \leftarrow \text { addr if } \\ & \overline{\mathrm{INT}}=0 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+ \\ & 2 \text { if } \overline{\mathrm{INT}}=1 \end{aligned}$ | Jump to specified address if $\overline{\text { INT input is LOW }}$ | $\begin{array}{cccccccc} 1 & 0 & 0 & 0 & 0 & 1 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}$ | 2 | 2 |  |  |  |  |  |
|  | JNTO addr | $\begin{aligned} & \left(\mathrm{PC}_{0-7}\right) \leftarrow \text {-addr if } \\ & \mathrm{TO}=0 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \text { if TO }=1 \end{aligned}$ | Jump to specified address if TO is LOW | $\left\lvert\, \begin{array}{cccccccc} 0 & 0 & 1 & 0 & 0 & 1 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}\right.$ | 2 | 2 |  |  |  |  |  |
|  | JNT1 addr | $\begin{aligned} & \left(\mathrm{PC}_{0}-7\right) \leftarrow \mathrm{addr} \text { if } \\ & \mathrm{T} 1=0 ;(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \text { if } \mathrm{T} 1=1 \end{aligned}$ | Jump to specified address if T 1 is LOW | $\left\|\begin{array}{cccccccc} 0 & 1 & 0 & 0 & 0 & 1 & 1 & 0 \\ a_{7} & a_{6} & a_{5} & a_{4} & a_{3} & a_{2} & a_{1} & a_{0} \end{array}\right\|$ | 2 | 2 |  |  |  |  |  |

DEVELOPMENT DATA



Table 2 (continued)


DEVELOPMENT DATA

| $\dot{\dot{0}}$ | XCHD A,@Rr | $\begin{aligned} & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\mathrm{Rr}_{0}-3\right) \\ & \text { for } \mathrm{r}=0-1 \end{aligned}$ | Exchange indirect 4-bit contents of A with data memory | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 0 & 0 & 0 & r\end{array}$ | 1 | 1 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{l} 9 \\ 0 \\ 4 \\ u \end{array}\right\|$ | $\begin{aligned} & \text { CPL C } \\ & \text { CPL F0 } \\ & \text { CPL F1 } \\ & \text { CLR C } \\ & \text { CLR F0 } \\ & \text { CLR F1 } \end{aligned}$ | $\begin{aligned} & (\mathrm{C}) \leftarrow \text { NOT }(\mathrm{C}) \\ & (\text { FO }) \leftarrow \text { NOT }(\text { FO }) \\ & (\text { F1 }) \leftarrow \text { NOT (F1) } \\ & (\mathrm{C}) \leftarrow 0 \\ & (\text { F0 }) \leftarrow 0 \\ & (\text { F1 }) \leftarrow 0 \end{aligned}$ | Complement content of carry bit Complement content of flag FO Complement content of flag F1 Clear content of carry bit to 0 Clear content of flag F0 to 0 Clear content of flag F1 to 0 | $\begin{array}{llllllll} 1 & 0 & 1 & 0 & 0 & 1 & 1 & 1 \\ 1 & 0 & 0 & 1 & 0 & 1 & 0 & 1 \\ 1 & 0 & 1 & 1 & 0 & 1 & 0 & 1 \\ 1 & 0 & 0 & 1 & 0 & 1 & 1 & 1 \\ 1 & 0 & 0 & 0 & 0 & 1 & 0 & 1 \\ 1 & 0 & 1 & 0 & 0 & 1 & 0 & 1 \end{array}$ | $1$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | - | $\bullet \cdot$ | - |  |
|  | ANL BUS,\#data <br> ANL Pp, \#data <br> ANLD Pp,A <br> IN A, Pp <br> INS A,BUS <br> MOVD A,Pp <br> MOVD Pp,A <br> ORLD Pp,A <br> ORL BUS, \#data <br> ORL Pp, \#data <br> OUTL BUS,A <br> OUTL Pp,A | $\begin{aligned} & (B \cup S) \leftarrow(B \cup S) \text { AND } \\ & \text { data } \\ & (P p) \leftarrow(P p) \text { AND } \\ & \text { data; } p=1-2 \\ & (P p) \leftarrow(P p) \text { AND } \\ & \left(A_{0}-3\right) ; p=4-7 \\ & (A) \leftarrow(P p) \\ & p=1-2 \\ & (A) \leftarrow(B \cup S) \\ & \left(A_{0}-3\right) \leftarrow(P p) ; p=4-7 \\ & (A 4-7) \leftarrow 0 \\ & (P p) \leftarrow(A 0-3) \\ & p=4-7 \\ & (P p) \leftarrow(P p) \text { OR } \\ & (A 0-3) ; p=4-7 \\ & (B \cup S) \leftarrow(B \cup S) \text { OR } \\ & \text { data } \\ & (P p) \leftarrow(P p) \text { OR data } \\ & p=1-2 \\ & (B \cup S) \leftarrow(A) \\ & (P p) \leftarrow(A) \\ & p=1-2 \end{aligned}$ | Logical AND immediate data with BUS <br> Logical AND immediate data with designated port (1 or 2) <br> Logical AND contents of A with designated port (4-7) <br> Input data from designated port (1-2) into A <br> Input strobed BUS data into $A$ <br> Move contents of designated port (4-7) into A <br> Move contents of $A$ to designated port (4-7) <br> Logical OR contents of A with designated port (4-7) <br> Logical OR immediate data with BUS <br> Logical OR immediate data with designated port (1-2) <br> Output contents A onto BUS <br> Output contents A to designated port (1-2) | 1 0 0 1 1 0 0 0 <br> $d_{7}$ $d_{6}$ $d_{5}$ $d_{4}$ $d_{3}$ $d_{2}$ $d_{1}$ $d_{0}$ <br> 1 0 0 1 1 0 $p$ $p$ <br> $d_{7}$ $d_{6}$ $d_{5}$ $d_{4}$ $d_{3}$ $d_{2}$ $d_{1}$ $d_{0}$ <br> 1 0 0 1 1 1 $p$ $p$ <br> 0 0 0 0 1 0 $p$ $p$ <br> 0 0 0 0 1 0 0 0 <br> 0 0 0 0 1 1 $p$ $p$ <br> 0 0 1 1 1 1 $p$ $p$ <br> 1 0 0 0 1 1 $p$ $p$ <br> 1 0 0 0 1 0 0 0 <br> $d_{7}$ $d_{6}$ $d_{5}$ $d_{4}$ $d_{3}$ $d_{2}$ $d_{1}$ $d_{0}$ <br> 1 0 0 0 1 0 $p$ $p$ <br> $d_{7}$ $d_{6}$ $d_{5}$ $d_{4}$ $d_{3}$ $d_{2}$ $d_{1}$ $d_{0}$ <br> 0 0 0 0 0 0 1 0 <br> 0 0 1 1 1 0 $p$ $p$ | 2 2 2 2 2 2 2 1 1 2 2 2 1 | 2 2 1 1 1 1 1 1 2 2 1 1 |  |  |  |  |

Table 2 (continued)


Table 3 Instruction timing (see also Figs 11 and 12)

|  | cycle 1 |  |  |  |  | cycle 2 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| instruction | S1 | S2 | S3 | S4 | S5 | S1 | S2 | S3 | S4 | S5 |
| IN A, P | fetch instruction | increment program counter | - | increment timer | - | - | read port | * - | - | - |
| OUTL P,A | $1$ | $1$ | - | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | output to port | - | - | * - | - | - |
| ANL P, \#data | i |  | - | $1$ | read <br> port | fetch immediate data | - | *increment program counter | output to port | - |
| ORL P, \#data | $1$ |  | - | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | read <br> port | fetch immediate data | - | *increment program counter | output to port | - |
| INS A,BUS | $1$ | $1$ | - | $1$ | - | - | read port | * - | - | - |
| OUTL BUS,A | $1$ | $1$ | - | $1$ | output to port | - | - | * - | - | - |
| ANL BUS,\#data | $1$ |  | - | $1$ | read <br> port | fetch immediate data | - | *increment progran counter | output to port | - |
| ORL BUS,\#data | i | * 1 | - | $1$ | read <br> port | fetch immediate data | - | *increment program counter | output to port | - |
| MOVX @R,A | $1$ | $1$ | output RAM address | $1$ | output <br> data <br> to RAM | - | - | * - | - | - |
| MOVX A,@R | $1$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | output RAM address | 1 | - | - | read <br> data | * | - | - |
| MOVD A,P | 1 fetch instruction | increment program counter | output opcode/ address | $\begin{gathered} 1 \\ \text { increment } \\ \text { timer } \end{gathered}$ | - | - | read P2 <br> lower | * - | - | - |

Table 3 Instruction timing (continued)


|  | cycle 1 |  |  |  |  | cycle 2 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| instruction | S1 | S2 | S3 | S4 | S5 | S1 | S2 | S3 | S4 | S5 |
| MOVD P,A | fetch instruction | increment program counter | output opcode/ address | increment timer | output data to P2 lower | - | - | * - | - | - |
| ANILD P,A | 1 |  | output opcode/ address | $1$ | output data | - | - | * - | - | - |
| ORLD P,A | $1$ |  | output opcode/ address | $1$ | output data | - | - | * - | - | - |
| $J$ (conditional) | $1$ | * | sample condition | increment timer | - | fetch immediate data | - | *update program counter | - | - |
| STRT CNT STRT T | , | * | - | - | start counter |  |  |  |  |  |
| STOP TCNT | 1 | * | - | - | stop counter |  |  |  |  |  |
| EN I | $1$ | * | - | enable interrupt | - |  |  |  |  |  |
| DIS I | $1$ | * | - | disable interrupt | - |  |  |  |  |  |
| ENTO CLK | fetch instruction | *increment program counter | - | enable clock | - |  |  |  |  |  |


|  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S5 | S1 | S2 | S3 | S4 | S5 | S1 |
|  | INPUT <br> INSTR. | DECODE | EXECUTION |  |  | INPUT |
| OUTPUT ADDRESS | INC. PC | OUTPUT ADDRESS |  |  |  |  |

Fig. 11 Instruction cycle.


Fig. 12 Instruction cycle timing.

Table 4 Instruction map.

| first hexadicimal character of opcode |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $0 \quad 1$ | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| 0 | NOPIDLE <br> mode | OUTL BUS,A | ADD <br> A. \#data | JMP page 0 | EN I |  | DEC A | $\begin{aligned} & \text { INS } \\ & \text { A,BUS } \end{aligned}$ | $\begin{array}{ll} \mathrm{IN} A, & \mathrm{Pp} \\ 1 & \\ \hline \end{array}$ |  |  | $\begin{aligned} & \text { MOVD A, Pp } \\ & 4 \\ & 4 \end{aligned}$ |  |  |  |
| 1 | $\begin{array}{ll} \hline \text { INC @Rr } \\ 0 & 1 \end{array}$ | $\begin{aligned} & \text { JBO } \\ & \text { addr } \end{aligned}$ | ADDC <br> A, \#data | CALL page 0 | DIS I | JTF addr | INC A | INC Rr 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 2 | $\begin{aligned} & \text { XCH A, @Rr } \\ & 0 \end{aligned}$ |  | MOV <br> A, \#data | JMP page 1 | $\begin{aligned} & \text { EN } \\ & \text { TCNTI } \end{aligned}$ | JNTO addr | CLR A | $\begin{aligned} & \mathrm{XCH} A, \mathrm{Rr} \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 3 | $\begin{aligned} & \text { XCHD A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB1 } \\ & \text { addr } \end{aligned}$ |  | CALL page 1 | DIS <br> TCNTI | JTO addr | CPL A |  | $\begin{array}{l\|l} \text { OUTL Pp,A } \\ 1 & 2 \end{array}$ |  |  | $\begin{array}{l\|l\|l} \hline \text { MOVD Pp,A } \\ 4 & 5 & 6 \end{array}$ |  |  |  |
| 4 | $\begin{aligned} & \text { ORL A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \mathrm{A}, \mathrm{~T} \end{aligned}$ | ORL <br> A, \#data | JMP page 2 | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 addr | $\begin{aligned} & \text { SWAP } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { ORL A, Rr } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 5 | $\begin{aligned} & \text { ANL A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB2 } \\ & \text { addr } \end{aligned}$ | ANL <br> A, \#data | CALL page 2 | $\begin{aligned} & \text { STRT } \\ & \text { T } \end{aligned}$ | JT1 addr | DA, A | $\begin{aligned} & \text { ANL A, Rr } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 6 | $\begin{aligned} & \text { ADD A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { T,A } \end{aligned}$ |  | JMP page 3 | STOP TCNT |  | RRC A | $\begin{aligned} & \text { ADD A, Rr } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 7 | $\begin{aligned} & \text { ADDC A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB3 } \\ & \text { addr } \end{aligned}$ |  | CALL page 3 | $\begin{aligned} & \text { ENTO } \\ & \text { CLK } \end{aligned}$ | JF1 addr | RR A | $\begin{aligned} & \text { ADDC } \mathrm{A}, \mathrm{Rr} \\ & 0 \end{aligned}$ | $1$ | $2$ | 3 | 4 | 5 | 6 | 7 |
| 8 | $\begin{aligned} & \text { MOVX A, @Rr } \\ & 0 \end{aligned}$ |  | RET | JMP page 4 | $\begin{aligned} & \text { CLR } \\ & \text { FO } \end{aligned}$ | JN1 addr |  | ORL BUS, \#data | ORL Pp, \#data1 |  |  | ORLD Pp, A   <br> 4 5 6 |  |  | 7 |
| 9 | $\begin{array}{ll} \text { MOVX @Rr,A } \\ 0 & 1 \end{array}$ | JB4 addr | RETR | CALL page 4 | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{FO} \end{aligned}$ | JNZ addr | CLR C | ANL BUS, \#data | ANP Pp, \#data $1 \quad 2$ |  |  | $\begin{array}{l\|l\|l} \text { ANLD Pp, A } \\ \hline 4 & 5 & 6 \\ \hline \end{array}$ |  |  | 7 |
| A | $\begin{aligned} & \text { MOV @Rr, A } \\ & 0 \end{aligned}$ |  | MOVP <br> A, @A | JMP page 5 | $\begin{aligned} & \text { CLR } \\ & \text { F1 } \end{aligned}$ |  | CPL C | $\begin{aligned} & \text { MOV Rr,A } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| B | MOV @Rr, \#data $0$ | $\begin{aligned} & \text { JB5 } \\ & \text { addr } \end{aligned}$ | JMPP @A | CALL page 5 | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{~F} 1 \\ & \hline \end{aligned}$ | JFO addr |  | $\begin{aligned} & \text { MOV R, \# data } \\ & 0 \end{aligned}$ |  | $2$ | 3 | 4 | 5 | 6 | 7 |
| C |  |  |  | JMP page 6 | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | JZ addr | MOV <br> A, PSW | DEC Rr $0$ | $1$ | $2$ | 3 | 4 | 5 | 6 | 7 |
| D | $\begin{aligned} & \text { XRL A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB6 } \\ & \text { addr } \end{aligned}$ | $\overline{X R L}$ <br> A, \#data | CALL page 6 | $\begin{aligned} & \hline \text { SEL } \\ & \text { RB1 } \end{aligned}$ |  | MOV PSW, A | $\begin{aligned} & \text { XRL A, Rr } \\ & 0 \end{aligned}$ | $1$ | 2 | 3 | 4 | 5 | 6 | 7 |
| E |  |  | MOVP3 <br> A @A | JMP page 7 | SEL <br> MBO | JNC addr | RL A | DJNZ Rr, addr $0 \quad 1$ |  | 2 | 3 | 4 | 5 | 6 | 7 |
| F | $\begin{aligned} & \text { MOV A, @Rr } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { JB7 } \\ & \text { addr } \end{aligned}$ |  | CALL page 7 | SEL MB1 | JC addr | RLC A | $\begin{aligned} & \text { MOV A,Rr } \\ & 0 \end{aligned}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 |

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
D.C. current into any input or output

Total power dissipation
Storage temperature range
Operating ambient temperature range

| $\pm \mathrm{I}_{1}, \pm \mathrm{I}_{\mathrm{O}}$ | max. | 10 mA |
| :--- | :--- | ---: |
| $\mathrm{P}_{\text {tot }}$ | max. | $0,5 \mathrm{~W}$ |
| $\mathrm{~T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |  |
| $\mathrm{T}_{\mathrm{amb}}$ | 0 to $+70{ }^{\circ} \mathrm{C}$ |  |

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$; unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voitage | $\begin{aligned} & V_{C C}= \\ & V_{D D} \end{aligned}$ | 4,5 | 5,0 | 5,5 | V |  |
| Supply current |  | - | - | 15 | mA | $\mathrm{f}=11 \mathrm{MHz}$ |
| total | ${ }_{\text {tot }}$ | - | - | 8,5 | mA | $f=6 \mathrm{MHz} \mathrm{I}_{\text {tot }}=I_{\text {CC }}+I_{\text {DD }}$ |
|  |  | - | - | 3 | mA | $f=1 \mathrm{MHz}$ |
|  |  | - | - | 6 | mA | $f=11 \mathrm{MHz}$ |
| IDLE mode | $\mathrm{I}_{\text {idle }}$ | - | - | 4 | mA | $f=6 \mathrm{MHz}$ |
|  |  | - | - | 1,2 | mA | $f=1 \mathrm{MHz}$ |
| power down mode | $\mathrm{I}_{\mathrm{pd}}$ | - | - | 2 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{DD}}=2 \mathrm{~V} ; \overline{\mathrm{RESET}}=$ LOW |
| Inputs |  |  |  |  |  |  |
| Input voltage LOW all inputs except |  |  |  |  |  |  |
| $\begin{aligned} & \text { RESET: XTAL } 1 \text {; } \\ & \text { XTAL } 2 \end{aligned}$ | $\mathrm{V}_{\text {IL }}$ | -0,5 | - | $0,18 x \mid$ | V |  |
| Input voltage LOW |  |  |  |  |  |  |
| $\begin{aligned} & \text { RESET; XTAL } 1 \text {; } \\ & \text { XTAL } 2 \end{aligned}$ | VIL1 | -0,5 | - | $0,13 x$ | V |  |
| Input voltage HIGH all inputs except |  |  |  | V |  |  |
| RESET; XTAL 1; <br> XTAL 2 | $\mathrm{V}_{\text {IH }}$ | 0,4 x | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input voltage HIGH |  | $\mathrm{V}_{\text {CC }}$ |  |  |  |  |
| $\begin{aligned} & \text { RESET; XTAL } 1 \text {; } \\ & \text { XTAL } 2 \end{aligned}$ | $\mathrm{V}_{\mathrm{IH} 1}$ | 0,7x | - | $\mathrm{V}_{\text {cc }}$ | V |  |
| Outputs |  |  |  |  |  |  |
| Output voltage LOW BUS | $\mathrm{V}_{\text {OL }}$ | - | - | 0,45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| Output voltage LOW $\overline{\mathrm{RD}} ; \overline{\mathrm{WR}} ; \overline{\mathrm{PSEN}} ; \mathrm{ALE}$ | $\mathrm{V}_{\text {OL1 }}$ | - | - | 0,45 | V | $\mathrm{I}_{\mathrm{OL}}=1,8 \mathrm{~mA}$ |
| Output voltage LOW PROG | $\mathrm{V}_{\text {OL2 }}$ | - | - | 0,45 | V | $\mathrm{IOL}=1 \mathrm{~mA}$ |
| Output voltage LOW all other outputs | $\mathrm{V}_{\text {OL3 }}$ | - | - | 0,45 | V | $\mathrm{I}_{\mathrm{OL}}=1,6 \mathrm{~mA}$ |

## D.C. CHARACTERISTICS (continued)

| parameter | symbol | min . | typ. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Output voltage HIGH BUS | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 0,75 \times \\ & \mathrm{V}_{\mathrm{CC}} \end{aligned}$ | - | - | V | $-\mathrm{I}^{\text {OH }}=400 \mu \mathrm{~A}$ |
| Output voltage HIGH $\overline{\mathrm{RD}} ; \overline{\mathrm{WR}} ; \overline{\mathrm{PSEN}} ; \mathrm{ALE}$ | VOH1 | $\begin{aligned} & 0,75 \times \\ & \mathrm{V}_{\mathrm{CC}} \end{aligned}$ | - | - | V | $-\mathrm{IOH}^{\prime}=100 \mu \mathrm{~A}$ |
| Output voltage HIGH all other outputs | $\mathrm{V}_{\mathrm{OH} 2}$ | $\begin{aligned} & 0,75 \times \\ & \mathrm{V}_{\mathrm{CC}} \end{aligned}$ | - | - | V | $-^{-1} \mathrm{OH}=40 \mu \mathrm{~A}$ |
| Input leakage current INT; T1; EA | $\pm 1 / L$ | - | - | 10 | $\mu \mathrm{A}$ | without internal pull-up; $\mathrm{v}_{\mathrm{SS}}<\mathrm{V}_{1}<\mathrm{v}_{\mathrm{CC}}$ |
| Input leakage current $\mathrm{P} 10-\mathrm{P} 17 ; \mathrm{P} 20-\mathrm{P} 27 ; \overline{\mathrm{SS}}$ | -1/L1 | - | - | 500 | $\mu \mathrm{A}$ | with internal pull-up; $\mathrm{V}_{\mathrm{SS}}+0,45<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{CC}}$ |
| Input leakage current RESET | -IILR | 20 | - | 300 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}} \leqslant \mathrm{V}_{\text {IL1 }}$ |
| Output leakage current BUS; TO at high impedance state | $\pm{ }^{1} \mathrm{OL}$ | - | - | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0,45<\mathrm{V}_{1}<\mathrm{V}_{\text {CC }}$ |

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; note 1
See waveforms Figs 13, 14, 15, 16 and 17

| parameter | $f\left(\mathrm{t}_{\mathrm{CL}}\right)$ <br> (note 2) | symbol | 11 MHz |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Clock period (note 2) | 1/(fXTAL) | ${ }^{\mathrm{t}} \mathrm{CL}$ | 90,9 | 1000 | ns |
| ALE pulse width | 7/30tCL-170 | ${ }^{\text {t LL }}$ | 150 | - | ns |
| Address set-up time to ALE | 1/5t CL-110 | ${ }^{t} A L$ | 160 | - | ns |
| Address hold time from ALE | 1/15t CL-40 | ${ }^{\text {t }}$ LA | 50 | - | ns |
| Control pulse width $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 1/2t ${ }^{\text {CLL }}$-200 | ${ }^{\text {t CC1 }}$ | 480 | - | ns |
| $\frac{\text { Control pulse width }}{\overline{\text { PSEN }}}$ | 2/5t ${ }^{\text {CL }}$-200 | ${ }^{\mathrm{t}} \mathrm{CC2}$ | 350 | - | ns |
| Data set-up time before $\overline{W R}$ | 13/30t ${ }^{\text {CL }}$-200 | ${ }^{\text {t }}$ DW | 390 | - | ns |
| Data hold time after $\overline{W R}$ (note 3) | $1 / 15 \mathrm{t}$ CL -50 | ${ }^{\text {tw }}$ | 40 | - | ns |
| $\frac{\text { Data hold time }}{\overline{\text { RD }}, \overline{\text { PSEN }}}$ | 1/10t ${ }_{\text {CL }}-30$ | ${ }^{\text {t }}$ R | 0 | 110 | ns |
| $\overline{\mathrm{RD}}$ to data input | $2 / 5 \mathrm{t}$ CL-170 | ${ }^{\text {t R }}$ 1 1 | - | 375 | ns |
| $\overline{\text { PSEN }}$ to data input | $3 / 10 \mathrm{tCL}-170$ | ${ }^{\text {t RD2 }}$ | - | 240 | ns |
| Address set-up time to $\overline{W R}$ | $1 / 3 \mathrm{t}$ CL-150 | ${ }^{\text {t }}$ AW | 300 | - | ns |
| Address set-up time to data input ( $\overline{\mathrm{RD}}$ ) | $7 / 10{ }^{\text {c }}$ CL-250 | ${ }^{t}$ AD1 | - | 730 | ns |
| Address set-up time to data input ( $\overline{\mathrm{PSEN}}$ ) | 1/2t ${ }^{\text {CL }}$-220 | ${ }^{t} A D 2$ | - | 460 | ns |
| Address floating to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 2/15t $\mathrm{CL}^{-40}$ | ${ }^{t}$ AFC1 | 140 | - | ns |
| Address floating to $\overline{\text { PSEN }}$ | $1 / 30 \mathrm{t}_{\mathrm{CL}}-40$ | ${ }^{\text {t }}$ AFC2 | 10 | - | ns |
| ALE to control pulse $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $1 / 5 \mathrm{t}_{\mathrm{CL}}-75$ | ${ }^{\text {t }}$ LAFC1 | 200 | - | ns |
| $\frac{\mathrm{ALE} \text { to control pulse }}{\mathrm{PSEN}}$ | 1/10t ${ }_{\text {CL }}-75$ | ${ }^{\text {t }}$ LAFC2 | 60 | - | ns |
| Control pulse to ALE $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ | $1 / 15 \mathrm{t}_{\mathrm{CL}}-40$ | ${ }^{\text {t }}$ CA1 | 50 | - | ns |
| $\frac{\text { Control pulse to ALE }}{\text { PSEN }}$ | 4/15t $\mathrm{CL}^{-40}$ | ${ }^{\text {t }} \mathrm{CA} 2$ | 320 | - | ns |
| $\begin{aligned} & \text { Port control set-up } \\ & \text { to } \overline{\text { PROG }} \end{aligned}$ | $1 / 10 \mathrm{t}_{\mathrm{CL}}-80$ | ${ }^{\mathrm{t}} \mathrm{CP}$ | 50 | - | ns |

## A.C. CHARACTERISTICS (continued)

| parameter | $f(t C L)$ | symbol | 11 MHz |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | min. | max. |  |
| Port control hold to $\overline{\text { PROG }}$ | 4/15t $\mathrm{CL}^{-260}$ | tPC | 100 | - | ns |
| $\overline{\mathrm{PROG}}$ to time port 2 input must be valid | $17 / 30 \mathrm{t}$ CL- 120 | tPR | - | 650 | ns |
| Input data hold time from $\overline{\text { PROG }}$ | 1/10t CL | tPF | 0 | 140 | ns |
| Output data set-up time | 2/5t CL-290 | ${ }^{\text {t }}$ DP | 250 | - | ns |
| Output data hold time | $1 / 10 \mathrm{t}_{\mathrm{CL}}-90$ | ${ }^{\text {tPD }}$ | 40 | - | ns |
| $\overline{\text { PROG pulse width }}$ | 7/10t CL - 250 | tPP | 700 | - | ns |
| Port 2 I/O data set-up time to ALE | 4/15t $\mathrm{CL}^{-200}$ | ${ }^{\text {tPL }}$ | 160 | - | ns |
| Port 2 I/O data hold time to ALE | 1/10t ${ }^{\text {CL }}$-120 | ${ }^{t}$ LP | 15 | - | ns |
| Port output from ALE | $3 / 10 \mathrm{t}_{\mathrm{CL}}+100$ | tpV | - | 510 | ns |
| Cycle time | $(1 / \mathrm{f}$ XTAL $) \times 15$ | ${ }^{\mathrm{t}} \mathrm{CY}$ | 1,36 | 15 | $\mu \mathrm{s}$ |
| T0 repetition rate | $3 / 15 \mathrm{t}$ CL | ${ }^{\text {topRR }}$ | 270 | - | ns |
| Clock period (note 2) | 1/(f XTAL) | ${ }^{t} \mathrm{CL}$ | 98,8 | 1000 | ns |

## Notes to A.C. characteristics

1. Control outputs: $C_{L}=80 \mathrm{pF}$

## Bus outputs: $\quad C_{L}=150 \mathrm{pF}$.

2. $f\left(\mathrm{t}_{\mathrm{CL}}\right)$ assumes $50 \%$ duty cycle on XTAL 1 and XTAL. 2; minimum frequency $=1 \mathrm{MHz}$.
3. Bus high-impedance load: 20 pF .


Fig. 13 Read from external data memory.


Fig. 14 Write to external data memory.


Fig. 15 Instruction fetch from external program memory.


Fig. 16 Port 2 timing.


## SINGLE-CHIP 8-BIT MICROCONTROLLER

## GENERAL DESCRIPTION

The PCB83C552 single-chip 8-bit microcontroller is manufactured in an advanced CMOS process and is a derivative of the PCB80C51 microcontroller family. PCF83C552 has the same instruction set as the PCB80C51. Two versions of the derivative exist although the generic term "PCB83C552" is used to refer to both family members:

- PCB80C552: ROM-less version of the PCB83C552
- PCB83C552: 8 K bytes mask programmable ROM, 256 bytes RAM

This I/O intensive device provides architectural enhancements to function as a controller in the field of automotive electronics, specifically engine management and gear box control.
The PCB83C552 contains a non-volatile $8 \mathrm{~K} \times 8$ read-only program memory (not ROM-less version), a volatile $256 \times 8$ read/write data memory; six 8 -bit I/O ports; two 16 -bit timer/event counters (identical to the timers of the 80 C 51 ); an additional 16 -bit timer coupled to capture and compare latches; a fifteensource, two-priority-level, nested interrupt structure; an ADC and DAC pulse width modulated interface, two serial interfaces; UART and $1^{2} \mathrm{C}$-bus, a 'watchdog' timer and on-chip oscillator and timing circuits. For systems that require extra capability, the PCB83C552 can be expanded using standard TTL compatible memories and logic.
The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of over 100 instructions; 44\% one-byte, 41\% two-byte and $15 \%$ three-byte. With a 12 MHz crystal, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ and $40 \%$ in $2 \mu \mathrm{~s}$. Multiply and divide instructions require $4 \mu \mathrm{~s}$.

## Features

- 80C51 central processing unit
- $8 \mathrm{~K} \times 8$ ROM, expandable externally to 64 K bytes
- $256 \times 8$ RAM, expandable externally to 64 K bytes
- Two standard 16-bit timer/counters
- An additional 16-bit timer/counter coupled to four capture registers and three compare registers
- An A/D converter with 8 multiplexed analogue inputs and 10-bit resolution
- Two 8-bit resolution, Pulse Width Modulated analogue outputs
- Five 8-bit I/O ports plus one 8-bit input port shared with analogue inputs
- $I^{2} \mathrm{C}$ Bus serial I/O port with byte orientated master and slave functions
- Full-duplex UART compatible with the standard PCB80C51
- On-chip watchdog timer


## PACKAGE OUTLINE

PCB83C552: 68-lead PLCC; plastic, leaded-chip-carrier (SOT-188A).

(0) alternative function of port 0
(3) alternative function of port 3
(1) alternative function of port 1
(4) alternative function of port 4
(2) alternative function of port 2
(5) alternative function of port 5
(6) not present in PCB80C552

POWER $\left\{\xrightarrow{V_{C C}+5 V \text { MAIN SUPPLY }}\right.$
SUPPLY $\left\{\begin{array}{l}\longrightarrow \\ V_{S S} \text { GROUND }\end{array}\right.$

Fig. 1 Block diagram.


Fig． 2 Functional diagram．

n.c. $=$ not connected

Fig. 3 Pinning diagram for PCB83C552.

## PINNING



| PINNING (continued) |  |  |
| :---: | :---: | :---: |
| 36 | XTAL1 | Connection to timing component (crystal) that determines the frequency of the internal oscillator. It is also the input for an external clock source |
| 35 | XTAL2 | Connection to other side of timing component |
| 37,38 | $\mathrm{V}_{\text {SS }}$ | Two digital ground pins |
|  |  | Port 2 |
| $\begin{aligned} & 39- \\ & 46 \end{aligned}$ | $\begin{aligned} & \text { P2.0- } \\ & \text { P2.7 } \end{aligned}$ | 8-bit quasi-bidirectional I/O port |
|  |  | Pin Alternative function |
|  |  | P2.0-P2.7 High-order address byte for external memory (A08-A15) |
| 47 | $\overline{\text { PSEN }}$ | Program store enable: active LOW read strobe to external program memory |
| 48 | ALE | Address latch enable: latches the low byte of the address during accesses to external memory. It is activated every six oscillator periods. During a data memory access one ALE pulse is skipped. ALE can drive up to 8 LSTTL inputs and handles CMOS inputs without an external pull-up |
| 49 | $\overline{E A}$ | External access: When $\overline{E A}$ is held at TTL level HIGH, the CPU executes out of the internal program ROM, provided the program counter is less than 8192. When $\overline{E A}$ is held at TTL LOW level, the CPU executes out of external program memory. $\overline{E A}$ is not allowed to float. |
|  |  | Port 0 |
| $\begin{aligned} & 50- \\ & 57 \end{aligned}$ | $\begin{aligned} & \text { P0.7- } \\ & \text { P0.0 } \end{aligned}$ | 8-bit binary I/O port |
|  |  | Pin Alternative function |
|  |  | P0.7-P0.0 Multiplexed low-order address and data bus of external memory (AD7-ADO) |
| 58 | $A V_{\text {ref }}{ }^{-}$ | LOW end of analogue to digital conversion reference resistor |
| 59 | $A V_{\text {ref }}{ }^{+}$ | High end of analogue to digital conversion reference resistor |
| 60 | $A V_{S S}$ | Analogue ground |
| 61 | $A V_{\text {DD }}$ | Analogue power supply |
| 62- | P5.7- | 8-bit input port |
| 68 | P5.0 |  |
| 1 |  | Pin Alternative function |
|  |  | P5.0-P5.7 Eight input channels to ADC (ADC0-ADC7) |

At power-on, the voltage on any pin at any time must not be higher or lower than $\mathrm{V}_{\mathrm{CC}}+0,5 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{SS}}-0,5 \mathrm{~V}$ respectively.

## FUNCTIONAL DESCRIPTION

## General

The PCB83C552 is a stand-alone high-performance microcontroller designed for use in real-time applications such as instrumentation, industrial control and specific automotive control applications.

The device provides in addition to the 80C51 standard functions, a number of dedicated hardware functions for these applications.

The PCB83C552 is a control-oriented CPU with on-chip program and data memory. It can be extended with external program memory up to 64 K bytes. For systems requiring extra capability, the PCB80C552 can be expanded using standard memories and peripherals.
The PCB83C552 has two software selectable modes of reduced activity for further power reduction - Idle and Power Down. The Idle mode freezes the CPU while allowing the RAM, timers, serial port and interrupt system to continue functioning. The Power Down mode saves the RAM contents but freezes the oscillator causing all other chip functions to be inoperative.

## Memory organisation

The central processing unit (CPU) manipulates operands in three memory spaces; these are the 64 K-byte external data memory, 256-byte internal data memory and the 64 K -byte internal and external program memory. The internal data memory address space is sub-divided into the 256-byte internal data RAM and 128-byte Special Function Register (SFR) address spaces, as shown in Fig. 4. Figures 5(a) and (b) show the Special Function Register memory map. Internal RAM locations 0-127 are directly and indirectly addressable. Internal RAM locations 128-256 are only indirectly addressable as internal data RAM. The special function register locations 128-255 are only directly addressable.


Fig. 4 Memory map.

FUNCTIONAL DESCRIPTION (continued)


Figures 5 a and 5 b show the special function registers memory map.


Fig. 5b.

Figures 5 a and 5 b show the special function registers memory map.

## FUNCTIONAL DESCRIPTION (continued)

The internal data RAM contains four register banks (each with eight registers), 128 addressable bits, and the stack. The stack depth is limited by the available internal data RAM and its location is determined by the 8 -bit stack pointer. All registers except the program counter and the four 8 -register banks reside in the special function register address space. These memory mapped registers include arithmetic registers, pointers, I/O ports, interrupt system registers, ADC and PWM registers, timers and serial port registers. There are 128 addressable bit locations in the SFR address space.

The PCB83C552 contains 256 bytes of internal data RAM and 57 special function registers. It provides a non-paged program memory address space to accommodate relocatable code. Conditional branches are performed relative to the program counter. The register-indirect jump permits branching relative to a 16 -bit base register with an offset provided by an 8 -bit index register. 16 -bit jumps and calls permit branching to any location in the contiguous 64 K program memory address space.

## Addressing

The PCB83C552 has five methods for addressing source operands:

- Register
- Direct
- Register-Indirect
- Immediate
- Base-Register plus Index-Register-Indirect

The first three methods can be used for addressing destination operands. Most instructions have a "destination/source" field that specifies the data type, addressing methods and operands involved. For operations other than MOVs, the destination operand is also a source operand.
Access to memory addressing is as follows:

- Registers in one of the four 8-register banks through Register, Direct, or Register-Indirect
- 256 bytes of internal data RAM through Direct or Register-Indirect. Bytes 0-127 may be addressed directly/indirectly. Bytes $128-255$ share their address locations with the SFR registers and so may only be addressed indirectly as data RAM
- Special function registers through Direct at address locations 128-255
- External data memory through Register-Indirect
- Program memory look-up tables through Base-Register-plus Index-Register-Indirect


## Instruction set

The PCB83C552 uses a powerful instruction set to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Assigned opcodes add new high-power operations and permit new addressing modes. The instruction set consists of 49 single-byte, 45 two-byte and 17 three-byte instructions. When using a 12 MHz oscillator, 64 instructions execute in $1 \mu \mathrm{~s}$ and 45 instructions execute in $2 \mu \mathrm{~s}$. Multiply and divide instructions execute in $4 \mu \mathrm{~s}$.

## I/O facilities

The PCB83C552 has six 8-bit ports. Ports 0-3 are the same as in the 80C51, with the exception of the additional functions of port 1. The parallel I/O function of port 4 is equal to that of ports 1,2 and 3 . Port 5 has a parallel input port function, but has no function as an output port. Port lines P1.7 and P1.6 may be selected as the SDA and SCL lines of serial port SIO1 (I $\left.{ }^{2} \mathrm{C}\right)$. Because the $\mathrm{I}^{2} \mathrm{C}$ bus may be active while the device is disconnected from $V_{D D}$, these pins are provided with open drain drivers.
N.B. Therefore these pins do not have pull-up devices when used as ports.

Ports 0, 1, 2, 3, 4 and 5 perform the following alternative functions:

- Port 0; provides the multiplexed low-order address and data bus used for expanding the PCB83C552 with standard memories and peripherals.
- Port 1 ; port 1 is used for a number of special functions;
- 4 capture inputs
- external counter input
- external counter reset input
- SCL and SDA for the $1^{2} \mathrm{C}$ interface

Bits whose alternate function is not used may be used as normal bidirectional I/O pins.

- Port 2; provides the high-order address bus when expanding the PCB83C552 with external program memory and/or external data memory.
- Port 3; pins can be configured individually to provide:
- external interrupt request inputs
- counter inputs
- serial port receiver input and transmitter output
- control signals to READ and WRITE external data memory

The generation or use of a Port 3 pin as an alternative function is carried out automatically by the PCB83C552 provided the pin is loaded with a HIGH content.

- Port 4; can be configured to provide signals indicating a match between timer counter T2 and its compare registers.
- Port 5; may be used in conjunction with the $A / D$ converter interface. Unused analogue inputs can be used as digital inputs. As port 5 lines may be used as input to the A/D converter, these digital inputs have an inherent hysteresis to prevent the input logic from drawing too much current from the power lines when driven by analogue signals.
All ports are bidirectional with the exception of port 5 which is an input port.


Fig. 6 I/O buffers in the PCB83C552 (Ports 1, 2, 3 and 4).

## FUNCTIONAL DESCRIPTION (continued)

In addition to the standard 8-bit ports, the I/O facilities of the PCB83C552 also include a number of specialist I/O lines:

## Pulse width modulated outputs

Two pulse width modulated output channels are provided with the PCB83C552. These channels output pulses of programmable length and interval. The interval length is defined by an 8 -bit prescaler PWMP which generates the clock for the counter. Both the prescaler and counter are common to both PWM channels. The 8 -bit counter counts modulo 255 i.e. from 0 to 254 inclusive. The value of the 8 -bit counter is compared to the contents of two registers; PWM0 and PWM1. Provided the contents of either of these registers is greater than the counter value, the output of PWMON or PWM1N is set LOW. If the contents of these registers are equal to, or less than the counter value, the output will be HIGH. The pulse-width-ratio is therefore defined by the contents of the registers PWMO and PWM1. The pulse-width-ratio is in the range of 0 to 255/255 and may be programmed in increments of $1 / 255$.
The repetition frequency fPWM, at the PWMnN outputs is given by:

$$
f_{P W M}=\frac{f_{\text {OSC }}}{(2+2(P W M P)) \times 255}
$$

This gives a repetition frequency range of 92 Hz to $23,5 \mathrm{kHz}$ ( $\mathrm{f}_{\mathrm{osc}}=12 \mathrm{MHz}$ ).
By loading the PWM registers with either OOH or FFH, the PWM outputs can be retained at a constant HIGH or LOW level respectively. When loading FFH to the PWM registers, the 8 -bit counter will never actually reach this value.
Both PWMnN output pins are driven by push-pull drivers, and are not shared with any other function.
Prescaler frequency control register PWMP

PWMP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

| Bit | Function |
| :--- | :--- |
| PWMP.0-7 | Prescaler division factor $=($ PWMP $)+1$ |

Pulse width registers PWMO and PWM1

PWMO | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PWM1 |  |  |  |  |  |  |  |
| MSB |  |  |  |  |  |  |  | LSB

Bit Function
$\begin{array}{ll}\text { PWM0.0-7 } & \text { Low/high ratio of PWMnN signals }=\frac{(P W M n)}{255-(P W M n)} \\ \text { PWM1.0-7 } & \end{array}$


Fig. 7 Functional diagram of pulse width modulated outputs.

## Analogue input pins

The analogue input circuitry consists of an 8 -input analogue multiplexer and an $A / D$ converter with 10 bit resolution. The analogue reference voltage and analogue power supplies are connected via separate input pins. The conversion time takes 88 machine cycles i.e. $88 \mu \mathrm{~s}$ at 12 MHz oscillator frequency.
The A/D converter is controlled using the ADCON control register. Input channels are selected by the analogue multiplexer, care of ADCON register bits 0-2.
A/D control register ADCON

ADCON
ADC1 ADC0 ADEX ADCI ADCS AADR2 AADR1 AADR0

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Bit
ADCON. 7 - ADC1
ADCON. 6 - ADCO
ADCON. 5 - ADEX

ADCON. 4 - ADCI

## Function

Bit 1 of ADC converted value
Bit 0 of ADC converted value
Enable external start of conversion by STADC
$0=$ Conversion cannot be started externally by STADC
1 = Conversion can be started externally by STADC
ADC interrupt flag: This flag is set when an A/D conversion result is ready to be read. An interrupt is invoked if this is enabled. The flag must be cleared by software. It cannot be set by software.

FUNCTIONAL DESCRIPTION (continued)
ADCON. 3 - ADCS $\quad$ ADC start and status: Setting this bit starts an $A / D$ conversion. It may be set by software or by the external signal STADC. The ADC logic ensures that this signal is HIGH while the ADC is busy. On completion of the conversion, ADCS is reset at the same time the interrupt flag ADCI is set. ADCS can not be reset by software.

| ADCI | ADCS | OPERATION |
| :--- | :--- | :--- |
| 0 | 0 | ADC not busy, a conversion can be started |
| 0 | 1 | ADC busy, start of a new conversion is blocked |
| 1 | 0 | Conversion completed, start of a new conversion is blocked |
| 1 | 1 | Not possible |

$\left.\begin{array}{l}\text { ADCON. } 2-\text { AADR2 } \\ \text { ADCON. } 1 \text { - AADR1 } \\ \text { ADCON. } 0 \text { - AADRO }\end{array}\right\} \begin{aligned} & \text { Analogue input select: This binary coded address selects one of the eight } \\ & \text { analogue port bits of P5 to be input to the converter. It can only be changed } \\ & \text { when } A D C I \text { and ADCS are both LOW. }\end{aligned}$
The completion of the 10 -bit $A / D$ conversion is flagged by $A D C 1$ in the $A D C O N$ register and the result is stored in special function register ADCH (upper 8 bits) and the 2 LSBs in register ADCON.
An A/D conversion in progress is unaffected by an external or software ADC start. The result of a completed conversion remains unaffected provided $A D S I=$ logic 1 . During as $A D C S=$ logic 1 or $A D C I=$ logic 1, a new ADC START will be blocked and consequently lost. An A/D conversion already in progress is aborted when the IDLE or Power Down mode is entered. The result of a completed conversion ( $\mathrm{ADCI}=$ logic 1) remains unaffected when entering the IDLE mode.


Fig. 8 Functiona! diagram of analogue input.

## Timer/event counters

The PCB83C552 contains three 16 -bit timer/event counters; Timer 0, Timer 1 and Timer T2 and one 8 -bit timer, T 3 . Timer 0 and Timer 1 may be programmed to carry out the following functions:

- Measure time intervals and pulse durations
- Count events
- Generate interrupt requests

Timer 0 and Timer 1 can be programmed independently to operate in three modes:

- Mode 0;8-bit timer or 8-bit counter each with divide by 32 prescaler
- Mode 1; 16-bit time-interval or event counter
- Mode 2; 8-bit time-interval or event counter with automatic reload upon overflow

Timer 0 can be programmed to operate in an additional mode as follows:

- Mode 3; one 8-bit time-interval or event counter and one 8-bit time-interval counter

When Timer 0 is in Mode 3, Timer 1 can be programmed to operate in Modes 0 , 1 or 2 but cannot set an interrupt request flag or generate an interrupt. However the overflow from Timer 1 can be used to pulse the serial Port transmission-rate generator.
The frequency handling range of these counters with a 12 MHz crystal is as follows:

- In the timer function, the timer is incremented at a frequency of 1 MHz , that is, a division by 12 of the oscillator frequency
- 0 Hz to an upper limit of $0,5 \mathrm{MHz}$ when programmed for external inputs

Both internal and external inputs can be gated to the counter by a second external source for directly measuring pulse durations.

The counters are started and stopped under software control. Each one sets its interrupt request flag when it overflows from all logic 1 s to all logic 0 s (or automatic reload value), with the exception of mode 3 as previously described.

## Timer T2

Timer T2 is a 16 bit register which has, coupled to it, capture and compare facilities. The operational diagram is shown in Fig. 9.
The 16 bit timer/counter is clocked via a prescaler with a programmable division factor of $1,2,4$ or 8 . The input of the prescaler is clocked with $1 / 12$ of the oscillator frequency, or with positive edges on the T2 input, or it is switched to the off position. This prescaler is cleared if its division factor or its input source is changed, or if the timer/counter is reset. T2 is readable 'on the fly', but posseses no extra read latches, this means that software precautions have to be taken against misinterpretation in overflow from least to most significant byte during read. T2 is not loadable and is reset by the RST signal or at the positive edge of the input signal RT2, is enabled. In the IDLE mode the timer/counter and prescaler are reset and halted.
T2 is connected to four 16 -bit capture registers; (CT0), CT1, CT2 and CT3). These registers are loaded with the contents of T2 and an interrupt requested upon receipt of the input signals CTOI, CT11, CT21 or CT3I. These input signals are shared with port 1 . Using the capture register CTCON, an interrupt/ capture on a positive, negative edge or both may be triggered.

## FUNCTIONAL DESCRIPTION (continued)

The contents of the compare registers CMO, CM1 and CM2 are continually compared with the counter value of Timer T2. When a match is found an interrupt may be invoked. Using the match signal of CMO, the controller sets bits $0-5$ of port 4, if the corresponding bits of the set enable register STE are logic 1. Considering a match with CM1, if the corresponding bits of the reset/toggle enable register RTE are logic 1 , then the controller will use the match signal to reset bits $0-5$ of port 4 . Bits 6 and 7 of port 4 may be 'toggled' by the signal that indicates a match between Timer T2 and CM2, again, if the corresponding bits of RTE are logic 1. CM0, CM1 and CM2 are reset by the RST signal.
Port 4 can be read and written by software without affecting the toggle, set and reset signals. At byte overflow of the least significant byte, or at a 16 -bit overflow of the timer/counter, an interrupt sharing the same interrupt vector is requested. Either or both of these overflows can be programmed to request an interrupt.
All interupt flags must be reset by software.


Fig. 9 Block diagram of Timer T2 configuration.

Capture control register CTCON
CTCON

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

Bit Capture/interrupt at:

| CTCON.0 | CTOI | positive edge |
| :--- | :--- | :--- |
| CTCON. 1 | CT01 | negative edge |
| CTCON.2 | CT1I | positive edge |
| CTCON.3 | CT1I | negative edge |
| CTCON.4 | CT21 | positive edge |
| CTCON.5 | CT21 | negative edge |
| CTCON.6 | CT31 | positive edge |
| CTCON. 7 | CT31 | negative edge |

Counter control register TM2CON
TM2CON

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

## Bit

TM2CON. 0
TM2CON. 1
" $x$ " MODE SELECT BIT
"x" MODE SELECT BIT

TM2CON. 2 " $x$ " PRESCALER BIT
TM2CON. 3 " $x$ " PRESCALER BIT

## Function

T2CON.0/T2CON. 1
$00=$ Timer T2 is halted
$01=$ Timer T2 input source $=\frac{\mathrm{f}_{\text {osc }}}{12}$
$10=$ Test mode, do not use
$11=$ Timer T2 input source $=\operatorname{pin}$ T2
T2CON.3/T2CON. 2
$00=$ DIVISION by 1
$01=$ DIVISION by 2
$10=$ DIVISION by 4
$11=$ DIVISION by 8

TM2CON. 4 T2 Byte overflow INT flag
TM2CON. 5 ERT2 switch
TM2CON. 6 Select byte overflow interrupt
TM2CON. 7 Select 16 bit overflow interrupt
Timer interrupt enable register IEN1
IEN1

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

## Bit

IEN1.7 " $0 / 1^{\prime \prime} \quad$ T2 overflow interrupts disabled/enabled
IEN1.6 " $0 / 1$ " interrupt CM2 disabled/enabled
IEN1.5 " $0 / 1$ " interrupt CM1 disabled/enabled
IEN1.4 " $0 / 1$ " interrupt CMO disabled/enabled
IEN1.3 " $0 / 1$ " interrupt CT3 disabled/enabled
IEN1.2 " $0 / 1$ " interrupt CT2 disabled/enabled
IEN1.1 " $0 / 1$ " interrupt CT1 disabled/enabled
IEN1.0 " $0 / 1 "$ interrupt CTO disabled/enabled

FUNCTIONAL DESCRIPTION (continued)
Timer interrupt flag register TM2IR
TM2IR

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

Bit
Function
TM2IR. 7
T2 16-bit overflow interrupt flag
TM2IR. 6
CM2 interrupt flag
TM2IR. $5 \quad$ CM1 interrupt flag
TM2IR. $4 \quad$ CM0 interrupt flag
TM2IR. $3 \quad$ CT3 interrupt flag
TM2IR. $2 \quad$ CT2 interrupt flag
TM2IR. 1 CT1 interrupt flag
TM2IR. $0 \quad$ CTO interrupt flag
Interrupt priority register IP1 is used to determine the timer interrupt priority.
The set enable register STE.
STE

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

## Bit

Function
STE. 0 " 1 " := P40 is set at match CMO and T2
STE. 1 " 1 " := P41 is set at match CMO and T2
STE. 2 " 1 " $:=\mathrm{P} 42$ is set at match CMO and T2
STE. 3 "1" := P43 is set at match CMO and T2
STE. 4 " 1 " $:=\mathrm{P} 44$ is set at match CMO and T2
STE. 5 " 1 " := P 45 is set at match CMO and T2
STE. $6 \quad:=$ not used
STE. $7 \quad:=$ not used
STE.n " 0 " := P 4 n is not affected by a match
The reset/toggle enable register RTE.
RTE

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  |  |  |  |  |  |

Bit Function
RTE. 0 " 1 " := P40 is reset at match CM1 and T2
RTE. 1 " 1 " $=$ P41 is reset at match CM1 and T2
RTE. 2 " 1 " := P42 is reset at match CM1 and T2
RTE. 3 " 1 " $:=\mathrm{P} 43$ is reset at match CM1 and T2
RTE. 4 " 1 " $:=$ P44 is reset at match CM1 and T2
RTE. 5 " 1 " $=$ P45 is reset at match CM1 and T2
RTE. 6 " 1 " $:=$ P46 toggles at match CM2 and T2
RTE. 7 " 1 " $:=\mathrm{P} 47$ toggles at match CM2 and T2
RTE.n " 0 " $:=\mathrm{P} 4 \mathrm{n}$ is not affected by a match


Fig. 10 Functional diagram of T 3 watchdog timer.
T3 The watchdog timer (see Fig. 10)
In addition to Timer T2 and the standard timers, a watchdog timer consisting of an 11-bit prescaier and an 8-bit timer are also incorporated.
The timer is incremented every 2 ms , derived from the oscillator frequency of 12 MHz by the following:

$$
\mathrm{f}_{\text {timer }}=\frac{\mathrm{f}_{\mathrm{osc}}}{12 \times 2048}
$$

When a timer overflow occurs, the microcontroller is reset and a reset output pulse is generated at pin RST. To prevent a system reset the timer must be reloaded in time by the application software. If the processor suffers a hardware/software malfunction, the software will fail to reload the timer. This failure will produce a reset upon overflow thus preventing the processor running out of control.
The watchdog timer can only be reloaded if the condition flag WLE $=$ PCON. 4 has been previously set by software.
At the moment the counter is loaded the condition flag is automatically cleared.
The time interval between the timer's reloading and occurance of a reset, is dependent upon the reloaded value. This may range from 2 ms to $0,5 \mathrm{~s}$ at an oscillator frequency of 12 MHz .
In the IDLE state the watchdog timer and reset circuitry remain active.
The watchdog timer is controlled by the watchdog enable pin (EWN). A logic 0 enables the watchoiog timer and disables the Power Down mode. A logic 1 disables and resets the watchdog timer and enables the power-down mode.

## FUNCTIONAL DESCRIPTION (continued)

## Serial I/O (see Fig. 11)

The PCB83C552 is equipped with two independent serial ports. SIO0 is the full duplex UART port and is identical to the serial port of the PCB80C51.
Serial port SIO1 supports the $I^{2} \mathrm{C}$ bus, the function of which is controlled by the S1CON register. S1STA is the status register whose contents may also be used as a vector to various service routines. S1DAT is the data shift register and S1ADR the slave address register.


Fig. 11 Block diagram of $\mathrm{I}^{2} \mathrm{C}$ serial $\mathrm{I} / \mathrm{O}$.
The $\mathrm{I}^{2} \mathrm{C}$ serial $\mathrm{I} / \mathrm{O}$ has complete autonomy in byte handling and operates in 4 modes:

1. Master transmitter
2. Master receiver
3. Slave transmitter
4. Slave receiver

Slave address recognition is performed by hardware.
The $I^{2} \mathrm{C}$ bus consists of two lines; a data line (SDA) and a clock line (SCL). These lines also function as the I/O port lines on P1.7 and P1.6. The system is unique because data transport, clock generation, address recognition and bus control arbitration are all controlled by hardware.
Serial control register S1CON

S1CON

| $X$ | ENSI | STA | STO |  |  |  | SI |  |  | CR1 | CRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |

Bits CR1 and CR0 determine the clock frequency that is generated in the master mode of operation.
Table 1 displays the clock rate when using a 12 MHz crystal.

Table 1 Clock state when using a 12 MHz crystal

| CR1/CR0 |  | bit frequency | $f_{\text {osc }}$ divided by |
| :--- | :--- | :--- | :--- |
| 0 | 0 | $12,5 \mathrm{kHz}$ | 960 |
| 0 | 1 | 100 kHz | 120 |
| 1 | 0 | 200 kHz | $60\left(\mathrm{f}_{\text {osc }}<6 \mathrm{MHz}\right.$ meeting $\left.{ }^{2} \mathrm{C}\right)$ <br> 1 1 |

AA
Assert acknowledge bit. When this bit is set, an acknowledge is returned after any one of the following conditions:

- Own slave address is received
- General call address is received (S1ADR.0 = logic 1)
- A data byte is received, while the device is programmed to be a master receiver
- A data byte is received, while the device is a selected slave receiver

When this bit is reset, no acknowledge is returned. Consequently, no interrupt is requested when the own address or general call address is received.

## SI

SIO1 interrupt flag. This flag is set, and an interrupt request is generated, after any of the following events occur:

- A START condition is generated in MST mode
- The own slave address has been received during AA = logic 1
- The general call address has been received while S1ADR. 0 and AA $=$ logic 1
- A data byte has been received or transmitted in MST mode (even if arbitration is lost)
- A data byte has been received or transmitted as selected slave
- A STOP or START condition is received as selected slave receiver or transmitter


## STO

STOP flag. When in master mode, and this bit is set a STOP condition is generated. A STOP condition detected on the $I^{2} \mathrm{C}$ bus clears this bit. This bit may also be set in slave mode in order to recover from an error condition. Then no STOP condition is generated to the $I^{2} \mathrm{C}$ bus, but the hardware releases the SDA and SCL lines and switches to the not selected slave receiver mode. The STOP flag is cleared by the hardware.

## STA

START flag. When this bit is set in slave mode, the hardware checks the $I^{2} \mathrm{C}$ bus and generates a START condition if the bus is free or after the bus becomes free. If the device operates in master mode it will generate a repeated START condition.

## FUNCTIONAL DESCRIPTION (continued)

## ENSI

$0=$ Serial I/O Disabled and reset. P1.6 and P1.7 I/O port function with open drain
$1=$ Serial I/O Enabled. Output ports P1.6 and P1.7 must be set to logic 1
Serial status register S1STA (S1STA is a read-only register)

S1STA

| SC4 | SC3 | SC2 | SC1 | SC0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

S1STA. 3 - S1STA. 7 hold a status code. S1STA. 0 - S1STA. 2 are held LOW. The contents of the status register may be used as a vector to a service routine. This optimizes the response time of the software and consequently that of the $I^{2} \mathrm{C}$ bus.
The following is a list of the status codes in decimal representation. The decimal value corresponds to the value of the upper five bits of the status register.

| SLA | $:$ 7-bit slave address |
| :--- | :--- |
| R | : Read bit |
| W | : Write bit |
| ACK | : Acknowledgement (acknowledge bit = logic 0) |
| $\overline{\text { ACK }}$ | : Not acknowledgement (acknowledge bit = logic 1) |
| DATA | $:$ 8-bit data byte to or from $1^{2}$ C bus |
| MST | $:$ Master |
| SLV | : Slave |
| TRX | : Transmitter |
| REC | : Receiver |

## MST/TRX mode

## SISTA value

1 - A START condition has been transmitted
2 - A repeated START condition has been transmitted
3 - SLA and W have been transmitted, ACK has been received
4 - SLA and W have been transmitted, $\overline{\text { ACK }}$ received
5 - DATA of S1DAT has been transmitted, ACK received
6 - DATA of S1DAT has been transmitted, $\overline{\text { ACK }}$ received
7 - Arbitration lost in SLA and R/W or DATA

## MST/REC mode

S1STA value
7 - Arbitration lost while returning $\overline{\text { ACK }}$
8 - SLA and R have been transmitted, ACK received
9 - SLA and $R$ have been transmitted, $\overline{A C K}$ received
10 - DATA has been received, ACK returned
11 - DATA has been received, $\overline{\mathrm{ACK}}$ returned

## SLV/REC mode

## S1STA value

12 - Own SLA and $W$ have been received, ACK returned
13 - Arbitration lost in SLA and R/W as MST. Own SLA and W have been received, ACK returned
14 - General CALL has been received, ACK returned
15 - Arbitration lost in SLA and R/W as MST. General call has been received
16 - Previously addressed with own SLA. DATA byte received, ACK returned
17 - Previously addressed with own SLA. DATA byte received $\overline{\text { ACK }}$ returned
18 - Previously addressed with general call. DATA byte has been received ACK has been returned
19 - Previously addressed with general call. DATA byte has been received, $\overline{\text { ACK }}$ has been returned
20 - A STOP condition or repeated START condition has been received while still addressed as SLV/REC or SLV/TRX.

## SLV/TRX mode

## S1STA value

21 - Own SLA and R have been received, ACK returned
22 - Arbitration lost in SLA and R/W as MST. Own SLA and R have been received, ACK returned
23 - DATA byte has been transmitted, ACK received
24 - DATA byte has been transmitted, $\overline{\text { ACK }}$ received
24 - Last DATA byte has been transmitted ( $A A=$ logic 0 ) ACK received

## Miscellaneous

## S1STA value

00 - Bus error during MST mode or selected SLV mode, due to an erroneous START or STOP condition

## The data shift register S1DAT

S1DAT $\quad$| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

This register contains the serial data to be transmitted or data which has just been received. Bit 7 is transmitted or received first; i.e. data is shifted from right to left.

## Address register S1ADR

S1ADR

| slave address |  |  |  |  |  | GC |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

S1ADR.0, GC : $0=$ general call address is not recognized
$1=$ general call address is recognized
S1ADR,7-1 : own slave address
This 8-bit register may be loaded with the 7-bit slave address to which the controller will respond when programmed as a slave receiver/transmitter. The LSB bit (GC) is used to determine whether the general call address is recognized.

## FUNCTIONAL DESCRIPTION (continued)

Idle and Power-down operation (see Fig. 12)
Idle mode operation permits the interrupt, serial ports and timer blocks to continue to function while the clock to the CPU is halted. The following functions are also switched off when the processor enters the IDLE mode.

| Timer T2 | (stopped and reset) |
| :--- | :--- |
| PWM0, PWM1 | (reset, output = HIGH) |
| ADC | (aborted if in progress) |

The following functions remain active during IDLE mode. These functions may generate an interrupt or reset and thus end the IDLE mode.

Timer 0, Timer 1
Timer T3
SIOO, SIO1
External interrupt
The Power-down operation freezes the oscillator. The Power-down mode can only be activated by setting the PD bit in the PCON register. The PD bit can only be set if the EWN input is HIGH.

## Idle mode

The instruction that sets PCON. 0 is the last instruction executed in the normal operating mode before Idle mode is activated. Once in the Idle mode, the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM and all other registers maintain their data during Idle mode. The status of the external pins during Idle mode is shown in Table 2.
There are two ways to terminate the Idle mode:
Activation of any enabled interrupt will cause PCON. 0 to be cleared by hardware terminating Idle mode. The interrupt is serviced, and following return from interrupt instruction RETI, the next instruction to be executed will be the one which follows the instruction that wrote a logic 1 to PCON.0.
The flag bits GFO and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the instruction that writes to PCON. 0 can also set or clear one or both flag bits. When Idle mode is terminated by an interrupt, the service routine can examine the status of the flag bits.
The second way of terminating the Idle mode is with an external hardware reset, or an internal reset caused by an overflow of Timer T3. Since the oscillator is still running, the hardware reset is required to be active for two machine cycles ( 24 oscillator periods) to complete the reset operation.

## Power-down mode

The instruction that sets PCON. 1 is the last executed prior to going into the Power-down mode. Once in Power-down mode, the oscillator is stopped. Only the contents of the on-chip RAM are preserved. The Special Function Registers are not saved. A hardware reset is the only way of exiting the Powerdown mode.
In the Power-down mode, $\mathrm{V}_{\mathrm{DD}}$ may be reduced to minimize circuit power consumption. The voltage must not be reduced until the Power-down mode is entered, but must be restored before the hardware reset is applied which will free the oscillator. Reset should not be released until the oscillator has restarted and stabilized.
The status of the external pins during Power-down mode is shown in Table 2. If the Power-down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a logic 1, the port pin is held HIGH during the Powerdown mode by the strong pull-up transistor P1 (see Fig. 6).

Table 2 Status of external pins during Idle and Power-down modes

| mode | memory | ALE | $\overline{\text { PSEN }}$ | Port 0 | Port 1 | Port 2 | Port 3 | Port 4 | PWMON/PWM1N |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Idle (1) | internal | 1 | 1 | port data | port data | port data | port data | port data | HIGH |
| Idle (1) | external | 1 | 1 | floating | port data | address | port data | port data | HIGH |
| Power-down | internal | 0 | 0 | port data | port data | port data | port data | port data | HIGH |
| Power-down | external | 0 | 0 | floating | port data | port data | port data | port data | HIGH |

Power control register (PCON)
These special modes are activated by software via the Special Function Register PCON. Its hardware address is 87 H . PCON is not bit addressable.

PCON

| SMOD | X | X | WLE | GF1 |  | GF0 | PD |  | IDL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |

## Bit Definition

SMOD PCON. 7 Double Baud rate bit. When set to logic 1 the baud rate is doubled when the serial port SIOO is being used in modes 1, 2 or 3

DEVELOPMENT DATA
WLE PCON. 4 Watchdog load enable; This flag must be set by software prior to loading T3 (watchdog timer). It is cleared by loading T3
GF1 PCON. 3 general-purpose flag bit
GF0 PCON. 2 general-purpose flag bit
PD PCON. 1 Power-down bit; setting this bit activates power-down mode, can only be set if input EWN is logic 1
IDL PCON. $0 \quad$ Idle mode bit; setting this bit activates the idle mode operation
If logic 1 s are written to PD and IDL at the same time, PD takes precedence. The reset value of PCON is ( $0 \times \times 00000$ ).


Fig. 12 Internal Idle and Power-down clock configuration.

## FUNCTIONAL DESCRIPTION (continued)

## Interrupt system (see Fig. 13)

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, two-priority-level, nested interrupt system is provided. Interrupt response latency is from $3 \mu \mathrm{~s}$ to $8 \mu \mathrm{~s}$ when using a 12 MHz crystal. The PCB83C552 acknowledges interrupt requests from fifteen sources as follows:

- $\overline{\text { INTO }}$ and $\overline{\mathrm{INT} 1}$; externally via pins 26 and 27 respectively
- Timer 0 and Timer 1 ; from the two internal counters
- Timer T2, 8 separate interrupts; 4 capture interrupts, 3 compare interrupts and an overflow interrupt
- ADC end-of-conversion interrupt
- $I^{2} \mathrm{C}$ serial I/O port interrupt
- UART serial I/O port interrupt

Each interrupt vectors to a separate location in program memory for its service program. Each source can be individually enabled or disabled by a corresponding bit in the IEO or IE1 register, moreover each interrupt may be programmed to a high or low priority level using a corresponding bit in the IPO or IP1 register. Also all enabled sources can be globally disabled or enabled. Both external interrupts can be programmed to be level-activated or transition-activated; an active LOW level allows "wire-ORing" of several interrupt sources to one input pin.


Fig. 13 Interrupt system

## FUNCTIONAL DESCRIPTION (continued)

Interrupt enable registers
IENO

| EA | EAD | ES1 | ES0 | ET1 | EX1 | ET0 | EX0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bit
IENO. 7 EA
Function
General enable/disable control
$0=$ No interrupt is enabled
1 = Any individually enabled interrupt will be accepted
IENO.6 EAD Enable ADC interrupt
IEN0.5 ES1 Enable SIO1 $I^{2} \mathrm{C}$ interrupt
IENO.4 ES Enable SIOO (UART) interrupt
IEN0.3 ET1 Enable Timer 1 interrupt
IEN0.2 EX1 Enable External 1 interrupt
IENO. 1 ETO Enable Timer 0 interrupt
IENO.O EXO Enable External 0 interrupt

IEN1

| ET2 |
| :--- |
| EMC2 |
| EMC1 |
|  ECMO ECT3 ECT2 ECT1 ECT0 |


| Bit |  | Function |
| :--- | :--- | :--- |
| IEN1.7 | ET2 | Enable T2 overflow interrupt(s) |
| IEN1.6 | ECM2 | Enable T2 comparator 2 interrupt |
| IEN1.5 | ECM1 | Enable T2 comparator 1 interrupt |
| IEN1.4 | ECM0 | Enable T2 comparator 0 interrupt |
| IEN1.3 | ECT3 | Enable T2 capture register 3 interrupt |
| IEN1.2 | ECT2 | Enable T2 capture register 2 interrupt |
| IEN1.1 | ECT1 | Enable T2 capture register 1 interrupt |
| IEN1.0 | ECT0 | Enable T2 capture register 0 interrupt |

Interrupt priority registers
IPO

| X | PAD | PS1 | PS0 | PT1 | PX1 |  | PTO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bit
IP0.7
IP0.6
IP0.5
IP0.4
IP0. 3
IP0.2
IP0.1
IPO.O
IP1

DEVELOPMENT DATA
Bit
IP1.7
IP1.6
IP1.5
IP1.4
IP1.3
IP1.2
IP1.1
IP1.0

Function
Unused
ADC interrupt priority level
PAD ADC interrupt priority level
PS1 SIO1 ( $\left.I^{2} \mathrm{C}\right)$ interrupt priority level
PSO SIOO (UART) interrupt priority level
PT1 Timer 1 interrupt priority level
PX1 External interrupt 1 priority level
PTO Timer 0 interrupt priority level
PX0 External interrupt 0 priority level

| PT2 | PCM2 | PCM1 | РСМО | PCT3 | PCT2 | PCT1 | РСТО |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Function
PT2 T2 overflow interrupt(s) priority level
PCM2 T2 comparator 2 priority interrupt
PCM1 T2 comparator 1 priority interrupt
PCMO T2 comparator 0 priority interrupt
PCT3 T2 capture register 3 priority interrupt
PCT2 T2 capture register 2 priority interrupt
PCT1 T2 capture register 1 priority interrupt
PCTO T2 capture register 0 priority interrupt

FUNCTIONAL DESCRIPTION (continued)
Table 3 shows the interrupt vectors. The vector indicates the ROM location where the appropriate interrupt service routine starts.

Table 3 Interrupt vectors

| Source |  | Vector |
| :--- | :--- | :--- |
| External 0 | X0 | 0003 H |
| Timer 0 overflow | T0 | 000 BH |
| External 1 | X1 | 0013 H |
| Timer 1 overflow | T1 | 001 BH |
| Serial I/O 0 (UART) | SO | 0023 H |
| Serial I/O $1\left(I^{2} \mathrm{C}\right)$ | S1 | 002 BH |
| T2 capture 0 | CT0 | 0033 H |
| T2 capture 1 | CT1 | 003 BH |
| T2 capture 2 | CT2 | 0043 H |
| T2 capture 3 | CT3 | 004 BH |
| ADC completion | ADC | 0053 H |
| T2 compare 0 | CM0 | 005 BH |
| T2 compare 1 | CM1 | 0063 H |
| T2 compare 2 | CM2 | 006 BH |
| T2 overflow | T2 | 0073 H |

## Interrupt priority

Each interrupt source can be provided by software with two priority levels; logic 1 and logic 0 . If both levels are requested simultaneously, the processor will branch to the logic 1 vector. If there are simultaneous requests from sources of the same priority, then interrupts will be serviced in the following order:

X0, S1, ADC, T0, CT0, CM0, X1, CT1, CM1, T1, CT2, CM2, S0, CT3, T2
A logic 0 interrupt routine can be interrupted by a logic 1 interrupt.

## Oscillator circuitry

The oscillator circuitry of the PCB83C552 is a single-stage inverting amplifier in a Pierce oscillator configuration. The circuitry between XTAL 1 and XTAL 2 is basically an inverter biased to the transfer point. Either a crystal or ceramic resonator can be used as the feedback element to complete the oscillator circuitry. Both are operated in parallel resonance. XTAL 1 (pin 36) is the high gain amplifier input, and XTAL 2 (pin 35) is the output (see Fig. 14). To drive the PCB83C552 externally, XTAL 1 is driven from an external source and XTAL 2 left open-circuit (see Fig. 15).


Fig. 14 PCB83C552 oscillator circuit.


Fig. 15 Driving the PCB83C552 from an external source.

## Reset circuitry (see Fig. 16)

The reset circuitry for the PCB83C552 is connected to the reset pin RST. A Schmitt trigger is used at the input for noise rejection. The output of the Schmitt trigger is sampled by the reset circuitry every machine cycle.


Fig. 16 Reset configuration at RST.
A reset is accomplished by holding the RST pin HIGH for at least two machine cycles ( 24 oscillator periods), while the oscillator is running. The CPU responds by executing an internal reset. During reset ALE and PSEN output a HIGH level. In order to perform a correct reset, this level must not be affected by external elements.
Also with the PCB83C552, the RST line can be pulled HIGH internally by a pull-up transistor activated by the watchdog timer T3. The length of the output pulse from T3 is 3 machine cycles. A pulse of such short duration is necessary in order to recover from a processor or system fault as fast as possible.

## FUNCTIONAL DESCRIPTION (continued)

N.B. It can be seen, that the short reset pulse from Timer T3 cannot discharge the power-on reset capacitor (see Fig. 17). Consequently, when the watchdog timer is also used to reset external devices this capacitor arrangement should not be connected to the RST pin, and an extra circuit should be used to perform the power-on reset operation. It should be remembered that a Timer T3 overflow, if enabled, will force a reset condition to the 83C552 by an internal connection, whether the output RTS is tied LOW or not.

The internal reset is executed during the second cycle in which RST is HIGH and is repeated every cycle until RST goes LOW. It leaves the internal registers as follows:

| Register | Content |  |
| :---: | :---: | :---: |
| ACC | 0000 | 0000 |
| ADCON | XX00 | 0000 |
| ADCH | XXXX | XXXX |
| B | 0000 | 0000 |
| CMLO - CML2 | 0000 | 0000 |
| CMHO-CMH1 | 0000 | 0000 |
| CTCON | 0000 | 0000 |
| CTLO - CTL3 | XXXX | XXXX |
| CTH0-CTH3 | XXXX | XXXX |
| DPL | 0000 | 0000 |
| DPH | 0000 | 0000 |
| IENO | 0000 | 0000 |
| IEN1 | 0000 | 0000 |
| IPO | X000 | 0000 |
| IP1 | 0000 | 0000 |
| PCH | 0000 | 0000 |
| PCL | 0000 | 0000 |
| PCON | OXX0 | 0000 |
| PSW | 0000 | 0000 |
| PWMO | 0000 | 0000 |
| PWM1 | 0000 | 0000 |
| PWMP | 0000 | 0000 |
| P0 - P4 | 1111 | 1111 |
| P5 | XXXX | XXXX |
| RTE | 0000 | 0000 |
| SOBUF | XXXX | XXXX |
| SOCON | 0000 | 0000 |
| S1ADR | 0000 | 0000 |
| S1CON | X000 | 0000 |
| S1DAT | 0000 | 0000 |
| S1STA | 1111 | 1000 |
| SP | 0000 | 0111 |
| STE | XX00 | 0000 |
| TCON | 0000 | 0000 |
| THO, TH1 | 0000 | 0000 |
| TMH2 | 0000 | 0000 |
| TL0, TL1 | 0000 | 0000 |
| TML2 | 0000 | 0000 |
| TMOD | 0000 | 0000 |
| TM2CON | 0000 | 0000 |
| TM2IR | 0111 | 0000 |
| T3 | 0000 | 0000 |

The internal RAM is not affected by reset. When $V_{D D}$ is turned on, the RAM content is indeterminate.

## Power-on reset (see Fig. 17)

When $V_{D D}$ is turned on, and provided its rise-time does not exceed 10 ms , an automatic reset can be obtained by connecting the RST pin to $\mathrm{V}_{\text {DD }}$ via a $10 \mu \mathrm{~F}$ capacitor. When the power is switched on, the current drawn by RST is the difference between $V_{D D}$ and the capacitor voltage, and decreases from $V_{D D}$ as the capacitor charges through the internal resistor ( $\mathrm{R}_{\mathrm{RST}}$ ) to ground. The larger the capacitor, the more slowly $\mathrm{V}_{\text {RST }}$ decreases. $\mathrm{V}_{\text {RST }}$ must remain above the lower threshold of the Schmitt trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles.


Fig. 17 Power-on reset.

INSTRUCTION SET
Table 4 Instruction set description

| mnemonic |  | description |  |  | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Arithmetic operations |  |  |  |  |  |
| ADD | A, Rr | Add register to A | 1 | 1 | 2* |
| ADD | A,direct | Add direct byte to A | 2 | 1 | 25 |
| ADD | A,@Ri | Add indirect RAM to A | 1 | 1 | 26, 27 |
| ADD | A, \#data | Add immediate data to A | 2 | 1 | 24 |
| ADDC | A, Rr | Add register to A with carry flag | 1 | 1 | 3* |
| ADDC | A,direct | Add direct byte to A with carry flag | 2 | 1 | 35 |
| ADDC | A,@Ri | Add indirect RAM to A with carry flag | 1 | 1 | 36, 37 |
| ADDC | A, \#data | Add immediate data to A with carry flag | 2 | 1 | 34 |
| SUBB | A, Rr | Subtract register from A with borrow | 1 | 1 | 9* |
| SUBB | A,direct | Subtract direct byte from A with borrow | 2 | 1 | 95 |
| SUBB | A,@Ri | Subtract indirect RAM from A with borrow | 1 | 1 | 96, 97 |
| SUBB | A,\#data | Subtract immediate data from A with borrow | 2 | 1 | 94 |
| INC | A | Increment A | 1 | 1 | 04 |
| INC | Rr | Increment register | 1 | 1 | 0* |
| INC | direct | Increment direct byte | 2 | 1 | 05 |
| INC | @Ri | Increment indirect RAM | 1 | 1 | 06, 07 |
| DEC | A | Decrement A | 1 | 1 | 14 |
| DEC | Rr | Decrement register | 1 | 1 | 1* |
| DEC | direct | Decrement direct byte | 2 | 1 | 15 |
| DEC | @Ri | Decrement indirect RAM | 1 | 1 | 16, 17 |
| INC | DPTR | Increment data pointer | 1 | 2 | A3 |
| MUL | AB | Multuply A \& B | 1 | 4 | A4 |
| DIV | $A B$ | Divide A by B | 1 | 4 | 84 |
| DA | A | Decimal adjust $A$ | 1 | 1 | D4 |


| mnemonic |  | description |  |  | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logic operations |  |  |  |  |  |
| ANL | A, Rr | AND register to A | 1 | 1 | 5* |
| ANL | A,direct | AND direct byte to A | 2 | 1 | 55 |
| ANL | A,@Ri | AND indirect RAM to $A$ | 1 | 1 | 56,57 |
| ANL | A,\#data | AND immediate data to $A$ | 2 | 1 | 54 |
| ANL | direct,A | AND A to direct byte | 2 | 1 | 52 |
| ANL | direct,\#data | AND immediate data to direct byte | 3 | 2 | 53 |
| ORL | A, Rr | OR register to A | 1 | 1 | 4* |
| ORL | A, direct | OR direct byte to $A$ | 2 | 1 | 45 |
| ORL | A,@Ri | OR indirect RAM to $A$ | 1 | 1 | 46, 47 |
| ORL | A, \#data | OR immediate data to $A$ | 2 | 1 | 44 |
| ORL | direct, A | OR A to direct byte | 2 | 1 | 42 |
| ORL | direct,\#data | OR immediate data to direct byte | 3 | 2 | 43 |
| XRL | A, Rr | Exclusive-OR register to $A$ | 1 | 1 | 6* |
| XRL | A,direct | Exclusive-OR direct byte to $A$ | 2 | 1 | 65 |
| XRL | A,@Ri | Exclusive-OR indirect RAM to $A$ | 1 | 1 | 66, 67 |
| XRL | A, \#data | Exclusive-OR immediate data to $A$ | 2 | 1 | 64 |
| XRL | direct, A | Exclusive-OR A to direct byte | 2 | 1 | 62 |
| XRL | direct,\#data | Exclusive-OR immediate data to direct byte | 3 | 2 | 63 |
| CLR | A | Clear A | 1 | 1 | E4 |
| CPL | A | Complement $A$ | 1 | 1 | F4 |
| RL | A | Rotate A left | 1 | 1 | 23 |
| RLC | A | Rotate A left through the carry flag | 1 | 1 | 33 |
| RR | A | Rotate A right | 1 | 1 | 03 |
| RRC | A | Rotate A right through the carry flag | 1 | 1 | 13 |
| SWAP | A | Swap nibbles within A | 1 | 1 | C4 |

INSTRUCTION SET (continued)

| mnemonic | description | bytes/ <br> cycles | opcode <br> (hex.) |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Data transfer |  |  |  |  |  |
| MOV | A,Rr | Move register to A | 1 | 1 | E* $^{*}$ |
| MOV | A,direct** | Move direct byte to A | 2 | 1 | E5 |
| MOV | A,@Ri | Move indirect RAM to A | 1 | 1 | E6, E7 |
| MOV | A,\#data | Move immediate data to A | 2 | 1 | 74 |
| MOV | Rr,A | Move A to register | 1 | 1 | F $^{*}$ |
| MOV | Rr,direct | Move direct byte to register | 2 | 2 | A* $^{*}$ |
| MOV | Rr,\#data | Move immediate data to register | 2 | 1 | $7^{*}$ |
| MOV | direct,A | Move A to direct byte | 2 | 1 | F5 |
| MOV | direct,Rr | Move register to direct byte | 2 | 2 | $8^{*}$ |
| MOV | direct,direct | Move direct byte to direct | 3 | 2 | 85 |
| MOV | direct,@Ri | Move indirect RAM to direct byte | 2 | 2 | 86,87 |
| MOV | direct,\#data | Move immediate data to direct byte | 3 | 2 | 75 |
| MOV | @Ri,A | Move A to indirect RAM | 1 | 1 | F6, F7 |
| MOV | @Ri,direct | Move direct byte to indirect RAM | 2 | 2 | A6, A7 |
| MOV | @Ri,\#data | Move immediate data to indirect RAM | 2 | 1 | 76,77 |
| MOV | DPTR,\#data16 | Load data pointer with a 16-bit constant | 3 | 2 | 90 |
| MOVC | A,@A+DPTR | Move code byte relative to DPTR to A | 1 | 2 | 93 |
| MOVC | A,@A+PC | Move code byte relative to PC to A | 1 | 2 | 83 |
| MOVX | A,@Ri | Move external RAM (8-bit address) to A | 1 | 2 | E2,E3 |
| MOVX | A,@DPTR | Move external RAM (16-bit address) to A | 1 | 2 | EO |
| MOVX | @Ri,A | Move A to external RAM (8-bit address) | 1 | 2 | F2, F3 |
| MOVX | @DPTR,A | Move A to external RAM (16-bit address) | 1 | 2 | F0 |
| PUSH | direct | Push direct byte onto stack | 2 | 2 | C0 |
| POP | direct | Pop direct byte from stack | 2 | 2 | D0 |
| XCH | A,Rr | Exchange register with A | 1 | 1 | C* |
| XCH | A,direct | Exchange direct byte with A | 2 | 1 | C5 |
| XCH | A,@Ri | Exchange indirect RAM with A | 1 | 1 | C6, C7 |
| XCHD | A,@Ri | Exchange LOW-order digit indirect RAM with A | 1 | 1 | D6, D7 |

[^6]| mnemonic |  | description |  |  | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Boolean variable manipulation |  |  |  |  |  |
| CLR | C | Clear carry flag | 1 | 1 | C3 |
| CLR | bit | Clear direct bit | 2 | 1 | C2 |
| SETB | C | Set carry flag | 1 | 1 | D3 |
| SETB | bit | Set direct bit | 2 | 1 | D2 |
| CPL | C | Complement carry flag | 1 | 1 | B3 |
| CPL | bit | Complement direct bit | 2 | 1 | B2 |
| ANL | C, bit | AND direct bit to carry flag | 2 | 2 | 82 |
| ANL | C,/bit | AND complement of direct bit to carry flag | 2 | 2 | B0 |
| ORL | C, bit | OR direct bit ti carry flag | 2 | 2 | 72 |
| ORL | C,/bit | OR complement of direct bit to carry flag | 2 | 2 | A0 |
| MOV | C,bit | Move direct bit to carry flag | 2 | 1 | A2 |
| MOV | bit, C | Move carry flag to direct bit | 2 | 2 | 92 |
| Program and machine control |  |  |  |  |  |
| ACALL addr11 |  | Absolute subroutine call | 2 | 2 | -1addr |
| LCALL addr16 |  | Long subroutine call | 3 | 2 | 12 |
| RET |  | Return from subroutine | 1 | 2 | 22 |
| RET1 |  | Return from interrupt | 1 | 2 | 32 |
| AJMP | addr11 | Absolute jump | 2 | 2 | -1addr |
| LJMP | addr16 | Long jump | 3 | 2 | 02 |
| SJMP | rel | Short jump (relative address) | 2 | 2 | 80 |
| JMP | @A+DPTR | Jump indirect relative to the DPTR | 1 | 2 | 73 |
| JZ | rel | Jump if $A$ is zero | 2 | 2 | 60 |
| JNZ | rel | Jump if A is not zero | 2 | 2 | 70 |
| JC | rel | Jump if carry flag is set | 2 | 2 | 40 |
| JNC | rel | Jump is no carry flag | 2 | 2 | 50 |
| JB | bit, rel | Jump if direct bit is set | 3 | 2 | 20 |
| JNB | bit,rel | Jump if direct bit is not set | 3 | 2 | 30 |
| JBC | bit,rel | Jump if direct bit is set and clear bit | 3 | 2 | 10 |
| CJNE | A,direct,rel | Compare direct to $A$ and jump if not equal | 3 | 2 | B5 |
| CJNE | A, \#data, rel | Compare immediate to $A$ and jump if not equal | 3 | 2 | B4 |
| CJNE | Rr,\#data, rel | Compare immediate to reg. and jump if not equal | 3 | 2 | B* |
| CJNE | @Ri,\#data, rel | Compare immediate to ind. and jump if not equal | 3 | 2 | B6, B7 |
| DJNZ | Rr,rel | Decrement register and jump if not zero | 2 | 2 | D* |
| DJNZ | direct,rel | Decrement direct and jump if not zero | 3 | 2 | D5 |
| NOP |  | No operation | 1 | 1 | 00 |

## Notes to Table 4

## Data addressing modes

$\mathrm{Rr} \quad$ Working register RO-R7.
direct $\quad 128$ internal RAM locations and any special function register (SFR).
@Ri Indirect internal RAM location addressed by register R0 or R1 of the actual register bank.
\#data $\quad 8$-bit constant included in instruction.
\#data16 16-bit constant included as bytes 2 and 3 of instruction.
bit direct addressed bit in internal RAM or SFR.
addr16 16-bit destination address. Used by LCALL and LJMP. The branch will be anywhere within the 64 K -byte program memory address space.
addr11 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 K -byte page of program memory as the first byte of the following instruction.
rel Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is -128 to +127 bytes relative to first byte of the following instruction.

## Hexadecimal opcode cross-reference to Table 5

* : 8, 9, A, B, C, D, E, F.
- : 11, 31, 51, 71, 91, B1, D1, F1.
© : $01,21,41,61,81, \mathrm{~A} 1, \mathrm{C} 1, \mathrm{E} 1$.


## DEVELOPMENT DATA

Table 5 Instruction map
_ first hexadecimal character of opcode
second hexadecimal character of opcode

| 1 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP | AJMP page 0 | LJMP <br> addr16 | RR A | INC A | INC dir | $\begin{aligned} & \text { INC @Ri } \\ & 0 \end{aligned}$ | 1 |  |  | 2 | 3 | 4 | 5 | 6 | 7 |
| 1 | $\begin{aligned} & \text { JBC } \\ & \text { bit,addr8 } \end{aligned}$ | ACALL page 0 | LCALL addr16 | RRC A | DEC A | DEC dir | $\begin{aligned} & \text { DEC @Ri } \\ & 0 \end{aligned}$ | 1 |  |  |  | 3 | 4 | 5 | 6 | 7 |
| 2 | JB <br> bit,addr8 | AJMP page 1 | RET | RL A | ADD <br> A,\#data | ADD <br> A, dir | $\begin{aligned} & \text { ADD A,@Ri } \\ & 0 \end{aligned}$ | 1 |  | $1$ | $\begin{gathered} \mathrm{Rr} \\ 2 \end{gathered}$ | 3 | 4 | 5 | 6 | 7 |
| 3 | JNB bit,addr8 | ACALL page 1 | RET1 | RLC A | ADDC <br> A,\#data | ADDC <br> A, dir | ADDC A, @Ri 0 | 1 |  | $1$ | $\begin{gathered} A, R r \\ 2 \end{gathered}$ | 3 | 4 | 5 | 6 | 7 |
| 4 | JC addr8 | AJMP page 2 | ORL <br> dir, A | ORL dir,\#data | ORL <br> A,\#data | ORL <br> A, dir | $\begin{aligned} & \text { ORL A,@Ri } \\ & 0 \\ & \hline \end{aligned}$ | 1 |  | $1$ | $\begin{array}{r} \mathrm{Rr} \\ 2 \end{array}$ | 3 | 4 | 5 | 6 | 7 |
| 5 | JNC addr8 | ACALL page 2 | ANL dir,A | ANL dir,\#data | ANL <br> A,\#data | ANL A,dir | $\begin{aligned} & \text { ANL A,@Ri } \\ & 0 \end{aligned}$ | 1 |  | $1$ | $\begin{array}{r} \mathrm{Rr} \\ 2 \end{array}$ | 3 | 4 | 5 | 6 | 7 |
| 6 | $J Z$ <br> addr8 | AJMP page 3 | $\begin{aligned} & \text { XRL } \\ & \mathrm{dir}, \mathrm{~A} \end{aligned}$ | XRL <br> dir,\#data | XRL <br> A,\#data | XRL <br> A, dir | $\begin{aligned} & \text { XRL A,@Ri } \\ & 0 \end{aligned}$ | 1 |  | $1$ | $2$ | 3 | 4 | 5 | 6 | 7 |
| 7 | JNZ <br> addr8 | ACALL page 3 | ORL <br> C,bit | $\begin{aligned} & \text { JMP } \\ & @ A+D P T R \end{aligned}$ | MOV <br> A,\#data | MOV dir,\#data | MOV @Ri,\#d 0 | 1 |  |  |  | ta | 4 | 5 | 6 | 7 |
| 8 | SJMP addr8 | AJMP page 4 | ANL <br> C,bit | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+PC } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{DIV} \\ & \mathrm{AB} \\ & \hline \end{aligned}$ | MOV <br> dir,dir | MOV dir,@Ri 0 | 1 |  | $1$ | $\begin{gathered} r, R r \\ 2 \\ \hline \end{gathered}$ | 3 | 4 | 5 | 6 | 7 |
| 9 | MOV DPTR, \#data 16 | ACALL page 4 | MOV bit,C | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+DPTR } \end{aligned}$ | SUBB <br> A,\#data | SUBB <br> A, dir | $\begin{aligned} & \text { SUBB A,@Ri } \\ & 0 \end{aligned}$ | 1 |  | $1$ | $\begin{gathered} \mathrm{Rr} \\ 2 \mid \end{gathered}$ | $3$ | 4 | 5 | 6 | 7 |
| A | ORL C,/bit | AJMP page 5 | MOV <br> C,bit | INC DPTR | $\begin{aligned} & M U L \\ & A B \end{aligned}$ |  | MOV @Ri,dir 0 | 1 |  | $1$ | $\begin{gathered} \text { dir } \\ 21 \\ \hline \end{gathered}$ | $3$ | 4 | 5 | 6 | 7 |
| B | ANL C,/bit | ACALL page 5 | CPL <br> bit | CPL C | CJNE A, \#data, addr8 | $\begin{aligned} & \text { CJNE } \\ & \text { A,dir, addr8 } \end{aligned}$ | CJNE @Ri,\#da 0 | 1 |  |  |  | 3 | 4 | 5 | 6 | 7 |
| C | PUSH <br> dir | AJMP page 6 | $\begin{aligned} & \text { CLR } \\ & \text { bit } \end{aligned}$ | CLR C | SWAP <br> A | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{dir} \end{aligned}$ | $\begin{aligned} & \text { XCH A,@Ri } \\ & 0 \end{aligned}$ | 1 |  |  | $\begin{array}{r} \mathrm{Rr} \\ 2 \\ \hline \end{array}$ | 3 | 4 | 5 | 6 | 7 |
| D | $\begin{aligned} & \text { POP } \\ & \text { dir } \end{aligned}$ | ACALL page 6 | SETB <br> bit | $\begin{aligned} & \text { SETB } \\ & \mathrm{C} \end{aligned}$ | DAA | DJNZ <br> dir,addr8 | $\begin{aligned} & \text { XCHD A,@Ri } \\ & 0 \end{aligned}$ | 1 |  |  | $2$ | $\begin{gathered} \mathrm{dr} 8 \\ 3 \end{gathered}$ | 4 | 5 | 6 | 7 |
| E | $\begin{aligned} & \text { MOVX } \\ & \text { A,@DPTR } \end{aligned}$ | AJMP page 7 | $\begin{aligned} & \text { MOVX } \\ & 0 \end{aligned}$ | $\begin{gathered} @ R i \\ 1 \end{gathered}$ | CLR A | MOV <br> A,dir | MOV A,@Ri 0 | 1 |  | $1$ | $\begin{gathered} \mathrm{Rr} \\ 2 \end{gathered}$ | 3 | 4 | 5 | 6 | 7 |
| F | MOVX <br> @DPTR,A | ACALL page 7 | $\begin{aligned} & \text { MOVX } \\ & 0 \end{aligned}$ | $\begin{aligned} & R i, A \\ & 1 \end{aligned}$ | CPL A | MOV <br> dir, A | $\begin{aligned} & \text { MOV @Ri,A } \\ & 0 \end{aligned}$ | 1 |  | $1$ | $\begin{gathered} \mathrm{A} \\ 2 \end{gathered}$ | 3 | 4 | 5 | 6 | 7 |

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Input voltage on any pin with respect to ground ( $\mathrm{V}_{\mathrm{SS}}$ )
Input, output current
Total power dissipation
Storage temperature range
Operating ambient temperature range

$$
-0,5 \text { to }+7 \mathrm{~V}
$$

$\pm 1, I_{0}$
max. $\quad 5 \mathrm{~mA}$
$P_{\text {tot }}$
$\mathrm{T}_{\mathrm{stg}}$
max. 1 W
-65 to $+150{ }^{\circ} \mathrm{C}$
Tamb

0 to $+70^{\circ} \mathrm{C}$

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified.

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $V_{\text {DD }}$ | 4,5 | 5,5 | V |  |
| Supply current operating (note 1) | IDD | - | tbf | mA | $\mathrm{f}_{\text {CLK }}=12 \mathrm{MHz}$ |
| idle mode (note 2) | ${ }^{\text {I DD }}$ | - | tbf | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz}$ |
| Power-down current | IPD | - | tbf | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{DD}}=2 \mathrm{~V}$ (note 3) |
| Inputs (see note 6) |  |  |  |  |  |
| LOW level input voltage (except $\overline{E A}, \mathrm{P} 1.6 / \mathrm{SCL}$, P1.7/SDA) | $V_{\text {IL }}$ | -0,5 | $0,2 \mathrm{~V}_{\text {DD }}-0,1$ | V |  |
| LOW level input voltage ( $\overline{E A}$ ) | $V_{\text {IL1 }}$ | -0,5 | $0,2 V_{\text {DD }}-0,3$ | V |  |
| LOW level input voltage (P1.6/SCL, P1.7/SDA) | $V_{\text {IL2 }}$ | -0,5 | 1,5 | V |  |
| HIGH level input voltage (except XTAL 1, RST, P1.6/SCL, P1.7/SDA) | $V_{\text {IH }}$ | $0,2 \mathrm{~V}_{\text {DD }}+0,9$ | $V_{D D}+0,5$ | V |  |
| HIGH level input voltage (XTAL 1, RST) | $\mathrm{V}_{\text {IH1 }}$ | $0,7 V_{\text {CC }}$ | $\mathrm{V}_{\mathrm{DD}}+0,5$ | V |  |
| HIGH level input voltage (P1.6/SCL, P1.7/SDA) | $\mathrm{V}_{\text {IH2 }}$ | 3,0 | $\mathrm{V}_{\mathrm{DD}}+0,5$ | V |  |
| Input current logic 0 (Ports 1, 2, 3 and 4; except P1.6/SCL, P1.7/SDA) | $-^{-I L}$ | - | 50 | $\mu \mathrm{A}$ | $V_{1}=0,45 \mathrm{~V}$ |
| Input current logic 1 to 0 transition (Ports 1, 2, 3 and 4; except P.1/SCL, P1.7/SDA) | ${ }^{-1} \mathrm{TL}$ | - | 500 | $\mu \mathrm{A}$ | $V_{1}=2 \mathrm{~V}$ |
| Input leakage current (Port 0, EA, STADC, EWN, P1.6/SCL, P1.7/SDA) | $\pm \mathrm{I}_{\mathrm{LI}}$ | - | 10 | $\mu \mathrm{A}$ | $0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{DD}}$ |



## D.C. CHARACTERISTICS (continued)

$V_{D D}=5,0 \mathrm{~V} \pm 10 \% ; A V_{S S}=0 \mathrm{~V} ; \mathrm{V}_{\mathrm{REF}}=5,0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | symbol | min. | max. | unit |
| :---: | :---: | :---: | :---: | :---: |
| Analogue inputs |  |  |  |  |
| Analogue input voltage | $A V_{\text {IN }}$ | A $\mathrm{VSS}^{-0,2}$ | $\mathrm{A}_{\text {VDD }}+0,2$ | V |
| Reference voltage | $A V_{\text {REF- }}$ | $\mathrm{AV}_{\text {SS }}-0,2$ | - | V |
|  | $A V_{\text {REF }+}$ |  | $\mathrm{AV}_{D D^{+0,2}}$ | V |
| Analogue input capacitance (note 7) | C | - | - | pF |
| Sampling time | ${ }^{\text {t }}$ ADS | - | ${ }^{32}{ }^{\text {c }} \mathrm{C} Y$ | $\mu \mathrm{s}$ |
| Conversion time (including sample time) | ${ }^{\text {t }}$ ADC | - | ${ }^{88 t}{ }^{\text {c }} \mathrm{Y}$ | $\mu \mathrm{s}$ |
| Differential non-linearity <br> $A V_{\text {REF }}=A V_{D D}$ <br> $A V_{\text {REF- }}=A V_{S S}$ | $\mathrm{DL}_{\mathrm{e}}$ | - | $\pm 1,0$ | LSB |
| Integral non-linearity <br> $A V_{\text {REF }}=A V_{D D}$ <br> $A V_{\text {REF- }}=A V_{S S}$ | $\mathrm{IL}_{\mathrm{e}}$ | - | tbf | LSB |
| Offset error | $\mathrm{OS}_{\mathrm{e}}$ | - | tbf | mV |
| Gain error | $\mathrm{G}_{\mathrm{e}}$ | - | tbf | \% |
| AV REF supply current (note 8) | $\mathrm{Al}_{5}$ | - | tbf | $\mu \mathrm{A}$ |
| Internal resistance of analogue source | $\mathrm{R}_{\text {ia } \max }$ | - | tbf | 0 |
| Internal resistance of analogue reference source | $\mathrm{R}_{\text {ir max }}$ | - | tbf | 0 |

## Notes to the d.c. characteristics

1. The operating supply current is measured with all output pins disconnected; XTAL 1 driven with $\mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}+0,5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}-0,5 \mathrm{~V} ; \mathrm{XTAL} 2$ not connected; $\overline{E A}=R S T=$ Port $0=V_{D D}$.
2. The idle mode supply current is measured with all output pins disconnected; XTAL 1 driven with $\mathrm{t}_{\mathrm{r}}=\mathrm{tf}_{\mathrm{f}}=10 \mathrm{~ns}, \mathrm{~V}_{\text {IL }}=\mathrm{V}_{\mathrm{SS}}+0,5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}-0,5 \mathrm{~V} ;$ XTAL 2 not connected; $E A=$ Port $0=V_{D D} ; R S T=V_{S S}$.
3. The power down current is measured with all output pins disconnected; XTAL 2 not connected; $\overline{E A}=$ Port $0=$ VDD; RST $=$ VSS .
4. Capacitive loading on Port 0 and Port 2 may cause spurious noise pulses to be superimposed on the LOW level output voltage of ALE, Port 1 and Port 3. The noise is due to external Bus capacitance discharging into the Port 0 and Port 2 pins when these pins make a 1 -to- 0 transition during bus operations. In the most adverse condition (capacitive loading $>100 \mathrm{pF}$ ) the noise pulse on ALE line may exceed $0,8 \mathrm{~V}$. In this event it may be required to qualify ALE with a Schmitt trigger, or use an address latch with a Schmitt trigger STROBE input.
5. Capacitive loading on Port 0 and Port 2 may cause the HIGH level output voltage on ALE and PSEN to momentarily fall below the $0,9 \mathrm{~V}$ DD specification when the address bits are stabilizing.
6. The input threshold voltage of P1.6 and P1.7 (SIO1) meets the $\mathrm{I}^{2} \mathrm{C}$ specification, so an input voltage below $1,5 \mathrm{~V}$ will be recognized as a logic 0 while an input voltage above $3,0 \mathrm{~V}$ will be recognized as a logic 1.
7. The internal resistance of the analogue source must be less than the $\mathrm{R}_{\mathrm{i}}$ max to ensure full loading of the sample capacitance during sample time.
8. The internal resistance of the analogue reference source must be less than $\mathrm{R}_{\text {ir max }}$.

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (Port 0, ALE and $\overline{\text { PSEN }}$ ); $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ (all other outputs); unless otherwise specified (see waveforms Figs 19, 20 and 21)

| parameter | symbol | 10 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min . | max. |  |
| Program memory |  |  |  |  |  |  |  |  |
| ALE pulse duration | ${ }^{\text {t }}$ LL | 160 | - | 127 | - | $2 \mathrm{tcK}-40$ | - | ns |
| Address set-up time to ALE | ${ }^{t} A L$ | 60 | - | 43 | - | ${ }^{\text {t }}$ CK - 40 | - | ns |
| Address hold time after ALE | ${ }^{\text {t }}$ LA | 65 | - | 48 | - | ${ }^{\text {t }}$ CK -35 | - | ns |
| Time from ALE to valid instruction input | ${ }^{\text {t LIV }}$ | - | 300 | - | 233 | - | ${ }^{4 t} \mathrm{CK}-100$ | ns |
| Time from ALE to control pulse $\overline{\text { SEN }}$ | ${ }^{\text {t }}$ C | 75 | - | 58 | - | ${ }^{\text {t }} \mathrm{CK}^{-25}$ | - | ns |
| Control pulse duration PSEN | ${ }^{\text {t }} \mathrm{C}$ | 265 | - | 215 | - | $3{ }^{\text {ctek }}$-35 | - | ns |
| Time from $\overline{\text { PSEN }}$ to valid instruction input | ${ }^{\text {t }} \mathrm{CIV}$ | - | 175 | - | 125 | - | $3{ }^{\text {¢ }} \mathrm{CK}-125$ | ns |
| Input instruction hold time after $\overline{\text { PSEN }}$ | ${ }^{\mathrm{t}} \mathrm{Cl}$ | 0 | - | 0 | - | 0 | - | ns |
| Input instruction float delay after $\overline{\text { PSEN }}$ * | ${ }^{\text {t C IF }}$ | - | 80 | - | 63 | - | ${ }^{\text {t }} \mathrm{CK}^{-20}$ | ns |
| Address valid after $\overline{\text { PSEN }}{ }^{*}$ | ${ }^{t} A C$ | 92 | - | 75 | - | ${ }^{\text {t }} \mathrm{CK}^{-8}$ | - | ns |
| Address to valid instruction input | ${ }^{\text {t }}$ AIV | - | 385 | - | 302 | - | ${ }^{5 t} \mathrm{CK}^{-115}$ | ns |
| Address float time to $\overline{\text { PSEN }}$ | ${ }^{\text {t }}$ AFC | -12 | - | -12 | - | 0 | -- | ns |

[^7]A.C. CHARACTERISTICS (continued)

| parameter | symbol | 10 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min . | max. | min. | max. | min. | max. |  |
| External data memory |  |  |  |  |  |  |  |  |
| $\overline{\mathrm{RD}}$ pulse duration | ${ }^{\text {t }}$ R $R$ | 500 | - | 400 | - | ${ }^{61} \mathrm{CK}^{-100}$ | - | ns |
| $\overline{\text { WR }}$ pulse duration | ${ }^{\text {t }}$ WW | 500 | - | 400 | - | 6 t CK-100 | - | ns |
| Address set up time to ALE | ${ }^{t} A L$ | - | - | 28 | - |  |  | ns |
| Address hold time after ALE | ${ }^{\text {t }}$ LA | 65 | - | 48 | - | ${ }^{\text {t }} \mathrm{CK}-35$ | - | ns |
| $\overline{\mathrm{RD}}$ to valid data input | ${ }^{\text {t } R D}$ | - | 335 | - | 250 | - | ${ }^{5} \mathrm{C}$ CK -165 | ns |
| Data hold time after $\overline{\mathrm{RD}}$ | ${ }^{t} \mathrm{DR}$ | 0 | - | 0 | - | 0 | - | ns |
| Data float delay after $\overline{\mathrm{RD}}$ | ${ }^{\text {t }}$ DFR | - | 130 | - | 97 | - | $2 \mathrm{t} \mathrm{CK}^{-70}$ | ns |
| Time from ALE to valid data input | ${ }^{\text {t }}$ LD | - | 650 | - | 517 | - | ${ }^{8 t} \mathrm{CKK}^{-150}$ | ns |
| Address to valid data input | ${ }^{t} A D$ | - | 735 | - | 585 | - | ${ }^{9 t} \mathrm{CK}-165$ | ns |
| Time from ALE to $\overline{R D}$ or $\overline{W R}$ | ${ }^{\text {t }}$ LW | 250 | 350 | 200 | 300 | ${ }^{3} \mathrm{t}$ CK-50 | ${ }^{3} \mathrm{C} \mathrm{CK}^{+50}$ | ns |
| Time from address to $\overline{\text { PD }}$ or $\overline{W R}$ | ${ }^{\text {t }}$ AW | 270 | - | 203 | - | ${ }^{4 t} \mathrm{CK}^{-130}$ | - | ns |
| Time from $\overline{R D}$ or $\overline{W R}$ HIGH to ALE HIGH | ${ }^{\text {t }}$ WHLH | 60 | 140 | 43 | 123 | ${ }^{\text {t }}$ CK - 40 | ${ }^{\text {t }} \mathrm{CK}^{+40}$ | ns |
| Data valid to $\overline{W R}$ transition | ${ }^{\text {t }}$ WWX | 40 | - | 23 | - | ${ }^{\text {t }}$ CK -60 | - | ns |
| Data set-up time before $\overline{W R}$ | ${ }^{\text {t }}$ WW | 550 | - | 433 | - | ${ }^{7 t} \mathrm{CKK}^{-150}$ | - | ns |
| Data hold time after $\overline{W R}$ | twD | 50 | - | 33 | - | ${ }^{\mathrm{t}} \mathrm{CK}-50$ | - | ns |
| Address float delay after $\overline{R D}$ | ${ }^{t} A F R$ | - | 12 | - | 12 | - | 12 | ns |

## Where:

$1 / \mathrm{t} \mathrm{CK}=3,5$ to 12 MHz (see Fig. 19 and Table 6).

(a)


Fig. 18 A.C. testing input, output waveform (a) and float waveform (b).
A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 . Timing measurements are taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for logic 0 . The float state is defined as the point at which a Port 0 pin sinks 3,2 mA or sources $400 \mu \mathrm{~A}$ at the voltage test levels.


Fig. 19 External clock drive XTAL 1 (see Table 6).
Table 6 External clock drive XTAL 1 (see Fig. 19)

| parameter | symbol | variable clock ( $\mathrm{f}=3,5$ to 12 MHz ) |  | unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| oscillator clock period | ${ }^{\text {t }}$ CK | 83,3 | 286 | ns |
| HIGH time | ${ }^{\text {tHIGH }}$ | 20 | ${ }^{\text {t }}$ CK ${ }^{\text {t }}$ LOW | ns |
| LOW time | ${ }^{\text {t }}$ LOW | 20 | ${ }^{\text {t }}$ CK-t ${ }^{\text {thigh }}$ | ns |
| rise time | $\mathrm{t}_{\mathrm{r}}$ | - | 20 | ns |
| fall time | $\mathrm{t}_{\mathrm{f}}$ | - | 20 | ns |

## A.C. CHARACTERISTICS (continued)



Fig. 20 Read from program memory.


Fig. 21 Read from data memory.


Fig. 22 Write to data memory.


Purchase of Philip' $\left.\right|^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specifications defined by Philips.


## SINGLE-CHIP 8-BIT MICROCONTROLLER

## GENERAL DESCRIPTION

The PCB83C652 single-chip 8-bit microcontroller is manufactured in an advanced CMOS process and is a derivative of the PCB80C51 microcontroller family. PCB83C652 has the same instruction set as the PCB80C51. Two versions of the derivative exist although the generic term "PCB83C652" is used to refer to both family members:

- PCB80C652: ROM-less version of the PCB83C652
- PCB83C652: 8 K bytes mask -programmable ROM, 256 bytes RAM

This device provides architectural enhancements that make it applicable in a variety of applications, in general control systems.
The PCB83C652 contains a non-volatile $8 \mathrm{~K} \times 8$ read-only program memory (not ROM-less version), a volatile $256 \times 8$ read/write data memory; four 8 -bit I/O ports; two 16 -bit timer/event counters (identical to the timers of the 80C51), a multi-source, two-priority-level, nested interrupt structure; an $I^{2} \mathrm{C}$ interface, UART and on-chip oscillator and timing circuits. For systems that require extra capability, the PCB83C652 can be expanded using standard TTL compatible memories and logic.
The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of over 100 instructions; $44 \%$ one-byte, $41 \%$ two-byte and $15 \%$ three-byte. With a 12 MHz crystal, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ and $40 \%$ in $2 \mu$ s. Multiply and divide instructions require $4 \mu \mathrm{~s}$.

## Features

- 80C51 central processing unit
- $8 \mathrm{~K} \times 8$ ROM, expandable externally to 64 K bytes
- $256 \times 8$ RAM, expandable externally to 64 K bytes
- Two standard 16 -bit timer/counters
- Four 8-bit I/O ports
- $1^{2} \mathrm{C}$ bus serial I/O port with byte orientated master and slave functions
- Full-duplex UART facilities


## PACKAGE OUTLINE

PCB83C652: 44-lead PLCC; plastic, leaded-chip-carrier (SOT-187A)


Fig. 1 Block diagram.


Fig. 2 Functional diagram.


Fig. 3 Pinning diagram for PCB83C652.

2-9 P1.0-P1.7 Port 1: 8-bit quasi-bidirectional I/O port. Port 1 can sink/source one TTL ( $=4$ LS TTL) input.
It can drive CMOS inputs without external pull-ups, except P1.6 and P1.7 which have open drain outputs.
Port pin Alternative function
P1.6 SCL: $1^{2} \mathrm{C}$-bus serial port clock line
P1.7 SDA: $1^{2} \mathrm{C}$-bus serial port data line
RST: a high level on this pin for two machine cycles while the oscillator is running resets the device. An internal pull-down permits Power-On reset using only a capacitor connected to $\mathrm{V}_{\text {DD }}$.

11, 13-19 P3.0-P3.7 Port 3: 8-bit quasi-bidirectional I/O port with internal pull-ups. It also serves the following alternative functions:
Port pin Alternative function
P3.0 RXD/data: serial port receiver data input (asynchronous) or data input/output (synchronous)
P3.1 TXD/clock: serial port transmitter data output (asynchronous) or clock output (synchronous)
P3.2 $\overline{\text { INTO }}$ : external interrupt 0 or gate control input for timer/event counter 0

P3.3 $\overline{\text { INT1 }}$ : external interrupt 1 or gate control input for timer/event counter 1
P3.4 T0: external input for timer/event counter 0
P3.5 T1: external input for timer/event counter 1
P3.6 $\overline{W R}$ : external data memory write strobe
P3.7 $\overline{\mathrm{RD}}$ : external data memory read strobe
Operation of an alternative function is determined by the relevant output latch programmed to logic 1. Port 3 can sink/source one TTL (= 4 LSTTL) input. It can drive CMOS inputs without external pull-ups.
DEVELOPMENT DATA
20 XTAL 2

21
XTAL 1 Crystal input 1: input to the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external oscillator clock signal when an external oscillator is used (see Figs 10 and 11).
$22 \quad V_{\text {SS }} \quad$ Ground: circuit ground potential.
$32 \overline{\text { PSEN }}$

33
Crystal input 2: output of the inverting amplifier that forms the oscillator. Left open-circuit when an external oscillator clock is used (see Figs 10 and 11).

Port 2: 8 -bit quasi-bidirectional I/O port with internal pull-ups. During access to external memories (RAM/ROM) that use 16 -bit addresses (MOVX @DPTR) Port 2 emits the high order address byte. When external RAM is accessed with an 8-bit address (MOVX @Ri) Port 2 emits the contents of the P2 special function register. Port 2 can sink/source one TTL ( $=4$ LSTTL) input. It can drive CMOS inputs without external pull-ups.
Program Store Enable output: read strobe to the external Program Memory via port 0 and 2. It is activated twice each machine cycle during fetches from external Program Memory. When executing out of external Program Memory two activations of PSEN are skipped during each access to external Data Memory. $\overline{\text { PSEN }}$ is not activated (remains HIGH) during no fetches from external Program Memory. $\overline{\text { PSEN }}$ can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pull-up.
ALE Address Latch Enable output: latches the low byte of the address during accesses to external memory in normal operation. It is activated every six oscillator periods except during an external data memory access. ALE can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pull-up.

PININING (continued)

36-43 P0.7-P0.0 Port 0: 8-bit open drain bidirectional I/O port. It is also the multiplexed
$35 \quad \overline{E A}$

44

External Access input: When $\overline{E A}$ is held at a TTL high level the CPU executes out of the internal Program Memory (ROM) provided the program counter is less than 8192. When EA is held at a TTL low level, the CPU executes out of external Program Memory via port 0 and port 2. $\overline{E A}$ is not allowed to float. low-order address and data bus during accesses to external memory (during these accesses it activates internal pull-ups). Port 0 can sink/source eight LSTTL inputs.
Power supply: +5 V power supply pin during normal operation, Idle mode and Power Down mode.
At power-on, the voltage on any pin at any time must not be higher or lower than $\mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{SS}}-0,5 \mathrm{~V}$ respectively.

## FUNCTIONAL DESCRIPTION

## General

The PCB83C652 is a stand-alone high-performance microcontroller designed for use in real-time applications such as instrumentation and industrial control.

The device provides, in addition to the 80C51 standard functions, a serial $I^{2} \mathrm{C}$ bus interface. As well as the parallel bus, functions may also be expanded using the $I^{2} \mathrm{C}$ bus utilizing the complete line of the $1^{2} \mathrm{C}$ clips family.
The PCB83C652 is a control-oriented CPU with on-chip program and data memory. It can be extended with external program and data memory up to 64 K bytes. For systems requiring extra capability, the PCB83C652 can be expanded using standard memories and peripherals.
The PCB83C652 has two software selectable modes of reduced activity for further power reduction - Idle and Power Down. The Idle mode freezes the CPU while allowing the RAM, timers, serial ports and interrupt system to continue functioning. The Power Down mode saves the RAM contents but freezes the oscillator causing all other chip functions to be inoperative.

## Memory organization

The central processing unit (CPU) manipulates operands in three memory spaces; these are the 64 K-byte external data memory, 256 -byte internal data memory and the 64 K -byte internal and external program memory. The internal data memory address space is sub-divided into the 256 -byte internal data RAM and 128 -byte Special Function Register (SFR) address spaces, as shown in Fig. 4. Figure 5 shows the Special Function Register memory map. Internal RAM locations 0-127 are directly and indirectly addressable. Internal RAM locations 128-255 are only indirectly addressable as internal data RAM. The special function register locations 128-255 are only directly addressable.


Fig. 4 Memory map.

\# S1STA is a read-only register.
Fig. 5 Special function registers memory map.

## FUNCTIONAL DESCRIPTION (continued)

The internal data RAM contains four register banks (each with eight registers), 128 addressable bits, and the stack. The stack depth is limited by the available internal data RAM and its location is determined by the 8 -bit stack pointer. All registers except the program counter and the four 8 -register banks reside in the special function register address space. These memory mapped registers include arithmetic registers, pointers, I/O ports, interrupt system registers, timers and serial port registers. There are 128 addressable bit locations in the SFR address space.
The PCB83C652 contains 256 bytes of internal data RAM and 24 special function registers. It provides a non-paged program memory address space to accommodate relocatable code. Conditional branches are performed relative to the program counter. The register-indirect jump permits branching relative to a 16 -bit base register with an offset provided by an 8 -bit index register. 16 -bit jumps and calls permit branching to any location in the contiguous 64 K program memory address space.

## Addressing

The PCB83C652 has five methods for addressing source operands:

- Register.
- Direct.
- Register-Indirect.
- Immediate.
- Base-Register plus Index-Register-Indirect.

The first three methods can be used for addressing destination operands. Most instructions have a "destination/source" field that specifies the data type, addressing methods and operands involved. For operations other than MOVs, the destination operand is also a source operand.
Access to memory addressing is as follows:

- Registers in one of the four 8-register banks through Register, Direct, or Register-Indirect.
- 256 bytes of internal data RAM through Direct or Register-Indirect. Bytes 0-127 may be addressed directly/indirectly. Bytes 128-255 share their address locations with the SFR registers and so may only be addressed indirectly as data RAM.
- Special function registers through Direct at address locations 128-255.
- External data memory through Register-Indirect.
- Program memory look-up tables through Base-Register plus Index-Register-Indirect.

The PCB83C652 is classified as an 8-bit device since the internal ROM, RAM, Special Function Registers (SFR), Arithmetic Logic Unit (ALU), and external data bus are each 8-bits wide. It performs operations on bit, nibble, byte and double-byte data types.
Facilities are available for byte transfer, logic, and integer arithmetic operations. Data transfer, logic, and conditional branch operations can be performed directly on Boolean variables to provide excellent bit handling.

## Instruction set

The PCB83C652 uses a powerful instruction set to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Assigned opcodes add new high-power operations and permit new addressing modes. The instruction set consists of 49 single-byte, 45 two-byte and 17 three-byte instructions. When using a 12 MHz oscillator, 64 instructions execute in $1 \mu$ s and 45 instructions execute in $2 \mu \mathrm{~s}$. Multiply and divide instructions execute in $4 \mu \mathrm{~s}$.

## FUNCTIONAL DESCRIPTION (continued)

## I/O facilities

The PCB83C652 has four 8-bit ports. Ports $0-3$ are the same as in the 80C51, with the exception of the additional functions of port 1. Port lines P1.7 and P1.6 may be selected as the SDA and SCL lines of serial port SIO1 $\left(1^{2} \mathrm{C}\right)$. Because the $\mathrm{I}^{2} \mathrm{C}$ bus may be active while the device is disconnected from $V_{D D}$, these pins are provided with open drain drivers.
N.B. Therefore these pins do not have pull-up devices when used as ports.

Ports $0,1,2$ and 3 perform the following alternative functions:

- Port 0; provides the multiplexed low-order address and data bus used for expanding the PCB83C652 with standard memories and peripherals.
- Port 1 ; Port 1 is partly used for the $I^{2} \mathrm{C}$ bus functions;
- SCL and SDA for the $1^{2} \mathrm{C}$ interface, P 1.6 and P 1.7 respectively.

Bits whose alternate function is not used may be used as normal bidirectional I/O pins.

- Port 2; provides the high-order address bus when expanding the PCB83C652 with external program memory and/or external data memory.
- Port 3; pins can be configured individually to provide:
- external interrupt request inputs
- counter inputs
- serial port receiver input and transmitter output
- control signals to READ and WRITE external data memory

The generation or use of a Port 3 pin as an alternative function is carried out automatically by the PCB83C652 provided the pin is loaded with a HIGH content.


Fig. 6 I/O buffers in the PCB83C652 (Ports 1, 2 and 3).

## Timer/event counters

The PCB83C652 contains two 16 -bit timer/event counters; Timer 0 and Timer 1. Timer 0 and Timer 1 may be programmed to carry out the following functions:

- Measure time intervals and pulse durations
- Count events
- Generate interrupt requests.

Timer 0 and Timer 1 can be programmed independently to operate in three modes:

- Mode 0;8-bit timer or 8 -bit counter each with divide by 32 prescaler
- Mode 1; 16-bit time-interval or event counter
- Mode 2;8-bit time-interval or event counter with automatic reload upon overflow.

Timer 0 can be programmed to operate in an additional mode as follows:

- Mode 3; one 8-bit time-interval or event counter and one 8-bit time-interval counter.

When Timer 0 is in Mode 3, Timer 1 can be programmed to operate in Modes 0, 1 or 2 but cannot set an interrupt request flag or generate an interrupt. However the overflow from Timer 1 can be used to pulse the serial Port transmission-rate generator.
The frequency handling range of these counters with a 12 MHz crystal is as follows:

- In the timer function, the timer is incremented at a frequency of 1 MHz , that is, a division by 12 of the oscillator frequency
- 0 Hz to an upper limit of $0,5 \mathrm{MHz}$ when programmed for external inputs.

Both internal and external inputs can be gated to the counter by a second external source for directly measuring pulse durations.

The counters are started and stopped under software control. Each one sets its interrupt request flag when it overflows from all logic 1s to all logic 0 s (or automatic reload value), with the exception of mode 3 as previously described.

## Serial I/O (see Fig. 7)

The PCB83C652 is equipped with two independent serial ports. SIOO is the full duplex UART port and is identical to the serial port of the PCB80C51.

Serial port SIO1 supports the $I^{2} \mathrm{C}$ bus, the function of which is controlled by the S1CON register. S1STA is the status register whose contents may also be used as a vector to various service routines. S1DAT is the data shift register and S1ADR the slave address register.

FUNCTIONAL DESCRIPTION (continued)


Fig. 7 Block diagram of $\mathrm{I}^{2} \mathrm{C}$ serial $\mathrm{I} / \mathrm{O}$.
The $\mathrm{I}^{2} \mathrm{C}$ serial I/O has complete autonomy in byte handling and operates in 4 modes:

1. Master transmitter
2. Master receiver
3. Slave transmitter
4. Slave receiver

Slave address recognition is performed by hardware.
The $I^{2} \mathrm{C}$ bus consists of two lines; a data line (SDA) and a clock line (SCL). These lines also function as the I/O port lines on P1.7 and P1.6. The system is unique because data transport, clock generation, address recognition and bus control arbitration are all controlled by hardware.

Serial control register S1CON

|  | X | ENSI | STA | STO | SI | AA | CR1 | CRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S1CON | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bits CR1 and CR0 determine the clock frequency that is generated in the master mode of operation.
Table 1 displays the clock rate when using a 12 MHz crystal.
Table 1 Clock rate when using a 12 MHz crystal

| CR1 / CR0 |  | bit frequency | fosc divided by |
| :--- | :--- | :--- | :--- |
| 0 | 0 | $12,5 \mathrm{kHz}$ | 960 |
| 0 | 1 | 100 kHz | 120 |
| 1 | 0 | 200 kHz | $60\left(\mathrm{f}_{\text {osc }}<6 \mathrm{MHz}\right.$ meeting $\left.\mathrm{I}^{2} \mathrm{C}\right)$ |
| 1 | 1 | $62,5-0,5 \mathrm{kHz}$ | $96 \times(256-$ reload value Timer 1) |
|  |  | (reload value range: $0-254$ in mode 2) |  |

## AA

Assert acknowledge bit. When this bit is set, an acknowledge is returned after any one of the following conditions:

- Own slave address is received
- General call address is received (S1ADR. $0=$ logic 1 )
- A data byte is received, while the device is programmed to be a master receiver
- A data byte is received, while the device is a selected slave receiver.

When this bit is reset, no acknowledge is returned. Consequently, no interrupt is requested when the own address or general call address is received.

## SI

SIO1 interrupt flag. This flag is set, and an interrupt request is generated, after any of the following events occur:

- A START condition is generated in MST mode
- The own slave address has been received during $A A=$ logic 1
- The general call address has been received while S1ADR. 0 and AA $=$ logic 1
- A data byte has been received or transmitted in MST mode (even if arbitration is lost)
- A data byte has been received or transmitted as selected slave
- A STOP or START condition is received as selected slave Rx or Tx.


## STO

STOP flag. When in master mode, and this bit is set a STOP condition is generated. A STOP condition detected on the $1^{2} \mathrm{C}$ bus clears this bit. This bit may also be set in slave mode in order to recover from an error condition. Then no STOP condition is generated to the $I^{2} \mathrm{C}$ bus, but the hardware releases the SDA and SCL lines and switches to the not selected slave receiver mode. The STOP flag is cleared by the hardware.

## STA

START flag. When this bit is set, the hardware checks the $I^{2} \mathrm{C}$ bus and generates a START condition if the bus is free. If the device is already programmed as either master/transmitter or master/receiver, it will generate a repeated START condition.

## ENSI

$0=$ Serial I/O Disabled and reset. P1.6 and P1.7 I/O port function with open drain
$1=$ Serial I/O Enabled. Output ports P1.6 and P1.7 must be set to logic 1.

## FUNCTIONAL DESCRIPTION (continued)

Serial status register S1STA

S1ST.A

| SC4 | SC3 | SC2 | SC1 | SC0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

S1STA. 3 - S1STA. 7 hold a status code. S1STA. 0 - S1STA. 2 are held LOW. The contents of the status register may be used as a vector to a service routine. This optimizes the response time of the software and consequently that of the $1^{2} \mathrm{C}$ bus.
The following is a list of the status codes in decimal representation. The decimal value corresponds to the value of the upper five bits of the status register.

SLA : 7-bit slave address
R : Read bit
W : Write bit
ACK : Acknowledgement (acknowledge bit = logic 0)
$\overline{\text { ACK }}$ : Not acknowledgement (acknowledge bit = logic 1)
DATA : 8-bit data byte to or from $1^{2} \mathrm{C}$ bus
MST : Master
SLV : Slave
TRX : Transmitter
REC : Receiver

## MST/TRX mode

## S1STA value

1 - A START condition has been transmitted
2 - A repeated START condition has been transmitted
3 - SLA and W have been transmitted, ACK has been received
4 - SLA and $W$ have been transmitted, $\overline{A C K}$ received
5 - DATA of S1DAT has been transmitted, ACK received
6 - DATA of S1DAT has been transmitted, $\overline{A C K}$ received
7 - Arbitration lost in SLA and R/W or DATA

## MST/REC mode

S1STA value
7 - Arbitration lost while returning $\overline{A C K}$
8 - SLA and R have been transmitted, ACK received
9 - SLA and R have been transmitted, $\overline{A C K}$ received
10 - DATA has been received, ACK returned
11 - DATA has been received, $\overline{\mathrm{ACK}}$ returned

## SLV/REC mode

## S1STA value

12 - Own SLA and W have been received, ACK returned
13 - Arbitration lost in SLA and R/W as MST. Own SLA and W have been received, ACK returned
14 - General CALL has been received, ACK returned
15 - Arbitration lost in SLA and R/W as MST. General call has been received
16 - Previously addressed with own SLA. DATA byte received, ACK returned
17 - Previously addressed with own SLA. DATA byte received, $\overline{\text { ACK }}$ returned
18 - Previously addressed with general call. DATA byte has been received, ACK has been returned
19 - Previously addressed with general call. DATA byte has been received, $\overline{\mathrm{ACK}}$ has been returned
20 - A STOP condition or repeated START condition has been received while still addressed as SLV/REC or SLV/TRX.

## SLV/TRX mode

## S1STA value

21 - Own SLA and R have been received, ACK returned
22 - Arbitration lost in SLA and R/W as MST. Own SLA and R have been received, ACK returned
23 - DATA byte has been transmitted, ACK received
24 - DATA byte has been transmitted, $\overline{A C K}$ received
25 - Last DATA byte has been transmitted ( $A A=$ logic 0 ), ACK received

## Miscellaneous

S1STA value
00 - Bus error during MST mode or selected SLV mode, due to an erroneous START or STOP condition.

The data shift register S1DAT
S1DAT

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

This register contains the serial data to be transmitted or data which has just been received. Bit 7 is transmitted or received first; i.e. data is shifted from right to left.

Address register S1ADR

|  | slave address |  |  |  |  |  | GC |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| 7 |  |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

S1ADR.0, GC : $0=$ general call address is not recognized
1 = general call address is recognized
S1ADR,7-1 : own slave address
This 8 -bit register may be loaded with the 7 -bit slave address to which the controller will respond when programmed as a slave receiver/transmitter. The LSB bit (GC) is used to determine whether the general call address is recognized.

## FUNCTIONAL DESCRIPTION (continued)

Idle and Power-down operation (see Fig. 8)
Idle mode operation permits the interrupt, serial ports and timer blocks to continue to function while the clock to the CPU is halted.
The following functions remain active during IDLE mode. These functions may generate an interrupt or reset and thus end the IDLE mode:

Timer 0, Timer 1
SIOO, SIO1
External interrupt
The Power-down operation freezes the oscillator. The Power-down mode can only be activated by setting the PD bit in the PCON register.


Fig. 8 Internal Idle and Power-down clock configuration.

## Power control register (PCON)

These special modes are activated by software via the Special Function Register PCON. Its hardware address is 87 H . PCON is not bit addressable.

PCON
SMOD $\quad X \quad X \quad X \quad$ GF1

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |



## Bit

| SMOD | PCON. 7 | Double Baud rate bit. When set to logic 1 the baud rate is doubled if the <br> serial port SIOO is being used in modes 1,2 or 3. |
| :--- | :--- | :--- |
|  | PCON. 6 | (reserved) <br> (reserved) |
|  | PCON. 5 | PCON. 4 <br> (reserved) |
| GF1 | PCON. 3 | general-purpose flag bit |
| GF0 | PCON. 2 | general-purpose flag bit |
| PD | PCON. 1 | Power-down bit; setting this bit activates power-down mode |
| IDL | PCON. 0 | Idle mode bit; setting this bit activates the idle mode operation. |

If logic 1s are written to PD and IDL at the same time, PD takes precedence. The reset value of PCON is ( $0 \times \times 00000$ ).

## Idle mode

The instruction that sets PCON. 0 is the last instruction executed in the normal operating mode before Idle mode is activated. Once in the Idle mode, the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM and all other registers maintain their data during Idle mode. The status of the external pins during Idle mode is shown in Table 2.

There are two ways to terminate the Idle mode:
Activation of any enabled interrupt will cause PCON. 0 to be cleared by hardware terminating Idle mode. The interrupt is serviced, and following return from interrupt instruction RETI, the next instruction to be executed will be the one which follows the instruction that wrote a logic 1 to PCON.O.
The flag bits GF0 and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the instruction that writes to PCON. 0 can also set or clear one or both flag bits. When Idle mode is terminated by an interrupt, the service routine can examine the status of the flags bits.

The second way of terminating the Idle mode is with an external hardware reset. Since the oscillator is still running, the hardware reset is required to be active for two machine cycles ( 24 oscillator periods) to complete the reset operation.

## Power-down mode

The instruction that sets PCON. 1 is the last executed prior to going into the Power-down mode. Once in Power-down mode, the oscillator is stopped. Only the contents of the on-chip RAM are preserved. The Special Function Registers are not saved. A hardware reset is the only way of exiting the Power--down mode.

In the Power-down mode, $V_{\text {DD }}$ may be reduced to minimize circuit power consumption. The voltage must not be reduced until the Power-down mode is entered, but must be restored before the hardware reset is applied which will free the oscillator. Reset should not be released until the oscillator has restarted and stabilized.
The status of the external pins during Power-down mode is shown in Table 2. If the Power-down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a logic 1, the port pin is held HIGH during the Power--down mode by the strong pull-up transistor p1 (see Fig. 6).

## FUNCTIONAL DESCRIPTION (continued)

Table 2 Status of the external pins during Idle and Power-down modes.

| mode | memory | ALE | $\overline{\text { PSEN }}$ | Port 0 | Port 1 | Port 2 | Port 3 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Idle | internal | 1 | 1 | port data | port data | port data | port data |
| Idle | external | 1 | 1 | floating | port data | address | port data |
| Power-down | internal | 0 | 0 | port data | port data | port data | port data |
| Power-down | external | 0 | 0 | floating | port data | port data | port data |

Note: Port 1.7 and 1.6 if selected, function as SDA and SCL respectively in the IDLE mode.

## Interrupt system (see Fig. 9)

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, two-priority-level, nested interrupt system is provided. Interrupt response latency is from $3 \mu \mathrm{~s}$ to $8 \mu \mathrm{~s}$ when using a 12 MHz crystal. The PCB83C652 acknowledges interrupt requests from six sources as follows:

- $\overline{\mathrm{INTO}}$ and $\overline{\mathrm{INT1}}$; externally via pins 14 and 15 respectively
- Timer 0 and Timer 1 ;-from the two internal counters
- $1^{2} \mathrm{C}$ serial I/O interrupt
- UART serial I/O port interrupt

Each interrupt vectors to a separate location in program memory for its service program. Each source can be individually enabled or disabled by a corresponding bit in the IE register, moreover each interrupt may be programmed to a high or low priority level using a corresponding bit in the IP register. Also all enabled sources can be globally disabled or enabled. Both external interrupts can be programmed to be level-activated or transition-activated, and an active LOW level allows "wire--ORing" of several interrupt sources to the input pin.
interrupt enable register

polling hardware


Fig. 9 Interrupt system.

FUNCTIONAL DESCRIPTION (continued)
Interrupt enable register
IE

| EA | - | ES1 | ESO | ET1 | EX1 | ETO | EX0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| Bit |  | Function |
| :--- | :--- | :--- |
| IE. 7 | EA | General enable/disable control <br> $0=$ No interrupt is enabled |
|  |  | $1=$ Any individually enabled interrupt will be accepted |
| IE. 6 | - | Unused |
| IE. 5 | ES1 | Enable SIO1 $I^{2}$ C interrupt |
| IE.4 | ESO | Enable SIOO (UART) interrupt |
| IE.3 | ET1 | Enable Timer 1 interrupt |
| IE. 2 | EX1 | Enable External 1 interrupt |
| IE. 1 | ETO | Enable Timer 0 interrupt |
| IE. 0 | EXO | Enable External 0 interrupt |

Interrupt priority register
IP

| X | X | PS1 | PSO | PT1 | PX1 | PTO | PX0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bit Function
IP. 7 - Unused
IP. 6 - Unused

IP. $5 \quad$ PS1 $1 \quad$ SIO1 $\left(I^{2} \mathrm{C}\right)$ interrupt priority level
IP. 4 PSO SIOO (UART) interrupt priority level
IP. 3 PT1 Timer 1 interrupt priority level
IP. 2 PX1 External interrupt 1 priority level
IP. 1 PTO Timer 0 interrupt priority level
IP. 0 PXO External interrupt 0 priority level

Table 3 shows the interrupt vectors. The vector indicates the ROM location where the appropriate interrupt reduce routine starts.

Table 3 Interrupt vectors

| Source |  | Vector |
| :--- | :--- | :--- |
| External 0 | X0 | 0003 H |
| Timer 0 overflow | T0 | 000 BH |
| External 1 | X1 | 0013 H |
| Timer 1 overflow | T1 | 001 BH |
| Serial I/O 0 (UART) | SO | 0023 H |
| Serial I/O 1 $\left(I^{2} \mathrm{C}\right)$ | S1 | 002 BH |

## Interrupt priority

Each interrupt source can be provided by software with two priority levels; logic 1 and logic 0 . If both levels are requested simultaneously, the processor will branch to the level logic 1 vector. If there are simultaneous requests from sources of the same priority, then interrupts will be serviced in the following order:
X0, S1, T0, X1, T1, S0
A logic 0 interrupt routine can be interrupted by a logic 1 interrupt.

## Oscillator circuitry

The oscillator circuitry of the PCB83C652 is a single-stage inverting amplifier in a Pierce oscillator configuration. The circuitry between XTAL 1 and XTAL 2 is basically an inverter biased to the transfer point. Either a crystal or ceramic resonator can be used as the feedback element to complete the oscillator circuitry. Both are operated in parallel resonance. XTAL 1 ( pin 21 ) is the high gain amplifier input, and XTAL 2 (pin 20) is the output (see Fig. 10). To drive the PCB83C652 externally, XTAL 1 is driven from an external source and XTAL 2 left open-circuit (see Fig. 11).


Fig. 10 PCB83C652 oscillator circuit.


Fig. 11 Driving the PCB83C652 from an external source.

## FUNCTIONAL DESCRIPTION (continued)

Reset circuitry (see Fig. 12)
The reset circuitry for the PCB83C652 is connected to the reset pin RST. A Schmitt trigger is used at the input for noise rejection. The output of the Schmitt trigger is sampled by the reset circuitry every machine cycle.


Fig. 12 Reset configuration at RST.
A reset is accomplished by holding the RST pin HIGH for at least two machine cycles (24 oscillator periods), while the oscillator is running. The CPU responds by executing an internal reset. During reset ALE and PSEN output a HIGH level. In order to perform a correct reset, this level must not be affected by external elements.

The internal reset is executed during the second cycle in which RST is HIGH and is repeated every cycle until RST goes LOW. It leaves the internal registers as follows:

| Register | Content |
| :--- | :--- |
| ACC | 00000000 |
| B | 00000000 |
| DPL | 00000000 |
| DPH | 00000000 |
| IE | $0 \times 000000$ |
| IP | XX00 0000 |
| PCH | 00000000 |
| PCL | 00000000 |
| PCON | $0 \times X \times 0000$ |
| PSW | 00000000 |
| PO - P3 | 11111111 |
| SOBUF | XXXX XXXX |
| SOCON | 00000000 |
| S1ADR | 00000000 |
| S1CON | X000 0000 |
| S1DAT | 00000000 |
| S1STA | 11111000 |
| SP | 00000111 |
| TCON | 00000000 |
| TH0, TH1 | 00000000 |
| TLO, TL1 | 00000000 |
| TMOD | 00000000 |

The internal RAM is not affected by reset. When $V_{D D}$ is turned on, the RAM content is indeterminate.

## Power-on reset (see Fig. 13)

When $V_{D D}$ is turned on an automatic reset can be obtained by connecting the RST pin to $V_{D D}$ via a $10 \mu \mathrm{~F}$ capacitor. When the power is switched on, the current drawn by RST is the difference between $V_{D D}$ and the capacitor voltage, and decreases from $V_{D D}$ as the capacitor charges through the internal resistor ( $\mathrm{R}_{\mathrm{RST}}$ ) to ground. The larger the capacitor, the more slowly $\mathrm{V}_{\text {RST }}$ decreases. $\mathrm{V}_{\text {RST }}$ must remain above the lower threshold of the Schmitt trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles.


Fig. 13 Power-on reset.

## INSTRUCTION SET

Table 4 Instruction set description

| mnemonic | description | bytes/ cycles |  | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Arithmetic operations |  |  |  |  |
| ADD A,Rr | Add register to A | 1 | 1 | 2* |
| ADD A,direct | Add direct byte to A | 2 | 1 | 25 |
| ADD A,@Ri | Add indirect RAM to $A$ | 1 | 1 | 26, 27 |
| ADD A,\#data | Add immediate data to $A$ | 2 | 1 | 24 |
| ADDC A,Rr | Add register to A with carry flag | 1 | 1 | 3* |
| ADDC A,direct | Add direct byte to A with carry flag | 2 | 1 | 35 |
| ADDC A,@Ri' | Add indirect RAM to A with carry flag | 1 | 1 | 36,37 |
| ADDC A,\#data | Add immediate data to A with carry flag | 2 | 1 | 34 |
| SUBB A,Rr | Subtract register from A with borrow | 1 | 1 | 9* |
| SUBB A,direct | Subtract direct byte from A with borrow | 2 | 1 | 95 |
| SUBB A,@Ri | Subtract indirect RAM from A with borrow | 1 | 1 | 96, 97 |
| SUBB A,\#data | Subtract immediate data from A with borrow | 2 | 1 | 94 |
| INC A | Increment A | 1 | 1 | 04 |
| INC Rr | Increment register | 1 | 1 | 0* |
| INC direct | Increment direct byte | 2 | 1 | 05 |
| INC @Ri | Increment indirect RAM | 1 | 1 | 06, 07 |
| DEC A | Decrement A | 1 | 1 | 14 |
| DEC Rr | Decrement register | 1 | 1 | 1* |
| DEC direct | Decrement direct byte | 2 | 1 | 15 |
| DEC @Ri | Decrement indirect RAM | 1 | 1 | 16, 17 |
| INC DPTR | Increment data pointer | 1 | 2 | A3 |
| MUL AB | Multiply A \& B | 1 | 4 | A4 |
| DIV $A B$ | Divide A by B | 1 | 4 | 84 |
| DA A | Decimal adjust A | 1 | 1 | D4 |


| mnemonic | description | bytes/ cycles |  | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Logic operations |  |  |  |  |
| ANL A,Rr | AND register to $A$ | 1 | 1 | 5* |
| ANL A,direct | AND direct byte to $A$ | 2 | 1 | 55 |
| ANL A,@Ri | AND indirect RAM to $A$ | 1 | 1 | 56, 57 |
| ANL A,\#data | AND immediate data to $A$ | 2 | 1 | 54 |
| ANL direct,A | AND A to direct byte | 2 | 1 | 52 |
| ANL direct,\#data | AND immediate data to direct byte | 3 | 2 | 53 |
| ORL A,Rr | OR register to $A$ | 1 | 1 | 4* |
| ORL A,direct | OR direct byte to $A$ | 2 | 1 | 45 |
| ORL A,@Ri | OR indirect RAM to $A$ | 1 | 1 | 46.47 |
| ORL A,\#data | OR immediate data to $A$ | 2 | 1 | 44 |
| ORL direct,A | OR A to direct byte | 2 | 1 | 42 |
| ORL direct,\#data | OR immediate data to direct byte | 3 | 2 | 43 |
| XRL A,Rr | Exclusive-OR register to $A$ | 1 | 1 | $6 *$ |
| XRL A,direct | Exclusive-OR direct byte to $A$ | 2 | 1 | 65 |
| XRL A,@Ri | Exclusive-OR indirect RAM to $A$ | 1 | 1 | 66,67 |
| XRL A,\#data | Exclusive-OR immediate data to $A$ | 2 | 1 | 64 |
| XRL direct,A | Exclusive-OR A to direct byte | 2 | 1 | 62 |
| XRL direct,\#data | Exclusive-OR immediate data to direct byte | 3 | 2 | 63 |
| CLR A | Clear A | 1 | 1 | E4 |
| CPL A | Complement A | 1 | 1 | F4 |
| RL A | Rotate A left | 1 | 1 | 23 |
| RLC A | Rotate A left through the carry flag | 1 | 1 | 33 |
| RR A | Rotate A right | 1 | 1 | 03 |
| RRC A | Rotate A right through the carry flag | 1 | 1 | 13 |
| SWAP A | Swap nibbles within A | 1 | 1 | C4 |

INSTRUCTION SET (continued)

| mnemonic | description | bytes/ cycles |  | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Data transfer |  |  |  |  |
| MOV A,Rr | Move register to A | 1 | 1 | E* |
| MOV A,direct (**) | Move direct byte to $A$ | 2 | 1 | E5 |
| MOV A,@Ri | Move indirect RAM to $A$ | 1 | 1 | E6, E7 |
| MOV A,\#data | Move immediate data to $A$ | 2 | 1 | 74 |
| MOV Rr,A | Move A to register | 1 | 1 | F* |
| MOV Rr,direct | Move direct byte to register | 2 | 2 | A* |
| MOV Rr,\#data | Move immediate data to register | 2 | 1 | 7* |
| MOV direct,A | Move A to direct byte | 2 | 1 | F5 |
| MOV direct, Rr | Move register to direct byte | 2 | 2 | 8* |
| MOV direct,direct | Move direct byte to direct | 3 | 2 | 85 |
| MOV direct,@Ri | Move indirect RAM to direct byte | 2 | 2 | 86, 87 |
| MOV direct,\#data | Move immediate data to direct byte | 3 | 2 | 75 |
| MOV @Ri,A | Move A to indirect RAM | 1 | 1 | F6, F7 |
| MOV @Ri,direct | Move direct byte to indirect RAM | 2 | 2 | A6, A7 |
| MOV @Ri,\#data | Move immediate data to indirect RAM | 2 | 1 | 76,77 |
| MOV DPTR,\#data 16 | Load data pointer with a 16 -bit constant | 3 | 2 | 90 |
| MOVC A,@A+DPTR | Move code byte relative to DPTR to A | 1 | 2 | 93 |
| MOVC A,@A+PC | Move code byte relative to PC to $A$ | 1 | 2 | 83 |
| MOVX A,@Ri | Move external RAM (8-bit address) to A | 1 | 2 | E2, E3 |
| MOVX A,@DPTR | Move external RAM (16-bit address) to A | 1 | 2 | EO |
| MOVX @Ri,A | Move A to external RAM (8-bit address) | 1 | 2 | F2, F3 |
| MOVX @DPTR,A | Move A to external RAM (16-bit address) | 1 | 2 | FO |
| PUSH direct | Push direct byte onto stack | 2 | 2 | CO |
| POP direct | Pop direct byte from stack | 2 | 2 | D0 |
| XCH A,Rr | Exchange register with A | 1 | 1 | C* |
| XCH A,direct | Exchange direct byte with A | 2 | 1 | C5 |
| XCH A,@Ri | Exchange indirect RAM with A | 1 | 1 | C6, C7 |
| XCHD A,@Ri | Exchange LOW-order digit indirect RAM with A | 1 | 1 | D6, D7 |

[^8]| mnemonic |  | description | bytes/ cycles |  | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Boolean | variable manipul |  |  |  |  |
| CLR | C | Clear carry flag | 1 | 1 | C3 |
| CLR | bit | Clear direct bit | 2 | 1 | C2 |
| SETB | C | Set carry flag | 1 | 1 | D3 |
| SETB | bit | Set direct bit | 2 | 1 | D2 |
| CPL | C | Complement carry flag | 1 | 1 | B3 |
| CPL | bit | Complement direct bit | 2 | 1 | B2 |
| ANL | C,bit | AND direct bit to carry flag | 2 | 2 | 82 |
| ANL | C,/bit | AND complement of direct bit to carry flag | 2 | 2 | B0 |
| ORL | C,bit | OR direct bit to carry flag | 2 | 2 | 72 |
| ORL | C,/bit | OR complement of direct bit to carry flag | 2 | 2 | A0 |
| MOV | C,bit | Move direct bit to carry flag | 2 | 1 | A2 |
| MOV | bit, C | Move carry flag to direct bit | 2 | 2 | 92 |
| Program and machine control |  |  |  |  |  |
| ACALL | addr11 | Absolute subroutine call | 2 | 2 | -1addr |
| LCALL | addr16 | Long subroutine call | 3 | 2 | 12 |
| RET |  | Return from subroutine | 1 | 2 | 22 |
| RET1 |  | Return from interrupt | 1 | 2 | 32 |
| AJMP | addr11 | Absolute jump | 2 | 2 | 41addr |
| LJMP | addr16 | Long jump | 3 | 2 | 02 |
| SJMP | rel | Short jump (relative address) | 2 | 2 | 80 |
| JMP | @A+DPTR | Jump indirect relative to the DPTR | 1 | 2 | 73 |
| JZ | rel | Jump if $A$ is zero | 2 | 2 | 60 |
| JNZ | rel | Jump if $A$ is not zero | 2 | 2 | 70 |
| JC | rel | Jump if carry flag is set | 2 | 2 | 40 |
| JNC | rel | Jump if no carry flag | 2 | 2 | 50 |
| JB | bit,rel | Jump if direct bit is set | 3 | 2 | 20 |
| JNB | bit,rel | Jump if direct bit is not set | 3 | 2 | 30 |
| JBC | bit,rel | Jump if direct bit is set and clear bit | 3 | 2 | 10 |
| CJNE | A,direct,rel | Compare direct to $A$ and jump if not equal | 3 | 2 | B5 |
| CJNE | A,\#data, rel | Compare immediate to $A$ and jump if not equal | 3 | 2 | B4 |
| CJNE | Rr,\#data, rel | Compare immed. to reg. and jump if not equal | 3 | 2 | B* |
| CJNE | @Ri,\#data,rel | Compare immed. to ind. and jump if not equal | 3 | 2 | B6, B7 |
| DJNZ | Rr,rel | Decrement register and jump if not zero | 2 | 2 | D* |
| DJNZ | direct, rel | Decrement direct and jump if not zero | 3 | 2 | D5 |
| NOP |  | No operation | 1 | 1 | 00 |

## Notes to Table 4

Data addressing modes
$\mathrm{Rr} \quad$ Working register RO-R7.
direct 128 internal RAM locations and any special function register (SFR).
@Ri Indirect internal RAM location addressed by register RO or R1 of the actual register bank.
\#data 8-bit constant included in instruction.
\#data16 16-bit constant included as bytes 2 and 3 of instruction.
bit direct addressed bit in internal RAM or SFR.
addr16 16-bit destination address. Used by LCALL and LJMP. The branch will be anywhere within the 64 K-byte program memory address space.
addr11 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 K-byte page of program memory as the first byte of the following instruction.
rel Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is -128 to +127 bytes relative to first byte of the following instruction.

## Hexadecimal opcode cross-reference to Table 5

*: 8, 9, A, B, C, D, E, F.

- 11, 31,51, 71, 91, B1, D1, F1.

A: $01,21,41,61,81, A 1, C 1, E 1$.

Table 5 Instruction map

| - first hexadecimal character of opcode |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| 0 | NOP | AJMP page 0 | LJMP addr 16 | RR A | INC A | INC dir | INC @Ri <br> 0 |  | $\left.\begin{aligned} & \text { INC Rr } \\ & 0 \\ & 0 \end{aligned} 1 \right\rvert\, \begin{aligned} & 2 \\ & \hline \end{aligned}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 1 | JBC bit,addr8 | ACALL page 0 | LCALL addr16 | RRC A | DEC A | DEC $\mathrm{dir}$ | $\begin{aligned} & \text { DEC @Ri } \\ & 0 \end{aligned}$ | 1 | $\begin{array}{\|l\|l\|l\|l} \hline \text { DEC Rr } \\ \hline 0 & 1 & 1 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 2 | JB <br> bit,addr8 | AJMP page 1 | RET | RL A | ADD <br> A,\#data | ADD <br> A,dir | $\begin{aligned} & \text { ADD A,@Ri } \\ & 0 \\ & \hline \end{aligned}$ | 1 | $$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 3 | JNB bit,addr8 | ACALL page 1 | RET1 | RLC A | ADDC <br> A,\#data | ADDC <br> A, dir | ADDC A,@Ri 0 | 1 | $\begin{array}{l\|l\|l\|l} \begin{array}{l\|l\|l\|l\|l\|l\|l\|l\|} \hline \end{array} \\ \hline \end{array}$ |  |  |  | 4 | 5 | 6 | 7 |
| 4 | JC addr8 | AJMP page 2 | $\begin{aligned} & \text { ORL } \\ & \text { dir,A } \end{aligned}$ | ORL dir,\#data | ORL <br> A, \#data | ORL <br> A, dir | $\begin{aligned} & \text { ORL A,@Ri } \\ & 0 \end{aligned}$ | 1 | $\begin{array}{\|l\|l\|l\|} \hline 0 \text { ORL } A, R r \\ \hline 0 & 1 & 1 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 5 | JNC addr8 | ACALL page 2 | ANL <br> $\operatorname{dir}, A$ | ANL <br> dir,\#data | ANL <br> A,\#data | ANL <br> A, dir | $\begin{aligned} & \text { ANL A,@Ri } \\ & 0 \end{aligned}$ | $1$ | $$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 6 | JZ addr8 | AJMP page 3 | $\begin{aligned} & \text { XRL } \\ & \text { dir,A } \end{aligned}$ | XRL dir,\#data | XRL <br> A,\#data | XRL <br> A,dir | $\begin{aligned} & \text { XRL A,@Ri } \\ & 0 \end{aligned}$ | $1$ | $\begin{array}{\|l\|l\|l\|} \hline X R L & A, R r \\ 0 & 1 & 2 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| 7 | JNZ <br> addr8 | ACALL page 3 | $\begin{aligned} & \text { ORL } \\ & \text { C,bit } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & \text { @A+DPTR } \end{aligned}$ | MOV <br> A, \#data | MOV <br> dir,\#data | MOV @Ri,\#data 0 |  | MOV Rr,\#data $0\|1\| 2 \mid 3$ |  |  |  | 4 | 5 | 6 | 7 |
| 8 | SJMP <br> addr8 | AJMP page 4 | ANL C,bit | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+PC } \end{aligned}$ | $\begin{aligned} & \text { DIV } \\ & \text { AB } \end{aligned}$ | MOV <br> dir,dir | MOV dir,@Ri 0 |  |  |  |  |  | 4 | 5 | 6 | 7 |
| 9 | MOV DPTR, \#data 16 | ACALL page 4 | MOV <br> bit,C | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+DPTR } \end{aligned}$ | SUBB <br> A, \#data | SUBB <br> A, dir | $\begin{array}{l\|l} \text { SUBB A,@Ri } \\ 0 & 1 \\ \hline \end{array}$ |  | $$ |  |  |  | 4 | 5 | 6 | 7 |
| A | ORL <br> C,/bit | AJMP page 5 | $\begin{aligned} & \text { MOV } \\ & \text { C,bit } \end{aligned}$ | INC DPTR | $\begin{aligned} & M U L \\ & A B \end{aligned}$ |  | MOV @Ri,dir 0 |  | MOV Rr,dir $0\|1\| 2 \mid 3$ |  |  |  | 4 | 5 | 6 | 7 |
| B | ANL C,/bit | ACALL page 5 | CPL <br> bit | CPL C | CJNE A, \#data,addr8 | CJNE <br> A,dir,addr8 | CJNE @Ri, \#data,addr8 $0 \quad 11$ |  | CJNE Rr,\#data,addr8$\begin{array}{\|l\|l\|l\|l\|l\|l} \hline 0 & 1 & 2 & 3 & 1 & 5 \\ \hline \end{array}$ |  |  |  |  |  | 6 | 7 |
| C | PUSH dir | AJMP page 6 | $\begin{aligned} & \text { CLR } \\ & \text { bit } \end{aligned}$ | CLR C | $\begin{aligned} & \text { SWAP } \\ & \text { A } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{dir} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { XCH A,@Ri } \\ & 0 \end{aligned}$ | $1$ | $\begin{array}{\|l\|l\|l\|} \hline \mathrm{XCH} & \mathrm{~A}, \mathrm{Rr} \\ 0 & 1 & 2 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| D | $\begin{aligned} & \text { POP } \\ & \text { dir } \end{aligned}$ | ACALL page 6 | SETB <br> bit | $\begin{aligned} & \text { SETB } \\ & \mathrm{C} \end{aligned}$ | DA A | DJNZ <br> dir,addr8 | $\begin{aligned} & \text { XCHD A,@Ri } \\ & 0 \end{aligned}$ |  | DJNZ Rr,addr8$\begin{array}{l\|l\|l\|l\|l} 0 & 1 & 12 & 3 & 4 \\ \hline \end{array}$ |  |  |  |  | 5 | 6 | 7 |
| E | MOVX <br> A,@DPTR | AJMP page 7 | $\begin{aligned} & \text { MOVX A,@Ri } \\ & 0 \\ & M O V X @ R i, A \end{aligned}$ |  | CLR A | $\begin{aligned} & \text { MOV } \\ & \text { A, dir } \end{aligned}$ | $\begin{aligned} & \text { MOV A,@Ri } \\ & 0 \\ & \hline \end{aligned}$ | 1 | $\begin{array}{\|l\|l\|l\|} \hline \text { MOV } & \text { A, Rr } \\ 0 & 1 & 12 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |
| F | MOVX @DPTR,A | ACALL page 7 |  |  | CPL A | MOV $\operatorname{dir}, A$ | $\begin{aligned} & \text { MOV @Ri,A } \\ & 0 \end{aligned}$ |  | $\begin{array}{\|l\|l\|l\|} \hline \text { MOV } & \operatorname{Rr}, A \\ 0 & 1 & 12 \\ \hline \end{array}$ |  |  | 3 | 4 | 5 | 6 | 7 |

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Input voltage on any pin with respect to ground (VSS)
Input, output current
Total power dissipation
Storage temperature range
Operating ambient temperature range

| $V_{1}$ | $-0,5$ to +7 V |  |
| :--- | ---: | :--- |
| $\pm 1,10$ | max. | 5 mA |
| $P_{\text {tot }}$ | max. $\quad 1 \mathrm{~W}$ |  |
| $T_{\text {stg }}$ | -65 to $+150^{\circ} \mathrm{C}$ |  |
| $T_{\text {amb }}$ | 0 to $+70^{\circ} \mathrm{C}$ |  |

## D.C. CHARACTERISTICS

$V_{D D}=5 \mathrm{~V}( \pm 10 \%) ; V_{S S}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $V_{\text {DD }}$ | 4,5 | 5,5 | V |  |
| Supply current operating (note 1) |  |  |  |  |  |
|  | ID | - | tbf | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz}$ |
| idle mode (note 2) | IDD | - | tbf | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz}$ |
| Power-down current | IPD | - | tbf | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{DD}}=2 \mathrm{~V}$ (note 3) |
| Inputs (see note 6) |  |  |  |  |  |
| LOW level input voltage (except EA, P1.6/SGL, P1.7/SDA | VIL | -0,5 | 0,2V $\mathrm{DD}-0,1$ | V |  |
| LOW level input voltage ( $\overline{E A}$ ) | VIL1 | -0,5 | 0,2V $\mathrm{DD}-0,3$ | V |  |
| LOW level input voltage (P1.6/SCL, P1.7/SDA) | $V_{\text {IL2 }}$ | -0,5 | 1,5 | V |  |
| HIGH level input voltage (except XTAL 1, RST, P1.6/SCL, P1.7/SDA) | $V_{\text {IH }}$ | 0,2V $\mathrm{DD}^{+0,9}$ | $V_{D D}+0,5$ | V |  |
| HIGH level input voltage (XTAL 1, RST) | $\mathrm{V}_{1} \mathrm{H} 1$ | $0,7 \mathrm{~V}_{\mathrm{CC}}$ | V $\mathrm{DD}^{+0,5}$ | V |  |
| HIGH level input voltage (P1.6/SCL, P1.7/SDA) | $\mathrm{V}_{1 \mathrm{H} 2}$ | 3,0 | $\mathrm{V}_{\mathrm{DD}}+0,5$ | V |  |
| Input current logic 0 (Ports 1, 2, 3 and 4; except P1.6/SCL, P1.7/SDA) | -IIL | - | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=0,45 \mathrm{~V}$ |
| Input current logic 1 to 0 transition (Ports 1, 2, 3 and 4; except P.1/SCL, P1.7/SDA) | ${ }^{-1} \mathrm{TL}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=2 \mathrm{~V}$ |
| Input leak age current (Port 0, EA, STADC,EWN, P1.6/SCL, P1.7/SDA) | $\pm$ LI | - | 10 | $\mu \mathrm{A}$ | $0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\text {DD }}$ |



Bys
Purchase of Philips $\left.{ }^{\prime}\right|^{2} \mathrm{C}$ components conveys a license under the Philips $I^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$ system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specification defined by Philips.

## D.C. CHARACTERISTICS (continued)

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Outputs |  |  |  |  |  |
| LOW level output voltage (note 4) (Ports 1, 2, 3 and 4; except P1.6/SCL, P1.7/SDA) | VOL | - | 0,45 | V | $\mathrm{IOL}=1,6 \mathrm{~mA}$ |
| LOW level output voltage (note 4) (Port 0, ALE, $\overline{\text { PSEN }}$ ) | $\mathrm{V}_{\text {OL1 }}$ | - | 0,45 | V | $\mathrm{I} \mathrm{OL}=3,2 \mathrm{~mA}$ |
| LOW level output voltage (P1.6/SCL, P1.7/SCL) | V OL .2 | - | 0,4 | V | $\mathrm{IOL}=3,0 \mathrm{~mA}$ |
| HIGH level output voltage (Ports 1, 2, 3 and 4; except P1.6/SCL, P1.7/SDA) | VOH | $\begin{aligned} & 2,4 \\ & 0,75 V_{D D} \\ & 0,9 V_{D D} \end{aligned}$ | - | V V V | $\begin{aligned} & -\mathrm{IOH}=80 \mu \mathrm{~A} ; \\ & \mathrm{VDD}=5 \mathrm{~V} \pm 10 \% \\ & -\mathrm{IOH}=30 \mu \mathrm{~A} \\ & -\mathrm{IOH}=10 \mu \mathrm{~A} \end{aligned}$ |
| HIGH level output voltage (note 5) (Port 0 in external Bus mode, ALE, $\overline{\text { PSEN }}$ ) | $\mathrm{V}_{\mathrm{OH} 1}$ | $\begin{aligned} & 2,4 \\ & 0,75 V_{D D} \\ & 0,9 V_{D D} \end{aligned}$ | - | V V V | $\begin{aligned} & -\mathrm{IOH}=400 \mu \mathrm{~A} ; \\ & \mathrm{V} D \mathrm{DD}=5 \mathrm{~V} \pm 10 \% \\ & -\mathrm{IOH}=150 \mu \mathrm{~A} \\ & -\mathrm{IOH}=40 \mu \mathrm{~A} \end{aligned}$ |
| RST pull-down resistor | R RST | 40 | 125 | $\mathrm{k} \Omega$ |  |
| I/O pin capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ | - | 10 | pF | $\begin{aligned} & \text { test freq. }=1 \mathrm{MHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=255^{\circ} \mathrm{C} \end{aligned}$ |

## Notes to the d.c. characteristics

1. The operating supply current is measured with all output pins disconnected; XTAL 1 driven with $\mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns} ; \mathrm{V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}+0,5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}-0,5 \mathrm{~V} ; \mathrm{XTAL} 2$ not connected; $\overline{E A}=\mathrm{RST}=$ Port $0=V_{D D}$.
2. The idle mode supply current is measured with all output pins disconnected; XTAL 1 driven with $\mathrm{t}_{\mathrm{r}}=\mathrm{tf}_{\mathrm{f}}=10 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}+0,5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}-0,5 \mathrm{~V}$; XTAL 2 not connected; $\overline{\mathrm{EA}}=$ Port $0=$ $V_{D D} ; R S T=V_{S S}$.
3. The power-down current is measured with all output pins disconnected; XTAL 2 not connected; $\overline{E A}=$ Port $0=V_{D D} ; R S T=V_{S S}$.
4. Capacitive loading on Port 0 and Port 2 may cause spurious noise pulses to be superimposed on the LOW level output voltage of ALE, Port 1 and Port 3. The noise is due to external Bus capacitance discharging into the Port 0 and Port 2 pins when these pins make a 1 -to- 0 transition during Bus operations. In the most adverse condition (capacitive loading $>100 \mathrm{pF}$ ) the noise pulse on ALE line may exceed $0,8 \mathrm{~V}$. In this event it may be required to qualify ALE with a Schmitt trigger, or use an address latch with a Schmitt trigger STROBE input.
5. Capacitive loading on Port 0 and Port 2 may cause the HIGH level output voltage on ALE and PSEN to momentarily fall below the $0,9 \mathrm{~V}_{\mathrm{DD}}$ specification when the address bits are stabilizing.
6. The input threshold voltage of P 1.6 and P 1.7 (SIO1) meets the $\mathrm{I}^{2} \mathrm{C}$ specification, so an input voltage below $1,5 \mathrm{~V}$ will be recognized as a logic ' 0 ' while an input voltage above $3,0 \mathrm{~V}$ will be recognized as a logic 1 .

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (Port 0, ALE and $\overline{\text { PSEN }}$ ) $; \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ (all other outputs); unless otherwise specified (see waveforms Figs 16, 17 and 18)

| parameter | symbol | 10 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. |  |
| Program memory |  |  |  |  |  |  |  |  |
| ALE pulse duration | t LL | 160 | - | 127 | - | 2tck-40 | - | ns |
| Address set-up time to ALE | ${ }^{t} A L$ | 60 | - | 43 | - | ${ }^{\text {t }} \mathrm{CK}-40$ | - | ns |
| Address hold time after ALE | tha | 65 | - | 48 | - | ${ }^{\text {t }}$ CK-35 | - | ns |
| Time from ALE to valid instruction input | ${ }^{\text {t LIV }}$ | - | 300 | - | 233 | - | 4tCK-100 | ns |
| Time from ALE to control pulse $\overline{\mathrm{PSEN}}$ | ${ }^{\text {t }} \mathrm{C}$ | 75 | - | 58 | - | tck-25 | - | ns |
| Control pulse duration $\overline{\text { PSEN }}$ | ${ }^{\mathrm{t}} \mathrm{CC}$ | 265 | - | 215 | - | $3 \mathrm{tcK}-35$ | - | ns |
| Time from $\overline{\text { PSEN }}$ to valid instruction input | ${ }^{\text {t CIV }}$ | - | 175 | - | 125 | - | $3 \mathrm{tck}-125$ | ns |
| Input instruction hold time after $\overline{\mathrm{PSEN}}$ | ${ }^{\mathrm{t}} \mathrm{Cl}$ | 0 | - | 0 | - | 0 | - | ns |
| Input instruction float delay after $\overline{\text { PSEN* }}$ | ${ }^{\text {t }} \mathrm{CIF}$ | - | 80 | - | 63 | - | ${ }^{\text {t }} \mathrm{CK}-20$ | ns |
| Address valid after $\widehat{\text { PSEN }}$ * | ${ }^{t} A C$ | 92 | - | 75 | - | ${ }^{\text {t }}$ CK-8 | - | ns |
| Address to valid instruction input | ${ }^{\text {t A IV }}$ | - | 385 | - | 302 | - | 5 t CK-115 | ns |
| Address float time to PSEN | ${ }^{\text {t }} \mathrm{AFC}$ | -12 | - | -12 | - | 0 | - | ns |

* Interfacing the PCB83C652 to devices with float times up to 75 ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.
A.C. CHARACTERISTICS (continued)

| parameter | symbol | 10 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. |  |
| External data memory |  |  |  |  |  |  |  |  |
| $\overline{\mathrm{RD}}$ pulse duration | trR | 500 | - | 400 | - | 6tck-100 | - | ns |
| $\overline{\mathrm{WR}}$ pulse duration | tww | 500 | - | 400 | - | $6 \mathrm{CCK}-100$ | - | ns |
| Address hold time after ALE | tha | 65 | - | 48 | - | ${ }_{\text {t }} \mathbf{C K}-35$ | - | ns |
| $\overline{\mathrm{RD}}$ to valid data input | ${ }^{\text {t }} \mathrm{D}$ D | - | 335 | - | 250 | - | 5tCK-165 | ns |
| Data hold time after $\overline{\mathrm{RD}}$ | ${ }^{t} \mathrm{DR}$ | 0 | - | 0 | - | 0 | - | ns |
| Data float delay after $\overline{R D}$ | ${ }^{\text {t }}$ DFR | - | 130 | - | 97 | - | 2tck-70 | ns |
| Time from ALE to valid data input | ${ }^{\text {t }}$ LD | - | 650 | - | 517 | - | 8tck-150 | ns |
| Address to valid data input | ${ }^{t} A D$ | - | 735 | - | 585 | - | 9tCK-165 | ns |
| Time from ALE to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ LW | 250 | 350 | 200 | 300 | 3 t CK-50 | $3 \mathrm{tck}+50$ | ns |
| Time from address to $\overline{R D}$ or $\overline{W R}$ | ${ }^{\text {t }}$ AW | 270 | - | 203 | - | 4tCK-130 | - | ns |
| Time from $\overline{\mathrm{RD}}$ or $\overline{W R}$ HIGH to ALE HIGH | tWHLH | 60 | 140 | 43 | 123 | ${ }_{\text {t }} \mathrm{CK}-40$ | ${ }_{\text {t }} \mathrm{CK}+40$ | ns |
| Data valid to $\overline{W R}$ transition | tDWX | 40 | - | 23 | - | tCK-60 | - | ns |
| Data set-up time before $\overline{W R}$ | ${ }^{\text {t }}$ W $W$ | 550 | - | 433 | - | 7tCK-150 | - | ns |
| Data hold time after $\overline{W R}$ | twD | 50 | - | 33 | - | tCK-50 | - | ns |
| Address float delay after $\overline{\mathrm{RD}}$ | ${ }^{t} A F R$ | - | 12 | - | 12 | - | 12 | ns |

## Where:

$1 / \mathrm{t} \mathrm{CK}=3,5$ to 12 MHz (see Fig. 15 and Table 6).

(a)


Fig. 14 A.C. testing input, output waveform (a) and float waveform (b).
A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 . Timing measurements are taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for logic 0 . The float state is defined as the point at which a Port 0 pin sinks $3,2 \mathrm{~mA}$ or sources $400 \mu \mathrm{~A}$ at the voltage test levels.


Fig. 15 External clock drive XTAL 1 (see Table 6).
Table 6 External clock drive XTAL 1 (see Fig. 15)

| parameter | symbol | variable clock ( $\mathrm{f}=3,5$ to 12 MHz ) |  | unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min . | max. |  |
| oscillator clock period | ${ }^{\text {t CK }}$ | 83,3 | 286 | ns |
| HIGH time | thigh | 20 | tek-tLOW | ns |
| LOW time | tow | 20 | tCK-thigh | ns |
| rise time | $\mathrm{tr}_{\mathrm{r}}$ | - |  | ns |
| fall time | ${ }_{\text {tf }}$ | - | 20 | ns |

## A.C. CHARACTERISTICS (continued)



Fig. 16 Read from program memory.


Fig. 17 Read from data memory.


Fig. 18 Write to data memory.


## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The PCB85C51 is the software development version of the PCB80C51 8-bit microcontroller family. The PCB85C51, manufactured in CMOS technology, is chiefly used for the software/hardware development of PCB80C51 applications. The 85C51 has the same electrical parameters as the 80C51 and has an identical instruction set. The 85C51 contains no internal ROM but can address externally as 'quasi-internal', up to 16 K of program memory via its 14 address and 8 data lines. Lines M1/M2 operate as memory control, the signal PSENE serves as memory chip enable. The PCB85C51 does contain a volatile data memory RAM of $128 \times 8$ bytes; 32 I/O lines; two 16-bit timer/event counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and timing circuits. For systems that require extra capability, the PCB85C51 can be expanded using standard TTL compatible memories and logic.

The PCB85C51 has two software selectable modes of reduced activity for further power reduction Idle and Power Down.
The Idle mode freezes the CPU while allowing the RAM, timers, serial port and interrupt systern to continue functioning.
The Power Down mode saves the RAM contents but freezes the oscillator causing all other chip functions to be inoperative.
The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of 255 instructions; $44 \%$ one-byte, $41 \%$ two-byte and $15 \%$ three-byte. With a 12 MHz crystal, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ and $40 \%$ in $2 \mu \mathrm{~s}$. Multiply and divide instructions require $4 \mu \mathrm{~s}$. Multiply, divide, subtract and compare are among the many instructions added to the standard PCB80C49 instruction set.

## Features

- $128 \times 8$ RAM
- Four 8-bit ports, 32 I/O lines
- Two 16-bit timer/event counters
- Full-duplex serial port
- External memory expandable to 128 K , external ROM to 64 K and/or external RAM up to 64 K
- Boolean processing
- 218 bit-addressable locations
- On-chip oscillator
- Five-source interrupt structure with two priority levels
- $58 \%$ of instructions executed in $1 \mu \mathrm{~s}$; multiply and divide in $4 \mu \mathrm{~s}$; all other executed in $2 \mu \mathrm{~s}$ (at 12 MHz clock)
- Enhanced architecture with:
non-page-oriented instructions
direct addressing
four 8 -byte +1 byte register banks
stack depth up to 128 -bytes
multiply, divide, subtract and compare instructions.


## PACKAGE OUTLINES

PCB85C51B: 40-lead DIL piggy-back, metal ceramic (CERDIL) (SOT-215).


Fig. 1 PCB85C51 block diagram.


Fig. 2 Functional diagram of PCB85C51.


Fig. 3a Bottom pinning diagram for PCB85C51B.


Fig. 3b Top pinning on 40-pin EPROM socket for PCB85C51B.

## PIN DESIGNATION (PCB85C51B)

$$
\begin{array}{ll}
\text { 1-8 P1.0-P1.7 } & \begin{array}{l}
\text { Port 1: 8-bit quasi-bidirectional I/O port. Port } 1 \text { can sink/source one TTL } \\
\text { (= } 4 \text { LS TTL) input. It can drive CMOS inputs without external pull-ups. }
\end{array}
\end{array}
$$

$9 \quad$ RST: a high level on this pin for two machine cycles while the oscillator is running resets the device. An internal pull-down permits Power-on reset using only a capacitor connected to $\mathrm{V}_{\mathrm{CC}}$.
10-17 P3.0-P3.7 Port 3: 8-bit quasi-bidirectional I/O port with internal pull-ups. It also serves the following alternative functions:
Port pin Alternative function
P3.0 RXD/data: serial port receiver data input (asynchronous) or data input/output (synchronous)
P3.1 TXD/clock: serial port transmitter data output (asynchronous) or clock output (synchronous)
P3.2 INTO: external interrupt 0 or gate control input for timer/event counter 0
P3.3 INT1: external interrupt 1 or gate control input for timer/event counter 1
P3.4 T0: external input for timer/event counter 0
P3.5 T1: external input for timer/event counter 1
P3.6 WR: external data memory write strobe
P3.7 RD: external data memory read strobe
Operation of an alternative function is determined by the relevant output latch programmed to logic 1 . Port 3 can sink/source one TTL input. It can drive CMOS inputs without external pull-ups.
18 XTAL 2 Crystal input 2: output of the inverting amplifier that forms the oscillator. Left open-circuit when an external oscillator is used (see Figs 8 and 9).
XTAL 1 Crystal input 1: input to the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external oscillator signal when an external oscillator is used (see Figs 8 and 9).
$20 \quad \mathrm{~V}_{\text {SS }} \quad$ Ground: circuit ground potential.
21-28 P2.0-P2.7 Port 2: 8-bit quasi-bidirectional I/O port with internal pull-ups. Port 2 can sink/source one TTL input. It can drive CMOS inputs without external pull-ups. During the access to external memories (RAM/ROM) that use 16 -bit addresses (MOVX @DPTR) Port 2 emits the high order address byte. When used for an external RAM, an 8-bit address (MOVX @Ri) Port 2 emits the contents of P2 Special Function Register.
$29 \quad \overline{\text { PSEN }}$ Program Store Enable output: read strobe to the external Program Memory. It is activated twice each machine cycle during fetches from external Program Memory. When executing out of external Program Memory two activations of $\overline{\text { PSEN }}$ are skipped during each access to external Data Memory. $\overline{\text { PSEN }}$ is not activated (remains HIGH) during no fetches from external Program Memory. $\overline{\text { PSEN }}$ can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pull-up.
30 ALE
Address Latch Enable output: latches the low byte of the address during accesses to external memory in normal operation. It is activated every six oscillator periods except during an external data memory access. ALE can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pull-up.
$31 \quad \overline{E A} \quad$ External Access input: When $\overline{E A}$ is held at a TTL high level the CPU executes out of the internal Program Memory (ROM), provided the Program Counter is less than the boundary selected by M1, M2. When $\overline{E A}$ is held at a TTL low level, the CPU executes out of external Program Memory. $\overline{\mathrm{EA}}$ is not allowed to float.
32-39 P0.7-P0.0 Port 0: 8-bit open drain bidirectional I/O port, it is also the multiplexed low-order address and data bus during accesses to external memory (during these accesses it activates internal pull-ups). Port 0 can sink/source eight LSTTL inputs.
$40 \quad V_{\text {CC }} \quad$ Power supply: +5 V power supply pin during normal operation, Idle mode and Power Down mode.

## PIN DESIGNATION (Non-standard)

10-2 A0-A7, A12 Address Bus: for quasi-internal program memory
26-23, A13, A8, A9, A11
21 A10
11-13, D0-D2
Data Bus: for quasi-internal program memory
15-19 D3-D7
20 ( $\overline{\mathrm{CE}})$ PSENE
Chip enable: signal for external ROM connected via A0-A13 and D0-D7 (Active LOW). Available twice per machine cycle, timing same as user PSEN.*
$C D, A B \quad M 2, M 1 \quad$ Signals: set to control the switch from 'quasi-internal' to external program memory. Signals should only be changed during reset.

| M2 | M1 |  |
| :--- | :---: | :---: |
| 0 | 1 | 4 K Memory (80C51) |
| 1 | 0 | 8 K Memory |
| 1 | 1 | 16 K Memory |
| $0=V_{\text {SS }}$ | $1=V_{C C}$ |  |

* An exception to this is when user PSEN remains HIGH during RESET, when the chip executes from internal program memory or is in the second cycle of a MOVX instruction.


## FUNCTIONAL DESCRIPTION

## General

The PCB85C51 is designed for software development in real-time applications such as instrumentation, industrial control and intelligent computer peripherals.
The device provides the same hardware features, architectural enhancements and new instructions as the PCB80C51. The device can address up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.
The PCB85C51 has a control-oriented CPU without on-chip program memory. Lines M1 and M2 operate as memory control. Below the boundary marked by M1 and M2 the opcodes are fetches out of the quasi-internal ROM. Above this boundary the ROM can be expanded up to 64 K as normal via the ports 0 and 2. The signal PSENE serves as memory chip enable. The PCB85C51 has the lower 4, 8 or 16 K bytes of program memory connected via AO-A13 and DO-D7. For systems requiring extra capability, the PCB85C51 can be expanded using standard memories and peripherals.
This bond-out version of the 80C51 reduces development problems to a minimum and provides maximum flexibility.
The PCB85C51 contains no on-chip program ROM, but does contain a volatile $128 \times 8$ read/write data memory; 32 I/O lines; two 16-bit timer/event counters; a five-source, two-priority-level nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion or full duplex UART communications; and on-chip oscillator and timing circuits.

## Central processing unit

The central processing unit (CPU) manipulates operands in four memory spaces. These are the 64 K byte external data memory, 128 -byte internal data memory, the 64 K -byte internal and external program memory. The internal data memory address space is sub-divided into the 128 -byte internal data RAM and 128 -byte special register (SFR) address spaces, as shown in Fig. 4.


Fig. 4 Memory map.

## FUNCTIONAL DESCRIPTION (continued)

The internal data RAM contains four register banks (each with eight registers), 128 addressable bits, and the stack. The stack depth is limited by the available internal data RAM and its location is determined by the 8 -bit stack pointer. All registers except the program counter and the four 8 -register banks reside in the special function register address space. These memory mapped registers include arithmetic registers, pointers, I/O ports, interrupt system registers, timers and serial port. There are 128 bit addressable locations in the SFR address space.
The PCB85C51 contains 128 bytes of internal data RAM and 20 special function registers. It provides a non-paged program memory address space to accommodate relocatable code. Conditional branches are performed relative to the program counter. The register-indirect jump permits branching relative to a 16 -bit base register with an offset provided by an 8 -bit index register. 16 -bit jumps and calls permit branching to any location in the contiguous 64 K program memory address space.
The PCB85C51 has five methods for addressing source operands:

- Register.
- Direct.
- Register-Indirect.
- Immediate.
- Base-register-plus Index-Register-Indirect.

The first three methods can be used for addressing destination operands. Most instructions have a "destination/source" field that specifies the data type, addressing methods and operands involved. For operations other than moves, the destination operand is also a source operand.
Access addressing is as follows:

- Registers in the four 8 -register banks through Register, Direct, or Register-Indirect.
- 128 bytes of internal data RAM through Direct or Register-Indirect.
- Special function registers through Direct at address locations 128-255.
- External data memory through Register-Indirect.
- Program memory look-up tables through Base-Register-plus Index-Register-Indirect.

The PCB85C51 is classified as an 8-bit device since the external ROM, RAM, Special Function Registers (SFR), Arithmetic Logic Unit (ALU), and external data bus are each 8 -bits wide. It performs operations on bit, nibble, byte and double-byte data types.
Facilities are available for byte transfer, logic, and integer arithmetic operations. Data transfer, logic, and conditional branch operations can be performed directly on Boolean variables to provide excellent bit handling.

## Instruction set

The PCB85C51 uses the same powerful instruction set as the 80C51 to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Reassigned opcodes add new highpower operations and permit new addressing modes to make old operations more orthodox when compared to the 8048 family. The instruction set consists of 49 single-byte, 45 two-byte and 17 threebyte instructions. When using a 12 MHz oscillator, 64 instructions execute in $1 \mu$ s and 45 instructions execute in $2 \mu \mathrm{~s}$. Multiply and divide instructions execute in $4 \mu \mathrm{~s}$.

## I/O facilities

The PCB85C51 has 32 I/O lines treated as 32 individual addressable bits and as four parallel 8-bit addressable ports. Ports $0,1,2$ and 3 perform the following alternate functions:

- Port 0; provides the multiplexed low-order address and data bus used for expanding the PCB85C51 with standard memories and peripherals.
- Port 2; provides the high-order address bus when expanding the PCB85C51 with external program memory or more than 256 bytes of external data memory.
The address boundary for external access to program memory via port 0 and 2 , is set by the signal on M1 and M2.
- Port 3; pins can be configured individually to provide:
- external interrupt request inputs
- counter inputs
- serial port receiver input and transmitter output
- control signals to READ and WRITE to external data memory.

The generation or use of a Port 3 pin as an alternate function is carried out automatically by the PCB85C51 provided the pin is loaded with a HIGH content.


Fig. 5 I/O buffers in the PCB85C51 (Ports 1, 2 and 3).

## Timer/event counters

The PCB85C51 contains two 16 -bit registers, Timer 0 and Timer 1, that can be used as timers or event counters to carry out the following functions:

- Measure time intervals and pulse durations.
- Count events.
- Generate interrupt requests.

Each timer/event counter can be programmed independently to operate in three modes:

- Mode 0; 8-bit timer or 8-bit counter each with divide by 32 prescaler.
- Mode 1; 16-bit time-interval or event counter.
- Mode 2; 8-bit time-interval or event counter with automatic reload upon overflow.

Counter 0 can be programmed to operate in an additional mode as follows:

- Mode 3; one 8-bit time-interval or event counter and one 8-bit time-interval counter.


## FUNCTIONAL DESCRIPTION (continued)

When counter 0 is in Mode 3, counter 1 can be programmed to operate in Modes 0,1 or 2 but cannot set an interrupt request flag or generate an interrupt. However, the overflow from counter 1 can be used to pulse the serial Port transmission-rate generator.

The frequency handling range of these counters with a 12 MHz crystal is as follows:

- Up to 1 MHz when programmed for an input that is a division by 12 of the oscillator frequency.
- 0 Hz to an upper limit of 150 kHz to $0,5 \mathrm{MHz}$ when programmed for external inputs.

Both internal and external inputs can be gated to the counter by a second external source for directly measuring pulse durations.
The counters are started and stopped under software control. Each one sets its interrupt request flag when it overflows from all 1's to all 0's (or automatic reload value).

## On-chip peripheral functions

In addition to the CPU and memories, an interrupt system, extensive I/O facilities, and several peripheral functions are integrated on-chip to relieve the CPU of repetitious, complicated or timecritical tasks and to permit stringent real-time control of external system interfaces. The I/O facilities include the I/O pins, parallel ports, bidirectional address/data bus and the serial port for I/O expansion. The CPU peripheral functions integrated on-chip are the two 16 -bit timer/event counters and the serial port.

## Idle and Power Down operation (see Fig. 6)

The Power Down operation freezes the oscillator. The Idle mode operation allows the interrupt, serial port and timer blocks to continue to function while the clock to the CPU is halted.


Fig. 6 Internal Idle and Power Down clock configuration.

## Power control register (PCON)

These special modes are activated by software via the Special Function Register PCON. Its hardware address is 87 H . PCON is not bit addressable.

| MSB |  |  |  |  |  |  | LSB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |
| SMOD | - | - | - | GF1 | GFO | PD | IDL |


| symbol | position | name and function |
| :---: | :---: | :---: |
| SMOD | PCON. 7 | Double Baud rate bit when set to logic 1 the baud rate is doubled when the serial port is being used in either modes 1,2 or 3 |
| - | PCON. 6 | (reserved) |
| - | PCON. 5 | (reserved) |
| - | PCON. 4 | (reserved) |
| GF1 | PCON. 3 | general-purpose flag bit |
| GF0 | PCON. 2 | general-purpose flag bit |
| PD | PCON. 1 | Power-down bit setting this bit activates power-down operation |
| IDL | PCON. 0 | Idle mode bit setting this bit activates the idle mode operation |

If a logic ' 1 ' is written to PD and IDL at the same time, PD takes precedence. The reset value of PCON is ( $0 \times X \times 000$ ).

## Idle mode

The instruction that sets PCON. 0 is the last instruction executed in the normal operating mode before Idle mode is activated. Once in the Idle mode, the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM and all other registers maintain their data during Idle mode. The status of the external pins during Idle mode is shown in Table 1.

There are two ways to terminate the Idle mode:
Activation of any enabled interrupt will cause PCON. 0 to be cleared by hardware terminating Idle mode. The interrupt is serviced, and following return from interrupt instruction RETI, the next instruction to be executed will be the one which follows the instruction that wrote a logic 1 to PCON.0.

The flag bits GF0 and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the second instruction that writes to PCON. 0 can also set or clear one or both flag bits. When Idle mode is terminated by an interrupt, the service routine can examine the status of the flag bits.
The second way of terminating the Idle mode is with a hardware reset. Since the oscillator is still running, the hardware reset is required to be active for two machine cycles ( 24 oscillator periods) to complete the reset operation.

## FUNCTIONAL DESCRIPTION (continued)

## Power Down mode

The instruction that sets PCON. 1 is the last executed prior to going into the Power Down mode. Once in Power Down mode, the oscillator is stopped. Only the contents of the on-chip RAM are preserved. The Special Function Registers are not saved. A hardware reset is the only way of exiting the Power Down mode.
In the Power Down mode, $\mathrm{V}_{\mathrm{CC}}$ may be reduced to minimize circuit power consumption. The voltage must not be reduced until the Power Down mode is entered, but must be restored before the hardware reset is applied which will free the oscillator. Reset should not be released until the oscillator has restarted and stabilized.

The status of the external pins during Power Down mode is shown in Table 1. If the Power Down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a logic 1, the port pin is held HIGH during the Power Down mode by the strong pull-up transistor p1 (see Fig. 5).

Table 1 Status of the external pins during Idle and Power Down modes

| mode | memory | ALE | $\overline{\text { PSEN }}$ | Port 0 | Port 1 | Port 2 | Port 3 |
| :--- | :--- | :---: | :---: | :--- | :--- | :--- | :--- |
| Idle | internal | 1 | 1 | port data | port data | port data | port data |
| Idle | external | 1 | 1 | floating | port data | address | port data |
| Power-down | internal | 0 | 0 | port data | port data | port data | port data |
| Power-down | external | 0 | 0 | floating | port data | port data | port data |

## Interrupt system (see Fig. 7)

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution a multiple-source, two-priority-level, nested interrupt system is provided. Interrupt response latency is from $3 \mu$ s to $7 \mu$ s when using a 12 MHz crystal.
The PCB85C51 acknowledge interrupt requests from five sources as follows:

- INT0 and INT1; externally via pins 12 and 13 respectively.
- Timer 0 and Timer 1 ; from the two internal counters.
- Serial Port; from the internal serial I/O port.

Each interrupt vectors to a separate location in program memory for its service program.
Each source can be individually enabled or disabled and can be programmed to a high or low priority level. Also all enabled sources can be globally disabled or enabled. Both external interrupts can be programmed to be level-activated or transition-activated and are active LOW to allow "wire-ORing" of several interrupt sources to the input pin.


Fig. 7 Interrupt system.

## FUNCTIONAL DESCRIPTION (continued)

## Oscillator circuitry

The oscillator circuitry of the PCB85C51 is a single-stage inverting amplifier in a Pierce oscillator configuration. The circuitry between XTAL 1 and XTAL 2 is basically an inverter biased to the transfer point. Either a crystal or ceramic resonator can be used as the feedback element to complete the oscillator circuitry. Both are operated in parallel resonance. XTAL 1 (pin 19) is the high gain amplifier input, and XTAL 2 (pin 18) is the output (see Fig. 8). To drive the PCB85C51 externally, XTAL 1 is driven from an external source and XTAL 2 left open-circuit (see Fig. 9).


Fig. 8 PCB85C51 oscillator circuit.


Fig. 9 PCB85C51 driven from an external source.

## Reset circuitry

The reset circuitry for the PCB85C51 is connected to the reset pin, RST, as shown in Fig. 10. A Schmitt trigger is used at the input for noise rejection. The output of the Schmitt trigger is sampled by the reset circuitry every machine cycle.


Fig. 10 Reset configuration at RST.
A reset is accomplished by holding the RST pin HIGH for at least two machine cycles (24 oscillator periods), while the oscillator is running. The CPU responds by executing an internal reset. It also configures the ALE and PSEN pins as inputs. (They are quasi-bidirectional.)

The internal reset is executed during the second cycle in which RST is HIGH and is repeated every cycle until RST goes LOW. It leaves the internal registers as follows:

| Register | Content |
| :--- | ---: |
| PC | 000 H |
| ACC | 00 H |
| B | 00 H |
| PSW | 00 H |
| SP | 07 H |
| DPTR | 000 H |
| PO - P3 | 0 FFH |
| IP | $(X \times 000000)$ |
| IE | $10 \times 000000$ ) |
| TMOD | 00 H |
| TCON | 00 H |
| THO | 00 H |
| TLO | 00 H |
| TH1 | 00 H |
| TL1 | 00 H |
| SCON | 00 H |
| SBUF | Intermediate |
| PCON | (OXXX0000) |

The internal RAM is not affected by reset. When $\mathrm{V}_{\mathrm{CC}}$ is turned on, the RAM content is indeterminate.

## Power-on reset (see Fig. 11)

When $V_{C C}$ is turned on, and provided its rise-time does not exceed 10 ms , an automatic reset can be obtained by connecting the RST pin to $\mathrm{V}_{\mathrm{CC}}$ via a $10 \mu \mathrm{~F}$ capacitor. When the power is switched on, the voltage on the RST pin is the difference between $V_{C C}$ and the capacitor voltage, this decreases from $V_{C C}$ as the capacitor charges through the internal resistor ( $\mathrm{R}_{\mathrm{RST}}$ ) to ground. The larger the capacitor, the more slowly $\mathrm{V}_{\text {RST }}$ decreases. $\mathrm{V}_{\text {RST }}$ must remain above the lower threshold of the Schmitt trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles. To avoid a 'latch-up' of the CMOS circuitry, the power supply on the RST pin at switch-on must not exceed $\mathrm{V}_{\mathrm{CC}}+0,5 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{SS}}-0,5 \mathrm{~V}$.


Fig. 11 Power-on reset.

## INSTRUCTION SET

Table 2 Instruction set description

| mnemonic |  | description |  |  | opcode <br> (hex.) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Arithmetic operations |  |  |  |  |  |
| ADD | A, Rr | Add register to A | 1 | 1 | 2* |
| ADD | A,direct | Add direct byte to A | 2 | 1 | 25 |
| ADD | A,@Ri | Add indirect RAM to $A$ | 1 | 1 | 26, 27 |
| ADD | A, \#data | Add immediate data to $A$ | 2 | 1 | 24 |
| ADDC |  | Add register to A with carry flag | 1 | 1 | 3* |
| ADDC | A,direct | Add direct byte to A with carry flag | 2 | 1 | 35 |
| ADDC | A,@Ri | Add indirect RAM to A with carry flag | 1 | 1 | 36,37 |
| ADDC | A,\#data | Add immediate data to A with carry flag | 2 | 1 | 34 |
| SUBB | A, Rr | Subtract register from A with borrow | 1 | 1 | 9* |
| SUBB | A,direct | Subtract direct byte from A with borrow | 2 | 1 | 95 |
| SUBB | A,@Ri | Subtract indirect RAM from A with borrow | 1 | 1 | 96, 97 |
| SUBB | A, \#data | Subtract immediate data from A with borrow | 2 | 1 | 94 |
| INC | A | Increment A | 1 | 1 | 04 |
| INC | Rr | Increment register | 1 | 1 | 0* |
| INC | direct | Increment direct byte | 2 | 1 | 05 |
| INC | @Ri | Increment indirect RAM | 1 | 1 | 06, 07 |
| DEC | A | Decrement A | 1 | 1 | 14 |
| DEC | Rr | Decrement register | 1 | 1 | 1* |
| DEC | direct | Decrement direct byte | 2 | 1 | 15 |
| DEC | @Ri | Decrement indirect RAM | 1 | 1 | 16, 17 |
| INC | DPTR | Increment data pointer | 1 | 2 | A3 |
| MUL | $A B$ | Multiply A \& B | 1 | 4 | A4 |
| DIV | AB | Divide A by B | 1 | 4 | 84 |
| DA | A | Decimal adjust A | 1 | 1 | D4 |


| mnemonic | description |  |  | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: |
| Logic operations |  |  |  |  |
| ANL A,Rr | AND register to $A$ | 1 | 1 | 5* |
| ANL A, direct | AND direct byte to $A$ | 2 | 1 | 55 |
| ANL A,@Ri | AND indirect RAM to $A$ | 1 | 1 | 56, 57 |
| ANL A,\#data | AND immediate data to $A$ | 2 | 1 | 54 |
| ANL direct, A | AND A to direct byte | 2 | 1 | 52 |
| ANL direct,\#data | AND immediate data to direct byte | 3 | 2 | 53 |
| ORL A,Rr | OR register to $A$ | 1 | 1 | 4* |
| ORL A, direct | OR direct byte to $A$ | 2 | 1 | 45 |
| ORL A,@Ri | OR indirect RAM to $A$ | 1 | 1 | 46, 47 |
| ORL A,\#data | OR immediate data to $A$ | 2 | 1 | 44 |
| ORL direct,A | OR A to direct byte | 2 | 1 | 42 |
| ORL direct,\#data | OR immediate data to direct byte | 3 | 2 | 43 |
| XRL A,Rr | Exclusive-OR register to $A$ | 1 | 1 | 6* |
| XRL A, direct | Exclusive-OR direct byte to $A$ | 2 | 1 | 65 |
| XRL A,@Ri | Exclusive-OR indirect RAM to $A$ | 1 | 1 | 66, 67 |
| XRL A, \#data | Exclusive-OR immediate data to $A$ | 2 | 1 | 64 |
| XRL direct, $A$ | Exclusive-OR A to direct byte | 2 | 1 | 62 |
| XRL direct,\#data | Exclusive-OR immediate data to direct byte | 3 | 2 | 63 |
| CLR A | Clear A | 1 | 1 | E4 |
| CPL A | Complement A | 1 | 1 | F4 |
| RL A | Rotate A left | 1 | 1 | 23 |
| RLC A | Rotate A left through the carry flag | 1 | 1 | 33 |
| RR A | Rotate A right | 1 | 1 | 03 |
| RRC A | Rotate A right through the carry flag | 1 | 1 | 13 |
| SWAP A | Swap nibbles within A | 1 | 1 | C4 |

INSTRUCTION SET (continued)

| mnemonic | description | bytes/ <br> cycles | opcode <br> (hex.) |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Data transfer |  |  |  |  |  |
| MOV | A,Rr | Move register to A | 1 | 1 | E* |
| MOV | A,direct | Move direct byte to A | 2 | 1 | E5 |
| MOV | A,@Ri | Move indirect RAM to A | 1 | 1 | E6, E7 |
| MOV | A,\#data | Move immediate data to A | 2 | 1 | 74 |
| MOV | Rr,A | Move A to register | 1 | 1 | F* $^{*}$ |
| MOV | Rr,direct | Move direct byte to register | 2 | 2 | A* $^{*}$ |
| MOV | Rr,\#data | Move immediate data to register | 2 | 1 | $7^{*}$ |
| MOV | direct,A | Move A to direct byte | 2 | 1 | F5 |
| MOV | direct,Rr | Move register to direct byte | 2 | 2 | $8 *$ |
| MOV | direct,direct | Move direct byte to direct | 3 | 2 | 85 |
| MOV | direct,@Ri | Move indirect RAM to direct byte | 2 | 2 | 86,87 |
| MOV | direct,\#data | Move immediate data to direct byte | 3 | 2 | 75 |
| MOV | @Ri,A | Move A to indirect RAM | 1 | 1 | F6, F7 |
| MOV | @Ri,direct | Move direct byte to indirect RAM | 2 | 2 | A6, A7 |
| MOV | @Ri,\#data | Move immediate data to indirect RAM | 2 | 1 | 76,77 |
| MOV | DPTR,\#data16 | Load data pointer with a 16-bit constant | 3 | 2 | 90 |
| MOVC | A,@A+DPTR | Move code byte relative to DPTR to A | 1 | 2 | 93 |
| MOVC | A,@A+PC | Move code byte relative to PC to A | 1 | 2 | 83 |
| MOVX | A,@Ri | Move external RAM (8-bit address) to A | 1 | 2 | E2, E3 |
| MOVX | A,@DPTR | Move external RAM (16-bit address) to A | 1 | 2 | E0 |
| MOVX | @Ri,A | Move A to external RAM (8-bit address) | 1 | 2 | F2, F3 |
| MOVX | @DPTR,A | Move A to external RAM (16-bit address) | 1 | 2 | F0 |
| PUSH | direct | Push direct byte onto stack | 2 | 2 | C0 |
| POP | direct | Pop direct byte from stack | 2 | 2 | D0 |
| XCH | A,Rr | Exchange register with A | 1 | 1 | C* |
| XCH | A,direct | Exchange direct byte with A | 2 | 1 | C5 |
| XCH | A,@Ri | Exchange indirect RAM with A | 1 | 1 | C6, C7 |
| XCHD | A,@Ri | Exchange LOW-order digit indirect RAM with A | 1 | 1 | D6, D7 |
|  |  |  |  |  |  |


| mnemonic |  | description |  |  | opcode (hex.) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Boolean variable manipulation |  |  |  |  |  |
| CLR | C | Clear carry flag | 1 | 1 | C3 |
| CLR | bit | Clear direct bit | 2 | 1 | C2 |
| SETB | C | Set carry flag | 1 | 1 | D3 |
| SETB | bit | Set direct bit | 2 | 1 | D2 |
| CPL | C | Complement carry flag | 1 | 1 | B3 |
| CPL | bit | Complement direct bit | 2 | 1 | B2 |
| ANL | C,bit | AND direct bit to carry flag | 2 | 2 | 82 |
| ANL | C,/bit | AND complement of direct bit to carry flag | 2 | 2 | B0 |
| ORL | C,bit | OR direct bit to carry flag | 2 | 2 | 72 |
| ORL | C,/bit | OR complement of direct bit to carry flag | 2 | 2 | A0 |
| MOV | C,bit | Move direct bit to carry flag | 2 | 1 | A2 |
| MOV | bit, $C$ | Move carry flag to direct bit | 2 | 2 | 92 |
| Program and machine control |  |  |  |  |  |
| ACALL addr11 |  | Absolute subroutine call | 2 | 2 | -1addr |
| LCALL addr16 |  | Long subroutine call | 3 | 2 | 12 |
| RET |  | Return from subroutine | 1 | 2 | 22 |
| RETI |  | Return from interrupt | 1 | 2 | 32 |
| AJMP addr11 |  | Absolute jump | 2 | 2 | 41addr |
| LJMP | addr16 | Long jump | 3 | 2 | 02 |
| SJMP | rel | Short jump (relative address) | 2 | 2 | 80 |
| JMP | @A+DPTR | Jump indirect relative to the DPTR | 1 | 2 | 73 |
| JZ | rel | Jump if $A$ is zero | 2 | 2 | 60 |
| JNZ | rel | Jump if $A$ is not zero | 2 | 2 | 70 |
| JC | rel | Jump if carry flag is set | 2 | 2 | 40 |
| JNC | rel | Jump if no carry flag | 2 | 2 | 50 |
| JB | bit,rel | Jump if direct bit is set | 3 | 2 | 20 |
| JNB | bit,rel | Jump if direct bit is not set | 3 | 2 | 30 |
| JBC | bit,rel | Jump if direct bit is set and clear bit | 3 | 2 | 10 |
| CJNE | A,direct,rel | Compare direct to $A$ and jump if not equal | 3 | 2 | B5 |
| CJNE | A,\#data, rel | Compare immediate to $A$ and jump if not equal | 3 | 2 | B4 |
| CJNE | Rr,\#data,rel | Compare immed. to reg. and jump if not equal | 3 | 2 | B* |
| CJNE | @Ri,\#data, rel | Compare immed. to ind. and jump if not equal | 3 | 2 | B6, B7 |
| DJNZ | Rr,rel | Decrement register and jump if not zero | 2 | 2 | D* |
| DJNZ | direct,rel | Decrement direct and jump if not zero | 3 | 2 | D5 |
| NOP |  | No operation | 1 | 1 | 00 |

## Notes to Table 2

Data addressing modes
$\mathrm{Rr} \quad$ Working register R0-R7.
direct $\quad 128$ internal RAM locations and any special function register (SFR).
@Ri Indirect internal RAM location addressed by register R0 or R1 of the actual register bank.
\#data $\quad 8$-bit constant included in instruction.
\#data16 16-bit constant included as bytes 2 and 3 of instruction.
bit direct addressed bit in internal RAM or SFR.
addr16 16-bit destination address. Used by LCALL and LJMP. The branch will be anywhere within the 64 K-byte program memory address space.
addr11 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 K-byte page of program memory as the first byte of the following instruction.
rel $\quad$ Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is -128 to +127 bytes relative to first byte of the following instruction.

## Hexadecimal opcode cross-reference to Table 2

*: 8, 9, A, B, C, D, E, F.

- 11, 31, 51, 71, 91, B1, D1, F1.

A: $01,21,41,61,81, A 1, C 1, E 1$.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Input voltage on any pin
with respect to ground ( $\mathrm{V}_{\mathrm{SS}}$ )
Input, output current
Total power dissipation
Storage temperature range
Operating ambient temperature range

| $V_{I}$ | $-0,5$ to $+7 \mathrm{~V}$ |  |
| :--- | :--- | ---: |
| $\pm I_{1}, I_{O}$ | max. | 10 mA |
| $\mathrm{P}_{\text {tot }}$ | max. | 1 W |
| $\mathrm{~T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |  |
| $\mathrm{T}_{\text {amb }}$ | 0 to $+70{ }^{\circ} \mathrm{C}$ |  |

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified.

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4,5 | 5,5 | V |  |
| Supply current |  |  |  |  |  |
| operating (note 1) | ${ }^{\text {I C C }}$ | - | 30* | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz}$ |
| Idle mode (note 2) | ${ }^{\text {I CC }}$ | - | 10* | mA | ${ }^{\mathrm{f}} \mathrm{CLK}=12 \mathrm{MHz}$ |
| Power Down current | IPD | - | 100* | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=2 \mathrm{~V}$ (note 3$)$ |
| Inputs |  |  |  |  |  |
| LOW level input voltage (except $\overline{\mathrm{EA}}$ ) | $V_{\text {IL }}$ | -0,5 | $0,2 \mathrm{~V}_{\mathrm{CC}}-0,1$ | V |  |
| LOW level input voltage ( $\overline{\mathrm{EA}}$ ) | $V_{\text {IL1 }}$ | -0,5 | $0,2 \mathrm{~V}_{\mathrm{CC}}-0,3$ | V |  |
| HIGH level input voltage (except XTAL 1, RST) | $\mathrm{V}_{\text {IH }}$ | $0,2 V_{C C}+0,9$ | $V_{C C}+0,5$ | V |  |
| HIGH level input voltage (XTAL 1, RST) | $\mathrm{V}_{\text {IH1 }}$ | $0,7 V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}+0,5$ | V |  |
| Input current logic 0 <br> (Ports 1, 2 and 3) | $-1 / 2$ | - | 50 | $\mu \mathrm{A}$ | $V_{1}=0,45 \mathrm{~V}$ |
| Input current logic 1 to 0 transition <br> (Ports 1, 2 and 3) | ${ }^{-1} \mathrm{TL}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=2 \mathrm{~V}$ |
| Input leakage current (Port 0, EA) | $\pm \mathrm{ILI}^{\text {L }}$ | - | 10 | $\mu \mathrm{A}$ | $0,45 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}_{\mathrm{Cc}}$ |

[^9]D.C. CHARACTERISTICS (continued)

| parameter | symbol | min. | max. | unit | conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Outputs |  |  |  |  |  |
| LOW level output voltage (note 4) (Ports 1, 2 and 3) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0,45 | V | ${ }^{\prime} \mathrm{OL}=1,6 \mathrm{~mA}$ |
| LOW level output voltage (note 4) (Port 0, ALE, PSEN) | $\mathrm{V}_{\text {OL1 }}$ | - | 0,45 | V | $\mathrm{I}^{\prime} \mathrm{OL}=3,2 \mathrm{~mA}$ |
| HIGH level output voltage (Ports 1, 2 and 3) | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | V | $\begin{aligned} & -\mathrm{I}_{\mathrm{OH}}=80 \mu \mathrm{~A} ; \\ & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \end{aligned}$ |
|  |  | 0,75V CC | - | V | ${ }^{-1} \mathrm{OH}=30 \mu \mathrm{~A}$ |
|  |  | $0,9 V_{C C}$ | - | V | $-^{1} \mathrm{OH}=10 \mu \mathrm{~A}$ |
| HIGH level output voltage (note 5) (Port 0 in external | $\mathrm{V}_{\mathrm{OH} 1}$ |  | - | V | $\begin{aligned} & -\mathrm{IOH}=400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \end{aligned}$ |
| Bus mode, ALE, $\overline{\text { PSEN }}$ ) |  | 2,4 |  |  |  |
|  |  | $0,75 V_{\text {cc }}$ | - | V | $-\mathrm{IOH}^{\prime}=150 \mu \mathrm{~A}$ |
|  |  | $0,9 \mathrm{~V}_{\mathrm{CC}}$ | - | V | $-\mathrm{I}^{\mathrm{OH}}=40 \mu \mathrm{~A}$ |
| RST pull-down resistor | $\mathrm{R}_{\text {RST }}$ | 40 | 125 | k $\Omega$ |  |
| 1/O pin capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ | - | 10 | pF | $\begin{aligned} & \text { test freq. }=1 \mathrm{MHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ |

Notes to the d.c. characteristics

1. The operating supply current is measured with all output pins disconnected; XTAL 1 driven with $\mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}+0,5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0,5 \mathrm{~V}$;
XTAL 2 not connected; $\mathrm{EA}=\mathrm{RST}=$ Port $0=\mathrm{V}_{\mathrm{CC}}$.
2. The Idle mode supply current is measured with all output pins disconnected;

XTAL 1 driven $\mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns}, \mathrm{~V}_{\mathrm{IL}}=\mathrm{V}_{\mathrm{SS}}+0,5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0,5 \mathrm{~V}$;
XTAL 2 not connected; $\overline{E A}=$ Port $0=V_{C C} ; R S T=V_{S S}$.
3. The Power Down current is measured with all output pins disconnected;

XTAL 2 not connected; $\overline{E A}=$ Port $0=\mathrm{V}_{\mathrm{CC}} ;$ RST $=\mathrm{V}_{\mathrm{SS}}$.
4. Capacitive loading on Port 0 and Port 2 may cause spurious noise pulses to be superimposed on the LOW level output voltage of ALE, Port 1 and Port 3. The noise is due to external Bus capacitance discharging into the Port 0 and Port 2 pins when these pins make a 1 -to- 0 transition during Bus operations. In the most adverse condition (capacitive loading $>100 \mathrm{pF}$ ) the noise pulse on ALE line may exceed $0,8 \mathrm{~V}$. In this event it may be required to qualify ALE with a Schmitt trigger, or use an address latch with a Schmitt trigger STROBE input.
5. Capacitive loading on Port 0 and Port 2 may cause the HIGH level output voltage on ALE and $\overline{\text { PSEN }}$ to momentarily fall below the $0,9 \mathrm{~V}_{\mathrm{CC}}$ specification when the address bits are stabilizing.
A.C. CHARACTERISTICS (Non-standard pins. See Fig. 18)

Conditions: 12 MHz clock, $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ on A0-A13
$C_{L}=100 \mathrm{pF}$ on $\overline{\text { PSEN }}$, ALE
$V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{a m b}=0$ to $+70^{\circ} \mathrm{C}$

| parameter | symbol | min. | max. | unit |
| :---: | :---: | :---: | :---: | :---: |
| ALE pulse width | TLHLL | 140 | - | ns |
| Address set up to ALE | TAVLL | 45 | - | ns |
| Address hold up after ALE | TLLAX | 50 | - | ns |
| PSENE width | TPLPH | 230 | - | ns |
| PSENE, ALE cycle time | TLHLH | 500 | - | ns |
| $\overline{\text { PSENE }}$ to valid emulation instruction in | TPLDV | 150 | - | ns |
| Input emulation instruction hold after PSENE | TPHDX | 0 | - | ns |
| Address to valid emulation instruction in | TAVDV | - | 320 | ns |
| ALE to $\overline{\text { PSENE }}$ | TLLPL | 58 | - | ns |

A.C. CHARACTERISTICS (Standard pins)
$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C} ; \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (Port 0, ALE and $\overline{\text { PSENE }}$ );
$C_{L}=80 \mathrm{pF}$ (all other outputs); unless otherwise specified (see waveforms Figs 14, 15 and 16)


[^10]DEVELOPMENT DATA

| parameter | symbol | 10 MHz |  | 12 MHz |  | variable clock |  | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. | min. | max. |  |
| External data memory |  |  |  |  |  |  |  |  |
| $\overline{\mathrm{RD}}$ pulse duration | $t_{\text {R }}$ R | 500 | - | 400 | - | 6 t CK-100 | - | ns |
| $\overline{\mathrm{WR}}$ pulse duration | ${ }^{\text {t }}$ WW | 500 | - | 400 | - | $6^{\text {ctek }}$-100 | - | ns |
| Address hold time after ALE | ${ }_{\text {t }}$ LA | 65 | - | 48 | - | ${ }^{\text {t }}$ CK -35 | - | ns |
| $\overline{\mathrm{RD}}$ to valid data input | ${ }^{\text {t }}$ RD | - | 335 | - | 250 | - | ${ }^{51} \mathrm{CK}$-165 | ns |
| Data hold time after $\overline{\mathrm{RD}}$ | ${ }^{t} \mathrm{DR}$ | 0 | - | 0 | - | 0 | - | ns |
| Data float delay after $\overline{\mathrm{RD}}$ | ${ }^{\text {t DFR }}$ | - | 130 | - | 97 | - | 2 t CK -70 | ns |
| Time from ALE to valid data input | ${ }^{\text {t }}$ LD | - | 650 | - | 517 | - | ${ }^{8 t} \mathrm{CKK}^{-150}$ | ns |
| Address to valid data input | ${ }^{t} A D$ | - | 735 | - | 585 | - | 9 t CK-165 | ns |
| $\begin{aligned} & \text { Time from ALE to } \\ & \overline{R D} \text { or } \overline{W R} \end{aligned}$ | ${ }^{\text {t }}$ LW | 250 | 350 | 200 | 300 | ${ }^{31} \mathrm{CK}-50$ | $3{ }^{\text {chek }}+50$ | ns |
| Time from address to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ AW | 270 | - | 203 | - | ${ }^{4 t} \mathrm{CKK}^{-130}$ | - | ns |
| Time from $\overline{R D}$ or $\overline{W R}$ HIGH to ALE HIGH | ${ }^{\text {t WHLH }}$ | 60 | 140 | 43 | 123 | ${ }^{\text {t }}$ CK -40 | ${ }^{\text {t }} \mathrm{CK}^{+40}$ | ns |
| Data valid to $\overline{W R}$ transition | ${ }^{\text {t }}$ WX | 40 | - | 23 | - | ${ }^{\text {t }}$ CK -60 | - | ns |
| Data set-up time before $\overline{W R}$ | ${ }^{\text {t }}$ DW | 550 | - | 433 | - | ${ }^{7 \mathrm{t}} \mathrm{CK}-150$ | - | ns |
| Data hold time after $\overline{W R}$ | ${ }^{\text {t }}$ WD | 50 | - | 33 | - | ${ }^{\text {t }}$ CK-50 | - | ns |
| Address float delay after $\overline{\mathrm{RD}}$ | ${ }^{\text {t AFR }}$ | - | 12 | - | 12 | - | 12 | ns |

Where:
$1 / \mathrm{t} \mathrm{CK}=3,5$ to 12 MHz and are preliminary values (see Fig. 13 and Table 3).

## A.C. CHARACTERISTICS (continued)


(a)


Fig. 12 A.C. testing input, output waveform (a) and float waveform (b).
A.C. testing inputs are driven at $2,4 \mathrm{~V}$ for a logic 1 and $0,45 \mathrm{~V}$ for a logic 0 . Timing measurements are taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for logic 0 . The float state is defined as the point at which a Port 0 pin sinks 3,2 mA or sources $400 \mu \mathrm{~A}$ at the voltage test levels.


Fig. 13 External clock drive XTAL 1 (see Table 3).
Table 3 External clock drive XTAL 1 (see Fig. 13).

| parameter | symbol | $\begin{gathered} \text { variable clock } \\ (f=3,5 \text { to } 12 \mathrm{MHz})^{*} \end{gathered}$ |  | unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| Oscillator clock period | ${ }^{\text {t }} \mathrm{CK}$ | 83,3 | 286 | ns |
| HIGH time | ${ }^{\text {thigh }}$ | 20 | ${ }^{\text {t }}$ CK-t ${ }^{\text {L }}$ LOW | ns |
| LOW time | t LOW | 20 | ${ }^{\text {t }}$ CK ${ }^{-\mathrm{t}^{\text {H }} \mathrm{HIGH}}$ | ns |
| rise time | $\mathrm{t}_{\mathrm{r}}$ | - | 20 | ns |
| fall time | $\mathrm{t}_{\mathrm{f}}$ | - | 20 | ns |

[^11]

Fig. 15 Read from data memory via Port 0 and Port 2.


Fig. 16 Write to data memory via Port 0 and Port 2.

DEVELOPMENT DATA


Fig. 17 Instruction cycle timing.
D.C. characteristics for non-standard signals (PSENE, A0-A13, DO-D7)

PCB85C51 ( $\mathrm{V}_{\mathrm{CC}}=4,5$ to $5,5 \mathrm{~V}$ )

Non-standard pins
$V_{\text {OL }}$ output LOW voltage
$\mathrm{V}_{\mathrm{OH}}$ output HIGH voltage
$V_{\text {IL }}$ input LOW voltage
$\mathrm{V}_{\text {IH }}$ input HIGH voltage

| min. | max. | unit | conditions |
| :---: | :---: | :---: | :--- |
|  | 0,45 | V | $I_{\mathrm{OL}}=1,6 \mathrm{~mA}$ |
| 2,4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $-0,5$ | 0,8 | V |  |
| 2,0 | $\mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}<5,5 \mathrm{~V}$ |

PSENE
$\mathrm{V}_{\text {OL }}$ output LOW voltage

0,45
2,4

$$
V
$$

$$
\mathrm{I}_{\mathrm{OL}}=3,2 \mathrm{~mA}
$$

$\mathrm{V}_{\mathrm{OH}}$ output HIGH voltage

$$
V
$$

$$
\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}
$$



Fig. 18 Reading from quasi-internal program memory.
DEVELOPMENT DATA


Fig. 19 Connection diagram for piggy-back package.
Jumpers with a length of $15,24 \mathrm{~mm}$ for connecting M 1 and M 2 to $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$ may be ordered via catalogue number 431206501138.

## CMOS MICROCONTROLLER FOR TELEPHONE SETS

## GENERAL DESCRIPTION

The PCD3315C is a single-chip 8-bit microcontroller fabricated in CMOS and is a member of the PCD3343 family. It has special on-chip features for application in telephone sets.

## Features

- 8-bit CPU, ROM, RAM, I/O in a single 28 -lead DIL or SO package
- 1536 ROM bytes
- 160 RAM bytes
- 20 quasi-bidirectional I/O port lines
- Two test inputs: one of which is also the external interrupt input (CE/TO)
- Single-level vectored interrupts: external, timer/event counter
- 8 -bit programmable timer/event counter
- Over 80 instructions (based on MAB8048, MAB8400, PCD3343 and PCF8500)
- All instructions 1 or 2 cycles
- Clock frequency 100 kHz to 10 MHz
- Single supply voltage from $1,8 \mathrm{~V}$ to 6 V
- Low standby voltage and current
- STOP and IDLE mode
- On-chip oscillator with output drive capability for peripherals
- Configuration of all I/O port lines individually selected by mask: pull-up, open drain or push-pull
- Power-on-reset circuit and low supply voltage detection
- Reset state of all ports individually selected by mask
- Operating temperature range: -25 to $+70^{\circ} \mathrm{C}$


## PACKAGE OUTLINES

PCD3315CP: 28-lead DIL; plastic (SOT-117).
PCD3315CT: 28-lead mini-pack; plastic (SO-28; SOT-136A).


Fig. 1 Block diagram; PCD3315C.

(a)

Fig. 1a Replacement of dotted part in Fig. 1, for the PCD8500F bond-out version.

(b)

Fig. 1b Replacement of dotted part in Fig. 1, for the PCF8500B 'Piggy-back' version.

## PINNING



Fig. 2 Pinning diagram: PCD3315C

## PIN DESIGNATION

| 3 | n.c. | not connected |
| :---: | :---: | :---: |
| 4-11 | P00-P07 | Port 0: 8-bit quasi-bidirectional I/O port. |
| 12 | CE/TO | Interrupt/Test 0: external interrupt input (sensitive to positive-going edge edge)/test input pin; when used as a test input directly tested by conditional branch instructions JTO and JNTO. |
| 13 | T1 | Test 1: test input pin, directly tested by conditional branch instructions JT1 and JNT1. T1 also functions as an input to the 8-bit timer/event counter, using the STRT CNT instruction. |
| 14 | $\mathrm{V}_{\text {SS }}$ | Ground: circuit earth potential. |
| 15 | XTAL 1 | Crystal input: connection to timing component (crystal) which determines the frequency of the internal oscillator; also the input for an external clock source. |
| 16 | XTAL 2 | connection to the other side of the timing component. |
| 17 | RESET | Reset input: used to initialize the processor (active HIGH), or output of power-on-reset circuit. |
| 18-25 | P10-P17 | Port 1: 8-bit quasi-bidirectional I/O port. |
| 26, 27, 1, 2 | P20-P23 | Port 2: 4-bit quasi-bidirectional I/O port. |
| 28 | $\mathrm{V}_{\text {DD }}$ | Power supply: $1,8 \mathrm{~V}$ to 6 V . |

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-25$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}} ; \mathrm{f}=3,58 \mathrm{MHz}$ with $R_{S}=50 \Omega$; unless otherwise specified.

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage operating STOP mode for RAM retention <br> Supply current operating at $V_{D D}=3 V$ <br> IDLE mode at $V_{D D}=3 \mathrm{~V}$ <br> STOP mode (note 1) at $V_{D D}=1,8 \mathrm{~V} ; T_{a m b}=25^{\circ} \mathrm{C}$ <br> at $V_{D D}=1,8 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=55^{\circ} \mathrm{C}$ <br> at $\mathrm{V}_{\mathrm{DD}}=1,8 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C}$ <br> RESET I/O <br> Switching level <br> Sink current at $\mathrm{V}_{\mathrm{DD}}>\mathrm{V}_{\text {RESET }}$ <br> Inputs <br> Input voltage LOW <br> Input voltage HIGH <br> Input leakage current <br> at $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\mathrm{DD}}$ <br> Outputs <br> Output voltage LOW at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}} ;\left\|\\|_{\mathrm{O}}\right\|<1 \mu \mathrm{~A}$ <br> Output sink current LOW at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$ <br> Pull-up output source current HIGH at $V_{D D}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=0,9 \mathrm{~V}_{\mathrm{DD}}$ at $V_{D D}=3 V ; V_{O}=V_{S S}$ <br> Push-pull output source current HIGH at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{DD}}-0,4 \mathrm{~V}$ | $V_{\text {DD }}$ | 1,8 | - | 6 | V |
|  | $V_{\text {DD }}$ | 1,0 | - | 6 | V |
|  | IDD | - | 350 | - | $\mu \mathrm{A}$ |
|  | ${ }^{\prime}$ DD | - | 150 | - | $\mu \mathrm{A}$ |
|  | 1 | - | 1,2 | 2,5 | $\mu \mathrm{A}$ |
|  | ${ }^{1} \mathrm{DD}$ | - | - | 5 | $\mu \mathrm{A}$ |
|  | ${ }^{\text {I D D }}$ | - | - | 10 | $\mu \mathrm{A}$ |
|  |  |  |  |  |  |
|  | $\mathrm{V}_{\text {RESET }}$ | - | 1,2 | - | v |
|  | ${ }^{1} \mathrm{OL}$ | - | 7 | - | $\mu \mathrm{A}$ |
|  |  |  |  |  |  |
|  | $V_{\text {IL }}$ | 0 | - | $0,3 V_{\text {DD }}$ | V |
|  | $\mathrm{V}_{\text {IH }}$ | $0,7 V_{\text {DD }}$ | - | $V_{\text {DD }}$ | V |
|  | $\pm 1 \mathrm{IL}$ | - | - | 1 | $\mu \mathrm{A}$ |
|  |  |  |  |  |  |
|  | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0,05 | V |
|  | ${ }^{1} \mathrm{OL}$ | 0,6 | 1,5 | - | mA |
|  | ${ }^{-1} \mathrm{OH}$ | 10 | - | - | $\mu \mathrm{A}$ |
|  | ${ }^{-1} \mathrm{OH}$ | - | - | 200 | $\mu \mathrm{A}$ |
|  | ${ }^{-1} \mathrm{OH}$ | 0,6 | 1,5 | - | mA |

## Note 1

Crystal connected between XTAL 1 and XTAL 2; pin 2 pulled to $V_{D D}$ via $5,6 \mathrm{k} \Omega$ resistor;
CE and T 1 at $\mathrm{V}_{\mathrm{SS}}$.

## CMOS MICROCONTROLLER FOR TELEPHONE SETS

## GENERAL DESCRIPTION

The PCD3343 is a single-chip 8-bit microcontroller fabricated in CMOS. It has special on-chip features for application in telephone sets.
The device is mask programmable, designed to provide telephone dialling facilities such as redial, repertory dial, emergency call, keyboard scan and control for liquid crystal display, pulse dial and/or DTMF dial via dedicated peripheral.

## Features

- 8-bit CPU, ROM, RAM, I/O in a single 28 -lead DIL or SO package
- 3 K ROM bytes
- 224 RAM bytes
- 20 quasi-bidirectional I/O port lines
- Two test inputs: one of which is also the external interrupt input (CE/TO)
- Single-level vectored interrupts: external, timer/event counter, serial I/O
- Serial 1/O which can be used in bus systems with more than one master (serial I/O data via an existing port line and clock via a dedicated line)
- 8-bit programmable timer/event counter
- Over 80 instructions (based on MAB8048, MAB8400 and PCF8500)
- All instructions 1 or 2 cycles
- Clock frequency 100 kHz to 10 MHz
- Single supply voltage from $1,8 \mathrm{~V}$ to 6 V
- Low standby voltage and current
- STOP and IDLE mode
- On-chip oscillator with output drive capability for peripherals (e.g. PCD3312 DTMF generator)
- Configuration of all I/O port lines individually selected by mask: pull-up, open drain or push-pull
- Power-on-reset circuit and low supply voltage detection
- Reset state of all ports individually selected by mask
- Operating temperature range: -25 to $+70^{\circ} \mathrm{C}$


## PACKAGE OUTLINES



Fig. 1 Block diagram; PCD3343.

(a)

Fig. 1a Replacement of dotted part in Fig. 1, for the PCF8500F bond-out version.

(b)

Fig. 1b Replacement of dotted part in Fig. 1, for the PCF8500B 'Piggy-back' version.

## PINNING



Note CE/TO is labelled $\overline{\mathrm{NT}} / \mathrm{TO}$ on the PCF8500B and has inverted polarity.
Fig. 2 Pinning diagram: PCD3343 and bottom pinning PCF8500B.

## PIN DESIGNATION

| 3 | SCLK | Clock: bidirectional clock for serial I/O. |
| :---: | :---: | :---: |
| 4-11 | P00-P07 | Port 0: 8-bit quasi-bidirectional 1/O port. |
| 12 | CE/ $/ \overline{\mathrm{TO}}$ | Interrupt/Test 0: external interrupt input (sensitive to positive-going edge)/test input pin; when used as a test input directly tested by conditional branch instructions JTO and JNTO. |
| 13 | T1 | Test 1: test input pin, directly tested by conditional branch instructions JT1 and JNT1. T1 also functions as an input to the 8 -bit timer/event counter, using the STRT CNT instruction. |
| 14 | $\mathrm{V}_{\text {SS }}$ | Ground: circuit earth potential. |
| 15 | XTAL 1 | Crystal input: connection to timing component (crystal) which determines the frequency of the internal oscillator; also the input for an external clock source. |
| 16 | XTAL 2 | connection to the other side of the timing component. |
| 17 | RESET | Reset input: used to initialize the processor (active HIGH), or output of power-on-reset circuit. |
| 18-25 | P10-P17 | Port 1: 8 -bit quasi-bidirectional I/O port. |
| 26, 27, 1, 2 | P20-P23 | Port 2: 4-bit quasi-bidirectional I/O port. P23 is the serial data input/output in serial I/O mode. |
| 28 | VDD | Power supply: $1,8 \mathrm{~V}$ to 6 V . |

PINNING (continued)


Fig. 3a Connection of EPROM to 'Piggy-back' package PCF8500B.
Fig. 3 Pinning diagram: PCF8500B 'Piggy-back' version top pinning; to access a 2732 or 2764 EPROM.

## PIN DESIGNATION

| 14,22 | V SS | Ground |
| :--- | :--- | :--- |
| $1,26-28$ | VDD | Power supply |
| $10-3,25,24,21,23,2$ | AO-A12 | Address outputs |
| $11-13,15-19$ | DO-D7 | Data |
| 20 | $\overline{\text { PSEN }}$ | Program store enable |

## Notes

1. RAM capacity of PCF8500B is 256 bytes.
2. Access time for ROMS/EPROMS to be below $7 \times 1 / \mathrm{f} \times$ TAL.
3. Pin $12 \mathrm{CE} / \overline{\mathrm{TO}}$ is on the PCF8500B, inverted and labelled $\overline{\mathrm{INT}} / \mathrm{TO}$.

## FUNCTIONAL DESCRIPTION

## Bond-out version PCF8500F

The PCF8500F is a microcontroller that contains no on-board ROM, but has all address and data lines brought-out to access an external ROM or EPROM. This version has more pins than the PCD3343 with on-board ROM (see Fig. 1a). The RAM has 256 bytes. It can address 8 K bytes of ROM.

## 'Piggy-back' version PCF8500B

The PCF8500B is a special package that has standard pinning to the bottom which facilitates insertion as a mask-programmed device. An EPROM can be mounted on top in an additional socket. The total package height is greater than the standard DIL package. The RAM has 256 bytes and can also address 8 K bytes of program memory.

## Program memory PCD3343

The program memory consists of 3072 bytes ( 8 -bit words), in a read-only memory (ROM). Each location is directly addressable by the program counter. The memory is mask-programmed at the factory. Figure 4 shows the program memory map.
Four program memory locations are of special importance:

- Location 0; contains the first instruction to be executed after the processor is initialized (RESET),
- Location 3; contains the first byte of an external interrupt service subroutine,
- Location 5; contains the first byte of a serial I/O interrupt service subroutine,
- Location 7; contains the first byte of a timer/event counter interrupt service subroutine.

Program memory is arranged in banks of 2 K bytes, which are selected by SEL MB instructions. The program memory is further divided into location 'pages', each of 256 bytes. This latter division applies only for conditional branches. Memory bank boundaries can be crossed only by using the unconditional branch instructions after the appropriate memory bank has been selected. A CALL instruction can transfer control to a subroutine on any 'page'; RET and RETR instructions can transfer control from a subroutine back to the main program.

## Data memory PCD3343

Data memory consists of 224 bytes ( 8 -bit words), random-access data memory (RAM). All locations are indirectly addressable using RAM pointer registers; up to 16 designated locations are directly addressable. Memory also includes an 8 -level program counter stack addressed by a 3 -bit stack pointer. Figure 5 shows the data memory map.

## Working registers

Locations 0 to 7 are designated as working registers, directly addressable by the direct register instructions. Ease of addressing, and a minimum requirement of instruction bytes to manipulate their contents, makes these locations suitable for storing frequently addressed intermediate results. This bank of registers can be selected by the SEL RBO instruction.
Executing the select register bank instruction SEL RB1, designates locations 24 to 31 as working registers, instead of locations 0 to 7 , and these are then directly addressable. This second bank of working registers may be used as an extension of the first or reserved for use during interrupt service subroutines saving the first bank for use in the main program. If the second bank is not used, locations 24 to 31 may serve as general purpose RAM.
The first locations of each bank contain the RAM pointer registers R0, R1, RO' and R1', which indirectly address all RAM locations.
All RAM locations make efficient program loop counters when used with the decrement register and test instruction DJNZ.

## FUNCTIONAL DESCRIPTION (continued)



Fig. 4 Program memory map.


Fig. 5 Data memory map.

## Program counter stack

Locations 8 to 23 may be designated as an 8 -level program counter stack ( 2 locations per level), or as general purpose RAM. The program counter stack (Fig. 6) enables the processor to keep track of the return addresses and status generated by interrupts or CALL instructions by storing the contents of the program counter prior to servicing the subroutine. A 3 -bit stack pointer determines which of the eight register pairs of the program counter stack will be loaded with next generated return address.
The stack pointer, when initialized to 000 by RESET, points to RAM locations 8 and 9 . On the first subroutine CALL or interrupt, the contents of the program counter and bits 4,6 and 7 of the program status word (PSW) are transferred to locations 8 and 9 . The stack pointer increments by one and points to locations 10 and 11 ready for another CALL. Because an address may be up to 13 bits long, two bytes must be used to store each address.
At the end of a subroutine, which is signalled by a return instruction (RET or RETR), the stack pointer decrements by one and the contents of the register pair on top of the stack are transferred to the program counter. The saved PSW bits are transferred to the PSW only by the RETR instruction.
If not all 8 levels of subroutine and interrupt nesting are used, the unused portion of the stack may be used as any other indirectly addressable RAM locations. Possible locations from 32 to 223 may be used for storage of program variables or data.
Nesting of subroutines within subroutines can continue up to 8 times without overflowing the stack. If overflow does occur the deepest address stored (locations 8 and 9) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111.

The value of the saved contents of the program counter is different for an interrupt CALL compared to a normal CALL to subroutine. With an interrupt CALL, the program counter return address is saved; with a subroutine CALL, the saved program counter value is one less than the program counter return address.


Fig. 6 Program counter stack.

## IDLE and STOP modes

## IDLE mode

When the microcontroller enters the IDLE mode via the IDLE instruction ( $\mathrm{H}^{\prime} 01^{\prime}$ ) the oscillator, timer/counter and serial I/O are kept running. The microcontroller exits from the IDLE mode by one of three interrupts if they are enabled or by activating a RESET. If the interrupt is not enabled the processor will remain in the IDLE mode. An active signal on the RESET pin restarts the microcontroller and a normal RESET sequence is executed (see Fig. 7).


Fig. 7 Exit from IDLE mode via a RESET.

## FUNCTIONAL DESCRIPTION (continued)

An active signal coming from an enabled interrupt causes the execution of the normal interrupt routine since normal interrupt scanning is still being carried out. A LOW-to-HIGH transition on the external interrupt pin (CE/TO) reactivates the microcontroller. A HIGH level applied to CE/TO will reactivate the microcontroller only in the STOP mode. Thus, if CE/ $\overline{\mathrm{TO}}$ was HIGH before the microcontroller entered the IDLE mode, it must go LOW before the microcontroller can be reactivated (see Fig. 8).


Fig. 8 Exit from IDLE mode via an interrupt.
Wake-up from the IDLE mode is ensured when CE/TO is LOW for 4 CP (clock periods) followed by a HIGH for 7 CP . After the initial forced CALL H‘003' operation ( 60 CP ) the program continues with the external interrupt service routine.

## STOP mode

The microcontroller enters the STOP mode by the STOP instruction ( $\mathrm{H}^{\prime} 22^{\prime}$ ). The oscillator is switched off. The internal status of the CPU, RAM contents and the state of I/O ports are not affected. The microcontroller can be brought-out of the STOP mode by an active signal at the external interrupt input or by an external RESET signal. When one of these two signals is applied an internal delay of 1866 CP is provided to ensure that all internal clocks are operating correctly before restart (see Fig. 9). If the microcontroller exits from the STOP mode by activating RESET, a normal RESET sequence is executed.


Fig. 9 Entering and exiting the STOP mode.

If the microcontroller exits the STOP mode by pulling the external interrupt input pin HIGH, an interrupt sequence is executed only if the external interrupt is enabled. In this event the microcontroller resumes the normal program sequence after returning from the interrupt routine, as in the normal mode. If the interrupt is not enabled, it continues the normal program sequence, executing the instruction following the STOP instruction.

The microcontroller is restarted by a HIGH level applied at the CE/TO pin, and not by a LOW-to-HIGH transition as in a normal interrupt mechanism.
When the CE/TO level is active during the STOP instruction then no STOP is executed.
A HIGH level on the external interrupt input of at least $1 \mu \mathrm{~s}$ will cause the microcontroller to exit the STOP mode.

## I/O facilities

The PCD3343 family has 23 I/O lines arranged as:

- Port 0 parallel port of 8 lines (P00 to P07)
- Port 1 parallel port of 8 lines (P10 to P17)
- Port 2 parallel port of 4 lines (P20 to P23)
- SCLK serial I/O consisting of a data line shared with a parallel port line (P23) and a separate clock line SCLK
- CE/TO external interrupt and test input. When used as a test input can be directly tested by conditional branch instructions JTO and JNTO
- T1 test input which can alter program sequences when tested by conditional jump instructions JT1 and JNT1. T1 also functions as an input to the 8-bit timer/event counter.


## Parallel ports

All parallel ports can be used as outputs or inputs, their structure is quasi-bidirectional. Output data written to a port is latched and remains unchanged until rewritten. Input data is not latched and so must be present until read by an input instruction.

Input lines are fully CMOS compatible, output lines can drive one LS-TTL or CMOS load.


Fig. 10 Timing diagram of all ports on IN and OUTL instructions; for ANL and ORL instructions, the ports change on the time slot 7 of cycle 2.

Fig. 11 shows the quasi-bidirectional I/O interface with push-pull output and switched pull-up current source.
Each line is pulled up to VDD via a constant current source (TR4), which is enabled via TR3 whenever one of the two output latches contains a logic 1 . This current provides sufficient source current for a TTL HIGH level, yet can be pulled LOW by an external CMOS device, thus allowing the same pin to be used for both input and output.

## FUNCTIONAL DESCRIPTION (continued)

When a logic 1 is written to the line for the first time ( $M Q=1, S Q=0$ ), TR2 is switched on for the duration of the internal write pulse (one oscillator period), to provide a fast transition from logic 0 to logic 1. Subsequent writing of a logic 1 to the port lines will not switch TR2 on. This prevents unnecessary current through external components connected to the port lines of the same port which might be in the input mode and also connected to ground.
When a logic 0 is written to the line, TR3 switches off the current source. Current sinking capability is provided by TR1, which is now switched on. When used as an input, a logic 1 must first be written to the line, otherwise TR1 will remain low impedance.
In telephone applications this switched pull-up source may not be sufficient. Therefore the PCD3343 offers the possibility to select individually 19 of the 20 parallel port pins (not P23), by the following mask options:
Option 1- STANDARD PORT; quasi-bidirectional I/O with switched pull-up current source of $100 \mu \mathrm{~A}$ (typ.) and P-channel booster transistor TR2 ( $1,5 \mathrm{~mA}$ ). TR2 is only active during 1 clock cycle ( $0,28 \mu \mathrm{~s}$ at $3,58 \mathrm{MHz}$ ).
Option 2- OPEN DRAIN; quasi-bidirectional I/O with only an N -channel open drain output. Application as an output requires connection of an external pull-up resistor (Fig. 12).

Option 3- PUSH-PULL OUTPUT; drive capability of the output will be $1,5 \mathrm{~mA}$ (typ.) at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$ in both polarities. To avoid a large current flowing through the output transistors during the input mode, these push-pull pins must only be used as outputs (Fig. 13).
Also, individual mask selection of the RESET state of these port pins can be achieved by appending the following options $S$ and $R$ to options 1, 2 or 3.
Option S-SET; after RESET this pin will be initialized to HIGH.
Option R-RESET; after RESET this pin will be initialized to LOW.


Fig. 11 Standard output with switched pull-up current source.


Fig. 12 Open drain output.


Fig. 13 Push-pull output.

## FUNCTIONAL DESCRIPTION (continued)

## Serial I/O (SIO)

The PCD3343 has an on-chip serial I/O interface. This SIO interface is a versatile feature in an intelligent telephone set, as shown in application diagram Fig. 32.
In this application the SIO is used to communicate with the different peripherals, such as:

- DTMF generator (PCD3312)
- LCD drivers (PCF8577)
- External RAM (PCD8571)
- Clock calendar (PCB8573)

No extra hardware is required for decoding, addressing and data processing.
Whereas a normal microcontroller must regularly monitor the serial data bus for the presence of data, the serial I/O interface detects, receives and converts the serial data stream into parallel format without interrupting the execution of the current program. An interrupt is sent to the PCD3343 only when a complete byte is received. It then reads the data byte in one instruction. Likewise during transmission the serial I/O interface performs parallel to serial conversion and subsequent serial output of the data. The microcontroller is only interrupted in the execution of its programmed tasks when a complete byte has been transmitted.

The design of the PCD3343 serial I/O system allows any number of devices from PCF8500 family (clips) to be connected via the two-line serial bus. The ability of any devices to communicate, without interrupting the operation of any other devices on the bus, is an outstanding attribute of the system. This is achieved by allocating a specific 7-bit address to each device and providing a system whereby a device reacts only to a message prefixed with its own address or the 'general CALL' address.
Address recognition is performed by the interface hardware so that operation of the microcontroller need only be interrupted when a valid address has been received. This saves significant processing time and memory space compared with a conventional microcontroller employing a software serial interface. When the addressing facility is not required, for instance in a system with only two microcontrollers, direct data transfer without addressing can be performed. In multi-master systems, an automatically invoked arbitration procedure prevents two or more devices from continuing simultaneous transmission.

In NORMAL (running) and IDLE mode, the serial I/O logic remains active; its internal system clock will be switched off when there is no activity on the serial bus.
After execution of the STOP instruction, the oscillator of the PCD3343 is switched off. This means that the serial I/O logic will remain in the state it was at the occurance of the STOP instruction. To avoid "bus block" problems and to assure correct start-up of the bus after exit from the STOP mode, the user should disable the serial logic $(E S O=0)$ prior to the execution of the STOP instruction. This must be carried out only when the PCD3343 has finished a serial data transfer.

## Serial I/O interface

Figure 14 shows the serial I/O interface. The clock line of the serial bus has exclusive use of pin 3 (SCLK) while the data line shares pin 2 (serial data) with the I/O line P23 of port 2 . When the serial I/O is enabled, P23 is disabled as a parallel port line; (P23 and SCLK only open drain).

The microcontroller and interface communicate via the internal microcontroller bus and the Serial Interrupt Request line. Data and information controlling the operation of the interface are stored in four registers:

- Data shift register (SO)
- Serial 1/O interface status word (S1)
- Serial clock control word (S2)
- Address register


## Data shift register (SO)

Register SO converts serial data to parallel format and vice versa. A pending interrupt is generated only after a complete byte has been transmitted, or after a complete data byte, specific address or 'general CALL' address has been received. The most significant bit is transmitted first.
Serial I/O interface status word (S1)
Register S1 provides information concerning the state of the interface and stores information from the microcontroller. Bits 0 to 3 are duplicated: control bits in these positions can only be written by the microcontroller, while interface bits can only be read.
MST and TRX (see Table 1)
These bits determine the operating mode of the serial I/O interface.
Table 1 Operating modes of the serial I/O interface

| MST | TRX | operating mode |
| :--- | :--- | :--- |
| 0 | 0 | slave receiver |
| 1 | 0 | master receiver |
| 0 | 1 | slave transmitter |
| 1 | 1 | master transmitter |

BB: Bus Busy.
This is the flag which indicates the status of the bus.
PIN: Pending Interrupt Not
PIN = ' 0 ' indicates the presence of a pending interrupt, which will cause a Serial Interrupt Request when the serial interrupt mechanism is enabled.

ESO: Enable Serial output
The ESO flag enables/disables the serial $\mathrm{I} / \mathrm{O}$ interface: $\mathrm{ESO}={ }^{\prime} 1$ ' enables, $\mathrm{ESO}={ }^{\prime} 0^{\prime}$ disables. ESO can only be written by software.
$B C 0, B C 1$ and BC2
Bits $\mathrm{BCO}, \mathrm{BC} 1$ and BC 2 indicate the number of bits received or transmitted in a data stream. These bits can only be written by software.

## AL: Arbitration Lost

The arbitration lost flag is set by hardware when the serial I/O interface, as master transmitter, loses a bus arbitration procedure.
AAS: Addressed As Slave
This flag is set by hardware when the interface detects either its own specific address or the 'general CALL' address as the first byte of a transfer and the interface has been programmed to operate in the address recognition mode.

## ADO: Address Zero

This flag is set by hardware after detection of the 'general CALL' address when the interface is operating in the address recognition mode.
LRB: Last Received Bit
This contains either the last data bit received or, for a transmitting device in the acknowledgement mode, the acknowledgement signal from the receiving device.
Bits AL, AAS, ADO and LRB can only be read by software.

## FUNCTIONAL DESCRIPTION (continued)

Serial clock control word (S2)
Bits 0 to 4 of the clock control register 52 are used to set the frequency of the serial clock signal. When a $3,58 \mathrm{MHz}$ crystal is used, the frequency of the serial clock can be varied between 92 kHz and 580 Hz (see Table 2). An asymmetrical clock with a HIGH-to-LOW ratio of $3: 1$ can be generated using bit 5 . The asymmetrical clock allows a microcontroller more time per clock period for sampling the data line, making the timing of this action less critical. Bit 6 can be used to activate the acknowledge mode of the serial I/O. S2 is a write only register.

Address register
The address register contains the 7-bit address back-up latches and the bit (ALS) used to enable/disable the address recognition mode. The address register can be written using the MOV SO, A and MOV SO, $\#$ data instructions, but only when $\mathrm{ESO}={ }^{\prime} 0$ '.

Serial I/O interrupt logic
An EN SI instruction enables and a DIS SI instruction disables the interrupt logic. When the logic is enabled, a pending interrupt results in a serial I/O interrupt to the processor, causing a CALL to location 5 in the ROM. When disabled, the presence of an interrupt is still indicated by PIN in S1, allowing the interrupt to be serviced. However, vectored interrupt will not occur.

Table 2 SIO clock pulse frequency control when using a $3,58 \mathrm{MHz}$ crystal

| hexadecimal S20-S24 code | divisor | ${ }^{\mathrm{f}} \mathrm{SCLK}$ (kHz) <br> (approximate) |
| :---: | :---: | :---: |
| 0 | not allowed |  |
| 1 | 39 | 92 |
| 2 | 45 | 80 |
| 3 | 51 | 70 |
| 4 | 63 | 57 |
| 5 | 75 | 48 |
| 6 | 87 | 41 |
| 7 | 99 | 36 |
| 8 | 123 | 29 |
| 9 | 147 | 24 |
| A | 171 | 21 |
| B | 195 | 18 |
| C | 243 | 15 |
| D | 291 | 12 |
| E | 339 | 11 |
| F | 387 | 9,2 |
| 10 | 483 | 7,4 |
| 11 | 579 | 6,2 |
| 12 | 675 | 5,3 |
| 13 | 771 | 4,6 |
| 14 | 963 | 3,7 |
| 15 | 1155 | 3,1 |
| 16 | 1347 | 2,7 |
| 17 | 1539 | 2,3 |
| 18 | 1923 | 1,9 |
| 19 | 2307 | 1,6 |
| 1A | 2691 | 1,3 |
| 1B | 3075 | 1,2 |
| 1 C | 3843 | 0,93 |
| 1D | 4611 | 0,78 |
| 1 E | 5379 | 0,67 |
| 1F | 6147 | 0,58 |

FUNCTIONAL DESCRIPTION (continued)
Table 3 Serial I/O addresses for telephony peripherals

| type | address |  |  |  |  |  |  |  | description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| PCF8570A | 1 | 0 | 1 | 0 | A2 | A1 | X | $R / \bar{W}$ | 2 K RAM |
| PCF8570 | 1 | 0 | 1 | 0 | A2 | A1 | A0 | $\mathrm{R} / \bar{W}$ | 2 K RAM |
| PCD8571 | 1 | 0 | 1 | 0 | A2 | A1 | A0 | $\mathrm{R} / \bar{W}$ | 1 K RAM |
| PCD3311 | 0 | 1 | 0 | 0 | 1 | 0 | A0 | $\mathrm{R} / \mathrm{W}$ | DTMF dialler |
| PCD3312 | 0 | 1 | 0 | 0 | 1 | 0 | A0 | $\mathrm{R} / \mathrm{W}$ | DTMF dialler |
| PCE 2111 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | LCD driver * |
| PCD8573 | 1 | 1 | 0 | 1 | 0 | A1 | A0 | $\mathrm{R} / \bar{W}$ | clock calendar |
| PCF 8574 | 0 | 0 | 1 | 1 | A2 | A1 | A0 | $\mathrm{R} / \bar{W}$ | 8-bit I/O expander |
| PCF 8576 | 0 | 1 | 1 | 1 | 0 | 0 | SAO | $\mathrm{R} / \bar{W}$ | 1: 4 LCD driver |
| PCF 8577 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | $\mathrm{R} / \bar{W}$ | 1:2 LCD driver |

* LCD driver requires an additional enable line.

DEVELOPMENT DATA


Fig. 14 serial $1 / 0$ interface.

## FUNCTIONAL DESCRIPTION (continued)

## Interrupts (see Fig. 15)

When the external interrupt is enabled, a LOW-to-HIGH transition on the CE/TO input initiates an external interrupt subroutine which causes a CALL to program memory location 3 following completion of the current instruction.
The interrupt must remain enabled until the interrupt instruction is completed, otherwise the next instruction of the main program will be executed. Serial I/O interrupt, when enabled, causes a CALL to location 5, and a timer/event counter overflow forces a CALL to location 7 when the timer interrupt is enabled.
When an interrupt subroutine starts, the contents of the program counter and bits 4,6 and 7 of the PSW have been saved in the program counter stack. Accumulator contents have to be saved by software. Interrupt acknowledgement can be carried out by software via port pins. All interrupt subroutines must reside in memory bank 0 .
Since the interrupt system is single level, once an interrupt is detected, all further interrupt requests are latched, but ignored, pending a RETR instruction to re-enable the interrupt input logic. After executing RETR, the program continues in the main part; this is independent of the occurance of a second interrupt during the running of the first routine. If 2 or 3 interrupts occur simultaneously, their priority is:

- (1) external
- (2) serial I/O
- (3) timer/event counter

An external interrupt can be generated by using the timer/counter in the event counter mode. The counter is first preset to ( $H^{\prime} \mathrm{FF}^{\prime}$ ), then EN TCNTI instruction is executed. A LOW-to-HIGH transition of the T1 input will then initiate an interrupt subroutine and cause a CALL to location 7.

On execution of a DIS I instruction, the PCD3343 always clears the digital filter/latch and the External Interrupt Flag.
The Timer Flag (TF) is reset only when the JTF or JNTF instruction is executed or after RESET.
The Timer Interrupt Flag is set when timer overflow occurs, only if the timer interrupt is enabled.
The microcontroller will exit the IDLE mode when any one of the following three interrupts is enabled:

- External
- Serial I/O
- Timer/event counter

There is no internal pull-up or pull-down device connected to the external interrupt input (pin 12). If required pin 12 must be externally connected to a resistor ( $R \leqslant 100 \mathrm{k} \Omega$ ). When the external interrupt is not used pin 12 must be connected to $\mathrm{V}_{\mathrm{SS}}$.


Fig. 15 Interrupt logic.

## Notes to figure 15

1. CE/TO positive edge is always latched in the digital filter/latch.
2. Correct interrupt timing in ensured when CE/TO is LOW for $>4 \mathrm{CP}$ followed by a HIGH for $>7 \mathrm{CP}$.
3. When the interrupt in progress flag is set, further interrupts are latched but ignored, until RETR is executed.
4. A DIS I instruction always clears a pending external interrupt.

## FUNCTIONAL DESCRIPTION (continued)

Oscillator (see Fig. 16)
The $3,58 \mathrm{MHz}$ oscillator can be inhibited by the STOP instruction under software control. It is also inhibited when a low-voltage condition is present to prevent discharge of a weak back-up battery.
Provided the supply voltage is within the operating range, the oscillator will be restarted after a STOP instruction by a HIGH level at either the CE/TO or RESET pin.


Fig. 16 Oscillator with integrated elements.
The oscillator has the output drive capability for the DTMF generator (PCD3311/3312) via pin 16 (XTAL 2). An external clock can be applied to pin 15 (XTAL 1). A machine cycle consists of 10 time slots, each time slot being 3 oscillator periods.
In telephony applications the $3,58 \mathrm{MHz}$ crystal provides a $8,4 \mu \mathrm{~s}$ machine cycle. The range of the clock frequency is from 100 kHz up to a maximum which is a function of the supply voltage (see Fig. 23).

## Timer/event counter (see Fig. 17)

An internal 8 -bit up-counter is provided. This can count external events, modulo- 32 machine cycles, or machine cycles directly. Table 4 gives the instructions that control the counter and the prescaler, and the functions performed.

When used as a timer, the input to the counter is either the overflow or input of a 5 -bit prescaler. When used as an event counter, LOW-to-HIGH transitions on pin 13 (T1) are counted. The maximum rate at which the counter may be incremented is once every machine cycle $(182,6 \mathrm{kHz}$ for a $8,4 \mu \mathrm{~s}$ machine cycle). When the counter overflows, the timer flag is set. The flag can be tested and reset using the JTF (jump if timer flag $=1$ ) or JNTF instruction. Overflow also generates an interrupt to the processor via setting of the Timer Interrpt Flag when the timer/event counter interrupt is enabled.

Table 4 Timer/event counter control

| function | timer mode <br> modulo-1, modulo-32* | counter mode |
| :--- | :--- | :--- |
| CLEAR | MOV T,A (A) $=0$ | MOV T,A $(A)=0$ |
|  | or RESET | or RESET |
| PRESET | MOV T,A | MOV T,A |
| START | STRT T | STRT CNT |
| STOP | STOP TCNT | STOP TCNT |
|  | or RESET | or RESET |
| TEST | JTF/JNTF | JTF/JNTF |
| READ** | MOV A,T | MOV A,T |



Fig. 17 Timer/event counter.

Program status word (see Fig. 18)
The program status word (PSW) is an 8-bit word (1 byte) in the CPU which stores information about the current status of the microcontroller.
The PSW bits are:

- Bits 0 to 2 stack pointer bits $\left(\mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}\right)$
- Bit 3 prescaler select (PS);
- Bit 4 working register bank select (RBS);
- Bit 5 not used (1)
- Bit 6 auxiliary carry (AC); half-carry bit generated by an ADD instruction and used by the decimal adjust instruction DA A
- Bit 7 carry (CY); the carry flag indicates that previous operation has resulted in an overflow of the accumulator.


Fig. 18 Program status word.

* With prescaler select, $\mathrm{PS}=0$, the timer counts modulo- 32 machine cycles, with PS $=1$ it counts modulo-1 cycles (prescaler not used); prescaler cleared with STRT T, prescaler not readable.
** READ does not disturb the counting process.


## FUNCTIONAL DESCRIPTION (continued)

## Program status word (continued)

All bits can be read using the MOV A, PSW instruction. Bits 7 and 6 are set and cleared by CPU operation. Bit 4 can be changed by a SEL RB instruction, bit 3 by the MOV PSW, A instruction, and bits 0,1 and 2 by the CALL, RET or RETR instructions and in the event of an interrupt. Bits 7, 6 and 4 are stored in the program counter stack during subroutine and interrupt calls. These bits are restored in the PSW with a RETR (return and restore) instruction which must be used at the end of an interrupt and can be used at the end of a normal subroutine. The RET instruction has no restore feature and cannot be used at the end of an interrupt.

## Program counter (see Fig. 19)

A 13-bit program counter is used to facilitate 8 K bytes of ROM being addressed. The arrangement of the bits is shown in figure 19. During an interrupt subroutine $P_{11}$ and $P_{12}$ are forced to logic 0 . All 13 bits are saved in the stack during CALL and interrupt routines.


Fig. 19 Program counter.

## Central processing unit

The PCD3343 has arithmetic, logical and branching capabilities. The DA A, SWAP A and XCHD instructions simplify BCD arithmetic and the handling of nibbles. The MOVP A,@A instruction permits efficient table look-up from the current ROM page.

## Conditional branch logic

The conditional branch logic within the processor enables several conditions, internal and external to the processor, to be tested by the user's program. Table 5 lists the conditional jump instructions used to change the program sequence. The DJNZ instruction decrements a designated register or data memory location and branches if the contents are not zero. This instruction is useful for looping control. The JMPP@A instruction allows multiway branches to destinations determined by the contents of the accumulator.

Table 5 Conditional branches

| test | jump condition | jump instruction |
| :--- | :--- | :--- |
| accumulator | all bits zero | JZ |
| accumulator bit test | any bit non-zero | JNZ |
| carry flag | 1 | JBO to JB7 |
| timer overflow flag | 1 | JC |
|  | 0 | JNC |
| test input T0 | 1 | JTF |
|  | 0 | JNTF |
| test input T1 | 1 | JNT0 |
|  | 0 | JT0* |
| register | 1 | JT1 |
|  | 0 | DTT1 |
|  | non-zero | DJNZ |

## Test input T1 (pin 13)

The T1 input line can be used as:

- A test input for branch instructions JT1 and JNT1
- An external input to the event counter

When used as a test input:

- JT1 instruction tests for logic 1 level
- JNT1 instruction tests for logic 0 level

When used as an input to the event counter, T1 must be LOW for $>4$ CP, followed by a HIGH for $>4 \mathrm{CP}$. The transition can be recognized with a repetition rate of once per 30 oscillator clock periods (1 machine cycle).

There is no internal pull-up or pull-down resistor connected to the T1 input. If required it must be externally connected to a resistor ( $R=\leqslant 100 \mathrm{k} \Omega$ ). When $T 1$ is not used pin 13 must be connected to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$.

## Reset (pin 17)

A positive-going signal on the RESET input/output:

- Sets the program counter to zero
- Selects location 0 of memory band 0 and register bank 0
- Sets the stack pointer to zero (000); pointing to RAM address 8
- Disables the interrupts (external, timer and serial I/O)
- Stops the timer/event counter, then sets it to zero
- Sets the timer prescaler to modulo-32
- Resets the timer flag
- Sets all ports according to reset states
- Sets the serial I/O to slave receiver mode and disables the serial I/O
- Cancels IDLE and STOP mode

After the voltage is applied to RESET an internal delay of 1866 CP is introduced before the microcontroller commences operation.

[^12]
## FUNCTIONAL DESCRIPTION (continued)

## Power-on-reset and low-voltage detection (see Fig. 20)

In telephony applications, correct operation of the PCD3343 during moments of slowly changing supply voltages and low-voltage conditions is essential. This is achieved by the addition of an internal power-on-reset and low-voltage detection circuit.
To allow an external RESET signal being fed into the PCD3343, the reset pin (pin 17) has been configured as an input/output.

While a reset condition exists in the detection circuit, pin 17 is pulled HIGH by TR1 controlled by the reset circuit.
When the reset condition is not present a pull-down current source (TR2) will be activated. TR2 forces pin 17 LOW thus removing the RESET signal from the microcontroller.
Since the level at pin 17 is recognized by the microcontroller, the reset time constant can be stretched by connecting an external capacitor between $\mathrm{V}_{\mathrm{DD}}$ and pin 17 (see Fig. 22).
The signal at pin 17 can also be used as an output to reset other devices in the system.
The internal reset circuit monitors the PCD3343 supply voltage. If the voltage drops below the switching level (typ. 1,3 V), a reset (HIGH) is applied to pin 17. This reset is removed (pin 17 goes LOW), after a fixed delay ( $\mathrm{t}_{\mathrm{d}}$ ), when the supply voltage rises above the switching level again. The delay ensures a complete reset even when the supply voltage quickly rises above switching level after initial switch-on.
During a low-voltage condition the oscillator is inhibited to prevent complete discharge of a weak battery. The timing of the power-on-reset and low-voltage detection circuit is shown in figure 21.


Fig. 20 Power-on-reset configuration.


Where: (1) Oscillator inhibited
(2) Oscillator starting
(3) Oscillator running, but may be stopped with a STOP condition

Fig. 21 Timing of power-on-reset and low-voltage detection.


Fig. 22 Stretched power-on-reset with external capacitor.

## PCD3343

## INSTRUCTION SET

The PCD3343 instruction set consists of over 80 one and two byte instructions and is based on the MAB8048 instruction set. New instructions include those for serial I/O operation and memory bank selection. Program code efficiency is high because all RAM locations and all ROM locations on a 256 byte page require only a single byte address.
Table 8 gives the instruction set of the PCD3343. Table 7 shows the instruction map and Table 6 details the symbols and definition descriptions that are used.

Table 6 Symbols and definitions used in Table 8

| symbol | definition description |
| :--- | :--- |
| A | accumulator |
| addr | program memory address |
| Bb | bit designation (b $=0$-7) |
| RBS | register bank select |
| C | carry bit (bit CY) |
| CNT | event counter |
| D | mnemonic for 4-bit digit (nibble) |
| data | 8-bit number or expression |
| I | interrupt |
| MB | memory bank |
| MBFF | memory bank flip-flop |
| P | mnemonic for 'in-page' operation |
| PC | program counter |
| Pp | port designation ( $p=0,1$ or 2) |
| PSW | program status word |
| RB | register bank |
| Rr | register designation ( $r=0-7$ ) |
| Sn | serial I/O register |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| TO, T1 | test 0 and 1 inputs |
| $\#$ | immediate data prefix |
| $@$ | indirect address prefix |
| (X) | contents of $X$ |
| (X)) | contents of location addressed by $X$ |
| $\leftarrow$ | is replaced by |
| $\leftrightarrow$ | is exchanged with |

## DEVELOPMENT DATA

Table 7 PCD3343 instruction map


## INSTRUCTION SET (continued)

Table 8 Instruction set

|  | mnemonic | opcode <br> (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { ADD A, Rr } \\ & \text { ADD A, @Rr } \end{aligned}$ | $\begin{aligned} & 6^{*} \\ & 60 \\ & 61 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | Add register contents to $A$ <br> Add RAM data, addressed by $\operatorname{Rr}$, to $A$ | $\begin{aligned} & (A) \leftarrow(A)+(R r) \\ & (A) \leftarrow(A)+((R 0)) \\ & (A) \leftarrow(A)+((R 1)) \end{aligned}$ | $r=0-7$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  | ADD A, \#data | 03 data | 2/2 | Add immediate data to $A$ | $(A) \leftarrow(A)+$ data |  | 1 |
|  | ADDC A, Rr | 7* | 1/1 | Add carry and register contents to A | $(A) \leftarrow(A)+(R r)+(C)$ | $r=0-7$ | 1 |
|  | ADDC A, @Rr | 70 | $1 / 1$ | Add carry and RAM data, addressed | $(A) \leftarrow(A)+((R 0))+(C)$ |  | 1 |
|  |  | 71 |  | by Rr , to A | $(A) \leftarrow(A)+((R 1))+(C)$ |  |  |
|  | ADDC A, \#data | 13 data | 2/2 | Add carry and immediate data to $A$ | $(A) \leftarrow(A)+$ data $+(C)$ |  | 1 |
|  | ANL A, Rr | 5* | 1/1 | 'AND' Rr with A | $(\mathrm{A}) \leftarrow(\mathrm{A})$ AND (Rr) | $r=0-7$ |  |
|  | ANL A, @Rr | 50 | 1/1 | 'AND' RAM data, addressed by Rr, with A | $(A) \leftarrow(A)$ AND ( $(\mathrm{RO}))$ |  |  |
|  |  | 51 |  |  | $(A) \leftarrow(A)$ AND ( $(\mathrm{R} 1))$ |  |  |
|  | ANL A, \#data | 53 data | 2/2 | 'AND' immediate data with A | $(A) \leftarrow(A)$ AND data |  |  |
|  | ORL A, Rr | 4* | 1/1 | 'OR' Rr with A | $(A) \leftarrow(A) O R(R r)$ | $r=0-7$ |  |
|  | ORL A, @Rr | 40 | 1/1 | 'OR' RAM data, addressed by Rr, with A | $(A) \leftarrow(A) O R((R 0))$ |  |  |
|  |  | 41 |  |  | $(A) \leftarrow(A)$ OR ( $(\mathrm{R} 1))$ |  |  |
|  | ORL A, \#data | 43 data | 2/2 | 'OR' immediate data with $A$ | $(A) \leftarrow(A)$ OR data |  |  |
|  | XRL A, Rr | D* | 1/1 | 'XOR' Rr with A | $(A) \leftarrow(A) \times O R(R r)$ | $r=0-7$ |  |
|  | XRL A, @Rr | D0 | 1/1 | 'XOR' RAM, addressed by Rr, with A | $(A) \leftarrow(A) \times O R((R 0))$ |  |  |
|  |  | D1 |  |  | $(A) \leftarrow(A) X O R((R 1))$ |  |  |
|  | XRL A, \#data | D3 data | 2/2 | 'XOR' immediate data with A | $(\mathrm{A}) \leftarrow(\mathrm{A}) \times \mathrm{XOR}$ data |  |  |
|  | INC A | 17 | 1/1 | increment $A$ by 1 | $(A) \leftarrow(A)+1$ |  |  |
|  | DEC A | 07 | 1/1 | decrement $A$ by 1 | $(A) \leftarrow(A)-1$ |  |  |
|  | CLR A | 27 | 1/1 | clear A to zero | $(A) \leftarrow 0$ |  |  |
|  | CPL A | 37 | 1/1 | one's complement A | $(\mathrm{A}) \leftarrow \operatorname{NOT}(\mathrm{A})$ |  |  |
|  | RL A | E7 | 1/1 | rotate A left | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow\left(A_{n}\right) \\ & \left(A_{0}\right) \leftarrow\left(A_{7}\right) \end{aligned}$ | $n=0-6$ |  |

DEVELOPMENT DATA

| $\begin{array}{\|l\|} \hline \stackrel{\dot{L}}{\dot{0}} \\ \text { O} \end{array}$ | RLC A | F7 | 1/1 | rotate A left through carry | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow A_{n} \\ & \left(A_{0}\right) \leftarrow(C),(C) \leftarrow\left(A_{7}\right) \end{aligned}$ | $\mathrm{n}=0-6$ | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { r } \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | RR A | 77 | 1/1 | rotate A right | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow\left(A_{0}\right) \end{aligned}$ | $\mathrm{n}=0-6$ |  |
| $\underset{\substack{\text { D }}}{\substack{\text { N}}}$ | RRC A | 67 | 1/1 | rotate A right through carry | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow(C),(C) \leftarrow\left(A_{0}\right) \end{aligned}$ | $\mathrm{n}=0-6$ | 2 |
| $\begin{aligned} & \mathrm{J} \\ & 0 \\ & \hline \end{aligned}$ | DA $A$ SWAP A | $\begin{aligned} & 57 \\ & 47 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | decimal adjust $A$ <br> swap nibbles of $A$ | ( ${ }_{\text {-3 }}$ |  | 2 |
|  | MOV A, Rr | F* | 1/1 | move register contents to $A$ | $(\mathrm{A}) \leftarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | MOV A, @Rr | $\begin{aligned} & \text { F0 } \\ & \text { F1 } \end{aligned}$ | 1/1 | move RAM data, addressed by Rr , to A | $\begin{aligned} & (\mathrm{A}) \leftarrow((\mathrm{RO})) \\ & (\mathrm{A}) \leftarrow((\mathrm{R} 1)) \end{aligned}$ |  |  |
|  | MOV A, \#data | 23 data | 2/2 | move immediate data to A | (A) $<$ data |  |  |
|  | MOV Rr, A | A* | 1/1 | move accumulator contents to register | $(\mathrm{Rr}) \leftarrow(\mathrm{A})$ | $r=0-7$ |  |
|  | MOV @Rr, A | $\begin{array}{\|l\|} \text { A0 } \\ \text { A } \end{array}$ | 1/1 | move accumulator contents to RAM location addressed by Rr | $\begin{aligned} & ((\mathrm{RO})) \leftarrow(A) \\ & ((\mathrm{R} 1)) \leftarrow(A) \end{aligned}$ |  |  |
|  | MOV Rr, \#data | B* data | 2/2 | move immediate data to Rr | $(\mathrm{Rr}) \leftarrow$ data |  |  |
|  | MOV @Rr, \#data | BO data <br> B1 data | 2/2 | move immediate data to RAM location addressed by Rr | $\begin{aligned} & ((\mathrm{R}))<\text { data } \\ & ((\mathrm{R} 1)) \leftarrow \text { data } \end{aligned}$ |  |  |
|  | XCH A, Rr | 2* | 1/1 | exchange accumulator contents with Rr | $(\mathrm{A}) \leftrightarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | XCH A, @Rr |  | 1/1 | exchange accumulator contents with RAM data addressed by Rr | $\begin{aligned} & (A) \leftrightarrow((R 0)) \\ & (A) \leftrightarrow((R 1)) \end{aligned}$ |  |  |
|  | XCHD A, @Rr |  | 1/1 | exchange lower nibbles of A and RAM data addressed by Rr | $\begin{aligned} & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 0_{0-3}\right)\right) \\ & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 1_{0-3}\right)\right) \end{aligned}$ |  |  |
|  | MOV A, PSW | C7 | 1/1 | move PSW contents to accumulator | (A) $\leftarrow$ (PSW) |  |  |
|  | MOV PSW, A | D7 | 1/1 | move accumulator bit 3 to $\mathrm{PSW}_{3}$ | $\left(\mathrm{PSW}_{3}\right) \leftarrow\left(\mathrm{A}_{3}\right)$ |  | 3 |
|  | MOVP A, @A | A3 | 1/2 | move indirectly addressed data in current page to A | $\left(\mathrm{PC}_{0-7}\right) \leftarrow(\mathrm{A}),(\mathrm{A}) \leftarrow((\mathrm{PC}))$ |  |  |
| O | CLR C | 97 | 1/1 | clear carry bit | (C) $\leftarrow 0$ |  | 2 |
| - | CPL C | A7 | 1/1 | complement carry bit | (C) $\leftarrow$ NOT(C) |  | 2 |



## DEVELOPMENT DATA

|  | MOV A, T <br> MOV T, A <br> STRT CNT <br> STRT T <br> STOP TCNT <br> EN TCNTI <br> DIS TCNTI | 42 <br> 62 <br> 45 <br> 55 <br> 65 <br> 25 <br> 35 | $\begin{aligned} & \hline 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | move timer/event counter contents to accumulator <br> move accumulator contents to timer/event counter <br> start event counter <br> start timer <br> stop timer/event counter <br> enable timer/event counter interrupt <br> disable timer/event counter interrupt | $(A) \leftarrow(T)$ $(T) \leftarrow(A)$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 0 0 2 2 0 0 0 | EN I <br> DIS I <br> SEL RBO <br> SEL RB1 <br> SEL MBO <br> SEL MB1 <br> SEL MB2 <br> SEL MB3 <br> STOP <br> IDLE | $\begin{aligned} & 05 \\ & 15 \\ & \text { C5 } \\ & \text { D5 } \\ & \text { E5 } \\ & \text { F5 } \\ & \text { A5 } \\ & \text { B5 } \\ & 22 \\ & 01 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | enable external interrupt disable external interrupt select register bank 0 select register bank 1 select program memory bank 0 select program memory bank 1 select program memory bank 2 select program memory bank 3 enter STOP mode enter IDLE mode | $\begin{aligned} & (\text { RBS }) \leftarrow 0 \\ & (\text { RBS }) \leftarrow 1 \\ & (\text { MBFFO }) \leftarrow 0,(\text { MBFF1 }) \leftarrow 0 \\ & (M B F F 0) \leftarrow 1,(\text { MBFF1 }) \leftarrow 0 \\ & (\text { MBFF0 }) \leftarrow 0,(\text { MBFF1 }) \leftarrow 1 \\ & (\text { MBFF0 }) \leftarrow 1,(\text { MBFF1 }) \leftarrow 1 \end{aligned}$ | 5 5 |
|  | CALL addr <br> RET <br> RETR | $\triangle 4$ address <br> 83 <br> 93 | $2 / 2$ <br> $1 / 2$ <br> $1 / 2$ | jump to subroutine <br> return from subroutine <br> return from interrupt and restore bits 4, 6, 7 of PSW |  | 6 6 6 |


|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IN A, Pp <br> OUTL Pp, A <br> ANL Pp, \#data <br> ORL Pp, \#data | 08 <br> 09 <br> OA <br> 38 <br> 39 <br> 3A <br> 98 <br> 99 <br> 9A <br> 88 <br> 89 <br> 8A | 1/2 <br> $1 / 2$ <br> $2 / 2$ <br> $2 / 2$ | input port $p$ data to accumulator <br> output accumulator data to port $p$ <br> AND port $p$ data with immediate data <br> OR port $p$ data with immediate data | $\begin{aligned} & (\mathrm{A}) \leftarrow(\mathrm{P} 0) \\ & (\mathrm{A}) \leftarrow(\mathrm{P} 1) \\ & (\mathrm{A}) \leftarrow(\mathrm{P} 2) \\ & (\mathrm{PO}) \leftarrow(\mathrm{A}) \\ & (\mathrm{P} 1) \leftarrow(\mathrm{A}) \\ & (\mathrm{P} 2) \leftarrow(\mathrm{A}) \\ & (\mathrm{PO}) \leftarrow(\mathrm{PO}) \text { AND data } \\ & \text { (P1) } \leftarrow(\mathrm{P} 1) \text { AND data } \\ & (\mathrm{P} 2) \leftarrow(\mathrm{P} 2) \text { AND data } \\ & (\mathrm{PO}) \leftarrow(\mathrm{PO}) \text { OR data } \\ & (\mathrm{P} 1) \leftarrow(\mathrm{P} 1) \text { OR data } \\ & (\mathrm{P} 2) \leftarrow(\mathrm{P} 2) \text { OR data } \end{aligned}$ | 7 |
|  | MOV A, $S_{n}$ <br> MOV $S_{n}, A$ <br> MOV $S_{n}$, \#data <br> EN SI <br> DIS SI | $\begin{aligned} & O C \\ & 0 D \\ & 3 C \\ & 3 D \\ & 3 E \\ & 9 C \\ & 9 D \\ & 9 E \\ & 85 \\ & 95 \end{aligned}$ | $\begin{aligned} & 1 / 2 \\ & 1 / 2 \\ & 2 / 2 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | move serial I/O register contents to accumulator <br> move accumulator contents to serial I/O register <br> move immediate data to serial I/O register <br> enable serial I/O interrupt <br> disable serial I/O interrupt | $\begin{aligned} & (A) \leftarrow(S 0) \\ & (A) \leftarrow(S 1) \\ & (S 0) \leftarrow(A) \\ & (S 1) \leftarrow(A) \\ & (S 2) \leftarrow(A) \\ & (S 0) \leftarrow \text { data } \\ & (S 1) \leftarrow \text { data } \\ & (S 2) \leftarrow \text { data } \end{aligned}$ | 8 9 |
|  | NOP | 00 | 1/1 | no operation |  |  |

## Notes to Table 8

| 1. PSW CY, AC | affected |
| :--- | :--- |
| 2. PSW CY | affected |
| 3. PSW PS | affected |

5. PSW RBS affected
6. PSW $\mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ affected
7. $(A)=1111$ P23, P22, P21, P20.
8. Execution of JTF and JNTF instructions resets the Timer Flag (TF).

* : 8, 9, A, B, C, D, E, F
- : 0, 2, 4, 6, 8, A, C, E

8. (S1) has a different meaning for read and write operation, see serial I/O interface.
9. (S2) is a write only register. Reading S2 will give value FFH.

- : $1,3,5,7,9, B, D, F$


## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage (pin 28)
All input voltages
D.C. current into any input or output

Total power dissipation (see note)
Power dissipation per output except P23, SCLK P23, SCLK
Storage temperature range
Operating ambient temperature range
Operating junction temperature

## Note

Thermal resistance (junction to ambient) for SOT-117
for SOT-135A
$V_{D D}$
$V_{I}$
$\pm I_{1}, \pm I_{0}$
$P_{\text {tot }} \quad \max . \quad 500 \mathrm{~mW}$

| $\mathrm{P}_{\mathrm{O}}$ | max. | 50 mW |
| :--- | :--- | ---: |
| $\mathrm{P}_{\mathrm{O}}$ | max. | 180 mW |
| $\mathrm{~T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |  |
| $\mathrm{T}_{\mathrm{amb}}$ | -25 to $+70{ }^{\circ} \mathrm{C}$ |  |
| $\mathrm{T}_{\mathrm{j}}$ | max. | $125{ }^{\circ} \mathrm{C}$ |

$R_{\text {th j-a }} \quad$ max. $120 \mathrm{~K} / \mathrm{W}$ -
$R_{\text {th j-a }} \quad \max . \quad 60 \mathrm{~K} / \mathrm{W}$
$R_{\text {th j-a }} \max . \quad 150 \mathrm{~K} / \mathrm{W}$

## D.C. CHARACTERISTICS

$V_{D D}=2,75$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-25$ to $+70^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}} ; f=3,58 \mathrm{MHz}$ with $R_{S}=50 \Omega$; unless otherwise specified.

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage operating (see Fig. 23) | VDD | 1,8 | - | 6 | V |
| STOP mode for RAM retention | $V_{\text {DD }}$ | 1,0 | - | 6 | V |
| Supply current operating at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$ (see Fig. 24) | IDD | - | 600 | - | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { IDLE mode } \\ & \text { at } \mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V} \text { (see Fig. 25) } \end{aligned}$ | IDD | - | 300 | - | $\mu \mathrm{A}$ |
| STOP mode (see Fig. 26 and note 1) $\text { at } V_{D D}=1,8 \mathrm{~V} ; T_{\mathrm{amb}}=25^{\circ} \mathrm{C}$ | IDD | - | 1,2 | 2,5 | $\mu \mathrm{A}$ |
| at $\mathrm{V}_{\mathrm{DD}}=1,8 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=55^{\circ} \mathrm{C}$ | IDD | - | - | 5 | $\mu \mathrm{A}$ |
| at $V_{D D}=1,8 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C}$ | ${ }^{1} \mathrm{DD}$ | - | - | 10 | $\mu \mathrm{A}$ |
| RESET I/O |  |  |  |  |  |
| Switching level | $\mathrm{V}_{\text {RESET }}$ | - | 1,3 | - | v |
| Sink current at $\mathrm{V}_{\mathrm{DD}}>\mathrm{V}_{\text {RESET }}$ | ${ }^{\text {I OL }}$ | - | 7 | - | $\mu \mathrm{A}$ |
| Inputs |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IL }}$ | 0 | - | $0,3 V_{\text {DD }}$ | V |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | $0,7 V_{\text {DD }}$ | - | $\mathrm{V}_{\text {DD }}$ | v |
| Input leakage current at $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\mathrm{DD}}$ | $\pm \mathrm{IL}$ | - | - | 1 | $\mu \mathrm{A}$ |
| Outputs |  |  |  |  |  |
| Output voltage LOW at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}} ; \\|_{\mathrm{O}} \mid<1 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,05 | V |
| Output sink current LOW at $V_{D D}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$ except P23/SDA, SCLK (see Fig. 27) |  | 0,75 | 1,5 | - | mA |
| P23/SDA, SCLK (see Fig. 28) | IOL | 1,5 | - | - | mA |
| Pull-up output source current HIGH (see Fig. 29) at $V_{D D}=3 V ; V_{O}=0,9 V_{D D}$ | $-\mathrm{IOH}$ | 25 | - | - | $\mu \mathrm{A}$ |
| at $V_{D D}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=\mathrm{V}_{S S}$ | $-\mathrm{IOH}$ | - | - | 200 | $\mu \mathrm{A}$ |
| Push-pull output source current HIGH at $V_{D D}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{DD}}-0,4 \mathrm{~V}$ | ${ }^{-1} \mathrm{OH}$ | 0,75 | 1,5 | - | mA |

## Note 1

Crystal connected between XTAL 1 and XTAL 2; SCL and SDA pulled to $V_{D D}$ via $5,6 \mathrm{k} \Omega$ resistor; CE and T1 at $V_{S S}$.

(1) $\mathrm{T}_{\mathrm{amb}}=-25^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$
(3) $\mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C}$

Fig. 23 Maximum clock frequency ( $\mathrm{f}_{\mathrm{XTAL}}$ ) as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

(1) clock frequency $=4 \mathrm{MHz}$
(2) clock frequency $=2 \mathrm{MHz}$
(3) clock frequency $=500 \mathrm{kHz}$

Fig. 25 Typical supply current (IDD) in IDLE mode as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$.

(1) clock frequency $=4 \mathrm{MHz}$
(2) clock frequency $=2 \mathrm{MHz}$
(3) clock frequency $=500 \mathrm{kHz}$

Fig. 24 Typical supply current (IDD) in operating mode as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$.

(1) $\mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$

Fig. 26 Typical supply current (IDD) in STOP mode as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

(1) $\mathrm{T}_{\mathrm{amb}}=-25^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$
(3) $\mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C}$

Fig. 27 Output sink current LOW ( $\mathrm{I}_{\mathrm{OL}}$ ), except outputs P23/SDA and SCLK, as a function of supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$.

(1) $\mathrm{T}_{\mathrm{amb}}=-25^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=+25^{\circ} \mathrm{C}$
(3) $\mathrm{T}_{\mathrm{amb}}=+70^{\circ} \mathrm{C}$

Fig. 28 Output current LOW (IOL), outputs P23/SDA and SCLK, as a function of supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$.

(1) $T_{a m b}=25^{\circ} \mathrm{C} ; V_{O}=V_{S S}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{O}}=0,9 \mathrm{~V}_{\mathrm{DD}}$
(3) $\mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{O}}=V_{S S}$
(4) $\mathrm{T}_{\mathrm{amb}}=70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{O}}=0, \underline{0} \mathrm{~V}_{\mathrm{DD}}$

Fig. 29 Output source current $\mathrm{HIGH}\left(-\mathrm{I}_{\mathrm{OH}}\right)$ as a function of supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

## A.C. CHARACTERISTICS

Rise and fall times between 10 and $90 \%$ levels; $C_{L}=50 \mathrm{pF}$

| parameter | symbol | at $70^{\circ} \mathrm{C}$ max. value |  |  | unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | 1,8 | 3,0 | 6,0 | V |
| Fall time | $\mathrm{t}_{\mathrm{f}}$ | 200 | 100 | 70 | ns |
| Rise time | $\mathrm{t}_{\mathrm{r}}$ | 200 | 100 | 80 | ns |



Fig. 30 PCD3343 timing requirements for the P23 and SCLK input signals.
Table 9 Input timing shown in figure 30

| symbol | timing |
| :---: | :---: |
| ${ }^{\text {t }}$ BUF | $\geqslant 14 \mathrm{t} \times$ TAL |
| ${ }^{\text {t HD }}$; STA | $\geqslant 14 \mathrm{t} \times$ TAL |
| ${ }^{\text {t HIGH }}$ | $\geqslant 17 \mathrm{t} \times$ TAL |
| t LOW | $\geqslant 17 \mathrm{t} \times$ TAL |
| ${ }^{\text {t SY; STO }}$ | $\geqslant 14 \mathrm{t} \times$ TAL |
| thD;DAT | $>0$ |
| ${ }^{\text {t }}$ SU;DAT | $\geqslant 250 \mathrm{~ns}$ |
| ${ }^{\text {t }}$ R ${ }^{\text {d }}$ | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t } R C}$ | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ FD | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ FC | $\leqslant 0,3 \mu \mathrm{~s}$ |

## Notes to Table 9

${ }^{\mathrm{t}} \mathrm{XTAL}=$ one period of the XTAL input frequency ( ${ }^{\mathrm{X}} \mathrm{XTAL}$ )
$=280 \mathrm{~ns}$ for $\mathrm{f}^{\mathrm{X} T A L}=3,58 \mathrm{MHz}$.
These figures apply to all modes.
A.C. CHARACTERISTICS (continued)


Fig. 31 PCD3343 timing requirements for the P23 and SCLK output signals.
Taible 10 Output timing shown in figure 31


## Notes to Table 10

${ }^{\text {t }} \mathrm{XTAL}=$ one period of the XTAL input frequency ( ${ }^{\text {XXTAL }}$ )
$=280 \mathrm{~ns}$ for f XTAL $=3,58 \mathrm{MHz}$.
DF = divisor (see Table 2 Serial I/O section).
$\mathrm{C}_{\mathrm{b}} \quad=$ the maximum bus capacitance for each line.

## APPLICATION INFORMATION

A block diagram of an electronic featurephone built around the PCD3343 is shown in figure 32. It comprises the following dedicated telephony IC's:

- TEA1060/1061
- PCD3312
- PCE2111 or PCF8577
- PCD8571
- PCD3360/3361
transmission circuit for telephony
DTMF generator with Serial I/O
2 LCD drivers in LCD module MB7020160
1 K RAM's with Serial I/O; the number of RAM's depends on the required amount of stored telephone numbers
programmable multi-tone ringer
TRANSMISSION
dialling


Fig. 32 Block diagram of electronic featurephone with common line interface.
A detailed application diagram of the PCD3343 with PCD3312 (DTMF), two PCD8571 (RAM) and two PCE2111 (LCD display drivers) is shown in figure 33.
Row 5 of the keyboard contains the following special keys:

- P program and autodial
- FL flash or register recall
- R redial or extended redial
- AP access pause

Row 6 contains the different diode options.
Columns 5 and 6 contain the button keys M0 to M9; single name keys for repertory telephone numbers.


Fig. 33 Application diagram of PCD3343 for electronıc featurephone with associated keyboard.
Additional information is available on request for the following:

- Serial I/O
- $I^{2} \mathrm{C}$ bus specification
- Interrupt logic
- Instruction set descriptions
- Software routines for an intelligent telephone set


## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The PCF84C12 microcontroller is manufactured in CMOS technology.
It has 13 quasi-bidirectional I/O port lines, one single-level vectored interrupt, an 8 -bit timer event counter and on-board clock oscillator and clock circuits.

This microcontroller is an efficient controller as well as an arithmetic processor. The instruction set is based on that of the MAB8048 and is pin- and instruction set compatible with the MAB8400 family. The PCF84C12 has extensive bit handling abilities and facilities for both binary and BCD arithmetic.
For detailed information see the user manual "Single-chip 8 -bit microcontrollers".

## Features

- 8-bit CPU, ROM, RAM, I/O in a single 20-lead DIL or SO package
- 1 K ROM bytes
- 64 RAM bytes
- 13 quasi-bidirectional I/O port lines
- Two test inputs: one of which is also the external interrupt input
- Single-level vectored interrupts: external and timer/event counter
- 8 -bit programmable timer/event counter
- Clock frequency 100 kHz to 10 MHz
- Over 80 instructions (based on MAB8048) all of 1 or 2 cycles
- Single supply voltage from $2,5 \mathrm{~V}$ to $5,5 \mathrm{~V}$
- STOP and IDLE mode
- Power-on-reset circuit
- Operating temperature range: -40 to $+85{ }^{\circ} \mathrm{C}$


## PACKAGE OUTLINES

PCF84C12P: 20-lead DIL; plastic (SOT-146).
PCF84C12T: 20-lead mini-pack; plastic (SO-20; SOT-163A).


Fig. 1 Block diagram.

## PINNING

## PIN DESIGNATION

| 1-8 | POO-PO7 <br> 9 | Port 0: 8-bit quasi-bidirectional I/O port. <br> INT/TO |
| :--- | :--- | :--- |
| Interrupt/Test 0: external interrupt input (sensitive to negative-going edge)/test <br> input pin; when used as a test input directly tested by conditional branch in- <br> structions JTO and JNTO. |  |  |
| 10 | VSS | Ground: circuit earth potentional. |
| 11 | T1 | Test 1: test input pin, directly tested by conditional branch instructions JT1 <br> and JNT1. T1 also functions as an input to the 8-bit timer/event counter, <br> using the STRT CNT instruction. |
| 12 | XTAL 1 | Oscillator input: crystal which determines the internal oscillator frequency or <br> the external clock generator. |
| 13 | XTAL 2 | Oscillator output |
| 14 | RESET | Reset input: used to initialize the processor (active HIGH), or output of <br> power-on-reset circuit. |
| $15-19$ | P10-P14 | Port 1: quasi-bidirectional port in parallel port mode. |
| 20 | VDD | Power supply: $2,5 \mathrm{~V}$ to $5,5 \mathrm{~V}$. |

## FUNCTIONAL DESCRIPTION

## Program memory

The program memory consists of 1 K bytes, in a read-only memory (ROM). Each location is directly addressable by the program counter. The memory is mask-programmed at the factory. Figure 3 shows the program memory map.

Three program memory locations are of special importance:

- Location 0 ; contains the first instruction to be executed after the processor is initialized (RESET),
- Location 3; contains the first byte of an external interrupt service subroutine,
- Location 7; contains the first byte of a timer/event counter interrupt service subroutine.


## Data memory

Data memory consists of 64 bytes, random-access data memory (RAM). All locations are indirectly addressable using RAM pointer registers; up to 16 designated locations are directly addressable. Memory also includes an 8 -level program counter stack addressed by a 3 -bit stack pointer. Figure 4 shows the data memory map.

## Working registers

Locations 0 to 7 are designated as working registers, directly addressable by the direct register instructions. Ease of addressing, and a minimum requirement of instruction bytes to manipulate their contents, makes these locations suitable for storing frequently addressed intermediate results. This bank of registers can be selected by the SEL RBO instruction.
Executing the select register bank instruction SEL RB1, designates locations 24 to 31 as working registers, instead of locations 0 to 7 , and these are then directly addressable. This second bank of working registers may be used as an extension of the first or reserved for use during interrupt service subroutines saving the first bank for use in the main program. If the second bank is not used, locations 24 to 31 may serve as general purpose RAM.

The first locations of each bank contain the RAM pointer registers R0, R1, RO' and R1', which indirectly address all RAM locations.
All RAM locations make efficient program loop counters when used with the decrement register and test instruction DJNZ.


Fig. 3 Program memory map.


Fig. 4 Data memory map.

## Program counter stack

Locations 8 to 23 may be designated as an 8-level program counter stack ( 2 locations per level), or as general purpose RAM. The program counter stack (Fig. 5) enables the processor to keep track of the return addresses and status generated by interrupts or CALL instructions by storing the contents of the program counter prior to servicing the subroutine. A 3-bit stack pointer determines which of the eight register pairs of the program counter stack will be loaded with next generated return address.
The stack pointer, when initialized to 000 by RESET, points to RAM locations 8 and 9 . On the first subroutine CALL or interrupt, the contents of the program counter and bits 4,6 and 7 of the program status word (PSW) are transferred to locations 8 and 9 . The stack pointer increments by one and points to locations 10 and 11 ready for another CALL. Because an address may be up to 13 bits long, two bytes must be used to store each address.

At the end of a subroutine, which is signalled by a return instruction (RET or RETR), the stack pointer decrements by one and the contents of the register pair on top of the stack are transferred to the program counter. The saved PSW bits are transferred to the PSW only by the RETR instruction.
If not all 8 levels of subroutine and interrupt nesting are used, the unused portion of the stack may be used as any other indirectly addressable RAM locations.

Nesting of subroutines within subroutines can continue up to 8 times without overflowing the stack. If overflow does occur the deepest address stored (locations 8 and 9) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111.

FUNCTIONAL DESCRIPTION (continued)
The value of the saved contents of the program counter is different for an interrupt CALL compared to a normal CALL to subroutine. With an interrupt CALL, the program counter return address is saved; with a subroutine CALL, the saved program counter value is one less than the program counter return address.


Fig. 5 Program counter stack.

## IDLE and STOP modes

## IDLE mode

When the microcontroller enters the IDLE mode via the IDLE instruction ( $\mathrm{H}^{\prime} 01^{\prime}$ ) the oscillator and timer/counter are kept running. The microcontroller exits from the IDLE mode by one of three interrupts if they are enabled or by activating a RESET. If the interrupt is not enabled the processor will remain in the IDLE mode. An active signal on the RESET pin restarts the microcontroller and a normal RESET sequence is executed (see Fig. 6).


Fig. 6 Exit from IDLE mode via a RESET.

An active signal coming from an enabled interrupt causes the execution of the normal interrupt routine since normal interrupt scanning is still being carried out. A HIGH-to-LOW transition on the external interrupt pin ( $\overline{\mathrm{NT}} / \mathrm{TO}$ ) reactivates the microcontroller. A LOW level applied to $\overline{\mathrm{INT}} / \mathrm{TO}$ will reactivate the microcontroller only in the STOP mode. Thus, if $\overline{\mathrm{NT}} / \mathrm{TO}$ was LOW before the microcontroller entered the IDLE mode, it must go HIGH before the microcontroller can be reactivated (see Fig. 7).


Fig. 7 Exit from IDLE mode via an interrupt.
Wake-up from the IDLE mode is ensured when INT/TO is HIGH for 4 CP (clock periods) followed by a LOW for 7 CP . After the initial forced CALL 003 H operation ( 60 CP ) the program continuea with the external interrupt service routine.

## STOP mode

The microcontroller enters the STOP mode by the STOP instruction $(22 \mathrm{H})$. The oscillator is switched off. The internal status of the CPU, RAM contents and the state of I/O ports are not affected. The microcontroller can be brought-out of the STOP mode by an active signal at the external interrupt input or by an external RESET signal. When one of these two signals is applied an internal delay of 1866 CP is provided to ensure that all internal clocks are operating correctly before restart (see Fig. 8).

Note; the start-up time of a crystal oscillator is measured in milliseconds, and the 1866 CP count begins after this start-up time.
If the microcontroller exists from the STOP mode by activating RESET, a normal RESET sequence is executed.


## FUNCTIONAL DESCRIPTION (continued)

If the microcontroller exits the STOP mode by pulling the external interrupt input pin LOW, an interrupt sequence is executed only if the external interrupt is enabled. In this event the microcontroller resumes the normal program sequence after returning from the interrupt routine, as in the normal mode. If the interrupt is not enabled, it continues the normal program sequence, executing the instruction following the STOP instruction.
The microcontroller is restarted by a LOW level applied at the $\overline{\mathrm{INT}} / \mathrm{TO}$ pin, and not by a HIGH-to-LOW transition as in a normal interrupt mechanism.
When the $\overline{\mathrm{NT}} / \mathrm{TO}$ level is active during the STOP instruction then no STOP is executed.
A LOW level on the external interrupt input of at least $1 \mu \mathrm{~s}$ will cause the microcontroller to exit the STOP mode.

## I/O facilities

The PCF84C12 family has 15 I/O lines arranged as:

- Port 0 parallel port of 8 lines (P00 to P07)
- Port 1 parallel port of 5 lines (P10 to P14)
- $\overline{\mathrm{NT}} / \mathrm{TO}$ external interrupt and test input. When used as a test input can be directly tested by conditional branch instructions JTO and JNTO
- T1 test input which can alter program sequences when tested by conditional jump instructions JT1 and JNT1. T1 also functions as an input to the 8 -bit timer/event counter.


## Parallel ports

All parallel ports can be used as outputs or inputs, their structure is quasi-bidirectional. Output data written to a port is latched and remains unchanged until rewritten. Input data is not latched and so must be present until read by an input instruction. Input lines are fully CMOS compatible, output lines can drive one TTL or CMOS load.


Fig. 9 Shows the timing diagram for all ports using IN, OUTL, ANL and ORL instructions. For the OUTL instruction data changes on time slot 7 of cycle 1. For the MOV, ANL and ORL instructions, the ports change on time slot 7 of cycle 2.

Fig. 10 shows the quasi-bidirectional I/O interface with push-pull output and switched pull-up current source.
Each line is pulled up to $V_{D D}$ via a constant current source (TR4), which is enabled via TR3 whenever one of the two output latches contains a logic 1 . This current provides sufficient source current for a TTL HIGH level, yet can be pulled LOW by an external CMOS device, thus allowing the same pin to be used for both input and output.

When a logic 1 is written to the line for the first time ( $M Q=1, S Q=0$ ), TR2 is switched on for the duration of the internal write pulse (one oscillator period), to provide a fast transition from logic 0 to logic 1 . Subsequent writing of a logic 1 to the port lines will not switch TR2 on. This prevents unnecessary current through external components connected to the port lines of the same port which might be in the input mode and also connected to ground.
When a logic 0 is written to the line, TR3 switches off the current source. Current sinking capability is provided by TR1, which is now switched on. When used as an input, a logic 1 must first be written to the line, otherwise TR1 will remain low impedance.

The PCF84C12 offers the possibility to select individually all the port pins by the following mask options:
Option 1 - STANDARD PORT; quasi-bidirectional I/O with switched pull-up current source of $100 \mu \mathrm{~A}$ (typ.) and P-channel booster transistor TR2. TR2 is only active during 1 clock cycle (Fig. 10).
Option 2 - OPEN DRAIN; quasi-bidirectional I/O with only an N -channel open drain output. Application as an output requires connection of an external pull-up resistor (Fig. 11).
Option 3 - PUSH-PULL OUTPUT; drive capability of the output will be $1,6 \mathrm{~mA}$ (min.) at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ in both polarities. To avoid a large current flowing through the output transistors during the input mode, these push-pull pins must only be used as outputs (Fig. 12).


Fig. 10 Standard output with switched pull-up current source.

FUNCTIONAL DESCRIPTION (continued)


Fig. 11 Open drain output.


Fig. 12 Push-pull output.

## Interrupts (see Fig. 13)

When the external interrupt is enabled, a HIGH-to-LOW transition on the INT/TO input initiates an external interrupt subroutine which causes a CALL to program memory location 3 following completion of the current instruction.
The interrupt must remain enabled until the interrupt instruction is completed, otherwise the next instruction of the main program will be executed. A timer/event counter overflow forces a CALL to location 7 when the timer interrupt is enabled.

When an interrupt subroutine starts, the contents of the program counter and bits 4, 6 and 7 of the PSW have been saved in the program counter stack. Accumulator contents have to be saved by software. Interrupt acknowledgement can be carried out by software via port pins. All interrupt subroutines must reside in memory bank 0 .
Since the interrupt system is single level, once an interrupt is detected, all further interrupt requests are latched, but ignored, pending a RETR instruction to re-enable the interrupt input logic. After executing RETR, the program continues in the main part; this is independent of the occurance of a second interrupt during the running of the first routine. If 2 interrupts occur simultaneously, their priority is:

- (1) external
- (2) timer/event counter

An external interrupt can be generated by using the timer/counter in the event counter mode. The counter is first preset to ( $H^{\prime} \mathrm{FF}^{\prime}$ ), then EN TCNTI instruction is executed. A LOW-to-HIGH transition of the T1 input will then initiate an interrupt subroutine and cause a CALL to location 7.

On execution of a DIS I instruction, the PCF84C12 always clears the digital filter/latch and the External Interrupt Flag.
The Timer Flag (TF) is reset only when the JTF or JNTF instruction is executed or after RESET.
The Timer Interrupt Flag is set when timer overflow occurs, only if the timer interrupt is enabled.
The microcontroller will exit the IDLE mode when one of the following two interrupts is enabled:

- External
- Timer/event counter

There is no internal pull-up or pull-down device connected to the external interrupt input (pin 9). If required pin 9 must be externally connected to a resistor ( $R \leqslant 100 \mathrm{k} \Omega$ ). When the external interrupt is not used pin 9 must be connected to VDD.

## Improvements to interrupt and timer logic with respect to the MAB8400 family

For detailed information see the user manual "Single-chip 8-bit microcontrollers", PCF84C00 section.

FUNCTIONAL DESCRIPTION (continued)


Fig. 13 Interrupt logic.

## Notes to figure 13

1. $\overline{\mathrm{INT}} / \mathrm{TO}$ negative edge is always latched in the digital filter/latch.
2. Correct interrupt timing is ensured when $\overline{\mathrm{INT} / \mathrm{TO}}$ is HIGH for $>4 \mathrm{CP}$ followed by a LOW for $>7 \mathrm{CP}$.
3. When the interrupt in progress flag is set, further interrupts are latched but ignored, until RETR is executed.
4. A DIS I instruction always clears a pending external interrupt.
5. For all flip-flops, RESET overrules SET.

## Oscillator (see Fig. 14)

The oscillator can be inhibited by the STOP instruction under software control. It is also inhibited when a low-supply voltage condition is present to prevent discharge of a weak back-up battery. Provided the supply voltage is within the operating range the oscillator will be restarted after a STOP instruction by a LOW level at the $\overline{\mathrm{INT}} / \mathrm{TO}$ pin or a HIGH level at the RESET pin.


Fig. 14(a) Oscillator with integrated elements.


Fig. 14(b) Crystal unit equivalent circuit.

The values of crystal series resistance $R 1$ and the crystal's total load capacitance $C_{L}\left(C_{o}+\right.$ wiring + external capacitors) must not be above the curve (Fig. 14(c)) for the corresponding frequency. Note; if external capacitors are connected to XTAL 1 and XTAL they must be of equal value.


Fig. 14(c) Crystal circuit criteria.

The oscillator has the output drive capability via pin 13 (XTAL2). An external clock can be applied to pin 12 (XTAL1). A machine cycle consists of 10 time slots, each time slot being 3 oscillator periods.

## Timer/event counter (see Fig. 15)

An internal 8-bit up-counter is provided. This can count external events, modulo-32 machine cycles, or machine cycles directly. Table 1 gives the instructions that control the counter and the prescaler, and the functions performed.
When used as a timer, the input to the counter is either the overflow or input of a 5 -bit prescaler. When used as an event counter, LOW-to-HIGH transitions on pin 11 (T1) are counted. The maximum rate at which the counter may be incremented is once every machine cycle. When the counter overflows, the timer flag is set. The flag can be tested and reset using the JTF (jump is timer flag =1) or JNTF instruction. Overflow also generates an interrupt to the processor via setting of the Timer Interrupt Flag when the timer/event counter interrupt is enabled.

FUNCTIONAL DESCRIPTION (continued)
Table 1 Timer/event counter control

| function | timer mode <br> modulo-1, modulo-32* | counter mode |
| :--- | :--- | :--- |
| CLEAR | MOV T,A (A) $=0$ <br> or RESET | MOV T,A (A) =0 |
| PRESET | MOV T,A | or RESET |
| START | STRT T | MOV T,A |
| STOP | STOP TCNT | STRT CNT |
|  | or RESET | STOP TCNT |
| TEST | JTF/JNTF | or RESET |
| READ** | MOV A,T | JTF/JNTF |



Fig. 15 Timer/event counter.

Program status word (see Fig. 16)
The program status word (PSW) is an 8-bit word (1 byte) in the CPU which stores information about the current status of the microcontroller.
The PSW bits are:

- Bits 0 to 2 stack pointer bits $\left(\mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}\right)$
- Bit 3 prescaler select (PS);
$0=$ modulo-32; $1=$ modulo-1 (no prescaling)
- Bit 4 working register bank select (RBS);
$0=$ register bank 0; $1=$ register bank 1
- Bit 5
not used (1)
- Bit 6 auxiliary carry (AC); half-carry bit generated by an ADD instruction and used by the decimal adjust instruction DA A
- Bit 7 carry (CY); the carry flag indicates that previous operation has resulted in an overflow of the accumulator.

| saved in the stack |  | saved in the stack |  |  | stack pointer |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CY | AC | 1 | RBS | PS | $\mathrm{SP}_{2}$ | $\mathrm{SP}_{1}$ | $\mathrm{SP}_{0}$ |
| $\stackrel{7}{M S B}$ | 6 | 5 | 4 | 3 | 2 | 1 | $\stackrel{0}{\text { LSB }}$ |

Fig. 16 Program status word.

* With prescaler select, $\mathrm{PS}=0$, the timer counts modulo- 32 machine cycles, with $\mathrm{PS}=1$ it counts modulo-1 cycles (prescaler not used); prescaler cleared with STRT T, prescaler not readable.
** READ does not disturb the counting process.

Program, status word (continued)
All bits can be read using the MOV A, PSW instruction. Bits 7 and 6 are set and cleared by CPU operation. Bit 4 can be changed by a SEL RB instruction, bit 3 by the MOV PSW, A instruction, and bits 0,1 and 2 by the CALL, RET or RETR instructions and in the event of an interrupt. Bits 7, 6 and 4 are stored in the program counter stack during subroutine and interrupt calls. These bits are restored in the PSW with a RETR (return and restore) instruction which must be used at the end of an interrupt and can be used at the end of a normal subroutine. The RET instruction has no restore feature and cannot be used at the end of an interrupt.

## Program counter (see Fig. 17)

The 13-bit program counter is able to address 8 K bytes of ROM. The arrangement of the bits is shown in figure 17. During an interrupt subroutine $\mathrm{PC}_{11}$ and $\mathrm{PC}_{12}$ are forced to logic 0 . All 13 bits are saved in the stack during CALL and interrupt routines.


Fig. 17 Program counter.

## Central processing unit

The PCF84C12 has arithmetic, logical and branching capabilities. The DA A, SWAP A and XCHD instructions simplify BCD arithmetic and the handling of nibbles. The MOVP A,@A instruction permits efficient table look-up from the current ROM page.

## Conditional branch logic

The conditional branch logic within the processor enables several conditions, internal and external to the processor, to be tested by the user's program. Table 2 lists the conditional jump instructions used to change the program sequence. The DJNZ instruction decrements a designated register or data memory location and branches if the contents are not zero. This instruction is useful for looping control. The JMPP@A instruction allows multiway branches to destinations determined by the contents of the accumulator.

## FUNCTIONAL DESCRIPTION (continued)

Table 2 Conditional branches

| test | jump condition | jump instruction |
| :--- | :--- | :--- |
| accumulator | all bits zero | JZ |
| accumulator bit test | any bit non-zero | JNZ |
| carry flag | 1 | JBO to JB7 |
| timer overflow flag | 1 | JC |
|  | 0 | JNC |
| test input T0 | 1 | JTF |
|  | 0 | JNTF |
| test input T1 | 1 | JT0 |
|  | 0 | JNT0 |
| register | 1 | JT1 |
|  | 0 | DNT1 |
|  | non-zero | DJNZ |

Test input T1 (pin 11)
The T1 input line can be used as:

- A test input for branch instructions JT1 and JNT1
- An external input to the event counter

When used as a test input:

- JT1 instruction tests for logic 1 level
- JNT1 instruction tests for logic 0 level

When used as an input to the event counter, T1 must be LOW for $>4 \mathrm{CP}$, followed by a HIGH for $>4 \mathrm{CP}$. The transition can be recognized with a repetition rate of once per 30 oscillator clock periods (1 machine cycle).

There is no internal pull-up or pull-down resistor connected to the T1 input. If required it must be externally connected to a resistor ( $\mathrm{R}=\leqslant 100 \mathrm{k} \Omega$ ). When T 1 is not used pin 11 must be connected to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$.

Reset (pin 14)
A positive-going signal on the RESET input:

- Sets the program counter to zero
- Selects location 0 of memory band 0 and register bank 0
- Sets the stack pointer to zero ( 000 ); pointing to RAM address 8
- Disables the interrupts (external and timer)
- Stops the timer/event counter, then sets it to zero
- Sets the timer prescaler to modulo-32
- Resets the timer flag
- Sets all ports to input mode
- Cancels IDLE and STOP mode


## Power-on-reset and low-voltage detection (see Fig. 18)

Correct operation of the PCF84C12 during moments of slowly changing supply voltages and low-voltage conditions is essential. This is achieved by the addition of an internal power-on-reset and low-voltage detection circuit. To allow an external RESET signal being fed into the PCF84C12, the reset pin (pin 14) has been configured as an input/output.
While a reset condition exists in the detection circuit, pin 14 is pulled HIGH by TR1 controlled by the reset circuit.
When the reset condition is not present a pull-down current source (TR2) will be activated. TR2 forces pin 14 LOW thus removing the RESET signal from the microcontroller.

Since the level at pin 14 is recognized by the microcontroller, the reset time constant can be stretched by connecting an external capacitor between $V_{D D}$ and pin 14 (see Fig. 19).
The signal at pin 14 can also be used as an output to reset other devices in the system.
The internal reset circuit monitors the PCF84C12 supply voltage. If the voltage drops below the switching level (typ. 1,5 V), a reset (HIGH) is applied to pin 14. This reset is removed (pin 14 goes LOW), after a fixed delay ( $t_{d}$ ), when the supply voltage rises above the switching level again. The delay ensures a complete reset even when the supply voltage quickly rises above switching level after initial switch-on.

If the supply voltage does not reach its minimum value for the frequency of operation (see Fig. 21) within 1860 clock periods, the internal RESET delay is not sufficient.
During a low-voltage condition the oscillator is inhibited to prevent complete discharge of a weak battery. The timing of the power-on-reset and low-voltage detection circuit is shown in Fig. 19.


Fig. 18 Power-on-reset configuration.

## PCF84C12

FUNCTIONAL DESCRIPTION (continued)


Where: (1) Oscillator inhibited
(2) Oscillator starting
(3) Oscillator running, but may be stopped with a STOP condition

Fig. 19 Timing of power-on-reset and low-voltage detection.


Fig. 20 Stretched power-on-reset with external capacitor.

## INSTRUCTION SET

The PCF84C12 instruction set consists of over 80 one and two byte instructions and is identical to the MAB8400 instruction set. New instructions are added for STOP and IDLE mode. Program code efficiency is high because all RAM locations and all ROM locations on a 256 byte page require only a single byte address.
Table 5 gives the instruction set of the PCF84C12. Table 4 shows the instruction map and Table 3 details the symbols and definition descriptions that are used.

Table 3 Symbols and definitions used in Table 5

| symbol | definition description |
| :---: | :---: |
| A | accumulator |
| addr | program memory address |
| Bb | bit designation ( $b=0-7$ ) |
| RBS | register bank select |
| C | carry bit (bit CY) |
| CNT | event counter |
| D | mnemonic for 4-bit digit (nibble) |
| data | 8 -bit number or expression |
| 1 | interrupt |
| MBFF | memory bank flip-flop |
| P | mnemonic for 'in-page' operation |
| PC | program counter |
| Pp | port designation ( $\mathrm{p}=0,1$ or 2 ) |
| PSW | program status word |
| RB | register bank |
| Rr | register designation ( $r=0.7$ ) |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| T0, T1 | test 0 and 1 inputs |
| \# | immediate data prefix |
| @ | indirect address prefix contents of $X$ |
| $((X))$ | contents of location addressed by X |
| $\stackrel{\leftarrow}{\leftrightarrow}$ | is replaced by is exchanged with |

Table 4 PCF84C12 instruction map


Table 5 Instruction set

|  | mnemonic | opcode <br> (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ADD A, Rr ADD A, @Rr | $\begin{aligned} & \text { 6* } \\ & 60 \\ & 61 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | Add register contents to $A$ <br> Add RAM data, addressed by Rr , to A | $\begin{aligned} & (A) \leftarrow(A)+(R r) \\ & (A) \leftarrow(A)+((R 0)) \\ & (A) \leftarrow(A)+((R 1)) \end{aligned}$ | $r=0-7$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  | ADD A, \#data | 03 data | 2/2 | Add immediate data to A | $(A) \leftarrow(A)+$ data |  | 1 |
|  | ADDC A, Rr | 7* | 1/1 | Add carry and register contents to A | $(A) \leftarrow(A)+(R r)+(C)$ | $r=0-7$ | 1 |
|  | ADDC A, @Rr | 70 | 1/1 | Add carry and RAM data, addressed | $(A) \leftarrow(A)+((R 0))+(C)$ |  | 1 |
|  |  | 71 |  | by Rr, to A | $(A) \leftarrow(A)+((R 1))+(C)$ |  |  |
|  | ADDC A, \#data | 13 data | 2/2 | Add carry and immediate data to $A$ | $(A) \leftarrow(A)+$ data $+(C)$ |  | 1 |
|  | ANL A, Rr | 5* | 1/1 | 'AND' Rr with A | $(A) \leftarrow(A)$ AND (Rr) | $r=0-7$ |  |
|  | ANL A, @Rr | 50 | 1/1 | 'AND' RAM data, addressed by Rr, with A | $(A) \leftarrow(A)$ AND ((RO)) |  |  |
|  |  | 51 |  |  | $(A) \leftarrow(A)$ AND ( $(\mathrm{R} 1))$ |  |  |
|  | ANL A, \#data | 53 data | 2/2 | 'AND' immediate data with A | $(\mathrm{A}) \leftarrow(\mathrm{A})$ AND data |  |  |
|  | ORL A, Rr | 4* | 1/1 | 'OR' Rr with A | $(A) \leftarrow(A) O R(R r)$ | $r=0-7$ |  |
|  | ORL A, @Rr | 40 | 1/1 | 'OR' RAM data, addressed by Rr , with A | $(A) \leftarrow(A) O R((R 0))$ |  |  |
|  |  | 41 |  |  | $(A) \leftarrow(A) O R((R 1))$ |  |  |
|  | ORL A, \#data | 43 data | 2/2 | 'OR' immediate data with A | $(A) \leftarrow(A) O R$ data |  |  |
|  | XRL A, Rr | D* | 1/1 | 'XOR' Rr with A | $(A) \leftarrow(A) \times O R(R r)$ | $r=0-7$ |  |
|  | XRL A, @Rr | D0 | 1/1 | 'XOR' RAM, addressed by Rr, with A | $\begin{aligned} & (A) \leftarrow(A) \operatorname{XOR}((R 0)) \\ & (A) \leftarrow(A) \operatorname{XOR}((R 1)) \end{aligned}$ |  |  |
|  | XRL A, \#data | D3 data | 2/2 | 'XOR' immediate data with $A$ | $(A) \leftarrow(A)$ XOR data |  |  |
|  | INC A | 17 | 1/1 | increment A by 1 | $(A) \leftarrow(A)+1$ |  |  |
|  | DEC A | 07 | 1/1 | decrement A by 1 | $(A) \leftarrow(A)-1$ |  |  |
|  | CLR A | 27 | 1/1 | clear A to zero | $(A) \leftarrow 0$ |  |  |
|  | CPL A | 37 | 1/1 | one's complement $A$ | $(\mathrm{A}) \leftarrow \operatorname{NOT}(\mathrm{A})$ |  |  |
|  | RL A | E7 | 1/1 | rotate A left | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow\left(A_{n}\right) \\ & \left(A_{0}\right) \leftarrow\left(A_{7}\right) \end{aligned}$ | $n=0-6$ |  |

## INSTRUCTION SET (continued)

| $\begin{array}{\|l\|} \hline \stackrel{\rightharpoonup}{\mathrm{O}} \\ \text { O} \end{array}$ | RLC A | F7 | 1/1 | rotate A left through carry | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow A_{n} \\ & \left(A_{0}\right) \leftarrow(C),(C) \leftarrow\left(A_{7}\right) \end{aligned}$ | $\mathrm{n}=0-6$ | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \underset{y}{x} \\ & 0 \\ & 0 \end{aligned}$ | RR A | 77 | 1/1 | rotate A right | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow\left(A_{0}\right) \end{aligned}$ | $n=0-6$ |  |
|  | RRC A | 67 | 1/1 | rotate A right through carry | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow(C),(C) \leftarrow\left(A_{0}\right) \end{aligned}$ | $\mathrm{n}=0-6$ | 2 |
| $\begin{array}{\|l} 1 \\ 0 \\ \hline 0 \end{array}$ | DA A SWAP A | $\begin{aligned} & 57 \\ & 47 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | decimal adjust $A$ <br> swap nibbles of $A$ | $\left(\mathrm{A}_{4-7}\right) \leftrightarrow\left(\mathrm{A}_{0-3}\right)$ |  | 2 |
|  | MOV A, Rr | F* | 1/1 | move register contents to $A$ | $(\mathrm{A}) \leftarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | MOV A, @Rr | $\begin{aligned} & \text { F0 } \\ & \text { F1 } \end{aligned}$ | 1/1 | move RAM data, addressed by Rr, to A | $\begin{aligned} & (A) \leftarrow((R 0)) \\ & (A) \leftarrow((R 1)) \end{aligned}$ |  |  |
|  | MOV A, \#data | 23 data | 2/2 | move immediate data to A | (A) $\leftarrow$ data |  |  |
|  | MOV Rr, A | A* | 1/1 | move accumulator contents to register | $(\mathrm{Rr}) \leftarrow(\mathrm{A})$ | $r=0-7$ |  |
|  | MOV @Rr, A | $\begin{aligned} & \text { A0 } \\ & \text { A1 } \end{aligned}$ | 1/1 | move accumulator contents to RAM location addressed by Rr | $\begin{aligned} & ((\text { RO })) \leftarrow(A) \\ & ((R 1)) \leftarrow(A) \end{aligned}$ |  |  |
|  | MOV Rr, \#data | B* data | 2/2 | move immediate data to Rr | $(\mathrm{Rr}) \leftarrow$ data |  |  |
|  | MOV @Rr, \#data | B0 data B1 data | $2 / 2$ | move immediate data to RAM location addressed by Rr | $\begin{aligned} & ((\mathrm{RO})) \leftarrow \text { data } \\ & ((\mathrm{R} 1)) \leqslant \text { data } \end{aligned}$ |  |  |
|  | XCH A, Rr | 2* | 1/1 | exchange accumulator contents with Rr | $(\mathrm{A}) \leftrightarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | XCH A, @Rr | $\begin{array}{\|l} 20 \\ 21 \end{array}$ | 1/1 | exchange accumulator contents with RAM data addressed by Rr | $(A) \leftrightarrow((R 0))$ <br> $(A) \leftrightarrow((R 1))$ |  |  |
|  | XCHD A, @Rr | $\begin{aligned} & 30 \\ & 31 \end{aligned}$ | 1/1 | exchange lower nibbles of A and RAM data addressed by Rr | $\begin{aligned} & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 0_{0-3}\right)\right) \\ & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 1_{0-3}\right)\right) \end{aligned}$ |  |  |
|  | MOV A, PSW | C7 | 1/1 | move PSW contents to accumulator | $(\mathrm{A}) \leftarrow$ (PSW) |  |  |
|  | MOV PSW, A | D7 | 1/1 | move accumulator bit 3 to $\mathrm{PSW}_{3}$ | $\left(\mathrm{PSW}_{3}\right) \leftarrow\left(\mathrm{A}_{3}\right)$ |  | 3 |
|  | MOVP A, @A | A3 | 1/2 | move indirectly addressed data in current page to $A$ | $\left(\mathrm{PC}_{0-7}\right) \leftarrow(\mathrm{A}),(\mathrm{A}) \leftarrow((\mathrm{PC}))$ |  |  |
| 0 | CLR C | 97 | 1/1 | clear carry bit | (C) $\leftarrow 0$ |  | 2 |
| - | CPL C | A7 | 1/1 | complement carry bit | (C) $\leftarrow$ NOT (C) |  | 2 |


|  | mnemonic | opcode <br> (hex.) | bytes/ cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | INC Rr INC @Rr <br> DEC Rr <br> DEC @Rr | $\begin{aligned} & 1^{*} \\ & 10 \\ & 11 \\ & C^{*} \\ & C 0 \\ & C 1 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | increment register by 1 increment RAM data, addressed by Rr, by 1 <br> decrement register by 1 decrement RAM data, addressed by Rr, by 1 | $\begin{array}{ll} (R r) \leftarrow(R r)+1 & r=0-7 \\ ((R 0)) \leftarrow((R 0))+1 & \\ ((R 1)) \leftarrow((R 1))+1 & \\ (R r) \leftarrow(R r)-1 & r=0-7 \\ ((R 0)) \leftarrow((R 0))-1 & \\ ((R 1)) \leftarrow((R 1))-1 & \end{array}$ |  |
|  | JMP addr <br> JMPP @A <br> DJNZ Rr, addr <br> DJNZ @Rr, addr <br> JBb addr <br> JC addr <br> JNC addr <br> JZ addr <br> JNZ addr <br> JTO addr <br> JNTO addr <br> JT1 addr <br> JNT1 addr <br> JTF addr <br> JNTF addr | - 4 address <br> B3 <br> E* address <br> EO <br> E1 <br> - 2 address <br> F6 address <br> E6 address <br> C6 address <br> 96 address <br> 36 address <br> 26 address <br> 56 address <br> 46 address <br> 16 address <br> 06 address | $\begin{array}{\|l} 2 / 2 \\ \\ 1 / 2 \\ 2 / 2 \\ 2 / 2 \\ \\ \\ \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \end{array}$ | unconditional jump within a 2 K bank <br> indirect jump within a page decrement Rr by 1 and jump if not zero to addr <br> decrement RAM data, addressed by Rr by 1 and jump if not zero to addr <br> jump to addr if Acc. bit $b=1$ <br> jump to addr if $\mathrm{C}=1$ <br> jump to addr if $\mathrm{C}=0$ <br> jump to addr if $A=0$ <br> jump to addr if $A$ is NOT zero <br> jump to addr if $\mathrm{TO}=1$ <br> jump to addr if $T 0=0$ <br> jump to addr if T1 = 1 <br> jump to addr if $\mathrm{T} 1=0$ <br> jump to addr if Timer Flag $=1$ <br> jump to addr if Timer Flag $=0$ |  | 4 |

INSTRUCTION SET (continued)

\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline  \& \begin{tabular}{l}
MOV A, T \\
MOV T, A \\
STRT CNT \\
STRT T \\
STOP TCNT \\
EN TCNTI \\
DIS TCNTI
\end{tabular} \& \begin{tabular}{l}
42 \\
62 \\
45 \\
55 \\
65 \\
25 \\
35
\end{tabular} \& \[
\begin{aligned}
\& \hline 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1
\end{aligned}
\] \& \begin{tabular}{l}
move timer/event counter contents to accumulator \\
move accumulator contents to timer/event counter \\
start event counter \\
start timer \\
stop timer/event counter \\
enable timer/event counter interrupt \\
disable timer/event counter interrupt
\end{tabular} \& \[
(A) \leftarrow(T)
\]
\[
(T) \leftarrow(A)
\] \& \& \\
\hline \begin{tabular}{l}
1 \\
0 \\
ロ1 \\
2 \\
2 \\
0 \\
\hline
\end{tabular} \& \begin{tabular}{l}
EN I \\
DIS I \\
SEL RBO \\
SEL RB1 \\
STOP \\
IDLE
\end{tabular} \& \[
\begin{aligned}
\& 05 \\
\& 15 \\
\& \text { C5 } \\
\& \text { D5 } \\
\& 22 \\
\& 01
\end{aligned}
\] \& \[
\begin{aligned}
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1
\end{aligned}
\] \& enable external interrupt disable external interrupt select register bank 0 select register bank 1 enter STOP mode enter IDLE mode \& \[
\begin{aligned}
\& (\mathrm{RBS}) \leftarrow 0 \\
\& (\mathrm{RBS}) \leftarrow 1
\end{aligned}
\] \& \& 5 \\
\hline  \& \begin{tabular}{l}
CALL addr \\
RET \\
RETR
\end{tabular} \& \begin{tabular}{l}
4 address \\
83 \\
93
\end{tabular} \& \begin{tabular}{l}
\[
2 / 2
\] \\
\(1 / 2\) \\
\(1 / 2\)
\end{tabular} \& \begin{tabular}{l}
jump to subroutine \\
return from subroutine \\
return from interrupt and restore bits 4, 6, 7 of PSW
\end{tabular} \&  \& 6 \& 6

6 <br>
\hline
\end{tabular}

|  | mnemonic | opcode (hex.) | bytes/ <br> cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IN A, Pp | $\begin{aligned} & 08 \\ & 09 \end{aligned}$ | 1/2 | input port p data to accumulator | $\begin{aligned} & (A) \leftarrow(P D) \\ & (A) \leftarrow(P 1) \end{aligned}$ |  |
|  | OUTL Pp, A | $\begin{aligned} & 38 \\ & 39 \end{aligned}$ | 1/2 | output accumulator data to port p | $\begin{aligned} & (P 0) \leftarrow(A) \\ & (P 1) \leftarrow(A) \end{aligned}$ |  |
|  | ANL Pp, \#data | $\begin{aligned} & 98 \\ & 99 \end{aligned}$ | 2/2 | AND port $p$ data with immediate data | $(\mathrm{PO}) \leftarrow(\mathrm{PO})$ AND data $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1)$ AND data |  |
|  | ORL Pp, \#data | $\begin{aligned} & 88 \\ & 89 \end{aligned}$ | 2/2 | OR port p data with immediate data | $\begin{aligned} & (P 0) \leftarrow(P 0) \text { OR data } \\ & (P 1) \leftarrow(P 1) \text { OR data } \end{aligned}$ |  |
|  | NOP | 00 | 1/1 | no operation |  |  |

Notes to Table 8

| 1. PSW CY, AC | affected | 5. PSW RBS | affected |
| :--- | :--- | :--- | :--- |
| 2. PSW CY | affected | 6. PSW SP0, $\mathrm{SP}_{1}, \mathrm{SP}_{2}$ | affected |

3. PSW PS affected
4. $\mathrm{PSW}^{\mathrm{SP}} \mathrm{O}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$
affected
5. Execution of JTF and JNTF instructions resets the Timer Flag (TF).

* : 8, 9, A, B, C, D, E, F
: $0,2,4,6,8, A, C, E$
4 : $1,3,5,7,9, B, D, F$


## PCF84C12

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage (pin 20)
All input voltages
D.C. current into any input or output

Total power dissipation (see note)
Power dissipation per output
Storage temperature range
Operating ambient temperature range
Operating junction temperature

| $V_{D D}$ |  | $-0,8$ to +8 V |
| :--- | ---: | ---: |
| $\mathrm{~V}_{\mathrm{I}}$ | 0,8 to $\mathrm{V}_{\mathrm{DD}}+0,8 \mathrm{~V}$ |  |
| $\pm \mathrm{I}_{1} \pm \mathrm{I}_{\mathrm{O}}$ | max. | 10 mA |
| $\mathrm{P}_{\text {tot }}$ | max. | 500 mW |
| $\mathrm{P}_{\mathrm{O}}$ | max. | 50 mW |
| $\mathrm{~T}_{\text {stg }}$ | -65 to $+150 \mathrm{o}^{\circ} \mathrm{C}$ |  |
| $\mathrm{T}_{\text {amb }}$ |  | -40 to $+85 \mathrm{o}^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{j}}$ | max. | $125{ }^{\circ} \mathrm{C}$ |

## HANDLING

Inputs ândopoutputs are protected against electrostatic discharge in normal handling. However, to be totally safe, it is desirable to take normal precautions appropriate to handling MOS devices (see 'Handling MOS devices').

## Note

Thermal resistance (junction to ambient)

| for SOT-146 | $R_{\text {th } j \text {-a }}$ | $\max$ |
| :--- | :--- | :--- |$\quad 120 \mathrm{~K} / \mathrm{W}$,

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $5,5 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$; unless otherwise specified.

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage operating (see Fig. 21) | $V_{\text {DD }}$ | 2,5 | - | 5,5 | V |
| ```Supply current operating (see Fig. 22) at }\mp@subsup{V}{DD}{}=5\textrm{V};\mp@subsup{f}{XTAL}{}=6\textrm{MHz at }\mp@subsup{V}{DD}{}=3\textrm{V};\mp@subsup{\textrm{f}}{\textrm{XTAL}}{}=3;58\textrm{MHz``` | IDD | - | 2 | tbf | mA |
|  | IDD | - | 300 | tbf | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { IDLE mode (see Fig. 23) } \\ & \text { at } \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \mathrm{f}_{\mathrm{XTAL}}=6 \mathrm{MHz} \end{aligned}$ | IDD | - | 1 | tbf | mA |
| at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$; $\mathrm{f} \times \mathrm{TAL}=3,58 \mathrm{MHz}$ | ${ }^{\text {I D D }}$ | - | 150 | tbf | $\mu \mathrm{A}$ |
| STOP mode (see Fig. 24 and note 1) at $V_{D D}=2,5 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$ | ${ }^{1} \mathrm{DD}$ | - | 1,2 | 2,5 | $\mu \mathrm{A}$ |
| at $\mathrm{V}_{\mathrm{DD}}=2,5 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=85{ }^{\circ} \mathrm{C}$ | IDD | - | , | 10 | $\mu \mathrm{A}$ |
| RESET I/O |  |  |  |  |  |
| Switching level | $V_{\text {RESET }}$ | - | 1,5 | 2 | V |
| Sink current at $\mathrm{V}_{\mathrm{DD}}>\mathrm{V}_{\text {RESET }}$ | ${ }^{1} \mathrm{OL}$ | - | 7 | - | $\mu \mathrm{A}$ |
| Inputs |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IL }}$ | 0 | - | $0,3 V_{\text {DD }}$ | V |
| Input voltage HIGH | $V_{1 H}$ | $0,7 V_{\text {DD }}$ | - | $V_{\text {DD }}$ | V |
| Input leakage current as $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\mathrm{DD}}$ | $\pm I_{\text {IL }}$ | - | - | 1 | $\mu \mathrm{A}$ |
| Outputs |  |  |  |  |  |
| Output voltage LOW at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}} ; \\|_{\mathrm{O}} \mid<1 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,05 | V |
| Output sink current LOW $\text { at } V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=0,4 \mathrm{~V}$ | ${ }^{1} \mathrm{OL}$ | 1,6 | 3 | - | mA |
| $\begin{aligned} & \text { Pull-up output source current HIGH } \\ & \text { at } V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=0,7 \mathrm{~V}_{D D} \\ & \text { at } V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=V_{S S} \end{aligned}$ | -1 OH -IOH | 40 | - | $\overline{400}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| Push-pull output source current HIGH at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=V_{D D}-0,4 \mathrm{~V}$ | $-\mathrm{IOH}$ | 1,6 | 3 | - | mA |

## Note 1

Crystal connected between XTAL1 and XTAL2; T1 at $\mathrm{V}_{\mathrm{SS}}$, $\overline{\mathrm{INT}}$ at $\mathrm{V}_{\mathrm{DD}}$.

(1) clock frequency $=100 \mathrm{kHz}$
(2) clock frequency $=1 \mathrm{MHz}$
(3) clock frequency $=3 \mathrm{MHz}$
(4) clock frequency $=10 \mathrm{MHz}$

Fig. 21 Maximum clock frequency ( $f$ XTAL) as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

(1) clock frequency $=6 \mathrm{MHz}$
(2) clock frequency $=3,58 \mathrm{MHz}$

Fig. 23 Typical supply current (IDD) in IDLE mode as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$.

(1) clock frequency $=6 \mathrm{MHz}$
(2) clock frequency $=3,58 \mathrm{MHz}$

Fig. 22 Typical supply current (IDD) in operating mode as a function of the supply voltage ( $V_{D D}$ ); $T_{a m b}=25^{\circ} \mathrm{C}$.

(1) $T_{a m b}=85^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$

Fig. 24 Typical supply current (IDD) in STOP mode as a function of the supply voltage (VDD).

B4E

## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The PCF84CXX family of microcontrollers is manufactured in CMOS technology. The family consists of the following devices:

- PCF84C00 - 256 RAM bytes, external program memory
- PCF84C21-2K ROM/64 RAM bytes
- PCF84C41-4K ROM/128 RAM bytes
- PCF84C81 - 8 K ROM/256 RAM bytes

Each version has 20 quasi-bidirectional I/O port lines, a serial I/O interface, a single-level vectored interrupt circuit, an 8-bit timer event counter and on-board clock oscillator and clock circuits.
This microcontroller family is an efficient controller as well as an arithmetic processor. The instruction set is based on that of the MAB8048 and is pin- and instruction set compatible with the MAB8400 family.
The microcontrollers have bit handling abilities and facilities for both binary and BCD arithmetic.
For detailed information see the user manual "Single-chip 8-bit microcontrollers".

## Features

- 8-bit CPU, ROM, RAM, I/O in a single 28-lead DIL or SO package
- $2 \mathrm{~K}, 4 \mathrm{~K}$ or 8 K ROM bytes plus a ROM-less version
- 64, 128 or 256 RAM bytes
- 20 quasi-bidirectional I/O port lines
- Two test inputs: one of which is also the external interrupt input
- Single-level vectored interrupts: external, timer/event counter, serial I/O
- $\mathrm{I}^{2} \mathrm{C}$ hardware interface for serial data transfer on two lines; (serial I/O data via an existing port line and clock via a dedicated line)
- 8-bit programmable timer/event counter
- Clock frequency 100 kHz to 10 MHz
- Over 80 instructions (based on MAB8048) all of 1 or 2 cycles
- Single supply voltage from $2,5 \mathrm{~V}$ to $5,5 \mathrm{~V}$
- STOP and IDLE mode
- Power-on-reset circuit
- Operating temperature range: -40 to $+85{ }^{\circ} \mathrm{C}$


## PACKAGE OUTLINES

PCF84C21/41/81P: 28-lead DIL; plastic (SOT-117).
PCF84C21/41/81T: 28-lead mini-pack; plastic (SO-28; SOT-136A).
PCF84C00B : 28-lead 'Piggy-back' package (with up to 28-pin EPROM on top).
PCF84C00T : 56-lead mini-pack; plastic (VSO-56; SOT-190).


Fig. 1 Block diagram; PCF84CXX.

(a)

Fig. 1a Replacement of dotted part in Fig. 1, for the PCF84C00T ROM-less version.

(b)

Fig. 1b Replacement of dotted part in Fig. 1, for the PCF84C00B
'Piggy-back' version.

## PINNING



Fig. 2 Pin designation of the PCF84C21/41/81.
PIN DESIGNATION

| Pin | symbol | type | function |
| :--- | :--- | :--- | :--- |
| 3 | SCLK | I/O | $\begin{array}{l}\text { Clock: bidirectional clock for serial I/O. } \\ 4-11 \\ 12\end{array}$ |
| POO-PO7 | I/O | $\begin{array}{l}\text { Port 0: 8-bit quasi-bidirectional I/O port. }\end{array}$ |  |
| Interrupt/Test 0: external interrupt input (sensitive to negative-going |  |  |  |
| edge)/test input pin; when used as a test input directly tested by |  |  |  |
| conditional branch instructions JTO and JNTO. |  |  |  |
| Test 1: test input pin, directly tested by conditional branch instruc- |  |  |  |
| tions JT1 and JNT1. T1 also functions as an input to the 8-bit |  |  |  |
| timer/event countertimer/event counter, using the STRT CNT |  |  |  |
| instruction. |  |  |  |$\}$

PINNING (continued)
Pin designation of PCF84C00B piggy-back version


Fig. 3 Pinning diagram: PCF84C00B
'Piggy-back' version top pinning; to access a 2732 or 2764 EPROM.


Fig. 3a Connection of EPROM to 'Piggy-back' package PCF84C00B.

The PCF84C00B is chiefly used in prototyping and low volume production. The device is mounted in a 'piggy-back' package, i.e. a 4 K or 8 K byte EPROM may be mounted in the $24 / 28$ pin socket on top of the package.

## Notes

1. RAM capacity of PCF84C00B is 256 bytes.
2. Access time for ROMS/EPROMS to be below $7 \times 1 / \mathrm{f} \mathrm{XTAL}$.
3. Bottom pinning is identical to that of Fig. 2.
DEVELOPMENT DATA


Fig. 4 Pinning diagram; ROM-less version PCF84C00T.
The PCF84C00T is chiefly used for prototyping future derivatives of the PCF84CXX family or low-volume production. The device is packaged in a 56 -lead VSO outline. Additional signals are available (see pinning information following) to control external program memory and derivative functions.

PIN DESIGNATION (continued)

| pin | symbol | type | function |
| :--- | :--- | :--- | :--- |
| $\begin{array}{l}34-29 \\ 27-22,19 \\ 16-18 \\ 36-40\end{array}$ | AOO-A12 | O | Address outputs. |
| 41 | $\overline{\text { PSEN }}$ | I/O | Data lines, internal pull-ups provided. |
| 6 | DXALE | O | $\begin{array}{l}\text { Program store enable (active low). Used for enabling external } \\ \text { program memory. Active during TS9 and TS10 of each machine } \\ \text { cycle and TS1 of each following cycle. PSEN is halted during } \\ \text { STOP mode. }\end{array}$ |
| Address latch enable. Using the falling edge, the Dx address can be |  |  |  |
| latched in an appropriate external latch. This signal occurs only |  |  |  |
| during execution of the MOV Dx,A, MOV A,Dx, ANL Dx,A |  |  |  |
| and ORL Dx, A instructions, with x = O to FF H. |  |  |  |$\}$

[^13]
## FUNCTIONAL DESCRIPTION

## ROM-less version PCF84C00T

The PCF84C00T is a microcontroller that contains no on-board ROM, but has all address and data lines brought-out to access an external ROM or EPROM. This version has more pins than the PCF84CXX with on-board ROM (see Fig. 1a). The device has an address range of 8 K for ROM or external program memory, and has an internal data RAM of 256 bytes.

## 'Piggy-back' version PCF84C00B

The PCF84C00B is a special package that has standard pinning to the bottom which facilitates insertion as a mask-programmed device. An EPROM can be mounted on top in an additional socket. The total package height is greater than the standard DIL package. The device has an address range of 8 K for ROM or external RAM, and has an internal data RAM of 256 bytes.

## Program memory

The program memory consists of 2, 4 or 8 K bytes, in a read-only memory (ROM). Each location is directly addressable by the program counter. The memory is mask-programmed at the factory. Figure 5 shows the program memory map.
Four program memory locations are of special importance:

- Location 0; contains the first instruction to be executed after the processor is initialized (RESET),
- Location 3; contains the first byte of an external interrupt service subroutine;
- Location 5; contains the first byte of a serial I/O and derivative interrupt service subroutine,
- Location 7; contains the first byte of a timer/event counter interrupt service subroutine.

Program memory is arranged in banks of 2 K bytes, which are selected by SEL MB instructions. The program memory is further divided into location 'pages', each of 256 bytes. This latter division applies only for conditional branches. Memory bank boundaries can be crossed only by using unconditional branch instructions after the appropriate memory bank has been selected. A CALL instruction can transfer control to a subroutine on any 'page'; RET and RETR instructions can transfer control from a subroutine back to the main program.

## Data memory

Data memory consists of 64,128 or 256 bytes, random-access data memory (RAM). Allocations are indirectly addressable using RAM pointer registers; up to 16 designated locations are directly addressable. Memory also includes an 8 -level program counter stack addressed by a 3 -bit stack pointer. Figure 6 shows the data memory map.

## Working registers

Locations 0 to 7 are designated as working registers, directly addressable by the direct register instructions. Ease of addressing, and a minimum requirement of instruction bytes to manipulate their contents, makes these locations suitable for storing frequently addressed intermediate results. This bank of registers can be selected by the SEL RBO instruction.
Executing the select register bank instruction SEL RB1, designates locations 24 to 31 as working registers, instead of locations 0 to 7 , and these are then directly addressable. This second bank of working registers may be used as an extension of the first or reserved for use during interrupt service subroutines saving the first bank for use in the main program. If the second bank is not used, locations 24 to 31 may serve as general purpose RAM.
The first locations of each bank contain the RAM pointer registers R0, R1, RO' and R1', which indirectly address all RAM locations.
All RAM locations make efficient program loop counters when used with the decrement register and test instruction DJNZ.

FUNCTIONAL DESCRIPTION (continued)


Fig. 5 Program memory map.

## Program counter stack

Locations 8 to 23 may be designated as an 8 -level program counter stack ( 2 locations per level), or as general purpose RAM. The program counter stack (Fig. 7) enables the processor to keep track of the return addresses and status generated by interrupts or CALL instructions by storing the contents of the program counter prior to servicing the subroutine. A 3 -bit stack pointer determines which of the eight register pairs of the program counter stack will be loaded with next generated return address.
The stack pointer, when initialized to 000 by RESET, points to RAM locations 8 and 9 . On the first subroutine CALL or interrupt, the contents of the program counter and bits 4,6 and 7 of the program status word (PSW) are transferred to locations 8 and 9 . The stack pointer increments by one and points to locations 10 and 11 ready for another CALL. Because an address may be up to 13 bits long, two bytes must be used to store each address.
At the end of a subroutine, which is signalled by a return instruction (RET or RETR), the stack pointer decrements by one and the contents of the register pair on top of the stack are transferred to the program counter. The saved PSW bits are transferred to the PSW only by the RETR instruction.
If not all 8 levels of subroutine and interrupt nesting are used, the unused portion of the stack may be used as any other indirectly addressable RAM locations.

Nesting of subroutines within subroutines can continue up to 8 times without overflowing the stack. If overflow does occur the deepest address stored (locations 8 and 9 ) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111.

## FUNCTIONAL DESCRIPTION (continued)

The value of the saved contents of the program counter is different for an interrupt CALL compared to a normal CALL to subroutine. With an interrupt CALL, the program counter return address is saved; with a subroutine CALL, the saved program counter value is one less than the program counter return address.


Fig. 7 Program counter stack.

## IDLE and STOP modes

## IDLE mode

When the microcontroller enters the IDLE mode via the IDLE instruction ( 01 H ) the oscillator, timer/counter and serial I/O are kept running. The microcontroller exits from the IDLE mode by one of three interrupts if they are enabled or by activating a RESET. If the interrupt is not enabled the processor will remain in the IDLE mode. An active signal on the RESET pin restarts the microcontroller and a normal RESET sequence is executed (see Fig. 8).


Fig. 8 Exit from IDLE mode via a RESET.

An active signal coming from an enabled interrupt causes the execution of the normal interrupt routine since normal interrupt scanning is still being carried out. A HIGH-to-LOW transition on the external interrupt pin (INT/TO) reactivates the microcontroller. A LOW level applied to $\overline{\mathrm{INT}} / \mathrm{TO}$ will reactivate the microcontroller only in the STOP mode. Thus, if $\overline{\mathrm{INT}} / T O$ was LOW before the microcontroller entered the IDLE mode, it must go HIGH before the microcontroller can be reactivated (see Fig. 9).


Fig. 9 Exit from IDLE mode via an interrupt.
Wake-up from the IDLE mode is ensured when $\overline{\mathrm{INT}} / \mathrm{TO}$ is HIGH for at least 4 CP (clock periods) followed by a LOW for 7 CP . After the initial forced CALL 003 H operation ( 60 CP ) the program continues with the external interrupt service routine.

## STOP mode

The microcontroller enters the STOP mode by the STOP instruction ( 22 H ). The oscillator is switched off. The internal status of the CPU, RAM contents and the state of I/O ports are not affected. The microcontroller can be brought-out of the STOP mode by an active signal at the external interrupt input or by an external RESET signal. When one of these two signals is applied an internal delay of 1866 CP is provided to ensure that all internal clocks are operating correctly before restart (see Fig. 10). Note; the start-up time of a crystal oscillator is measured in milliseconds, and the 1866 CP count begins after this start-up time.
If the microcontroller exits from the STOP mode by activating RESET, a normal RESET sequence is executed.


Fig. 10 Entering and exiting the STOP mode.

## FUNCTIONAL DESCRIPTION (continued)

If the microcontroller exits the STOP mode by pulling the external interrupt input pin LOW, an interrupt sequence is executed only if the external interrupt is enabled. In this event the microcontroller resumes the normal program sequence after returning from the interrupt routine, as in the normal mode. If the interrupt is not enabled, it continues the normal program sequence, executing the instruction following the STOP instruction.
The microcontroller is restarted by a LOW level applied at the $\overline{\mathrm{NTT}} / \mathrm{TO}$ pin, and not by a HIGH-to-LOW transition as in a normal interrupt mechanism.
Note: when leaving the STOP mode with an interrupt, a further instruction in the main program series is executed prior to entering the interrupt routine.
When the $\overline{\mathrm{NT}} / \mathrm{TO}$ level is active during the STOP instruction then no STOP is executed.
A LOW level on the external interrupt input of at least $1 \mu \mathrm{~s}$ will cause the microcontroller to exit the STOP mode.

## I/O facilities

The PCF84CXX family has 23 I/O lines arranged as:

- Port 0 parallel port of 8 lines (P00 to P07)
- Port 1 parallel port of 8 lines (P10 to P17)
- Port 2 parallel port of 4 lines (P20 to P23)
- SCLK serial I/O clock line
- $\overline{\mathrm{INT}} / \mathrm{TO}$ external interrupt and test input. When used as a test input it can be directly tested by conditional branch instructions JTO and JNTO
- T1 test input which can alter program sequences when tested by conditional jump instructions JT1 and JTN1. T1 also functions as an input to the 8 -bit timer/event counter.


## Parallel ports

All parallel ports can be used as outputs or inputs, their structure is quasi-bidirectional. Output data written to a port is latched and remains unchanged until rewritten. Input data is not latched and so must be present until read by an input instruction.
Input lines are fully CMOS compatible, output lines can drive one TTL or CMOS load.


Fig. 11 Shows the timing diagram for all ports using IN, OUTL, ANL and ORL instructions. For the OUTL instruction data changes on time slot 7 of cycle 1. For the MOV, ANL and ORL instructions, the ports change on time slot 7 of cycle 2.

Fig. 12 shows the quasi-bidirectional I/O interface with push-pull output and switched pull-up current source.
Each line is pulled up to VDD via a constant current source (TR4), which is enabled via TR3 whenever one of the two output latches contains a logic 1. This current source is sufficient for a TTL. HIGH level, yet can be pulled LOW by an external CMOS device, thus allowing the same pin to be used for both input and output.

When a logic 1 is written to the line for the first time ( $M Q=1, S Q=0$ ), TR2 is switched on for the duration of the internal write pulse (one oscillator period), to provide a fast transition from logic 0 to logic 1. Subsequent writing of a logic 1 to the port lines will not switch TR2 on. This prevents unnecessary current through external components connected to the port lines of the same port which might be in the input mode and also connected to ground.
When a logic 0 is written to the line, TR3 switches off the current source. Current sinking capability is provided by TR1, which is now switched on. When used as an input, a logic 1 must first be written to the line, otherwise TR1 will remain low impedance.
The PCF84CXX family offers the possibility to seiect individually 19 of the 20 parallel port pins (not P23), by the following mask options: (PCF84C00 has only option 1):

Option 1 - STANDARD PORT; quasi-bidirectional I/O with switched pull-up current source of $100 \mu \mathrm{~A}$ (typ.) and P-channel booster transistor TR2. TR2 is only active during 1 clock cycle (Fig. 12).
Option 2 - OPEN DRAIN; quasi-bidirectional I/O with only an N-channel open drain output. Application as an output requires connection of an external pull-up resistor (Fig. 13).
Option 3 - PUSH-PULL OUTPUT; drive capability of the output will be $1,6 \mathrm{~mA}(\mathrm{~min}$.) at $V_{D D}=5 \mathrm{~V}$ in both polarities. To avoid a large current flowing through the output transistors during the input mode, these push-pull pins must only be used as outputs (Fig. 14).


Fig. 12 Standard output with switched pull-up current source.

FUNCTIONAL DESCRIPTION (continued)


Fig. 13 Open drain output.


Fig. 14 Push-pull output.

## Serial I/O (SIO)

The PCF84CXX has an on-chip serial I/O interface that supports $\mathrm{I}^{2} \mathrm{C}$-bus communication. Whereas a normal microcontroller must regularly monitor the serial data bus for the presence of data, the serial I/O interface detects, receives and converts the serial data stream into parallel format without interrupting the execution of the current program. An interrupt is sent to the PCF84CXX only when a complete byte is received. It then reads the data byte in one instruction.

The design of the PCF84CXX serial I/O system allows any number of devices from PCF8500 family (clips) to be connected via the two-line serial bus. The ability of any devices to communicate, without interrupting the operation of any other devices on the bus, is an outstanding attribute of the system. This is achieved by allocating a specific 7 -bit address to each device and providing a system whereby a device reacts only to a message prefixed with its own address or the 'general CALL' address.
Address recognition is performed by the interface hardware so that operation of the microcontroller need only be interrupted when a valid address has been received. This saves significant processing time and memory space compared with a conventional microcontroller employing a software serial interface. When the addressing facility is not required, for instance in a system with only two microcontrollers, direct data transfer without addressing can be performed. In multi-master systems, an automatically invoked arbitration procedure prevents two or more devices from continuing simultaneous transmission.
In NORMAL (running) and IDLE mode, the serial I/O logic remains active; its internal system clock will be switched off when there is no activity on the serial bus.
After execution of the STOP instruction, the oscillator of the PCF84CXX is switched off. This means that the serial I/O logic will remain in the state it was at the occurance of the STOP instruction. To avoid "bus block" problems and to assure correct start-up of the bus after exit from the STOP mode, the user should disable the serial logic $(E S O=0)$ prior to the execution of the STOP instruction. This must be carried out only when the PCF84CXX has finished a serial data transfer.

## Serial I/O interface

Figure 15 shows the serial I/O interface. The clock line of the serial bus has exclusive use of pin 3 (SCLK) while the data line shares pin 2 (serial data) with the I/O line P23 of port 2. When the serial I/O is enabled, P23 is disabled as a parallel port line; (P23 and SCLK only open drain).
The microcontroller and interface communicate via the internal microcontroller bus and the Serial Interrupt Request line. Data and information controlling the operation of the interface are stored in four registers:

- Data shift register (SO)
- Serial I/O interface status word (S1)
- Serial clock control word (S2)
- Address register


## FUNCTIONAL DESCRIPTION (continued)

## Data shift register (SO)

Register SO converts serial data to parallel format and vice versa. A pending interrupt is generated only after a complete byte has been transmitted, or after a complete data byte, specific address or 'general CALL' address has been received. The most significant bit is transmitted first.
Serial I/O interface status word (S1)
Register S1 provides information concerning the state of the interface and stores information from the microcontroller. Bits 0 to 3 are duplicated: control bits in these positions can only be written by the microcontroller, while interface bits can only be read.
MST and TRX (see Table 1)
These bits determine the operating mode of the serial I/O interface.

Table 1 Operating modes of the serial I/O interface

| MST | TRX | operating mode |
| :--- | :--- | :--- |
| 0 | 0 | slave receiver |
| 1 | 0 | master receiver |
| 0 | 1 | slave transmitter |
| 1 | 1 | master transmitter |

## BB: Bus Busy.

This is the flag which indicates the status of the bus.
PIN: Pending Interrupt Not
PIN $=$ ' 0 ' indicates the presence of a pending interrupt, which will cause a Serial Interrupt Request when the serial interrupt mechanism is enabled.

## ESO: Enable Serial output

The ESO flag enables/disables the serial I/O interface: ESO = ' 1 ' enables, $\mathrm{ESO}=$ ' 0 ' disables. ESO can only be written by software.
$\mathrm{BCO}, \mathrm{BC} 1$ and BC 2
Bits $B C 0, B C 1$ and $B C 2$ indicate the number of bits received or transmitted in a data stream. These bits can only be written by software.

## AL: Arbitration Lost

The arbitration lost flag is set by hardware when the serial I/O interface, as master transmitter, loses a bus arbitration procedure.

AAS: Addressed As Slave
This flag is set by hardware when the interface detects either its own specific address or the 'general CALL' address as the first byte of a transfer and the interface has been programmed to operate in the address recognition mode.

ADO: Address Zero
This flag is set by hardware after detection of the 'general CALL' address when the interface is operating in the address recognition mode.

LRB: Last Received Bit
This contains either the last data bit received or, for a transmitting device in the acknowledgement mode, the acknowledgement signal from the receiving device.

Bits AL, AAS, ADO and LRB can only be read by software.

Serial clock control word (S2)
Bits 0 to 4 of the clock control register $S 2$ are used to set the frequency of the serial clock signal. When a 6 MHz crystal is used, the frequency of the serial clock can be varied between 154 kHz and 1 kHz (see Table 2). An asymmetrical clock with a HIGH-to-LOW ratio of $3: 1$ can be generated using bit 5 . The asymmetrical clock allows a microcontroller more time per clock period for sampling the data line, making the timing of this action less critical. Bit 6 can be used to activate the acknowledge mode of the serial I/O. S2 is a write only register.
Address register
The address register contains the 7-bit address back-up latches and the bit (ALS) used to enable/disable the address recognition mode. The address register can be written using the MOV SO, A and MOV SO, \# data instructions, but only when ESO = ' 0 '.

Serial I/O interrupt logic
An EN SI instruction enables and a DIS SI instruction disables the interrupt logic. When the logic is enabled, a pending interrupt results in a serial I/O interrupt to the processor, causing a CALL to location 5 in the ROM. When disabled, the presence of an interrupt is still indicated by PIN in S1, allowing the interrupt to be serviced. However, vectored interrupt will not occur.

## FUNCTIONAL DESCRIPTION (continued)

Table 2 SIO clock pulse frequency control when using a 6 MHz and a 10 MHz crystal

| nexadecimal S20-S24 code | divisor | fXTAL 6 MHz$)$ ${ }^{\text {f SCLK }}(\mathrm{kHz}) ~ 4$ | $\text { fXTAL ( } 10 \mathrm{MHz} \text { ) }$ <br> fSCLK (kHz) 4 |
| :---: | :---: | :---: | :---: |
| 0 | not allowed |  |  |
| 1 | 39 | *154 | *256 |
| 2 | 45 | *133 | *222 |
| 3 | 51 | *118 | *196 |
| 4 | 63 | 95 | *159 |
| 5 | 75 | 80 | *133 |
| 6 | 87 | 69 | *115 |
| 7 | 99 | 61 | *101 |
| 8 | 123 | 49 | 81 |
| 9 | 147 | 41 | 68 |
| A | 171 | 35 | 58 |
| B | 195 | 31 | 51 |
| C | 243 | 25 | 41 |
| D | 291 | 21 | 34 |
| E | 339 | 18 | 29 |
| F | 387 | 16 | 26 |
| 10 | 483 | 12 | 21 |
| 11 | 579 | 10 | 17 |
| 12 | 675 | 8,9 | 15 |
| 13 | 771 | 7,8 | 13,4 |
| 14 | 963 | 6,2 | 10,4 |
| 15 | 1155 | 5,2 | 8,7 |
| 16 | 1347 | 4,5 | 7,4 |
| 17 | 1539 | 3,9 | 6,5 |
| 18 | 1923 | 3,1 | 5,2 |
| 19 | 2307 | 2,6 | 4,3 |
| 1 A | 2691 | 2,2 | 3,7 |
| 1B | 3075 | 2,0 | 3,3 |
| 1 C | 3843 | 1,6 | 2,6 |
| 1D | 4611 | 1,3 | 2,2 |
| 1 E | 5379 | 1,1 | 1,9 |
| 1F | 6147 | 1,0 | 1,6 |

* Not permitted for $I^{2} \mathrm{C}$ operation.
- The maximum clock frequency in the $\mathrm{I}^{2} \mathrm{C}$ systems is 100 kHz .


## DEVELOPMENT DATA



Fig. 15 Serial I/O interface.

## FUNCTIONAL DESCRIPTION (continued)

## Interrupts (see Fig. 16)

When the external interrupt is enabled, a HIGH-to-LOW transition on the $\overline{\text { INT/TO }}$ input initiates an external interrupt subroutine which causes a CALL to program memory location 3 following completion of the current instruction.
The interrupt must remain enabled until the interrupt instruction is completed, otherwise the next instruction of the main program will be executed. Serial I/O interrupt, when enabled, causes a CALL to location 5, and a timer/event counter overflow forces a CALL to location 7 when the timer interrupt is enabled.
When an interrupt subroutine starts, the contents of the program counter and bits 4,6 and 7 of the PSW have been saved in the program counter stack. Accumulator contents have to be saved by software. Interrupt acknowledgement can be carried out by software via port pins. All interrupt subroutines must reside in memory bank 0 .
Since the interrupt system is single level, once an interrupt is detected, all further interrupt requests are latched, but ignored, pending a RETR instruction to re-enable the interrupt input logic. After executing RETR, the program continues in the main part; this is independent of the occurance of a second interrupt during the running of the first routine. If 2 or 3 interrupts occur simultaneously, their priority is:

- (1) external
- (2) serial I/O
- (3) timer/event counter

An external interrupt can be generated by using the timer/counter in the event counter mode. The counter is first preset to (FFH), then EN TCNTI instruction is executed. A LOW-to-HIGH transition of the T1 input will then initiate an interrupt subroutine and cause a CALL to location 7.

On execution of a DIS I instruction, the PCF84CXX always clears the digital filter/latch and the External Interrupt Flag.
The Timer Flag (TF) is reset only when the JTF or JNTF instruction is executed or after RESET.
The Timer Interrupt Flag is set when timer overflow occurs, only if the timer interrupt is enabled.
The microcontroller will exit the IDLE mode when any one of the following three interrupts is enabled:

- External
- Serial I/O
- Timer/event counter

There is no internal pull-up or pull-down device connected to the external interrupt input (pin 12). If required pin 12 must be externally connected to a resistor ( $R \leqslant 100 \mathrm{k} \Omega$ ). When the external interrupt is not used pin 12 must be connected to $\mathrm{V}_{\text {DD }}$.

## Improvements to interrupt and timer logic with respect to the MAB8400 family

For detailed information see the PCF84CXX section in the user manual "Single-chip 8-bit microcontrollers".


Fig. 16 Interrupt logic.

## Notes to figure 16

1. $\overline{\mathrm{INT}} / \mathrm{TO}$ negative edge is always latched in the digital filter/latch.
2. Correct interrupt timing is ensured when $\overline{\mathrm{INT}} / \mathrm{TO}$ is HIGH for $>4 \mathrm{CP}$ followed by a LOW for $>7 \mathrm{CP}$.
3. When the interrupt in progress flag is set, further external and timer interrupts are latched but ignored, until RETR is executed.
4. A DIS I instruction always clears a pending external interrupt.
5. For all flip-flops, RESET overrules SET.
6. EXDI is an input of PCF8400T, in derivative versions it is connected internally to a logic ' 1 '.

## FUNCTIONAL DESCRIPTION (continued)

## Oscillator (see Fig. 17)

The oscillator can be inhibited by the STOP instruction under software control. It is also inhibited when a low-supply voltage condition is present to prevent discharge of a weak back-up battery. Provided the supply voltage is within the operating range the oscillator will be restarted after a STOP instruction by a LOW level at the $\overline{\mathrm{INT}} / \mathrm{TO}$ pin or a HIGH level at the RESET pin.


Fig. 17 Oscillator with integrated elements.


Fig. 18 Crystal unit equivalent circuit.

The values of crystal series resistance $R 1$ and the crystal's total load capacitance $C_{L}\left(C_{o}+\right.$ wiring + external capacitors) must not be above the curve (Fig. 19) for the corresponding frequency. Note; if external capacitors are connected to XTAL 1 and XTAL they must be of equal value.


Fig. 19 Crystal circuit criteria.
The oscillator has the output drive capability via pin 16 (XTAL2). An external clock can be applied to pin 15 (XTAL1). A machine cycle consists of 10 time slots, each time slot being 3 oscillator periods.

## Timer/event counter (see Fig. 20)

An internal 8-bit up-counter is provided. This can count external events, modulo-32 machine cycles, or machine cycles directly. Table 3 gives the instructions that control the counter and the prescaler, and the functions performed.
When used as a timer, the input to the counter is either the overflow or input of a 5 -bit prescaler. When used as an event counter, LOW-to-HIGH transitions on pin $13(\mathrm{~T} 1)$ are counted. The maximum rate at which the counter may be incremented is once every machine cycle. When the counter overflows, the timer flag is set. The flag can be tested and reset using the JTF (jump is timer flag = 1) or JNTF instruction. Overflow also generates an interrupt to the processor via setting of the Timer Interrupt Flag when the timer/event counter interrupt is enabled.

Table 3 Timer/event counter control

| function | timer mode <br> modulo-1, modulo-32* | counter mode |
| :--- | :--- | :--- |
| CLEAR | MOV T,A (A) = 0 | MOV T,A (A) = 0 |
|  | or RESET | or RESET |
| PRESET | MOV T,A | MOV T,A |
| START | STRT T | STRT CNT |
| STOP | STOP TCNT | STOP TCNT |
|  | or RESET | or RESET |
| TEST | JTF/JNTF | JTF/JNTF |
| READ** | MOV A,T | MOV A,T |



Fig. 20 Timer/event counter.

Program status word (see Fig. 21)
The program status word (PSW) is an 8-bit word (1 byte) in the CPU which stores information about the current status of the microcontroller.
The PSW bits are:

- Bits 0 to 2 stack pointer bits ( $\mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ )
- Bit 3 prescaler select (PS);
- Bit 4 working register bank select (RBS);
$0=$ register bank 0;1 = register bank
- Bit 5 not used (1)
- Bit 6 auxiliary carry (AC); half-carry bit generated by an ADD instruction and used by the decimal adjust instruction DA A
- Bit 7 carry (CY); the carry flag indicates that previous operation has resulted in an overflow of the accumulator.


Fig. 21 Program status word.

* With prescaler select, $\mathrm{PS}=0$, the timer counts modulo- 32 machine cycles, with PS $=1$ it counts modulo-1 cycles (prescaler not used); prescaler cleared with STRT T, prescaler not readable.
** READ does not disturb the counting process.


## FUNCTIONAL DESCRIPTION (continued)

## Program status word (continued)

All bits can be read using the MOV A, PSW instruction. Bits 7 and 6 are set and cleared by CPU operation. Bit 4 can be changed by a SEL RB instruction, bit 3 by the MOV PSW, A instruction, and bits 0,1 and 2 by the CALL, RET or RETR instructions and in the event of an interrupt. Bits 7,6 and 4 are stored in the program counter stack during subroutine and interrupt calls. These bits are restored in the PSW with a RETR (return and restore) instruction which must be used at the end of an interrupt and can be used at the end of a normal subroutine. The RET instruction has no restore feature and cannot be used at the end of an interrupt.

Program counter (see Fig. 22)
The 13 -bit program counter is able to address 8 K bytes of ROM. The arrangement of the bits is shown in figure 22. During an interrupt subroutine $\mathrm{PC}_{11}$ and $\mathrm{PC}_{12}$ are forced to logic 0 . All 13 bits are saved in the stack during CALL and interrupt routines.


Fig. 22 Program counter.

## Central processing unit

The PCF84CXX has arithmetic, logical and branching capabilities. The DA A, SWAP A and XCHD instructions simplify BCD arithmetic and the handling of nibbles. The MOVP A,@A instruction permits efficient table look-up from the current ROM page.

## Conditional branch logic

The conditional branch logic within the processor enables several conditions, internal and external to the processor, to be tested by the user's program. Table 4 lists the conditional jump instructions used to change the program sequence. The DJNZ instruction decrements a designated register or data memory location and branches if the contents are not zero. This instruction is useful for looping control. The JMPP@A instruction allows multiway branches to destinations determined by the contents of the accumulator.

Table 4 Conditional branches

| test | jump condition | jump instruction |
| :--- | :--- | :--- |
| accumulator | all bits zero | JZ |
| accumulator bit test | any bit non-zero | JNZ |
| carry flag | 1 | JBO to JB7 |
| timer overflow flag | 1 | JC |
| test input T0 | 0 | JNC |
|  | 1 | JTF |
| test input T1 | 0 | JNTF |
| register | 1 | JT0 |
|  | 0 | JTT0 |
|  | 1 | JT1 |
|  | 0 | DNT1 |
|  | non-zero | DJNZ |

Test input T1 (pin 13)
The T1 input line can be used as:

- A test input for branch instructions JT1 and JNT1
- An external input to the event counter

When used as a test input:

- JT1 instruction tests for logic 1 level
- JNT1 instruction tests for logic 0 level

When used as an input to the event counter, T1 must be LOW for $>4 \mathrm{CP}$, followed by a HIGH for $>4 \mathrm{CP}$. The transition can be recognized with a repetition rate of once per 30 oscillator clock periods (1 machine cycle).
There is no internal pull-up or pull-down resistor connected to the T1 input. If required it must be externally connected to a resistor ( $\mathrm{R}=\leqslant 100 \mathrm{k} \Omega$ ). When T 1 is not used pin 13 must be connected to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$.

## Reset (pin 17)

A positive-going signal on the RESET input

- Sets the program counter to zero
- Selects location 0 of memory bank 0 and register bank 0
- Sets the stack pointer to zero (000); pointing to RAM address 8
- Disables the interrupts (external, timer and serial I/O)
- Stops the timer/event counter, then sets it to zero
- Sets the timer prescaler to modulo-32
- Resets the timer flag
- Sets all ports to input mode
- Sets the serial I/O to slave receiver mode and disables the serial I/O
- Cancels IDLE and STOP mode


## FUNCTIONAL DESCRIPTION (continued)

## Power-on-reset

The internal power-on reset circuit monitors the PCF84CXX supply voltage VDD. For as long as the supply voltage remains below the internal reference level $\mathrm{V}_{\text {ref }}$ (typically $1,5 \mathrm{~V}$ ) the oscillator is inhibited and RESET (pin 17) has an undefined level. When VDD rises above the internal reference level, the oscillator is released and RESET is pulled high to VDD by TR1 for a period tD (typically $50 \mu \mathrm{~s}$ ).
N.B. Because of the narrow bandwidth of the crystal, the start-up time of the oscillator is typically 10 ms .
Three modes of power-on reset are possible:

1. If $V_{D D}$ can be switched with a fast rise time i.e. $V_{D D}$ reaches its minimum operating value (corresponding to the selected oscillator frequency) before the RESET signal ( ${ }_{\mathrm{D}}$ ) has finished, then no extra components are required (see Fig. 23 and 24). Note that the first instruction is executed after the oscillator start-up time plus 1866 clock periods have elapsed.
2. If $V_{D D}$ has a slow rise time then the RESET signal should be stretched by an external RC circuit (see Fig. 25 and 26). In the event of a short drop in the supply voltage, the diode path rapidly discharges the capacitor to ensure a reliable power-on reset. To ensure a correct reset, the RESET signal should reach at least $70 \%$ of the final value of VDD. Given that the RESET voltage and VDD rise exponententially, the above requirement is satisfied when the time constant $\tau$ of the RESET pulse is $>8$ times the time constant of $V_{D D}$. If $V_{D D}$ rises linearly, then a RESET time constant $>2$ times the rise time of $V_{D D}$ is required.
When a reset is completed (RESET goes LOW) before the oscillator has started up, program execution begins after the oscillator start-up time plus 1866 clock periods have elapsed (see Fig. 26). If the oscillator is started-up prior to the completion of RESET, then program execution begins 1866 clock periods after RESET goes LOW.
3. Figure 27 shows an external reset to the PCF84CXX during power-on. The external reset signal must remain HIGH until $V_{D D}$ has reached its minimum operating value corresponding to the selected oscillator frequency. When a reset is completed (RESET goes LOW) before the oscillator has started up, program execution begins after the oscillator start-up time plus 1866 clock periods have elapsed (see Fig. 28). If the oscillator is started-up prior to the completion of RESET, then program execution begins 1866 clock periods after RESET goes LOW.


Fig. 23 Power-on-reset configuration.
DEVELOPMENT DATA


Fig. 24 Timing of power-on-reset with fast rise time.

FUNCTIONAL DESCRIPTION (continued)


Fig. 25 Stretched power-on-reset with external components.


Fig. 26 Timing of power-on-reset with a slowly rising $\mathrm{V}_{\mathrm{DD}}$ and a stretched RESET pulse.


Fig. 27 External power-on-reset configuration.


Fig. 28 Timing of external power-on-reset.

## PCF84CXX <br> FAMILY

## INSTRUCTION SET

The PCF84CXX instruction set consists of over 80 one and two byte instructions and is identical to the MAB8400 instruction set. New instructions are added for STOP and IDLE mode. Program code efficiency is high because all RAM locations and all ROM locations on a 256 byte page require only a single byte address.
Table 7 gives the instruction set of the PCF84CXX. Table 6 shows the instruction map and Table 5 details the symbols and definition descriptions that are used.

Table 5 Symbols and definitions used in Table 7

| symbol | definition description |
| :--- | :--- |
| A | accumulator |
| addr | program memory address |
| Bb | bit designation $(b=0-7$ ) |
| RBS | register bank select |
| C | carry bit (bit CY) |
| CNT | event counter |
| Dx | mnemonic derivative register ( $x=0 \ldots$ 255) |
| data | 8-bit number or expression |
| I | interrupt |
| MB | memory bank |
| MBFF | memory bank flip-flop |
| P | mnemonic for 'in-page' operation |
| PC | program counter |
| Pp | port designation ( $p=0,1$ or 2$)$ |
| PSW | program status word |
| RB | register bank |
| Rr | register designation ( $r=0-7$ ) |
| Sn | serial $1 / 0$ register |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| T0, T1 | test 0 and 1 inputs |
| $\#$ | immediate data prefix |
| $@$ | indirect address prefix |
| $(X)$ | contents of $X$ |
| $((X))$ | contents of location addressed by $X$ |
| $\leftarrow$ | is replaced by |
| $\leftrightarrow$ | is exchanged with |

Table 6 PCF84CXX instruction map


## INSTRUCTION SET (continued)

Table 7 Instruction set

|  | mnemonic | opcode <br> (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ADD A, Rr ADD A, @Rr | $\begin{aligned} & 6^{*} \\ & 60 \\ & 61 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | Add register contents to $A$ <br> Add RAM data, addressed by Rr, to $A$ | $\begin{array}{ll} (A) \leftarrow(A)+(R r) & r=0-7 \\ (A) \leftarrow(A)+((R 0)) & \\ (A) \leftarrow(A)+((R 1)) & \end{array}$ |  | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
|  |  |  |  |  |  |  |  |
|  | ADD A, \#data ADDC A, Rr ADDC A, @Rr | $\begin{aligned} & 03 \text { data } \\ & 7^{*} \end{aligned}$ |  | Add immediate data to $A$ | $(A) \leftarrow(A)+$ data |  | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ |
|  |  |  | 1/1 | Add carry and register contents to $A$ Add carry and RAM data, addressed by Rr, to A | $\begin{aligned} & (A) \leftarrow(A)+(R r)+(C) \\ & (A) \leftarrow(A)+((R 0))+(C) \\ & (A) \leftarrow(A)+((R 1))+(C) \end{aligned}$ | $r=0-7$ |  |
|  |  | 70 | 1/1 |  |  |  |  |
|  |  | 71 |  |  |  |  |  |
|  |  |  |  |  |  |  | 1 |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

DEVELOPMENT DATA

| $\begin{array}{\|l\|} \hline \dot{\mathrm{L}} \\ \underline{0} \end{array}$ | RLC A | F7 | 1/1 | rotate A left through carry | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow A_{n} \\ & \left(A_{0}\right) \leftarrow(C),(C) \leftarrow\left(A_{7}\right) \end{aligned}$ | $\mathrm{n}=0-6$ | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \underset{\sim}{x} \\ & \underset{y}{c} \end{aligned}$ | RR A | 77 | 1/1 | rotate A right | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow\left(A_{0}\right) \end{aligned}$ | $\mathrm{n}=0-6$ |  |
| ${ }_{5}^{5}$ | RRC A | 67 | 1/1 | rotate A right through carry | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow(C),(C) \leftarrow\left(A_{0}\right) \end{aligned}$ | $n=0-6$ | 2 |
| $\begin{array}{\|} \overline{3} \\ 0 \\ \hline \end{array}$ | DA A SWAP A | $\begin{aligned} & 57 \\ & 47 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | decimal adjust $A$ swap nibbles of $A$ | $\left(\mathrm{A}_{4-7}\right) \leftrightarrow\left(\mathrm{A}_{0-3}\right)$ |  | 2 |
|  | MOV A, Rr | F* | 1/1 | move register contents to $A$ | $(\mathrm{A}) \leftarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | MOV A, @Rr | $\begin{array}{\|l\|} \hline \text { F0 } \\ \text { F1 } \end{array}$ | 1/1 | move RAM data, addressed by Rr, to A | $\begin{aligned} & (A) \leftarrow((R 0)) \\ & (A) \leftarrow((R 1)) \end{aligned}$ |  |  |
|  | MOV A, \#data | 23 data | 2/2 | move immediate data to $A$ | $(\mathrm{A}) \leftarrow$ data |  |  |
|  | MOV Rr, A | A* | 1/1 | move accumulator contents to register | $(\operatorname{Rr}) \leftarrow(A)$ | $r=0-7$ |  |
|  | MOV @Rr, A | $\begin{array}{\|l\|} \text { AO } \\ \text { A1 } \end{array}$ | 1/1 | move accumulator contents to RAM location addressed by Rr | $\begin{aligned} & ((R O)) \leftarrow(A) \\ & ((R 1)) \leftarrow(A) \end{aligned}$ |  |  |
|  | MOV Rr, \#data | B* data | 2/2 | move immediate data to Rr | $(\mathrm{Rr})<$ data |  |  |
|  | MOV @Rr, \#data | B0 data B1 data | 2/2 | move immediate data to RAM location addressed by Rr | $\begin{aligned} & ((\mathrm{RO})) \leftarrow \text { data } \\ & ((\mathrm{R} 1)) \leftarrow \text { data } \end{aligned}$ |  |  |
|  | XCH A, Rr | 2* | 1/1 | exchange accumulator contents with Rr | $(\mathrm{A}) \leftrightarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | XCH A, @Rr | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | 1/1 | exchange accumulator contents with RAM data addressed by Rr | $\begin{aligned} & (A) \leftrightarrow((R 0)) \\ & (A) \leftrightarrow((R 1)) \end{aligned}$ |  |  |
|  | XCHD A, @Rr | $\begin{array}{\|l\|} 30 \\ 31 \end{array}$ | 1/1 | exchange lower nibbles of A and RAM data addressed by Rr | $\begin{aligned} & \left(\mathrm{A}_{0}-3\right) \leftrightarrow\left(\left(\mathrm{R} 0_{0-3}\right)\right) \\ & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 1_{0-3}\right)\right) \end{aligned}$ |  |  |
|  | MOV A, PSW | C7 | 1/1 | move PSW contents to accumulator | ( A$) \leftarrow$ (PSW) |  |  |
|  | MOV PSW, A | D7 | 1/1 | move accumulator bit 3 to $\mathrm{PSW}_{3}$ | $\left(\mathrm{PSW}_{3}\right) \leftarrow\left(\mathrm{A}_{3}\right)$ |  | 3 |
|  | MOVP A, @A | A3 | 1/2 | move indirectly addressed data in current page to $A$. | $\left(\mathrm{PC}_{0-7}\right) \leftarrow(\mathrm{A}),(\mathrm{A}) \leftarrow((\mathrm{PC}))$ |  |  |
| O | CLR C | 97 | 1/1 | clear carry bit | (C) $\leftarrow 0$ |  | 2 |
| 4 | CPL C | A7 | 1/1 | complement carry bit | (C) $\leftarrow$ NOT (C) |  | 2 |

INSTRUCTION SET (continued) November 1986


DEVELOPMENT DATA

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline  \& \begin{tabular}{l}
MOV A, T \\
MOV T, A \\
STRT CNT \\
STRT T \\
STOP TCNT \\
EN TCNTI \\
DIS TCNTI
\end{tabular} \& \[
\begin{aligned}
\& 42 \\
\& 62 \\
\& 45 \\
\& 55 \\
\& 65 \\
\& 25 \\
\& 35
\end{aligned}
\] \& \[
\begin{aligned}
\& \hline 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1
\end{aligned}
\] \& \begin{tabular}{l}
move timer/event counter contents to accumulator \\
move accumulator contents to timer/event counter \\
start event counter \\
start timer \\
stop timer/event counter \\
enable timer/event counter interrupt \\
disable timer/event counter interrupt
\end{tabular} \& \[
\begin{aligned}
\& (A) \leftarrow(T) \\
\& (T) \leftarrow(A)
\end{aligned}
\] \& \\
\hline \[
\begin{aligned}
\& 1 \\
\& 0 \\
\& \stackrel{y}{x} \\
\& 2 \\
\& 0 \\
\& 0
\end{aligned}
\] \& \begin{tabular}{l}
EN I \\
DIS I \\
SEL RBO \\
SEL RB1 \\
SEL MBO \\
SEL MB1 \\
SEL MB2 \\
SEL MB3 \\
STOP \\
IDLE
\end{tabular} \& \[
\begin{aligned}
\& \text { O5 } \\
\& 15 \\
\& \text { C5 } \\
\& \text { D5 } \\
\& \text { E5 } \\
\& \text { F5 } \\
\& \text { A5 } \\
\& \text { B5 } \\
\& 22 \\
\& \text { }
\end{aligned}
\] \& \[
\begin{aligned}
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1 \\
\& 1 / 1
\end{aligned}
\] \& enable external interrupt disable external interrupt select register bank 0 select register bank 1 select program memory bank 0 select program memory bank 1 select program memory bank 2 select program memory bank 3 enter STOP mode enter IDLE mode \& \[
\begin{aligned}
\& (\text { RBS }) \leftarrow 0 \\
\& (\text { RBS }) \leftarrow 1 \\
\& (\text { MBFFO }) \leftarrow 0,(\text { MBFF1 }) \leftarrow 0 \\
\& (\text { MBFF0 }) \leftarrow 1,(\text { MBFF1 }) \leftarrow 0 \\
\& (\text { MBFFO }) \leftarrow 0,(\text { MBFF1 }) \leftarrow 1 \\
\& (\text { MBFF0 }) \leftarrow 1,(\text { MBFF1 }) \leftarrow 1
\end{aligned}
\] \& 5 \\
\hline  \& \begin{tabular}{l}
CALL addr \\
RET \\
RETR
\end{tabular} \& \begin{tabular}{l}
- 4 address \\
83 \\
93
\end{tabular} \& \begin{tabular}{l}
2/2 \\
\(1 / 2\) \\
\(1 / 2\)
\end{tabular} \& \begin{tabular}{l}
jump to subroutine \\
return from subroutine \\
return from interrupt and restore bits 4, 6, 7 of PSW
\end{tabular} \& \[
\begin{aligned}
\& ((\mathrm{SP})) \leftarrow(\mathrm{PC}),\left(\mathrm{PSW}_{4}, 6,7\right) \\
\& (\mathrm{SP}) \leftarrow(\mathrm{SP})+1 \\
\& \left(\mathrm{PC}_{8}-10\right) \leftarrow \text { addr } 8-10 \\
\& \left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addro-7 } \\
\& \left(\mathrm{PC}_{11-12)}\right) \leftarrow \mathrm{MBFF} 0-1 \\
\& (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\
\& (\mathrm{PC}) \leftarrow(\mathrm{SP})) \\
\& (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\
\& \left(\mathrm{PSW}_{4,6}, 7\right)+(\mathrm{PC}) \leftarrow((\mathrm{SP}))
\end{aligned}
\] \& 6

6
6 <br>
\hline
\end{tabular}

INSTRUCTION SET (continued)


## DEVELOPMENT DATA

|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MOVA, $S_{n}$ <br> MOV $S_{n}, A$ <br> MOV $S_{n}$, \#data <br> EN S! <br> DIS SI | OC <br> OD <br> 3C <br> 3D <br> 3E <br> 9C data <br> 9D data <br> $9 E$ data <br> 85 <br> 95 | 1/2 <br> $1 / 2$ <br> 2/2 <br> 1/1 <br> 1/1 | move serial I/O register contents to accumulator <br> move accumulator contents to serial I/O register <br> move immediate data to serial I/O register <br> enable serial !/O interrupt disable serial I/O interrupt | $\begin{aligned} & (A) \leftarrow(S 0) \\ & (A) \leftarrow(S 1) \\ & (S 0) \leftarrow(A) \\ & (S 1) \leftarrow(A) \\ & (S 2) \leftarrow(A) \\ & (S 0) \leftarrow \text { data } \\ & (S 1) \leftarrow \text { data } \\ & (S 2) \leftarrow \text { data } \end{aligned}$ | 9 |
|  | NOP | 00 | 1/1 | no operation |  |  |

Notes to Table 8

1. PSW CY, AC
affected
2. PSW RBS
affected
3. PSW CY affected
4. $\mathrm{PSW} \mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{7}$ affected
5. PSW PS affected
6. $(A)=0000 \mathrm{P} 23, \mathrm{P} 22, \mathrm{P} 21, \mathrm{P} 20$.
7. Execution of JTF and JNTF instructions resets the Timer Flag (TF).
8. Instructions for PCF84C00 only.

* : 8, 9, A, B, C, D, E, F
- : 0, 2, 4, 6, 8, A, C, E

9. (S1) has a different meaning for read and write operation, see serial I/O interface.

A : $1,3,5,7,9, B, D, F$

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage (pin 28)
All input voltages
D.C. current into any input or output

Total power dissipation (see note)
DIL-28 (SOT-177)
SO-28 (SOT-136A)
Storage temperature range
Operating ambient temperature range
Operating junction temperature

| $V_{\text {DD }}$ | $-0,8$ to +8 V |
| :---: | :---: |
| $V_{1}$ | $-0,5$ to $V_{D D}+0,5 \vee$ |
| $\pm 11 . \pm 10$ | max. 10 mA |
| $P_{\text {tot }}$ | max. $\quad 500 \mathrm{~mW}$ |
| $P_{\text {tot }}$ | max. 1 W |
| $\mathrm{P}_{\text {tot }}$ | max. $0,6 \mathrm{~W}$ |
| $\mathrm{T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |
| Tamb | -40 to $+85{ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{j}}$ | max. $125{ }^{\circ} \mathrm{C}$ |

## HANDLING

Inputs and outputs are protected against electrostatic discharge in normal handling. However, to be totally safe, it is desirable to take normal precautions appropriate to handling MOS devices (see 'Handling MOS devices').

## Note

Thermal resistance (junction to ambient)
for SOT-117D
for SOT-135A
for SOT-136A

| $R_{\text {th } j-a}$ | max. | $120 \mathrm{~K} / \mathrm{W}$ |
| :--- | :--- | ---: |
| $R_{\text {th } j-a}$ | max. | $60 \mathrm{~K} / \mathrm{W}$ |
| $R_{\text {th } j-a}$ | max. | $150 \mathrm{~K} / \mathrm{W}$ |

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $5,5 \mathrm{~V}$; $\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$; $\mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$; unless otherwise specified.

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage operating (see Fig. 33) | $V_{\text {DD }}$ | 2,5 | - | 5,5 | V |
| Supply current operating (see Fig. 34; not valid for PCF84C00) at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \mathrm{f} \mathrm{XTAL}=10 \mathrm{MHz}$ at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \mathrm{f} X \mathrm{TAL}=6 \mathrm{MHz}$ at $V_{D D}=3 \mathrm{~V} ; \mathrm{f}_{\mathrm{XTAL}}=3,58 \mathrm{MHz}$ |  |  |  |  |  |
|  | IDD | - | 1,6 | 3,2 | mA |
|  | IDD | - | 1 | 2 | mA |
|  | IDD | - | 0,3 | 0,6 | mA |
|  | IDD | - | 0,8 | 1,6 | mA |
|  | IDD | - | 0,5 | 1 | mA |
|  | 1 DD | -- | 0,15 | 0,4 | mA |
| $\begin{aligned} & \text { STOP mode (see Fig. } 41 \text { and note 1) } \\ & \text { at } \mathrm{V}_{\mathrm{DD}}=2,5 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=255^{\circ} \mathrm{C} \\ & \text { at } \mathrm{V}_{\mathrm{DD}}=2,5 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=85^{\circ} \mathrm{C} \end{aligned}$ | $1{ }^{1}$ | - | 1,2 | 2,5 | $\mu \mathrm{A}$ |
|  | ${ }^{\text {I D D }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Inputs |  |  |  |  |  |
| Input voltage LOW | $\mathrm{V}_{\text {IL }}$ | 0 | - | 0,3V | V |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | $0,7 V_{\text {DD }}$ | - | VDD | V |
| Input leakage current at $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\mathrm{DD}}$ | $\pm \mathrm{IL}$ | - | - | 1 | $\mu \mathrm{A}$ |
| Outputs |  |  |  |  |  |
| Output voltage LOW at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}} ; \\| \mathrm{O} \mid<1 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,05 | V |
| Output sink current LOW $\text { at } \mathrm{V} D D=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$ |  |  |  |  |  |
| except P23/SDA, SCLK (see Fig. 37) and port 1 | IOL | 1,6 | 3 | - | mA |
| P23/SDA, SCLK (see Fig. 38) | IOL | 3 | - | - | mA |
| P10-P17 (not PCF84C00) at $\mathrm{V}_{\mathrm{OL}}=1 \mathrm{~V}$ | IOL | 10 | - | - | mA |
| Pull-up output source current HIGH (see Fig. 39) at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=0,7 V_{D D}$ | $-\mathrm{IOH}$ | 40 | - | - | $\mu \mathrm{A}$ |
| at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{O}}=\mathrm{V}_{S S}$ | $-\mathrm{IOH}$ | - | - | 400 | $\mu \mathrm{A}$ |
| Push-pull output source current HIGH $\text { at } V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=V_{D D}-0,4 \mathrm{~V}$ | $-\mathrm{OH}$ | 1,6 | 3 | - | mA |

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $5,5 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85{ }^{\circ} \mathrm{C}$. All voltages with respect to $\mathrm{V}_{\mathrm{SS}}$ unless otherwise specified.

| parameter | symbol | min. | typ. | max. | unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
| PCF84C00/non-standard pins (note 12) |  |  |  |  |  |
| Control pulse width (note 1) | tCC | 900 | - | - | ns |
| Address to PSEN set-up (note 2) | tAS | 150 | - | - | ns |
| Data to PSEN set-up (note 3) | tDS | 260 | - | - | ns |
| Data hold time | tDR | 0 | - | - | ns |
| Address to data-in (note 4) | tAD | - | - | 790 | ns |
| Rise time all outputs (note 5) | tR | - | 30 | - | ns |
| Fall time all outputs (note 5) | tF | - | 30 | - | ns |
| Data out to DXWR set-up | tSDO | tbf | 2 | - | ns |
| Data out to DXWR hold (note 6) | thDO | 100 | - | - | ns |
| Time from DXALE to PSEN (note 7) | tSLPH | 150 | - | - | ns |
| Data-in to DXRD LOW to HIGH set-up (note 8) | tDS1 | 250 | - | - | ns |
| Data hold time after DXRD LOW to HIGH | tDR1 | 0 | - | - | ns |
| HIGH time of DXALE (note 9) | tDXALE | 450 | - | - | ns |
| LOW time of DXRD (note 10) | tDXRD | 600 | - | - | ns |
| LOW time of DXWR (note 11) | tDXWR | 300 | - | - | ns |

## Notes to characteristics

$1 \mathrm{CP}=1$ clock pulse $=100 \mathrm{~ns}$ at $\mathrm{f} \mathrm{XTAL}=10 \mathrm{MHz} ; 1$ time slot $=3 \mathrm{CP}$

1. $t_{C C}=9 \mathrm{CP}$
2. $\mathrm{t}_{\mathrm{AS}}=1,5 \mathrm{CP}$
3. $\mathrm{t} O \mathrm{~S}=2 \mathrm{CP}+\mathrm{t}_{\mathrm{CPS}} 1$
4. $\mathrm{t} A \mathrm{~A}=8,5 \mathrm{CP}-\mathrm{t} \mathrm{CPS} 1$
5. $\mathrm{CL}=50 \mathrm{pF}$
6. $\mathrm{tHDO}=1 \mathrm{CP}$
7. tSLPH $=1,5 \mathrm{CP}$
8. ${ }^{\text {DDS }}=2,5 \mathrm{CP}$
9. $\mathrm{t}_{\mathrm{DXALE}}=4,5 \mathrm{CP}$
10. $\mathrm{t}_{\mathrm{DXRD}}=6 \mathrm{CP}$
11. $t_{D X W R}=3 \mathrm{CP}$
12. All values for the PCF84C00 are preliminary.


Fig. 29 Instruction MOV Dx,A timing (PCF84C00T only).


Fig. 30 Instruction MOV A,Dx timing (PCF84C00T only).

## A.C. CHARACTERISTICS (continued)



Fig. 31 Timing external memory (PCF84C00T only).


Fig. 32 ANL/ORL derivitive interface timing (PCF84C00T only).

(1) clock frequency $=200 \mathrm{kHz}$
(2) clock frequency $=1 \mathrm{MHz}$
(3) clock frequency $=3 \mathrm{MHz}$
(4) clock frequency $=10 \mathrm{MHz}$

Fig. 33 Maximum clock frequency ( $f$ XTAL) as a function of the supply voltage ( $\mathrm{VDD}_{\mathrm{DD}}$ ).

(1) clock frequency $=10 \mathrm{MHz}$
(2) clock frequency $=6 \mathrm{MHz}$
(3) clock frequency $=3,58 \mathrm{MHz}$

Fig. 35 Maximum supply current (IDD) in IDLE mode as a function of the supply voltage (VDD).

(1) clock frequency $=10 \mathrm{MHz}$
(2) clock frequency $=6 \mathrm{MHz}$
(3) clock frequency $=3,58 \mathrm{MHz}$

Fig. 34 Maximum supply current (IDD) in operating mode as a function of the supply voltage.


Fig. 36 Typical supply current during IDLE mode as a function of frequency at $V_{D D}=3 V$ and $V_{D D}=5 \mathrm{~V}$.
A.C. CHARACTERISTICS (continued)


Fig. 37 Output sink current LOW (IOL), except outputs P23/SDA and SCLK, as a function of supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$.

(1) $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{SS}}$
(2) $\mathrm{V}_{\mathrm{O}}=0,7 \mathrm{~V}_{\mathrm{DD}}$

Fig. 39 Output source current $\mathrm{HIGH}\left(-\mathrm{I}_{\mathrm{OH}}\right)$ as a function of supply voltage ( $V_{D D}$ ).


Fig. 38 Output current LOW (IOL), outputs P23/SDA and SCLK, as a function of supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$.


Fig. 40 Typical supply current during operating mode as a function of frequency at $V_{D D}=3 \mathrm{~V}$ and $V_{D D}=5 \mathrm{~V}$.

Table 8 Input timing shown in figure 42.

(1) $\mathrm{T}_{\mathrm{amb}}=85^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$

DEVELOPMENT DATA
Fig. 41 Typical supply current (IDD) in STOP mode as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

| symbol | timing |
| :---: | :---: |
| ${ }_{\text {t }}$ BUF | $\geqslant 14 \mathrm{t} \times$ TAL |
| ${ }^{\text {thD }}$; STA | $\geqslant 14 \mathrm{t} \times$ TAL |
| ${ }_{\text {t HIGH }}$ | $\geqslant 17 \mathrm{t} \times$ TAL |
| tıow | $\geqslant 17 \mathrm{t} \times$ TAL |
| ${ }^{\text {t Su;STO }}$ | $\geqslant 14 \mathrm{t} \times$ TAL |
| thD;DAT | $>0$ |
| ${ }^{\text {t }}$ SU;DAT | $\geqslant 250 \mathrm{~ns}$ |
| ${ }^{\text {t }}$ RD | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{t} \mathrm{RC}$ | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ FD | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }_{\text {t }}{ }_{\text {F }}$ | $\leqslant 0,3 \mu \mathrm{~s}$ |

## Notes to Table 8

${ }^{t} \times T A L=$ one period of the XTAL input frequency ( f XTAL)
$=167 \mathrm{~ns}$ for $\mathrm{f}_{\mathrm{XTAL}}=6 \mathrm{MHz}$.
These figures apply to all modes.


Fig. 42 PCF84CXX timing requirements for the P23 and SCLK input signals.

Purchase of Philips' $\left.\right|^{2} \mathrm{C}$ components conveys a license under the Philips $I^{2} \mathrm{C}$ patent to use the components in the $1^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specifications defined
 by Philips.
A.C. CHARACTERISTICS (continued)


Fig. 43 PCF84CXX timing requirements for the P23 and SCLK output signals.
Table 9 Output timing shown in Figure 43

| symbol | timing |  |
| :---: | :---: | :---: |
|  | normal mode (ASC in S2 = 0) | low-speed mode (ASC in S2 = 1) |
| thD; STA | 1/2 (DF + 9) $\mathrm{t} \times$ TAL | $3 / 4$ (DF + 9) tXTAL |
| ${ }^{\text {thigh }}$ | ½ (DF) ${ }^{1}$ ¢ $\times$ TAL | $3 / 4$ (DF) t ${ }^{\text {t }}$ (TAL |
| ${ }^{\text {t LOW }}$ | ½ (DF) ${ }^{\text {t }}$ XTAL | $1 / 4$ (DF) ${ }^{\text {t }}$ XTAL |
| ${ }^{\text {t SU }}$; STO | ½ (DF-3) t XTAL | 1/4 (DF - 3) txTAL |
| ${ }^{\text {thD }}$; DAT <br> (slave transmitter |  |  |
| any DF | $\begin{aligned} & \geqslant 9 \mathrm{t} \times \text { TAL } \\ & \leqslant 12 \mathrm{t} \times \text { TAL } \end{aligned}$ | $\begin{aligned} & \geqslant 9 \mathrm{t} \times \text { TAL } \\ & \leqslant 12 \mathrm{t} \times \mathrm{TAL} \end{aligned}$ |
| ${ }^{t} H D ; D A T$ <br> (master transmitter) for $D F \leqslant 51$ |  |  |
|  | $\geqslant 9 t_{\text {XTAL }}$ | - |
|  | $\leqslant 12 \mathrm{t} \times$ TAL | - |
| for DF $\leqslant 99$ |  | $\geqslant 9 \mathrm{t}$ XTAL |
|  | - | $\leqslant 12 \mathrm{t}$ XTAL |
| ${ }^{\text {t }}$ SU; DAT (master transmitter) for DF > 51 |  |  |
|  | $\geqslant 15 t \times$ TAL | - |
|  | $\leqslant 24{ }^{\text {¢ }}$ XTAL | - |
| for DF > 99 |  | $\geqslant 15 \mathrm{t} \times$ TAL |
| ${ }^{t} A C$ | $\geqslant 9 \mathrm{txTAL}$ | $\geqslant 9 \mathrm{txTAL}$ |
|  | $\leqslant 12 \mathrm{tXTAL}$ | $\leqslant 12 \mathrm{t} \times$ TAL |
| ${ }^{\text {t F }}$, tFC | $\begin{aligned} & \leqslant 100 \mathrm{~ns} \\ & \text { at } C_{b}=400 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & \leqslant 100 \mathrm{~ns} \\ & \text { at } C_{b}=400 \mathrm{pF} \end{aligned}$ |

## Notes to Table 9

${ }^{\text {t }}$ XTAL $=$ one period of the XTAL input frequency ( $\mathrm{f}_{\mathrm{XTAL}}$ )
$=167 \mathrm{~ns}$ for $\mathrm{f}_{\mathrm{XTAL}}=6 \mathrm{MHz}$.
DF = divisor (see Table 2 Serial I/O section).
$C_{b} \quad=$ the maximum bus capacitance for each line.


Fig. 44 Block diagram of the external $D x$ register interface. The Dx interface can only be used with PCF84C00T.

PCF84C85

## SINGLE-CHIP 8-BIT MICROCONTROLLER

## DESCRIPTION

The PCF84C85 microcontroller is manufactured in CMOS, and is designed to be an efficient controller as well as an arithmetic processor. The instruction set is based on that of the MAB8048 and is software compatible with the PCF84CXX family. The PCF84C85 has two additional derivative ports and the microcontroller has bit handling abilities and facilities for both binary and BCD arithmetic.
For detailed information on the PCF84CXX see the "Single-chip 8-bit Microcontrollers" user manual.

## Features

- 8-bit CPU, ROM, RAM, I/O in a single 40-lead DIL or mini-pack package
- 8 K ROM
- 256 RAM bytes
- 32 quasi-bidirectional I/O port lines
- Two test inputs: one of which is also the external interrupt input
- Single-level vectored interrupts: external, timer/event counter, serial I/O
- Serial I/O which can be used in single or multi-master systems (serial I/O data via an existing port line and clock via a dedicated line)
- 8-bit programmable timer/event counter
- Clock frequency 100 kHz to 10 MHz
- Over 80 instructions (based on MAB8048) all of 1 or 2 cycles
- Single supply voltage from $2,5 \mathrm{~V}$ to $5,5 \mathrm{~V}$
- STOP and IDLE mode
- Power-on-reset circuit
- Operating temperature range: -40 to $+85{ }^{\circ} \mathrm{C}$


## PACKAGE OUTLINES



Fig. 1 Block diagram.

PINNING


Fig. 2 Pinning diagram.

## PIN DESIGNATION

38 SCLK Clock: bidirectional clock for serial I/O.
$1 \overline{\mathrm{INT} / \mathrm{TO}}$

39 T1

18 XTAL 1

19 XTAL 2
21 RESET

Interrupt/Test 0: external interrupt input (sensitive to negative-going edge)/test input pin; when used as a test input directly tested by conditional branch instructions JTO and JNTO.
Test 1: test input pin, directly tested by conditional branch instructions JT1 and JNT1. T1 also functions as an input to the 8 -bit timer/event counter, using the STRT CNT instruction.
XTAL 1 Crystal input: connection to timing component (crystal) which determines the frequency of the internal oscillator; also the input for an external clock source.
Connection to the other side of the timing component.
Reset input: used to initialize the processor (active HIGH), or output of power-on-reset circuit.

PIN DESIGNATION (continued)

| 2-9 | PO.0-PO.7 | Port 0: 8-bit quasi-bidirectional I/O port. |
| :--- | :--- | :--- |
| 10-17 | P1.0-P1.7 | Port 1: 8-bit quasi-bidirectional I/O port. |
| 37 | P23/SDA | Port 2: 1-bit quasi-bidirectional I/O port or serial data input/output in <br> serial I/O mode. |
| 22-29 | DPO.0-DPO.7 | Derivitive port 0: $\varepsilon$-bit quasi-bidirectional I/O port. |
| $30-36$ | DP1.0-DP1.6 | Derivitive port 1: 7-bit quasi-bidirectional I/O port. |
| 20 | VSS | Ground: circuit earth potentional. |
| 40 | VDD | Power supply: $2,5 \mathrm{~V}$ to $5,5 \mathrm{~V}$. |

## FUNCTIONAL DESCRIPTION

## Program memory

The program memory consists of 8 K bytes, in a read-only memory (ROM). Each location is directly addressable by the program counter. The memory is mask-programmed at the factory. Figure 3 shows the program memory map.

Four program memory locations are of special importance:

- Location 0; contains the first instruction to be executed after the processor is initialized (RESET),
- Location 3; contains the first byte of an external interrupt service subroutine;
- Location 5; contains the first byte of a serial I/O interrupt service subroutine.
- Location 7; contains the first byte of a timer/event counter interrupt service subroutine.

Program memory is arranged in banks of 2 K bytes, which are selected by SEL MB instructions. The program memory is further divided into location 'pages', each of 256 bytes. This latter division applies only for conditional branches. Memory bank boundaries can be crossed only by using unconditional branch instructions after the appropriate memory bank has been selected. A CALL instruction can transfer control to a subroutine on any 'page'; RET and RETR instructions can transfer control from a subroutine back to the main program.

## Data memory

Data memory consists of 256 bytes, random-access data memory (RAM). All locations are indirectly addressable using RAM pointer registers; up to 16 designated locations are directly addressable. Memory also includes an 8 -level program counter stack addressed by a 3-bit stack pointer. Figure 4 shows the data memory map.

## Working registers

Locations 0 to 7 are designated as working registers, directly addressable by the direct register instructions. Ease of addressing, and a minimum requirement of instruction bytes to manipulate their contents, makes these locations suitable for storing frequently addressed intermediate results. This bank of registers can be selected by the SEL RBO instruction.
Executing the select register bank instruction SEL RB1, designates locations 24 to 31 as working registers, instead of locations 0 to 7 , and these are then directly addressable. This second bank of working registers may be used as an extension of the first or reserved for use during interrupt service subroutines saving the first bank for use in the main program. If the second bank is not used, locations 24 to 31 may serve as general purpose RAM.
The first locations of each bank contain the RAM pointer registers R0, R1, RO' and R1', which indirectly address all RAM locations.
All RAM locations make efficient program loop counters when used with the decrement register and test instruction DJNZ.


Fig. 3 Program memory map.


Fig. 4 Data memory map.

## Program counter stack

Locations 8 to 23 may be designated as an 8 -level program counter stack ( 2 locations per level), or as general purpose RAM. The program counter stack (Fig.5) enables the processor to keep track of the return addresses and status generated by interrupts or CALL instructions by storing the contents of the program counter prior to servicing the subroutine. A 3-bit stack pointer determines which of the eight register pairs of the program counter stack will be loaded with next generated return address.
The stack pointer, when initialized to 000 by RESET, points to RAM locations 8 and 9 . On the first subroutine CALL or interrupt, the contents of the program counter and bits 4,6 and 7 of the program status word (PSW) are transferred to locations 8 and 9 . The stack pointer increments by one and points to locations 10 and 11 ready for another CALL. Because an address may be up to 13 bits long, two bytes must be used to store each address.
At the end of a subroutine, which is signalled by a return instruction (RET or RETR), the stack pointer decrements by one and the contents of the register pair on top of the stack are transferred to the program counter. The saved PSW bits are transferred to the PSW only by the RETR instruction.

If not all 8 levels of subroutine and interrupt nesting are used, the unused portion of the stack may be used as any other indirectly addressable RAM locations.
Nesting of subroutines within subroutines can continue up to 8 times without overflowing the stack. If overflow does occur the deepest address stored (locations 8 and 9 ) will be overwritten and iost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111.

## PCF84C85

## FUNCTIONAL DESCRIPTION (continued)

The value of the saved contents of the program counter is different for an interrupt CALL compared to a normal CALL to subroutine. With an interrupt CALL, the program counter return address is saved; with a subroutine CALL, the saved program counter value is one less than the program counter return address.


Fig. 5 Program counter stack.

## IDLE and STOP modes

## IDLE mode

When the microcontroller enters the IDLE mode via the IDLE instruction ( 01 H ) the oscillator, timer/counter and serial I/O are kept running. The microcontroller exits from the IDLE mode by one of three interrupts if they are enabled or by activating a RESET. If the interrupt is not enabled the processor will remain in the IDLE mode. An active signal on the RESET pin restarts the microcontroller and a normal RESET sequence is executed (see Fig. 6).


Fig. 6 Exit from IDLE mode via a RESET.

An active signal coming from an enabled interrupt causes the execution of the normal interrupt routine since normal interrupt scanning is still being carried out. A HIGH-to-LOW transition on the external interrupt pin (IINT/TO) reactivates the microcontroller. A LOW level applied to $\overline{\mathrm{INT}} / \mathrm{TO}$ will reactivate the microcontroller only in the STOP mode. Thus, if $\overline{I N T} / T O$ was LOW before the microcontroller entered the IDLE mode, it must go HIGH before the microcontroller can be reactivated (see Fig. 7).


Fig. 7 Exit from IDLE mode via an interrupt.
Wake-up from the IDLE mode is ensured when $\overline{I N T} / T O$ is HIGH for at least 4 CP (clock periods) followed by a LOW for 7 CP . After the initial forced CALL $(03 \mathrm{H})$ operation $(60 \mathrm{CP})$ the program continues with the external interrupt service routine.

## STOP mode

The microcontroller enters the STOP mode by the STOP instruction ( 22 H ). The oscillator is switched off. The internal status of the CPU, RAM contents and the state of I/O ports are not affected. The microcontroller can be brought-out of the STOP mode by an active signal at the external interrupt input or by an external RESET signal. When one of these two signals is applied an internal delay of 1866 CP is provided to ensure that all internal clocks are operating correctly before restart (see Fig. 8). Note; the start-up time of a crystal oscillator is measured in milliseconds, and the 1866 CP count begins after this start-up time.
If the microcontroller exits from the STOP mode by activating RESET, a normal RESET sequence is executed.


Fig. 8 Entering and exiting the STOP mode.

## FUNCTIONAL DESCRIPTION (continued)

If the microcontroller exits the STOP mode by pulling the external interrupt input pin LOW, an interrupt sequence is executed only if the external interrupt is enabled. In this event the microcontroller resumes the normal program sequence after returning from the interrupt routine, as in the normal mode. If the interrupt is not enabled, it continues the normal program sequence, executing the instruction following the STOP instruction.
The microcontroller is restarted by a LOW level applied at the $\overline{\mathrm{INT}} / \mathrm{TO}$ pin, and not by a HIGH-to-LOW transition as in a normal interrupt mechanism.
Note: when leaving the STOP mode with an interrupt, a further instruction in the main program series is executed prior to entering the interrupt routine.
When the $\overline{\mathrm{INT}} / \mathrm{TO}$ level is active during the STOP instruction then no STOP is executed.
A LOW level on the external interrupt input of at least $1 \mu \mathrm{~s}$ will cause the microcontroller to exit the STOP mode.

## 1/O facilities

The PCF84C85 family has 32 I/O lines arranged as:

- Port 0 parallel port of 8 lines (P0.0 to P0.7)
- Port 1 parallel port of 8 lines (P1.0 to P1.7)
- Port 2 parallel port of 1 line (P2.0)
- D port 0 parallel port of 8 lines (DPO.0-DP0.7)
- D port 1 parallel port of 7 lines (DP1.0-DP1.6)
- SCLK $\quad 1^{2}$ C-bus serial clock line shared with parallel port line P2.3
- INT/TO external interrupt and test input. When used as a test input can be directly tested by conditional branch instructions JTO and JNTO
- T1 test input which can alter program sequences when tested by conditional jump instructions JT1 and JTN1. T1 also functions as an input to the 8 -bit timer/event counter.


## Parallel ports

All parallel ports can be used as outputs or inputs, their structure is quasi-bidirectional. Output data written to a port is latched and remains unchanged until rewritten. Input data is not latched and so must be present until read by an input instruction. input lines are fully CMOS compatible, output lines can drive one TTL or CMOS load.


Fig. 9 Shows the timing diagram for all ports using IN, OUTL, ANL and ORL instructions. For the OUTL instruction data changes on time slot 7 of cycle 1. For the MOV, ANL and ORL instructions, the ports change on time slot 7 of cycle 2 .

Fig. 10 shows the quasi-bidirectional I/O interface with push-pull output and switched pull-up current source. Each line is pulled up to VDD via a constant current source (TR4), which is enabled via TR3 whenever one of the two output latches contains a logic 1 . This current source is sufficient for a TTL HIGH level, yet can be pulled LOW by an external CMOS device, thus allowing the same pin to be used for both input and output.

When a logic 1 is written to the line for the first time ( $M Q=1, S Q=0$ ), TR2 is switched on for the duration of the internal write pulse (one oscillator period), to provide a fast transition from logic 0 to logic 1. Subsequent writing of a logic 1 to the port lines will not switch TR2 on. This prevents unnecessary current through external components connected to the port lines of the same port which might be in the input mode and also connected to ground.
When a logic 0 is written to the line, TR3 switches off the current source. Current sinking capability is provided by TR1, which is now switched on. When used as an input, a logic 1 must first be written to the line, otherwise TR1 will remain low impedance.
The PCF84C85 family offers the possibility to select individually 31 of the 32 parallel port pins (not P23), by the following mask options:
Option 1 - STANDARD PORT; quasi-bidirectional I/O with switched pull-up current source of $100 \mu \mathrm{~A}$ (typ.) and P-channel booster transistor TR2. TR2 is only active during 1 clock cycle (Fig. 10).
Option 2 - OPEN DRAIN; quasi-bidirectional I/O with only an N-channel open drain output. Application as an output requires connection of an external pull-up resistor (Fig. 11).
Option 3 - PUSH-PULL OUTPUT; drive capability of the output will be $1,6 \mathrm{~mA}(\mathrm{~min}$.) at $V_{D D}=5 \mathrm{~V}$ in both polarities. To avoid a large current flowing through the output transistors during the input mode, these push-pull pins must only be used as outputs (Fig. 12).


Fig. 10 Standard output with switched pull-up current source.

FUNCTIONAL DESCRIPTION (continued)


Fig. 11 Open drain output.


Fig. 12 Push-pull output.

## Serial I/O (SIO)

The PCF84C85 has an on-chip serial I/O interface.
Whereas a normal microcontroller must regularly monitor the serial data bus for the presence of data, the serial I/O interface detects, receives and converts the serial data stream into parallel format without interrupting the execution of the current program. An interrupt is sent to the PCF84C85 only when a complete byte is received. It then reads the data byte in one instruction. Likewise during transmission the serial I/O interface performs parallel to serial conversion and subsequent serial output of the data. The microcontroller is only interrupted in the execution of its programmed tasks when a complete byte has been transmitted.

The design of the PCF84C85 serial I/O system allows any number of devices from PCF8500 family (clips) to be connected via the two-line serial bus. The ability of any devices to communicate, without interrupting the operation of any other devices on the bus, is an outstanding attribute of the system. This is achieved by allocating a specific 7 -bit address to each device and providing a system whereby a device reacts only to a message prefixed with its own address or the 'general CALL' address. Address recognition is performed by the interface hardware so that operation of the microcontroller need only be interrupted when a valid address has been received. This saves significant processing time and memory space compared with a conventional microcontroller employing a software serial interface. When the addressing facility is not required, for instance in a system with only two microcontrollers, direct data transfer without addressing can be performed. In multi-master systems, an automatically invoked arbitration procedure prevents two or more devices from continuing simultaneous transmission.
In NORMAL (running) and IDLE mode, the serial I/O logic remains active; its internal system clock will be switched off when there is no activity on the serial bus.
After execution of the STOP instruction, the oscillator of the PCF84C85 is switched off. This means that the serial I/O logic will remain in the state it was at the occurance of the STOP instruction. To avoid "bus block" problems and to assure correct start-up of the bus after exit from the STOP mode, the user should disable the serial logic ( $E S O=0$ ) prior to the execution of the STOP instruction. This must be carried out only when the PCF84C85 has finished a serial data transfer.

## Serial I/O interface

Figure 13 shows the serial I/O interface. The clock line of the serial bus has exclusive use of pin 38 (SCLK) while the data line shares pin 37 (serial data) with the I/O line P23 of port 2. When the serial I/O is enabled, P23 is disabled as a parallel port line; (P23 and SCLK only open drain).
The microcontroller and interface communicate via the internal microcontroller bus and the Serial Interrupt Request line. Data and information controlling the operation of the interface are stored in four registers:

- Data shift register (SO)
- Serial I/O interface status word (S1)
- Serial clock control word (S2)
- Address register


## FUNCTIONAL DESCRIPTION (continued)

## Data shift register (SO)

Register SO converts serial data to parallel format and vice versa. A pending interrupt is generated only after a complete byte has been transmitted, or after a complete data byte, specific address or 'general CALL' address has been received. The most significant bit is transmitted first.
Serial I/O interface status word (S1)
Register S1 provides information concerning the state of the interface and stores information from the microcontroller. Bits 0 to 3 are duplicated: control bits in these positions can only be written by the microcontroller, while interface bits can only be read.

## MST and TRX (see Table 1)

These bits determine the operating mode of the serial I/O interface.
Table 1 Operating modes of the serial I/O interface

| MST | TRX | operating mode |
| :---: | :---: | :--- |
| 0 | 0 | slave receiver |
| 1 | 0 | master receiver |
| 0 | 1 | slave transmitter |
| 1 | 1 | master transmitter |

BB: Bus Busy.
This is the flag which indicates the status of the bus.
PIN: Pending Interrupt Not
PIN $={ }^{\prime} 0^{\prime}$ indicates the presence of a pending interrupt, which will cause a Serial Interrupt Request when the serial interrupt mechanism is enabled.

## ESO: Enable Serial output

The ESO flag enables/disables the serial I/O interface: ESO = ' 1 ' enables, $\mathrm{ESO}=$ ' 0 ' disables. ESO can only be written by software.
$\mathrm{BCO}, \mathrm{BC} 1$ and BC 2
Bits $B C 0, B C 1$ and $B C 2$ indicate the number of bits received or transmitted in a data stream. These bits can only be written by software.
AL: Arbitration Lost
The arbitration lost flag is set by hardware when the serial I/O interface, as master transmitter, loses a bus arbitration procedure.

## AAS: Addressed As Slave

This flag is set by hardware when the interface detects either its own specific address or the 'general CALL' address as the first byte of a transfer and the interface has been programmed to operate in the address recognition mode.

## ADO: Address Zero

This flag is set by hardware after detection of the 'general CALL' address when the interface is operating in the address recognition mode.

## LRB: Last Received Bit

This contains either the last data bit received or, for a transmitting device in the acknowledgement mode, the acknowledgement signal from the receiving device.
Bits AL, AAS, ADO and LRB can only be read by software.

Serial clock control word (S2)
Bits 0 to 4 of the clock control register S2 are used to set the frequency of the serial clock signal. When a 6 MHz crystal is used, the frequency of the serial clock can be varied between 154 kHz and 1 kHz (see Table 2). An asymmetrical clock with a HIGH-to-LOW ratio of 3:1 can be generated using bit 5 . The asymmetrical clock allows a microcontroller more time per clock period for sampling the data line, making the timing of this action less critical. Bit 6 can be used to activate the acknowledge mode of the serial I/O. S2 is a write only register.

## Address register

The address register contains the 7-bit address back-up latches and the bit (ALS) used to enable/disable the address recognition mode. The address register can be written using the MOV SO, A and MOV SO, \# data instructions, but only when ESO = ' 0 '.
Serial I/O interrupt logic
An EN SI instruction enables and a DIS SI instruction disables the interrupt logic. When the logic is enabled, a pending interrupt results in a serial I/O interrupt to the processor, causing a CALL to location 5 in the ROM. When disabled, the presence of an interrupt is still indicated by PIN in S1, allowing the interrupt to be serviced. However, vectored interrupt will not occur.

## PCF84C85

FUNCTIONAL DESCRIPTION (continued)
Table 2 SIO clock pulse frequency control when using 6 MHz crystal

| hexadecimal S20-S24 code | divisor | ${ }^{\mathrm{f}} \mathrm{XTAL}(6 \mathrm{MHz})$ ${ }^{\mathrm{f}} \mathrm{SCLK}(\mathrm{kHz})$ | $\mathrm{f}_{\mathrm{XTAL}}(10 \mathrm{MHz})$ fSCLK (kHz) |
| :---: | :---: | :---: | :---: |
| 0 | not allowed |  |  |
| 1 | 39 | *154 | *256 |
| 2 | 45 | *133 | *222 |
| 3 | 51 | *118 | *196 |
| 4 | 63 | 95 | *159 |
| 5 | 75 | 80 | *133 |
| 6 | 87 | 69 | *115 |
| 7 | 99 | 61 | *101 |
| 8 | 123 | 49 | 81 |
| 9 | 147 | 41 | 68 |
| A | 171 | 35 | 58 |
| B | 195 | 31 | 51 |
| C | 243 | 25 | 41 |
| D | 291 | 21 | 34 |
| E | 339 | 18 | 29 |
| F | 387 | 16 | 26 |
| 10 | 483 | 12 | 21 |
| 11 | 579 | 10 | 17 |
| 12 | 675 | 8,9 | 15 |
| 13 | 771 | 7,8 | 13,4 |
| 14 | 963 | 6,2 | 10,4 |
| 15 | 1155 | 5,2 | 8,7 |
| 16 | 1347 | 4,5 | 7,4 |
| 17 | 1539 | 3,9 | 6,5 |
| 18 | 1923 | 3,1 | 5,2 |
| 19 | 2307 | 2,6 | 4,3 |
| 1A | 2691 | 2,2 | 3,7 |
| 1B | 3075 | 2,0 | 3,3 |
| 1 C | 3843 | 1,6 | 2,6 |
| 1 D | 4611 | 1,3 | 2,2 |
| 1 E | 5379 | 1,1 | 1,9 |
| 1F | 6147 | 1,0 | 1,6 |

* Not permitted for $I^{2} \mathrm{C}$ operation; the maximum clock frequency in the $\mathrm{I}^{2} \mathrm{C}$ systems is 100 kHz .

DEVELOPMENT DATA


Fig． 13 Serial I／O interface．

## FUNCTIONAL DESCRIPTION (continued)

## Interrupts (see Fig. 14)

When the external interrupt is enabled, a HIGH-to-LOW transition on the $\overline{\mathrm{INT}} / \mathrm{TO}$ input initiates an external interrupt subroutine which causes a CALL to program memory location 3 following completion of the current instruction.
Serial I/O interrupt, when enabled, causes a CALL to location 5, and a timer/event counter overflow forces a CALL to location 7 when the timer interrupt is enabled.

When an interrupt subroutine starts, the contents of the program counter and bits 4,6 and 7 of the PSW have been saved in the program counter stack. Accumulator contents have to be saved by software. Interrupt acknowledgement can be carried out by software via port pins. All interrupt subroutines must reside in memory bank 0 .
Since the interrupt system is single level, once an interrupt is detected, all further interrupt requests are latched, but ignored, pending a RETR instruction to re-enable the interrupt input logic. After executing RETR, the program continues in the main part; this is independent of the occurance of a second interrupt during the running of the first routine. If 2 or 3 interrupts occur simultaneously, their priority is:

- (1) external
- (2) serial I/O
- (3) timer/event counter

An external interrupt can be generated by using the timer/counter in the event counter mode. The counter is first preset to (FFH), then EN TCNTI instruction is executed. A LOW-to-HIGH transition of the T1 input will then initiate an interrupt subroutine and cause a CALL to location 7.
On execution of a DIS I instruction, the PCF84C85 always clears the digital filter/latch and the External Interrupt Flag.

The Timer Flag (TF) is reset only when the JTF or JNTF instruction is executed or after RESET.
The Timer Interrupt Flag is set when timer overflow occurs, only if the timer interrupt is enabled.
The microcontroller will exit the IDLE mode when any one of the following three interrupts is enabled:

- External
- Serial I/O
- Timer/event counter

There is no internal pull-up or pull-down device connected to the external interrupt input (pin 1). If required pin 1 must be externally connected to a resistor ( $R \leqslant 100 \mathrm{k} \Omega$ ). When the external interrupt is not used pin 1 must be connected to VDD.

Improvements to interrupt and timer logic with respect to the MAB8400 family
For detailed information see the user manual "Single-chip 8-bit Microcontrollers".
DEVELOPMENT DATA


Fig. 14 Interrupt logic.

## Notes to figure 14

1. $\overline{\mathrm{INT}} / \mathrm{TO}$ negative edge is always latched in the digital filter/latch.
2. Correct interrupt timing is ensured when INT/TO is HIGH for $>4 \mathrm{CP}$ followed by a LOW for $>7 \mathrm{CP}$.
3. When the interrupt in progress flag is set, further interrupts are latched but ignored, until RETR is executed.
4. A DIS I instruction always clears a pending external interrupt.
5. For all flip-flops, RESET overrules SET.

## FUNCTIONAL DESCRIPTION (continued)

## Oscillator (see Fig. 15)

The oscillator can be inhibited by the STOP instruction under software control. It is also inhibited when a low-supply voltage condition is present to prevent discharge of a weak back-up battery. Provided the supply voltage is within the operating range the oscillator will be restarted after a STOP instruction by a LOW level at the $\overline{\mathrm{INT}} / \mathrm{TO}$ pin or a HIGH level at the RESET pin.


Fig. 15 Oscillator with integrated elements.


Fig. 16 Crystal unit equivalent circuit.

The values of crystal series resistance $R 1$ and the crystal's total load capacitance $C_{L}\left(C_{o}+\right.$ wiring + external capacitors) must not be above the curve (Fig. 17) for the corresponding frequency. Note; if external capacitors are connected to XTAL 1 and XTAL they must be of equal value.


Fig. 17 Crystal circuit criteria.
The oscillator has the output drive capability via pin 19 (XTAL2). An external clock can be applied to pin 18 (XTAL1). A machine cycle consists of 10 time slots, each time slot being 3 oscillator periods.

## Timer/event counter (see Fig. 18)

An internal 8 -bit up-counter is provided. This can count external events, modulo- 32 machine cycles, or machine cycles directly. Table 3 gives the instructions that control the counter and the prescaler, and the functions performed.
When used as a timer, the input to the counter is either the overflow or input of a 5 -bit prescaler. When used as an event counter, LOW-to-HIGH transitions on pin 39 (T1) are counted. The maximum rate at which the counter may be incremented is once every machine cycle. When the counter overflows, the timer flag is set. The flag can be tested and reset using the JTF (jump is timer flag = 1) or JNTF instruction. Overflow also generates an interrupt to the processor via setting of the Timer Interrupt Flag when the timer/event counter interrupt is enabled.

Table 3 Timer/event counter control

| function | timer mode <br> modulo-1, modulo-32* | counter mode |
| :--- | :--- | :--- |
| CLEAR | MOV T,A (A) =0 | MOV T,A (A) = 0 |
|  | or RESET | or RESET |
| PRESET | MOV T,A | MOV T,A |
| START | STRT T | STRT CNT |
| STOP | STOP TCNT | STOP TCNT |
|  | or RESET | or RESET |
| TEST | JTF/JNTF | JTF/JNTF |
| READ** | MOV A,T | MOV A,T |



Fig. 18 Timer/event counter.

## Program status word (see Fig. 19)

The program status word (PSW) is an 8-bit word ( 1 byte) in the CPU which stores information about the current status of the microcontroller.
The PSW bits are:

- Bits 0 to 2 stack pointer bits ( $\mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ )
- Bit 3 prescaler select (PS);
- Bit 4 working register bank select (RBS);
- $0=$ register bank $0 ; 1=$ register bank 1
- Bit 5 not used (1)
- Bit 6 auxiliary carry (AC); half-carry bit generated by an ADD instruction and used by the decimal adjust instruction DA A
- Bit 7 carry (CY); the carry flag indicates that previous operation has resulted in an overflow of the accumulator.


Fig. 19 Program status word.

* With prescaler select, $\mathrm{PS}=0$, the timer counts modulo- 32 machine cycles, with PS $=1$ it counts modulo-1 cycles (prescaler not used); prescaler cleared with STRT T, prescaler not readable.
** READ does not disturb the counting process.


## FUNCTIONAL DESCRIPTION (continued)

## Program status word (continued)

All bits can be read using the MOV A, PSW instruction. Bits 7 and 6 are set and cleared by CPU operation. Bit 4 can be changed by a SEL RB instruction, bit 3 by the MOV PSW, A instruction, and bits 0,1 and 2 by the CALL, RET or RETR instructions and in the event of an interrupt. Bits 7, 6 and 4 are stored in the program counter stack during subroutine and interrupt calls. These bits are restored in the PSW with a RETR (return and restore) instruction which must be used at the end of an interrupt and can be used at the end of a normal subroutine. The RET instruction has no restore feature and cannot be used at the end of an interrupt.

## Program counter (see Fig. 20)

The 13 -bit program counter is able to address 8 K bytes of ROM. The arrangement of the bits is shown in figure 20. During an interrupt subroutine $\mathrm{PC}_{11}$ and $\mathrm{PC}_{12}$ are forced to logic 0 . All 13 bits are saved in the stack during CALL and interrupt routines.


Fig. 20 Program counter.

## Central processing unit

The PCF84C85 has arithmetic, logical and branching capabilities. The DA A, SWAP A and XCHD instructions simplify BCD arithmetic and the handling of nibbles. The MOVP A,@A instruction permits efficient table look-up from the current ROM page.

## Conditional branch logic

The conditional branch logic within the processor enables several conditions, internal and external to the processor, to be tested by the user's program. Table 4 lists the conditional jump instructions used to change the program sequence. The DJNZ instruction decrements a designated register or data memory location and branches if the contents are not zero. This instruction is useful for looping control. The JMPP@A instruction allows multiway branches to destinations determined by the contents of the accumulator.

Table 4 Conditional branches

| test | jump condition | jump instruction |
| :--- | :--- | :--- |
| accumulator | all bits zero | JZ |
| accumulator bit test | 1 | 1 |
| cany bit non-zero | JNZ |  |
|  | 1 | JBO to JB7 |
| timer overflow flag | 0 | JC |
| test input T0 | 1 | JNC |
|  | 0 | JTF |
| test input T1 | 1 | JNTF |
|  | 0 | JT0 |
| register | 1 | JNT0 |
|  | 0 | JT1 |
|  | non-zero | DJNZ |

## Test input T1 (pin 39)

The T1 input line can be used as:

- A test input for branch instructions JT1 and JNT1
- An external input to the event counter

When used as a test input:

- JT1 instruction tests for logic 1 level
- JNT1 instruction tests for logic 0 level

When used as an input to the event counter, T1 must be LOW for $>4 \mathrm{CP}$, followed by a HIGH for $>4 \mathrm{CP}$. The transition can be recognized with a repetition rate of once per 30 oscillator clock periods (1 machine cycle).
There is no internal pull-up or pull-down resistor connected to the T 1 input. If required it must be externally connected to a resistor ( $\mathrm{R}=\leqslant 100 \mathrm{k} \Omega$ ). When T 1 is not used pin 39 must be connected to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$.

## Reset (pin 21)

A positive-going signal on the RESET input

- Sets the program counter to zero
- Selects location 0 of memory bank 0 and register bank 0
- Sets the stack pointer to zero (000); pointing to RAM address 8
- Disables the interrupts (external, timer and serial I/O)
- Stops the timer/event counter, then sets it to zero
- Sets the timer prescaler to modulo-32
- Resets the timer flag
- Sets all ports to input mode
- Sets the serial I/O to slave receiver mode and disables the serial I/O
- Cancels IDLE and STOP mode


## FUNCTIONAL DESCRIPTION (continued)

## Power-on-reset

The internal power-on reset circuit monitors the PCF84C85 supply voltage $V_{D D}$. For as long as the supply voltage remains below the internal reference level $\mathrm{V}_{\text {ref }}$ (typically $1,5 \mathrm{~V}$ ) the oscillator is inhibited and RESET (pin 17) has an undefined level. When $V_{\text {DD }}$ rises above the internal reference level, the oscillator is released and RESET is pulled high to VDD by TR1 for a period tD (typically $50 \mu \mathrm{~s}$ ).
N.B. Because of the narrow bandwidth of the crystal, the start-up time of the oscillator is typically 10 ms .
Three modes of power-on reset are possible:

1. If $\mathrm{V}_{\mathrm{DD}}$ can be switched on with fast rise time i.e. $\mathrm{V}_{\mathrm{DD}}$ reaches its minimum operating value (corresponding to the selected oscillator frequency) before the RESET signal ( $\mathrm{t}_{\mathrm{D}}$ ) has finished, then no extra components are required (see Fig. 21 and 22). Note that the first instruction is executed after the oscillator start-up time plus 1866 clock periods have elapsed.
2. If $V_{D D}$ has a slow rise time then the RESET signal should be stretched by an external RC circuit (see Fig. 23 and 24).In the event of a short drop in the supply voltage, the diode path rapidly discharges the capacitor to ensure a reliable power-on reset. To ensure a correct reset, the RESET signal should reach at least $70 \%$ of the final value of $V_{D D}$. Given that the RESET voltage and $V_{D D}$ rise exponententially, the above requirement is satisfied when the time constant $\tau$ of the RESET pulse is $>8$ times the time constant of $V_{D D}$. If $V_{D D}$ rises linearly, then a RESET time constant $>2$ times the rise time of $V_{D D}$ is required.
When a reset is completed (RESET goes LOW) before the oscillator has started up, program execution begins after the oscillator start-up time plus 1866 clock periods have elapsed (see Fig. 24). If the oscillator is started-up prior to the completion of RESET, then program execution begins 1866 clock periods after RESET goes LOW.
3. Figure 25 shows an external reset to the PCF84C85 during power-on. The external reset signal must remain HIGH until $\mathrm{V}_{\text {DD }}$ has reached its minimum operating value corresponding to the selected oscillator frequency. When a reset is completed (RESET goes LOW) before the oscillator has started up, program execution begins after the oscillator start-up time plus 1866 clock periods have elapsed (see Fig. 26). If the oscillator is started-up prior to the completion of RESET, then program execution begins 1866 clock periods after RESET goes LOW.


Fig. 21 Power-on-reset configuration.
DEVELOPMENT DATA


Fig. 22 Timing of power-on-reset with fast rise time.

FUNCTIONAL DESCRIPTION (continued)


Fig. 23 Stretched power-on-reset with external components.


Fig. 24 Timing of power-on-reset with a slowly rising $\mathrm{V}_{\mathrm{DD}}$ and a stretched RESET pulse.


Fig. 25 External power-on-reset configuration.


* execution of first instruction at location 0
(1) RESET finishes after start - up time of the oscillator

7220162
(2) RESET finishes before start - up time of the oscillator

Fig. 26 Timing of external power-on-reset.

## PCF84C85

## INSTRUCTION SET

The PCF84C85 instruction set consists of over 80 one and two byte instructions and is identical to the MAB8400 instruction set. New instructions are added for STOP and IDLE mode. Program code efficiency is high because all RAM locations and all ROM locations on a 256 byte page require only a single byte address.
Table 7 gives the instruction set of the PCF84C85. Table 6 shows the instruction map and Table 5 details the symbols and definition descriptions that are used.

Table 5 Symbols and definitions used in Table 7

| symbol | definition description |
| :--- | :--- |
| A | accumulator |
| addr | program memory address |
| Bb | bit designation $(b=0-7)$ |
| RBS | register bank select |
| C | carry bit (bit CY) |
| CNT | event counter |
| Dx | Derivative register designation ( $x=0,1,2$ or 3) |
| data | 8-bit number or expression |
| I | interrupt |
| MB | memory bank |
| MBFF | memory bank flip-flop |
| P | mnemonic for 'in-page' operation |
| PC | program counter |
| Pp | port designation ( $p=0,1$ or 2$)$ |
| PSW | program status word |
| RB | register bank |
| Rr | register designation ( $r=0-7$ ) |
| Sn | serial I/O register |
| SP | stack pointer |
| T | timer |
| TF | timer flag |
| T0, T1 | test 0 and 1 inputs |
| $\#$ | immediate data prefix |
| $@$ | indirect address prefix |
| (X) | contents of $X$ |
| (X)) | contents of location addressed by $X$ |
| $\leftarrow$ | is replaced by |
| $\leftrightarrow$ | is exchanged with |

Table 6 PCF84C85 instruction map


INSTRUCTION SET (continued)

## Table 7 Instruction set

|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function |  | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { ADD A, Rr } \\ & \text { ADD A, @Rr } \end{aligned}$ | $\begin{aligned} & 6^{*} \\ & 60 \\ & 61 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | Add register contents to $A$ <br> Add RAM data, addressed by $\operatorname{Rr}$, to A | $\begin{aligned} & (A) \leftarrow(A)+(R r) \\ & (A) \leftarrow(A)+((R 0)) \\ & (A) \leftarrow(A)+((R 1)) \end{aligned}$ | $r=0-7$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  | ADD A, \#data | 03 data | 2/2 | Add immediate data to A | $(\mathrm{A}) \leftarrow(\mathrm{A})+$ data |  | 1 |
|  | ADDC A, Rr | 7* | 1/1 | Add carry and register contents to A | $(A) \leftarrow(A)+(R r)+(C)$ | $r=0-7$ | 1 |
|  | ADDC A, @Rr | 70 | 1/1 | Add carry and RAM data, addressed | $(A) \leftarrow(A)+((R 0))+(C)$ $(A) \leftarrow(A)+((R 1))+(C)$ |  | 1 |
|  |  | 71 |  | by Rr, to A | $(A) \leftarrow(A)+((R 1))+(C)$ |  |  |
|  | ADDC A, \#data | 13 data | 2/2 | Add carry and immediate data to $A$ | $(A) \leftarrow(A)+$ data $+(C)$ |  | 1 |
|  | ANL A, Rr | 5* | 1/1 | 'AND' Rr with A | $(A) \leftarrow(A)$ AND (Rr) | $r=0-7$ |  |
|  | ANL A, @Rr | 50 | 1/1 | 'AND' RAM data, addressed by Rr, with A | $(A) \leftarrow(A)$ AND ((RO)) |  |  |
|  |  | 51 |  |  | $(A) \leftarrow(A)$ AND ( $(\mathrm{R} 1))$ |  |  |
|  | ANL A, \#data | 53 data | 2/2 | 'AND' immediate data with A | $(A) \leftarrow(A)$ AND data |  |  |
|  | ORL A, Rr | 4* | 1/1 | 'OR' Rr with A | $(A) \leftarrow(A) O R(R r)$ | $r=0-7$ |  |
|  | ORL A, @Rr | 40 | 1/1 | 'OR' RAM data, addressed by Rr, with A | $\begin{aligned} & (A) \leftarrow(A) \text { OR }((R 0)) \\ & (A) \leftarrow(A) \text { OR }((R 1)) \end{aligned}$ |  |  |
|  | ORL A, \#data | 43 data | 2/2 | 'OR' immediate data with A | $(A) \leftarrow(A)$ OR data |  |  |
|  | XRL A, Rr | D* | 1/1 | 'XOR' Rr with A | $(A) \leftarrow(A) X O R(R r)$ | $r=0-7$ |  |
|  | XRL A, @Rr | $\begin{aligned} & \text { D0 } \\ & \text { D1 } \end{aligned}$ | 1/1 | 'XOR' RAM, addressed by Rr, with A | $\begin{aligned} & (A) \leftarrow(A) \operatorname{XOR}((R 0)) \\ & (A) \leftarrow(A) \operatorname{XOR}((R 1)) \end{aligned}$ |  |  |
|  | XRL A, \#data | D3 data | 2/2 | 'XOR' immediate data with $A$ | $(A) \leftarrow(A)$ XOR data |  |  |
|  | INC A | 17 | 1/1 | increment A by 1 | $(A) \leftarrow(A)+1$ |  |  |
|  | DEC A | 07 | 1/1 | decrement A by 1 | $(A) \leftarrow(A)-1$ |  |  |
|  | CLR A | 27 | 1/1 | clear A to zero | $(A) \leftarrow 0$ |  |  |
|  | CPL A | 37 | 1/1 | one's complement A | $(\mathrm{A}) \leftarrow \operatorname{NOT}(\mathrm{A})$ |  |  |
|  | RL A | E7 | 1/1 | rotate A left | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow\left(A_{n}\right) \\ & \left(A_{0}\right) \leftarrow\left(A_{7}\right) \end{aligned}$ | $n=0-6$ |  |

## DEVELOPMENT DATA

| $\begin{aligned} & \dot{5} \\ & \dot{0} \\ & \text { in } \end{aligned}$ | RLC A | F7 | 1/1 | rotate A left through carry | $\begin{aligned} & \left(A_{n}+1\right) \leftarrow A_{n} \\ & \left(A_{0}\right) \leftarrow(C),(C) \leftarrow\left(A_{7}\right) \end{aligned}$ | $\mathrm{n}=0-6$ | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & x \\ & 0 \\ & 0 \end{aligned}$ | RR A | 77 | $1 / 1$ | rotate A right | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow\left(A_{0}\right) \end{aligned}$ | $n=0-6$ |  |
| $\stackrel{5}{5}$ | RRC A | 67 | 1/1 | rotate A right through carry | $\begin{aligned} & \left(A_{n}\right) \leftarrow\left(A_{n}+1\right) \\ & \left(A_{7}\right) \leftarrow(C),(C) \leftarrow\left(A_{0}\right) \end{aligned}$ | $n=0-6$ | 2 |
|  | $\begin{aligned} & \text { DA A } \\ & \text { SWAP A } \end{aligned}$ | $\begin{aligned} & 57 \\ & 47 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \end{aligned}$ | decimal adjust A <br> swap nibbles of $A$ |  |  | 2 |
|  | MOV A, Rr | F* | $1 / 1$ | move register contents to $A$ | (A) $\leftarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | MOV A, @Rr |  | 1/1 | move RAM data, addressed by Rr , to A | $\begin{aligned} & (A) \leftarrow((R 0)) \\ & (A) \leftarrow((R 1)) \end{aligned}$ |  |  |
|  | MOV A, \#data | 23 data | 2/2 | move immediate data to $A$ | (A) - data |  |  |
|  | MOV Rr, A | A* | 1/1 | move accumulator contents to register | $(\mathrm{Rr}) \leftarrow(\mathrm{A})$ | $r=0-7$ |  |
|  | MOV @Rr, A |  | $1 / 1$ | move accumulator contents to RAM location addressed by Rr | $\begin{aligned} & ((R O)) \leftarrow(A) \\ & ((R 1)) \leftarrow(A) \end{aligned}$ |  |  |
|  | MOV Rr, \#data | B* data | 2/2 | move immediate data to Rr | $(\mathrm{Rr}) \leftarrow$ data |  |  |
|  | MOV @Rr, \#data | BO data <br> B1 data | 2/2 | move immediate data to RAM location addressed by Rr | $\begin{aligned} & ((\text { RO) ) } \leftarrow \text { data } \\ & ((\text { R1) }) \leftarrow \text { data } \end{aligned}$ |  |  |
|  | $\mathrm{XCH} \mathrm{A}, \mathrm{Rr}$ | 2* | 1/1 | exchange accumulator contents with Rr | $(\mathrm{A}) \leftrightarrow(\mathrm{Rr})$ | $r=0-7$ |  |
|  | XCH A, @Rr |  | 1/1 | exchange accumulator contents with RAM data addressed by Rr | $\begin{aligned} & (A) \leftrightarrow((R 0)) \\ & (A) \leftrightarrow((R 1)) \end{aligned}$ |  |  |
|  | XCHD A, @Rr | $\begin{array}{\|l\|} 30 \\ 31 \end{array}$ | $1 / 1$ | exchange lower nibbles of A and RAM data addressed by Rr | $\begin{aligned} & \left(A_{0-3}\right) \leftrightarrow\left(\left(\mathrm{RO}_{0-3}\right)\right) \\ & \left(\mathrm{A}_{0-3}\right) \leftrightarrow\left(\left(\mathrm{R} 1_{0-3}\right)\right) \end{aligned}$ |  |  |
|  | MOV A, PSW | C7 | 1/1 | move PSW contents to accumulator | $(\mathrm{A}) \leftarrow$ (PSW) |  |  |
|  | MOV PSW, A | D7 | 1/1 | move accumulator bit 3 to $\mathrm{PSW}_{3}$ | $\left(\mathrm{PSW}_{3}\right) \leftarrow\left(\mathrm{A}_{3}\right)$ |  | 3 |
|  | MOVP A, @A | A3 | 1/2 | move indirectly addressed data in current page to $A$. | $\left(\mathrm{PC}_{0-7}\right) \leftarrow(\mathrm{A}),(\mathrm{A}) \leftarrow((\mathrm{PC}))$ |  |  |
| ¢ | CLR C | 97 | 1/1 | clear carry bit | (C) $\leftarrow 0$ |  | 2 |
| 4 | CPLC | A7 | 1/1 | complement carry bit | (C) $\leftarrow$ NOT(C) |  | 2 |

INSTRUCTION SET (continued)

|  | mnemonic | opcode (hex.) | bytes/ cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | INC Rr INC @Rr <br> DEC Rr <br> DEC @Rr | $\begin{aligned} & 1^{*} \\ & 10 \\ & 11 \\ & C^{*} \\ & \text { C0 } \\ & \text { C1 } \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | increment register by 1 <br> increment RAM data, addressed by $R r$, by 1 <br> decrement register by 1 <br> decrement RAM data, addressed by Rr, by 1 | $\begin{array}{ll} (R r) \leftarrow(R r)+1 & r=0-7 \\ ((R 0)) \leftarrow((R 0))+1 & \\ ((R 1)) \leftarrow((R 1))+1 & \\ (R r) \leftarrow(R r)-1 & r=0-7 \\ ((R 0)) \leftarrow((R 0))-1 & \\ ((R 1)) \leftarrow((R 1))-1 & \end{array}$ |  |
|  | JMP addr <br> JMPP @A <br> DJNZ Rr, addr <br> DJNZ @Rr, addr <br> JBb addr <br> JC addr <br> JNC addr <br> JZ addr <br> JNZ addr <br> JTO addr <br> JNTO addr <br> JT1 addr <br> JNT1 addr <br> JTF addr <br> JNTF addr | - 4 address <br> B3 <br> E* address <br> EO address <br> E1 address <br> 4 2 address <br> F6 address <br> E6 address <br> C6 address <br> 96 address <br> 36 address <br> 26 address <br> 56 address <br> 46 address <br> 16 address <br> 06 address | $\begin{gathered} 2 / 2 \\ 1 / 2 \\ 2 / 2 \\ 2 / 2 \\ \\ \\ \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \\ 2 / 2 \end{gathered}$ | unconditional jump within a 2 K bank <br> indirect jump within a page decrement Rr by 1 and jump if not zero to addr decrement RAM data, addressed by Rr by 1 and jump if not zero to addr <br> jump to addr if Acc. bit $\mathrm{b}=1$ <br> jump to addr if $\mathrm{C}=1$ <br> jump to addr if $\mathrm{C}=0$ <br> jump to addr if $A=0$ <br> jump to addr if $A$ is NOT zero <br> jump to addr if TO = 1 <br> jump to addr if $T 0=0$ <br> jump to addr if $T 1=1$ <br> jump to addr if $\mathrm{T} 1=0$ <br> jump to addr if Timer Flag $=1$ <br> jump to addr if Timer Flag $=0$ |  | 4 |


|  | MOV A, T <br> MOV T, A <br> STRT CNT <br> STRT T <br> STOP TCNT <br> EN TCNTI <br> DIS TCNTI | $\begin{aligned} & 42 \\ & 62 \\ & 45 \\ & 55 \\ & 65 \\ & 25 \\ & 35 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | move timer/event counter contents to accumulator <br> move accumulator contents to timer/event counter <br> start event counter <br> start timer <br> stop timer/event counter <br> enable timer/event counter interrupt <br> disable timer/event counter interrupt | $\begin{aligned} & (A) \leftarrow(T) \\ & (T) \leftarrow(A) \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 1 \\ & 0 \\ & \mathbf{r} \\ & \mathbf{y} \\ & 0 \\ & 0 \end{aligned}$ | EN I <br> DIS I <br> SEL RBO <br> SEL RB1 <br> SEL MBO <br> SEL MB1 <br> SEL MB2 <br> SEL MB3 <br> STOP <br> IDLE | $\begin{aligned} & 05 \\ & 15 \\ & \text { C5 } \\ & \text { D5 } \\ & \text { E5 } \\ & \text { F5 } \\ & \text { A5 } \\ & \text { B5 } \\ & 22 \\ & 01 \end{aligned}$ | $\begin{aligned} & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \\ & 1 / 1 \end{aligned}$ | enable external interrupt disable external interrupt select register bank 0 select register bank 1 select program memory bank 0 select program memory bank 1 select program memory bank 2 select program memory bank 3 enter STOP mode enter IDLE mode | $\begin{aligned} & (\text { RBS }) \leftarrow 0 \\ & (\text { RBS }) \leftarrow 1 \\ & (\text { MBFF0 }) \leftarrow 0,(\text { MBFF1 }) \leftarrow 0 \\ & (\text { MBFF0 }) \leftarrow 1,(\text { MBFF1 }) \leftarrow 0 \\ & (\text { MBFF0 }) \leftarrow 0,(\text { MBFF1 }) \leftarrow 1 \\ & (\text { MBFFO }) \leftarrow 1,(\text { MBFF1 }) \leftarrow 1 \end{aligned}$ |  |  |
|  | CALL addr <br> RET <br> RETR | 4 4 address <br> 83 <br> 93 | 2/2 <br> $1 / 2$ <br> $1 / 2$ | jump to subroutine <br> return from subroutine <br> return from interrupt and restore bits 4, 6, 7 of PSW | $\begin{aligned} & ((\mathrm{SP})) \leftarrow(\mathrm{PC}),\left(\mathrm{PSW}_{4}, 6,7\right) \\ & (\mathrm{SP}) \leftarrow(\mathrm{SP})+1 \\ & \left(\mathrm{PC}_{8}-10\right) \leftarrow \text { addr8-10 } \\ & \left(\mathrm{PC}_{0-7}\right) \leftarrow \text { addro-7 } \\ & \left(\mathrm{PC}_{11-12}\right) \leftarrow \mathrm{MBFF} 0-1 \\ & (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\ & (\mathrm{PC}) \leftarrow((\mathrm{SP})) \\ & (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\ & \left(\mathrm{PSW}_{4,}, 7,7\right)+(\mathrm{PC}) \leftarrow((\mathrm{SP})) \end{aligned}$ | 6 | 6 6 6 |

INSTRUCTION SET (continued)

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \& mnemonic \& opcode (hex.) \& bytes/ cycles \& description \& function \& notes \\
\hline  \& IN A, Pp
OUTL Pp, A
ANL Pp, \#data
ORL Pp, \#data \& \begin{tabular}{l}
08 \\
09 \\
0 A \\
38 \\
39 \\
3A \\
98 data \\
99 data \\
9A data \\
88 data \\
89 data \\
8A data
\end{tabular} \& \begin{tabular}{l}
1/2 \\
\(1 / 2\) \\
\(2 / 2\) \\
\(2 / 2\)
\end{tabular} \& \begin{tabular}{l}
input port p data to accumulator \\
output accumulator data to port p \\
AND port p data with immediate data \\
OR port p data with immediate data
\end{tabular} \& \[
\begin{aligned}
\& (\mathrm{A}) \leftarrow(\mathrm{PO}) \\
\& (\mathrm{A}) \leftarrow(\mathrm{P} 1) \\
\& (\mathrm{A}) \leftarrow(\mathrm{P} 2) \\
\& (\mathrm{PO}) \leftarrow(\mathrm{P}) \\
\& (\mathrm{P} 1) \leftarrow(\mathrm{A}) \\
\& (\mathrm{P} 2) \leftarrow(\mathrm{A}) \\
\& (\mathrm{P} 0) \leftarrow(\mathrm{P}) \text { AND data } \\
\& (\mathrm{P} 1) \leftarrow(\mathrm{P} 1) \text { AND data } \\
\& (\mathrm{P} 2) \leftarrow(\mathrm{P} 2) \text { AND data } \\
\& (\mathrm{PO}) \leftarrow(\mathrm{PO}) \text { OR data } \\
\& (\mathrm{P} 1) \leftarrow(\mathrm{P} 1) \text { OR data } \\
\& (\mathrm{P} 2) \leftarrow(\mathrm{P} 2) \text { OR data }
\end{aligned}
\] \& 7 \\
\hline  \& \begin{tabular}{l}
MOV A, Dx \\
MOV Dx, A \\
ANL Dx, A \\
ORL Dx, A \\
MOV A, Dx
\end{tabular} \& \begin{tabular}{ll}
8 C \& 00 \\
8 C \& 01 \\
8 D \& 02 \\
8 D \& 03 \\
8 E \& 02 \\
8 E \& 03 \\
8 F \& 02 \\
8 F \& 03 \\
8 C \& 02 \\
8 C \& 03
\end{tabular} \& \begin{tabular}{l}
2/2 \\
2/2 \\
2/2 \\
2/2 \\
2/2 \\
2/2 \\
2/2 \\
2/2 \\
2/2 \\
2/2
\end{tabular} \& \begin{tabular}{l}
input pin data of port DPO, DP1 to accumulator \\
move contents of accumulator to latch of port DP0, DP1 \\
AND contents of DPO, DP1 latch with accumulator \\
OR contents of DPO, DP1 latch with accumulator \\
move contents of DPO, DP1 latch to accumulator
\end{tabular} \& \[
\begin{aligned}
\& (A) \leftarrow(D 0) \\
\& (A) \leftarrow(D 2) \\
\& (D 2) \leftarrow(A) \\
\& (D 3) \leftarrow(A) \\
\& (D 2) \leftarrow(D 2) \text { AND }(A) \\
\& \text { (D3) } \leftarrow(D 2) \text { AND }(A) \\
\& (D 2) \leftarrow(D 2) \text { OR }(A) \\
\& \text { (D3) } \leftarrow(D 3) \text { OR (A) } \\
\& \text { (A) } \leftarrow(D 2) \\
\& (A) \leftarrow(D 3)
\end{aligned}
\] \& 8

8 <br>
\hline
\end{tabular}

## DEVELOPMENT DATA

|  | mnemonic | opcode <br> (hex.) | bytes/ cycles | description | function | notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MOV A, $S_{n}$ <br> MOV Sn, $A$ <br> MOV $S_{n}$, \#data <br> EN SI <br> DIS SI | $\begin{aligned} & \text { OC } \\ & \text { OD } \\ & \text { 3C } \\ & \text { 3D } \\ & \text { 3E } \\ & 9 C \text { data } \\ & 9 D \text { data } \\ & 9 E \text { data } \\ & 85 \\ & 95 \end{aligned}$ | $1 / 2$ <br> $1 / 2$ <br> $2 / 2$ <br> 1/1 <br> 1/1 | move serial I/O register contents to accumulator <br> move accumulator contents to serial I/O register <br> move immediate data to serial I/O register <br> enable serial I/O interrupt <br> disable serial I/O interrupt | $\begin{aligned} & (A) \leftarrow(S 0) \\ & (A) \leftarrow(S 1) \\ & (S 0) \leftarrow(A) \\ & (S 1) \leftarrow(A) \\ & (S 2) \leftarrow(A) \\ & (S 0) \leftarrow \text { data } \\ & (S 1) \leftarrow \text { data } \\ & (S 2) \leftarrow \text { data } \end{aligned}$ | 9 |
|  | NOP | 00 | 1/1 | no operation |  |  |

Notes to Table 8

1. PSW CY, AC affected
2. PSW RBS affected
3. PSW CY affected
4. PSW $\mathrm{SP}_{0}, \mathrm{SP}_{1}, \mathrm{SP}_{2}$ affected
3 PSW PS affected
5. $(A)=0000$ P23 111
6. Execution of JTF and JNTF instructions resets the Timer Flag (TF).

* : 8,9,A,B,C,D,E,F
- : 9,2,4,6,8,A,C,E

8. The MSB of $A$ becomes a logic 1
9. (S1) has a different function in read and write operations, see serial I/O interface.

- : $1,3,5,7,9, B, D, F$


## PCF84C85

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage (pin 40)
All input voltages
D.C. current into any input or output

Total power dissipation (see note)
Power dissipation per output except P23, SCLK P23, SCLK

Storage temperature range
Operating ambient temperature range
Operating junction temperature

| $V_{D D}$ | $-0,8$ to +8 V |
| :--- | ---: |
| $V_{1}$ | $-0,8$ to $V_{D D}+0,8 \mathrm{~V}$ |
| $\pm 1_{1}, \pm 1_{0}$ | max. |

$\pm 1_{1}, \pm 1_{0}$ max. $\quad 10 \mathrm{~mA}$

| $P_{O}$ | max. | 50 mW |
| :--- | ---: | ---: |
| $\mathrm{PO}_{\mathrm{O}}$ | max. | 180 mW |
| $\mathrm{~T}_{\mathrm{stg}}$ |  | -65 to +150 o C |
| $\mathrm{T}_{\mathrm{amb}}$ |  | -40 to $+85{ }^{\circ} \mathrm{C} \mathrm{C}$ |
| $\mathrm{T}_{\mathrm{j}}$ | max. | $125{ }^{\circ} \mathrm{C}$ |

## HANDLING

Inputs and outputs are protected against electrostatic discharge in normal handling. However, to be totally safe, it is desirable to take normal precautions appropriate to handling MOS devices (see 'Handling MOS devices').

## D.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $5,5 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$; all voltages with respect to $\mathrm{V}_{\mathrm{SS}}$; unless otherwise specified.

| parameter |
| :---: |
| Supply voltage operating (see Fig. 27) |
| ```Supply current operating (see Fig. 28) at V at }\mp@subsup{V}{DD}{}=3\textrm{V};\mp@subsup{\textrm{f}}{\textrm{XTAL}}{}=3,58\textrm{MHz``` |

IDLE mode (see Fig. 30)
at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \mathrm{f} \mathrm{XTAL}=6 \mathrm{MHz}$
at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V} ; \mathrm{f} \mathrm{XTAL}=3,58 \mathrm{MHz}$
STOP mode (see Fig. 35 and note 1)
at $V_{D D}=2,5 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$
at $V_{D D}=2,5 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=85^{\circ} \mathrm{C}$

## RESET I/O

Switching level
Sink current
at $\mathrm{V}_{\mathrm{DD}}>\mathrm{V}_{\text {RESET }}$

## Inputs

Input voltage LOW
Input voltage HIGH
Input leakage current
as $\mathrm{V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\mathrm{DD}}$

## Outputs

Output voltage LOW at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}} ; \| \mathrm{IO} \mid<1 \mu \mathrm{~A}$
Output sink current LOW
at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=0,4 \mathrm{~V}$
except P23/SDA, SCLK (see Fig. 31)
P23/SDA, SCLK (see Fig. 32)
Pull-up output source current HIGH (see Fig. 33)
at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; V_{O}=0,7 V_{D D}$
at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{SS}}$
Push-pull output source current HIGH at $V_{D D}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{DD}}-0,4 \mathrm{~V}$

## Note 1

Crystal connected between XTAL1 and XTAL2; SCL and SDA pulled to VDD via $5,6 \mathrm{k} \Omega$ resistor;
T1 at $\mathrm{V}_{\mathrm{SS}}, \overline{\mathrm{NT}}$ at $\mathrm{V}_{\mathrm{DD}}$.

## A.C. CHARACTERISTICS (continued)


(1) clock frequency $=100 \mathrm{kHz}$
(2) clock frequency $=1 \mathrm{MHz}$
(3) clock frequency $=3 \mathrm{MHz}$
(4) clock frequency $=10 \mathrm{MHz}$

Fig. 27 Maximum clock frequency ( $f$ XTAL) as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

(1) clock frequency $=10 \mathrm{MHz}$
(2) clock frequency $=6 \mathrm{MHz}$
(3) clock frequency $=3,58 \mathrm{MHz}$

Fig. 29 Maximum supply current (IDD) in IDLE mode as a function of the supply voltage (VDD).

(1) clock frequency $=10 \mathrm{MHz}$
(2) clock frequency $=6 \mathrm{MHz}$
(3) clock frequency $=3,58 \mathrm{MHz}$

Fig. 28 Maximum supply current (IDD) in operating mode as a function of the supply voltage.

(1) $V_{D D}=3 V$
(2) $V_{D D}=5 \mathrm{~V}$

Fig. 30 Typical supply current during IDLE mode as a function of frequency.


Fig. 31 Output sink current LOW (IOL), except outputs P23/SDA and SCLK, as a function of supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ); $\mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$.

(1) $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{SS}}$
(2) $\mathrm{V}_{\mathrm{O}}=0,7 \mathrm{~V}_{\mathrm{DD}}$

Fig. 33 Output source current HIGH ( -IOH ) as a function of supply voltage ( $V_{D D}$ ).


Fig. 32 Output current LOW (IOL), outputs P23/SDA and SCLK, as a function of supply voltage ( $V_{D D}$ ); $\mathrm{V}_{\mathrm{O}}=0,4 \mathrm{~V}$.

(1) $V_{D D}=3 V$
(2) $V_{D D}=5 \mathrm{~V}$

Fig. 34 Typical supply current during operating mode as a function of frequency.
A.C. CHARACTERISTICS (continued)

Table 8 Input timing shown in figure 36.

(1) $\mathrm{T}_{\mathrm{amb}}=85^{\circ} \mathrm{C}$
(2) $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$

Fig. 35 Typical supply current (IDD) in STOP mode as a function of the supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ ).

| symbol | timing |
| :---: | :---: |
| $\mathrm{t}_{\text {BUF }}$ | $\geqslant 14 \mathrm{t}$ XTAL |
| ${ }^{\text {thD }}$; STA | $\geqslant 14 \mathrm{t} \times$ TAL. |
| ${ }^{\text {thigh }}$ | $\geqslant 17 \mathrm{t} \times$ TAL |
| ${ }^{\text {t L O W }}$ | $\geqslant 17 \mathrm{t} \times$ TAL |
| ${ }^{\text {t }}$ SU;STO | $\geqslant 14 \mathrm{t} \times$ TAL |
| thD;DAT | $>0$ |
| ${ }^{\text {t }}$ SU;DAT | $\geqslant 250 \mathrm{~ns}$ |
| ${ }^{\text {t }}$ RD | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{t} R C$ | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ FD | $\leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ FC | $\leqslant 0,3 \mu \mathrm{~s}$ |

## Notes to Table 8

${ }^{\mathrm{t}} \mathrm{XTAL}$ = one period of the XTAL input frequency ( $\mathrm{f}_{\mathrm{XTAL}}$ )
$=167 \mathrm{~ns}$ for $\mathrm{f}_{\mathrm{XTAL}}=6 \mathrm{MHz}$.
These figures apply to all modes.


Fig. 36 PCF84C85 timing requirements for the P23 and SCLK input signals.

Purchase of Philips $\left.\right|^{2} \mathrm{C}$ components conveys a license under the Philips $\left.\right|^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specifications defined by Philips.


ㅌ315


Fig. 37 PCF84C85 timing requirements for the P23 and SCLK output signals.
Table 9 Output timing shown in Figure 37

|  | symbol | timing |  |
| :---: | :---: | :---: | :---: |
|  |  | normal mode (ASC in S2 = 0) | low-speed mode (ASC in S2 = 1) |
|  | ${ }^{\text {thD }}$; STA <br> thigh <br> t LOW <br> tsu; STO <br> thD; DAT <br> (slave transmitter <br> any DF <br> ${ }^{\text {th }} \mathrm{D} ;$ DAT <br> (master transmitter) <br> for $D F \leqslant 51$ <br> for $D F \leqslant 99$ <br> ${ }^{\text {t }}$ SU; DAT <br> (master transmitter) <br> for DF > 51 <br> for DF $>99$ <br> ${ }^{t} A C$ <br> ${ }^{\mathrm{t}} \mathrm{FD}, \mathrm{tFC}$ |  |  |

## Notes to Table 9

${ }^{\mathrm{t}} \mathrm{XTAL}=$ one period of the XTAL input frequency ( f XTAL) $=167 \mathrm{~ns}$ for $\mathrm{f}_{\mathrm{XTAL}}=6 \mathrm{MHz}$.
DF = divisor (see Table 2 Serial I/O section).
$\mathrm{C}_{\mathrm{b}} \quad=$ the maximum bus capacitance for each line.

## SINGLE-CHIP 8-BIT MICROCONTROLLERS (bipolar)

Standard products ..... 513
Product support ..... 707
Software support ..... 763
Special purpose circuits ..... 767

## STANDARD PRODUCTS

8X300 ..... 515
8X305 ..... 535
8X310 ..... 557
8X320 ..... 569
8X330 ..... 577
8X350 ..... 593
8X353 ..... 597
8X355. ..... 605
8X360 ..... 613
8X371 ..... 615
8X372/8X376 ..... 623
8X374 ..... 633
8X382 ..... 643
8X401 ..... 653
8X450 ..... 673
8X470 ..... 681
8 T 31 ..... 695
8T32/8T36 ..... 699

## MICROCONTROLLER

## FEATURES

- Fetch, Decode, and Execute a 16-bit instruction in a minimum of 250 -nanoseconds (one machine cycle)
- Bit-oriented instruction set (addressable single-ormultiple bit subfields)
- Separate address, instruction, and I/O buses
- Source/destination architecture
- On-Chip oscillator and timing generation
- Eight 8 -bit working registers
- TTL inputs and outputs
- BiPolar Low-Power Schottky technology
- 3-State I/O bus
- Single +5 V supply


## ARCHITECTURAL OVERVIEW

The Signetics $8 \times 300$ Microcontroller (Figure 1) is a highspeed bipolar microprocessor implemented with low-power Schottky technology. The $8 \times 300$ brings together all the qualities needed-SPEED, FLEXIBILITY, and ECONOMYfor systems design in the many areas that require reliable bit stream management. Consider!-5V operation, TTL bus compatibility, and an on-chip clock-the result, a system with fewer parts. Consider! - the inherent power of LSI logic (programmable Rotate, Mask, Shift, and Merge functions in the data-processing path) and the ability to Fetch, Decode, and Execute a 16 -bit instruction in a minimum of 250 -nanoseconds-the resuit, a system with superior bit handling capabilities. Consider!-the 250 ns cycle time in conjunction with extended microcode-the result, the flexibility of bit-slice devices with the programming ease of MOS microprocessors. Now, consider the results!-a device tailored to bit-stream management in the areas of Industrial Control, Input/ Output Control, and Data Communications.
The $8 \times 300$ uses three separate buses-one for 13 -bit instruction addresses, one for 16 -bit instructions, and a bidirectional 8-bit input/output data bus; except for the 1/O bus, there are no time multiplexing of functions.

## PIN CONFIGURATION




Figure 1. CPU Architecture and PIN Designations For $8 \times 300$ microcontroller


Figure 2. Typical $8 \times 300$ System with Pin Definitions

## TYPICAL $8 \times 300$ SYSTEM HOOKUP

Although the system hookup shown in Figure 2 is of the simplest form, it provides a fundamental look at the $8 \times 300$ microcontroller and peripheral relationships. As indicated, program storage can be either ROM or PROM and, by using various addressing-methods/decoding-schemes, memory paging techniques can be easily implemented. Also, by proper bit assignment, some external interface logic and, under software control, the program memory can be used as a storage device for interrupt-service subroutines. The user interface (IV $\emptyset$ through IV7) is capable of addressing 256 Input/ Output ports and, with the additional bank-select bit ( $\overline{L B}$ and $\overline{\mathrm{RB}}$ ), the number of addressable $/ / O$ ports is 512 the left bank and right bank each consisting of 256 ports. The I/O ports of each bank can be used in a variety of ways; one of these ways is shown in Figure 2. When $\overline{L B}$ is active low, the left bank can be enabled and, providing there is an address match, anyone of 128 I/O ports or anyone of 128 locations within the RAM memory can be accessed for input /output operations. When $\overline{\mathrm{RB}}$ is active low, the same set of conditions are applicable to the right bank. With some sacrifice in speed, any given I/O port can be interfaced to a memory peripheral or other 1/O device of the user.

## PROGRAM STORAGE INTERFACE

As shown in Figure 2, program storage is connected to output address lines AO through A12 (A12 = LSB) and input instruction lines 10 through 115. An address output on AO/A12 identifies one 16-bit instruction word in program storage. The instruction word is subsequently input on 10/115 and defines the microcontroller operations which are to follow.

The Signetics 82S115 PROM or any TTL-compatible memory can be used for program storage. (Note. The worst-case access time depends upon the instruction cycle time, and also, the overall system configuration.)

## / O INTERFACE AND CONTROL.

An 8-bit $1 / O$ data bus is used by the microcontroller to communicate with two fields of I/O devices. The complementary $\overline{L B}$ and $\overline{R B}$ signals identify which field of the $1 / O$ devices is enabled.

Both data and address information are output on the $1 / 0$ bus. The SC (Select Command) and WC (Write Command) signals distinguish between data and address information as follows:

| SC | WC | FUNCTION |
| :--- | :--- | :--- |
| High | Low | $1 / O$ address is being output on the <br> $1 / O$ (IV) bus <br> $1 / O$ data is being output on the $1 / O$ <br> Low <br> Low <br> High bus <br> Input data expected from selected <br> $1 / O$ device <br> Invalid (not generated by $8 \times 300$ ) |

## DATA PROCESSING

From a data processing point of view, the $8 \times 300$ microcontroller chip (Figure 1) contains eight 8 -bit working
registers (R1 through R6, R11, AUXiliary), an arithmetic logic unit (ALU), an overflow register (OVF), rotate/shift/ mask/merge logic, and a bidirectional 8 -bit I/O bus. Internal 8 -bit data paths connect the registers and I/O bus to the ALU inputs, and the ALU output to the registers and $\mathrm{I} / \mathrm{O}$ bus. Inputs to the ALU are preceded by the data-rotate and datamask logic and the ALU output is followed by the shift and merge logic. Any one or all of the logic functions can operate on 8 -bits of data in a single instruction cycle. Data from the source register can be right-rotated (end around) before processing by the ALU; external data (I/O bus) can also be masked to isolate a portion of the 8 -bit field. Since the ALU always processes 8 -bits of data, bit positions not specified by the mask operation are filled with zeroes.

When less than 8 -bits of data are specified as output to the 1/O bus from the ALU, the data field (shifted and masked, as required) is merged with prior contents of the I/O latches to form the output data. Bit positions of the I/O data not affected by the logic operations are not modified. Depending upon whether an 1/O peripheral or an internal register is specified in the instruction as the source of data, the 1/O latches contain, respectively, 1/O-bus source data or destination data. For instance, when an internal register is specified as a source of data and an I/O peripheral as the destination, data from the peripheral is read into the $1 / O$ latches at the start of the instruction cycle; processed data is then merged with contents of the I/O latches to form the //O output data at the end of the instruction cycle. When an //O peripheral is specified as both data source and destination, data from the source is used both as the input to the 1/O latches and as data to be processed; the processed data is then merged with data from the $1 / O$ latches to form the previously-described I/O bus output. If the data source and destination are on opposite banks of the 8X300 bus, the destination data is written with a full 8 -bits, since the prior contents were not stored in the $1 / \mathrm{O}$ latches.

## INSTRUCTION CYCLE

Each microcontroller operation is executed in a single instruction cycle. The instruction cycle is divided into quarters with each quarter cycle being as short as 62.5 nanoseconds. Figure 3 shows the general functions that occur during each quarter cycle; specifics regarding minimum/maximum timing and other critical values are described under "Design Parameters" in this data sheet. During the first quarter cycle, a new instruction from program storage is input on signal lines 10 through 115; simultaneously, new data is fetched via the input/output bus (IVO through $\overline{\mathrm{V} 7}$ ). At the end of the first quarter cycle, the new instruction is latched in the instruction register and the new I/O data is present at the input of the chip but is not, as yet, latched by the IV latches.

In the second quarter cycle, the $1 / O$ data stabilizes and preliminary processing is completed; at the end of this quarter, the IV latches are closed and final processing can be accomplished. During the third quarter cycle, the address for the next instruction is output to the I/O (IV) bus, control signals are generated, and $1 / O$ data is setup for the output
phase. During the fourth quarter cycle, a master clock signal (MCLK) generated by the $8 \times 300$ is used to latch valid address or data into peripheral devices connected to the IV bus; MCLK is also used to synchronize any external logic with timing circuits of the $8 \times 300$. To summarize the action, the first half of the instruction cycle deals primarily with input functions and the second half is mostly concerned with output functions.


Figure 3. Instruction Cycle and MCLK with: Crystal $=\mathbf{8 M H z}$ and Cycle Time $=250 \mathrm{~ns}$

## INSTRUCTION SET

## General Format and Basic Operations

The 16 -bit instruction word ( 10 through 15) from program storage is input to the instruction register (Figure 1) and is
subsequently decoded to implement the events to occur during the current instruction cycle. The instruction word is formatted as follows:


Rather than discrete instructions, the three operation code (OP CODE) bits specify eight instruction classes. Each instruction class is subject to a number of powerful variations; these variations are specified by the thirteen operand bits. General areas of control for the eight instruction classes are:

- Arithmetic and Logic Operations (ADD, AND, AND XOR)
- Movement of Data and Constants (MOVE and XMIT)
- Branch or Test (JMP, NZT, and XEC)

Basic operations for each of the eight instruction classes are as follows; a summary of the instruction set is provided in Table 1.

MOVE-data in source register or I/O-bus input is moved to destination register or I/O-bus output. Data can be shifted any number of places and/or masked to any length.

ADD-data in source register or I/O-but input is added to content of AUX (RO) register and the result is placed in the destination register or I/O-bus output. Data can be shifted and/or masked, as required.

Table 1. SUMMARY OF $8 \times 300$ INSTRUCTION SET

| $\begin{gathered} \text { INSTRUC } \\ \text { CLASS } \end{gathered}$ | OPCODE | FORMATS | DESCRIPTION | $\begin{gathered} \text { I/O CONT } \\ \text { SIG } \end{gathered}$ | STATE OF CONTROL SIGNAL DURING INSTRUCTION CYCLE |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | INPUT PHASE (INSTRUCTION INPUT \& DATA PROCESSING) | OUTPUT PHASE (ADDRESS \& I/O BUS) |
| move | 0 | F1: Register to Register <br> Invalid values of " S "; $07_{8} \cdot 17_{8} \cdot 20_{8}-37_{8}$ <br> Invalid values of "D": $10_{8} \cdot 20_{8}-37_{8}$ | $(S)-D$ <br> Move content of internal register specified by S -field to internal register specified by D -field. Prior to the "MOVE" operation, right-rotate contents of internal source register by octal value ( 0 through 7 ) defined by the $R$-field. | $\begin{aligned} & S C= \\ & W C= \\ & \frac{L B}{L B}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & H \text { if "D" }{ }^{2}=07_{8},{ }^{17} 8 \\ & L \\ & H \text { if "D" }=17_{8} \\ & L \text { if "D" }=07_{8} \end{aligned}$ |
|  |  |  | Move right-rotated $1 / 0$ bus (source) data specified by the S -field to internal register specified by the D-field. The L-field specifies the length of source data starting from the LSB-position and, if less than 8 -bits, the remaining bits are filled with zeroes. | $\begin{aligned} & S C= \\ & W C= \\ & \frac{\mathrm{LB}}{\mathrm{LB}}= \\ & \mathrm{LB}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \text { if "S" }=20_{8}-27_{8} \\ & H \text { if "S" }=30_{8}^{-37} 8 \end{aligned}$ | $\begin{aligned} & H \text { if "D" }=07_{8}, 17_{8} \\ & L \\ & H \text { if "D" }=17_{8} \\ & L \text { if "D" }=07_{8} \end{aligned}$ |
|  |  |  | Move contents of internal register specified by the S-field to the I/O latches. Before outputting on I/O bus, data is shifted as specified by the least significant octai digit of the Dfield and the bits specified by the L-field are merged with the latched //O data. | $\begin{aligned} & S C= \\ & W C= \\ & \overline{C B}= \\ & \overline{L B}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \text { if " } D "=20_{8}-27_{8} \\ & H \text { if "D" }=30_{8}^{-37_{8}} 8 \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \text { if " } D \text { " }=20_{8}-27_{8} \\ & H \text { if " } D "=30_{8}-37_{8} \end{aligned}$ |
|  |  |  | Move right rotated I/O-bus (source) data specified by the S-field to the I/O latches. Before outputting on I/O bus, shift data as specified by the D-field; then merge source and latched I/O data as specified by the $L$ (length) field. | $\begin{aligned} & S C= \\ & W C= \\ & \frac{L B}{L B}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \text { if " } D "=20_{8}-278 \\ & H \text { if "D" }=30_{8}^{-37} 8 \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & H \\ & L \text { if " } D "=20_{8}-27_{8} \\ & H \text { if " } D "=30_{8}-37_{8} \end{aligned}$ |

Table 1. SUMMARY OF $8 \times 300$ INSTRUCTION SET (Continued)

| instruc CLASS | OPCODE | FORMATS |  |  |  | DESCRIPTION | $\begin{aligned} & \text { I/O CONT } \\ & \text { SIG } \end{aligned}$ | STATE OF CONTROL SIGNAL DURING INSTRUCTION CYCLE |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | INPUT PHASE (INSTRUCTION INPUT : DATA PROCESSING) |  | OUTPUT PHASE (ADDRESS : I/O BUS) |
| ADD | 1 | Same as MOVE instruction class |  |  |  |  | (S) plus (AUX) $\rightarrow D$ <br> Same as MOVE instruction class except that contents of AUX (RO) register are ADDed to the source data. If there is a "carry" from MSB, then OVF (overflow) $=1$, otherwise OVF $=0$. | Same as MOVE instruction class |  |  |
| AND | 2 | Same as MOVE instruction class |  |  |  | $(S) \wedge(A \cup X) \rightarrow D$ <br> Same as MOVE instruction class except that contents of AUX (RO) register are ANDed with source data. | Same as MOVE instruction class. |  |  |
| XOR | 3 | Same as MOVE instruction class |  |  |  | (S) $\qquad$ (AUX) $\rightarrow$ D <br> Same as MOVE instruction class except that contents of AUX (RO) register are exclusively ORed with source data. | Same as MOVE instruction class. |  |  |
| XEC | 4 | F3: Register <br> Invalid valu $0_{8},{ }^{17} 8$ Valid values $0_{8}{ }^{-37}$ | Immediate $\begin{aligned} & \text { es of "S": } \\ & 20_{8}-378 \\ & \text { s of "J": } \\ & 78 \end{aligned}$ |  | 12 13 14 15 <br> $J$    | Execute instruction at current page address offset by $J$ (literal) + (S). Return to normal Instruction flow unless a branch is encountered. <br> Execute instruction at an address determined by replacing the low-order 8 -bits of the Program Counter with the following derived sum: <br> - Value of literal (J-field) plus <br> - Contents of internal register specified by Sfield <br> The PC is not incremented and the overflow status (OVF) is not changed. | $\begin{aligned} & S C= \\ & W C= \\ & L B= \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{X} \end{aligned}$ | $\begin{array}{\|l} \mathrm{L} \\ \mathrm{~L} \\ \mathrm{X} \end{array}$ |
|  |  | $\begin{aligned} & \text { Valid values of "S": } 20_{8}^{-378} \\ & \text { Valid values of " } \mathrm{J} \text { ": } 00_{8}^{-37} 8 \end{aligned}$ |  |  |  | Execute instruction at an address determined by replacing the low-order 5-bits of Program Counter with the following derived sum: <br> - 5-bit value of literal (J-field) plus <br> - Value of rotated source data specified by S-field (The L-field specifies the length of source data starting from the LSB-position and, if less than 8 -bits, the remaining bits are filled with zeros; the Program Counter is not incremented and the overflow status (OVF) is not changed.) | $\begin{aligned} & S C= \\ & W C= \\ & \frac{L B}{L B}= \\ & \frac{1 B}{}= \end{aligned}$ | L <br> L <br> $L$ if " S " $=20_{8}-27_{8}$ <br> $H$ if " S " $=30_{8}^{-37_{8}}$ | $\begin{array}{\|l} \hline L \\ L \\ X \\ X \end{array}$ |
| NZT | 5 | F3: Reglater0.2 <br> OPCODE$\begin{aligned} & \text { Invalid values } \\ & \text { Valid values }\end{aligned}$ |  | 891011 <br>  <br>  <br> 178.2088 <br> $77_{8}$ |  | If data specified by the S -field is not equal to zero, jump to current page address offset by value of J-field; otherwise, increment the Program Counter. <br> If contents of internal register specified by Sfield is non-zero, transfer to address determined by replacing the low-order 8 -bits of Program Counter with " J ", otherwise, increment PC. | $\begin{aligned} & \mathrm{SC}= \\ & \mathrm{WC}= \\ & \overline{\mathrm{LB}}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & X \end{aligned}$ | $\left\lvert\, \begin{aligned} & \mathrm{L} \\ & \mathrm{x} \end{aligned}\right.$ |
|  |  | F4: 1/O BusO12 <br> OPCODE$\begin{aligned} & \text { Valid values } \\ & \text { Valid values }\end{aligned}$ |  | 8 9 10 <br>  $L$  <br> 8   <br> 8   <br> 8   | [1112131415 | If right-rotated I/O bus data is non-zero, transfer to address determined by replacing loworder 5 -bits of Program Counter with " J ", otherwise, increment PC. (The L-field specifies the length of source $1 / O$ data starting from the LSB-position and, if less than 8 -bits, the remaining bits are filled with zeroes.) | $\begin{aligned} & S C= \\ & W C= \\ & \overline{L B}= \\ & \overline{L B}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \text { if } S^{\prime \prime}=20_{8}-27_{8} \\ & H \text { if "S" }=30_{8}-37_{8} \end{aligned}$ | $\begin{array}{\|l\|} \hline L \\ L \\ X \\ X \\ \hline \end{array}$ |
| XMIT | 6 | F3: Register0.12  <br> OPCODE  <br> $\begin{array}{l}\text { Invalid values } \\ \text { Valid value }\end{array}$  |  |  | 12131415 | Transmit J $\rightarrow$ D <br> Transmit and store 8-bit binary pattern in Jfield to internal register specified by D-field. | $\begin{aligned} & S C= \\ & W C= \\ & \overline{L B}= \\ & \overline{L B}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & H \text { if } D=07_{8} \text { or } 17_{8} \\ & L \\ & H \text { if } D=17_{8} \\ & L \text { if } D=07_{8} \end{aligned}$ |
|  |  | F4: 1/O Bus <br> Valid value Valid value |  | 8 9 10 <br>  1  <br> 8   <br> 8   <br> 8   | 1112131415 <br> J | Transmit binary pattern in J-field to I/O bus. Before putting data on I/O bus, shift literal value " J " as specified by the D -field and merge bits specified by the L-field with existing I/O bus data. If the L-field specifies more than 5 bits starting from the LSB-position, all remaining bits are set to zero. | $\begin{aligned} & S C= \\ & W C= \\ & \overline{L B}= \\ & \overline{L B}= \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \text { if } D=20_{8}-27_{8} \\ & H \text { if } D=30_{8}-37_{8} \end{aligned}$ | L <br> H <br> $L$ if $D=20_{B}-27_{8}$ <br> $H$ is $D=30_{8}-37_{8}$ |
| JMP | 7 | F5: Address <br> O 12 <br> OPCODE. <br> Valid value | Immediate <br> 134567 | $\frac{891011}{\text { A }}$ | $\begin{array}{lll} 12 \quad 13 \quad 14 \quad 15 \end{array}$ | Jump to address in program storage specified by A-field; this address is loaded into the Address Register and the Program Counter. | $\begin{aligned} & \mathrm{SC}= \\ & \mathrm{WC}= \\ & \overline{\mathrm{LB}}= \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & X \end{aligned}$ |

NOTES $\cdot \overline{\mathrm{RB}}$ is complement of $\overline{L B}, X=$ Undefined

AND-data in source register or I/O-bus input is ANDed with content of AUX (RO) register and the result is placed in the destination register or $1 / 0$-bus output. Data can be shifted and/or masked, as required.

XOR-data in source register or I/O-bus input is exclusively ORed with contents of AUX (RO) register and the result is placed in the destination register or $1 / O$-bus output. Data can be shifted and/or masked, as required.
XMIT-immediate data field of instruction word replaces data in destination register or I/O-bus output.
XEC-executes instruction at the program address which is formed by replacing the least significant bits of the last address with the sum of:

- Literal (J) field value of instruction plus,
- Value of data in source register or $1 / \mathrm{O}$-bus input.

NZT-least significant bits of program address are replaced by literal ( J ) field of instruction if the source register or I/O-bus is not equal to zero.
JMP—program address is replaced by address field of the instruction word.

## Instruction Fields

As shown in Table 1, each instruction contains an operations
code (OPCODE) field and from one-to-three operand fields. The operand fields are: Source (S), Destination (D), Rotate/ Length (R/L), Literal (J), and Address (A). The OPCODE and operand fields are briefly described in the following paragraphs.

Operations Code Field: The three-bit OPCODE field specifies one of eight classes of $8 \times 300$ instructions; octal designations for this field and operands for each instruction class are shown in Table 1.

Source (S) and Destination (D) Fields: The five-bit (S) and (D) fields specify the source and destination of data for the operation defined by the OPCODE field. The AUXiliary (RO) register is an implied second operand for the ADD, AND, and XOR instructions, each of which require two source fields. That is, instructions of the form:
ADD X, Y
imply a third operand, say $Z$, located in the $A U X(R O)$ register. Thus, the operation for the preceding expression is actually $(X+Z)$, with the result stored in $Y$. The ( $S$ ) and / or (D) fields can specify an internal $8 \times 300$ register or any one-to-eight bit I/O field; octal values for these registers and Source / Destination field assignments are provided in Table 2.

Table 2. OCTAL ADDRESSES OF 8X300 REGISTERS AND ADDRESS/BIT ASSIGNMENTS OF SOURCE/DESTINATION FIELDS

| Octal Value | 8×300 Register | Octal Value | $8 \times 300$ Register |
| :---: | :---: | :---: | :---: |
| 00 | Auxiliary (RO) | 10 | OVF (Overflow Register)used only as a source |
| 01 | R1 | 11 | R11 |
| 02 | R2 | 12 | Unassigned |
| 03 | R3 | 13 | Unassigned |
| 04 | R4 | 14 | Unassigned |
| 05 | R5 | 15 | Unassigned |
| 06 | R6 | 16 | Unassigned |
| 07 | *IOL Register-Left Bank <br> I/O Address Register; Used only as destination | 17 | *IOR Register-Right Bank I/O Address Register; Used only as destination |

NOTE
*If IOL or IOR is specified as a source of data, the source data is all zeroes.


Rotate (R) and Length (L) Field: The three-bit R/L field performs one of two functions, specifying either the field length ( $L$ ) or a right-rotate (R). For a given instruction, the specified function depends upon the contents of the source $(S)$ and destination (D) fields.

- When an internal register is specified by both the source and destination fields, the (R) field is invoked and it specifies a right-rotate of the data specified in the ( $S$ ) field-see accompanying diagram. The source-register data (up to eight-bits) is right-rotated within one instruction cycle. (The right-rotate function is implemented on the bus and not in the source register.)

RIGHT-ROTATE FUNCTION


- When either or both of the source and destination fields specify a variable-length $1 / O$ data field, the ( L ) field specifies the length of the I/O data field-see accompanying diagram. If the source field specifies an $1 / O$ address ( $208^{-}$ $37_{8}$ ) and the destination field specifies an internal register $\left(00_{8}-06_{8}, 07_{8}, 11_{8}\right.$, or $178_{8}$ ), the L-field specifies the length of source data; the source data is formed by right-rotating the I/O bus data according to the source address (Table 2) and then masking result as specified by L-field. If length is less than eight-bits, all remaining bits are set to zero prior to processing data in the ALU. If the source field specifies an internal register $\left(0_{8},-06_{8}, 10_{8}\right.$, or $118_{8}$ ) and the destination field specifies $I / O$ bus data ( $20_{8}-37_{8}$ ), the $L$ field specifies the length of the destination data. To form the destination data, the ALU output is left-shifted according to the destination address (Table 2) and then masked to the required length - see DATA LENGTH SPECIFICATION. The destination data is merged with data in the I/O latches to finalize the I/O bus data. Hence, a one-to-eight bit destination data field can be inserted into the existing eight-bit I/O port without modifying surrounding bits. If both the source and destination fields specify I/O bus data ( $20_{8}-37_{8}$ ), the Lfield specifies the length of both the source and destination data.


## DATA LENGTH SPECIFICATION



To form the source data, the I/O bus data is right-rotated according to the source address (Table 2) and then masked to the required length-see preceding DATA LENGTH SPECIFICATION. If length is less than eight-bits, all remaining bits are set to zero before processing in the ALU. To form the destination data, the ALU output is left-shifted according to the destination address (Table 2) and masked to the required length specification. The destination data is then merged into the I/O bus data that was used to obtain the source; thus, if the source and destination addresses are on the same bank, the I/O bus data written to the destination register appears unmodified, except for bits changed during the shift-and-mask operations. If the source and destination addresses refer to different banks, the destination register is changed to contain the contents of the source register in those bit positions not affected by the destination data.
J-Field: The 5 -bit or 8 -bit ( J ) field is used to load a literal value (contained in the instruction) into a register, into a variable I/O data field, or to modify the low-order bits of the Program Counter. The bit-length of the ( J ) field is implied by the (S) field in the XEC, NZT, and XMIT instructions, based on the following considerations.

- When the source ( $S$ ) field specifies an internal register, the literal value of the $J$-field is an 8 -bit binary number.
- When the source ( S ) field specifies a variable $1 / 0$ data field, the literal value of the $J$-field is a 5 -bit binary number.
A-Field: The 13-bit (A) field is an address field which allows the $8 \times 300$ to directly address up 8192 locations in Program Storage memory.


## INSTRUCTION SEQUENCE CONTROL

## Formation of Instruction Address

The Address Register and Program Counter are used to generate addresses for accessing an instruction from program storage. The instruction address is formed in any one of four ways:

- For all except the JMP, XEC, and a "satisfied" NZT instruction, the Program Counter is incremented by one and placed in the Address Register.
- For the JMP instruction, the 13 -bit A-field contained in the JMP instruction word replaces the contents of both the Address Register and Program Counter.
- For the XEC instruction, the Address Register is loaded with the high-order bits of the Program Counter modified as follows:
XEC using I/O Bus Data: low order 5-bits of ALU output replaces counterpart bits in Address Register.
XEC using Data from Internal Register: low order 8-bits of ALU output replaces counterpart bits in Address Register.
The Program Counter is not modified for either of the above conditions.
- For a "satisfied" NZT instruction, the low order 5 -bits (NZT source is I/O Bus Data) or low order $8 /$ bits (NZT source is an Internal Register) of both the Address Register and Program Counter are loaded with the literal value specified by J -field of the instruction word.


## Data Addressing

The source and/or destination addresses of the data to be operated upon are specified as part of the instruction word. As shown in Table 3, source/destination addresses are specified using a five-bit address $\mathrm{O}_{8}$ through 378 ). When the most significant octal digit is a 0 or 1 , the source and / or destination address is an internal register; if the most significant digit is a 2 or 3 , an $1 / O$ bus address is indicated- -2 specifying a left-bank (LB) address and 3 specifying a rightbank (RB) address. The least significant octal digit ( 0 through 7) indicates either a specific internal register address or positioning information for the least significant bit when specifying $1 / O$ bus data. Referring to Table $i$, the AUXiliary register ( 00 ) is the implied source of the second argument for the ADD, AND, and XOR operations. IOL (destination address 078 ) and IVR (destination address 178) provide a means of routing address information to $/ / O$ registers. With IOL or IOR specified as the destination address, the data is placed on the I/O bus during the output phase of the instruction cycle. Simultaneously, a select command (SC) is generated to inform all $1 / O$ devices that information on the $1 / O$ bus is to be considered as an $1 / 0$ address. Since 10 L and IOR are not harware registers, they should never be specified as a source address.

Control outputs $\overline{\mathrm{LB}}$ and $\overline{\mathrm{RB}}$ are used to partition $1 / O$ bus devices into two fields of 256 addresses. With LB in the active-low state and a source address of $20_{8}-278$, the left bank of $1 / O$ devices are enabled during the input phase of the instruction cycle. With $\overline{R B}$ in the active-low state and a source address of $308-378$, the right bank of devices are enabled. During the output phase, $\overline{R B}$ is low if the destination address is $\operatorname{IOR}\left(17_{8}\right)$ or $30_{8}-37_{8} ; L B$ is low if the destination address is $10 \mathrm{~L}\left(07_{8}\right)$ or $208-278$. Each address field
( $\overline{\mathrm{LB}}$ and $\overline{\mathrm{RB}}$ ) can have a different $1 / O$ device selected; thus, two devices can be directly accessed within one instruction cycle.
Table 3. SOURCE/DESTINATION ADDRESSES


## DESIGN PARAMETERS

Hardware design of ani $8 \times 300$-based system largely consists of the following operations:

- Selecting and interfacing a Program Storage device ROM, PROM, etc. (Pins 2 through 9 and 45 through 49 for 13-bit address interface; Pins 13 through 28 for 16 bit instruction interface.)
- Selecting and interfacing Input/Output devicesRAM, Multiplexers, 1/O Ports, and other eight-bit addressable 1/O devices. (Pins 33 through 36 and pins 38 through 41 for eight-bit $1 / 0$ interface.)
- Choosing and implementing System Clock---Capaci-tor-Controlled, Crystal-Controiled, or Externally-Driyen. (Pins 10 and 11 for System Clock interface.)
- Selection of 5-volt power supply and off-chip seriespass transistor.
- External logic, as required, to meet the control requirements of a particular application.

All information required for easy implementation of these design requirements is provided under the following captions.

- DC Characteristics
- AC Characteristics
- Timing Considerations
- Clock Considerations
- HALT/RESETLogic
- Voltage Regulator

DC CHARACTERISTICS (Commercial Part) $4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$

|  | PARAMETER | TEST CONDITIONS | LImits |  |  | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\text {cc }}$ | Supply voltage |  | 475 | 5.0 | 5.25 | V | $5 \mathrm{~V} \pm 5 \%$; pin 37 only |
| $\mathrm{V}_{\mathrm{IH}}$ | High level input voltage |  | $\begin{aligned} & 0.6 \\ & 2.0 \end{aligned}$ |  | 2.0 | V | $\begin{aligned} & \mathrm{X} 1 \text { and } \mathrm{X} 2 \\ & \text { All other pins } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Low level input voltage |  |  |  | $\begin{aligned} & 0.4 \\ & 0.8 \end{aligned}$ | V | $\begin{aligned} & \mathrm{X} 1 \text { and } \mathrm{X} 2 \\ & \text { All other pins } \end{aligned}$ |
| VOH | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=\min ; \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 3.0 |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{min} ; I_{\mathrm{OL}}=6 \mathrm{~mA} \\ & V_{\mathrm{CC}}=\mathrm{min} ; \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.39 \\ & 0.39 \end{aligned}$ | $\begin{aligned} & 0.55 \\ & 0.55 \end{aligned}$ | V | AO through A12 <br> All other outputs |
| $\mathrm{v}_{\mathrm{CR}}$ | Regulator voltage | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |  | 3.1 |  | $v$ | From series-pass transistor |
| $\mathrm{V}_{1 \mathrm{C}}$ | Input clamp voltage | $\mathrm{V}_{\mathrm{CC}}=\min ; \mathrm{I}_{1 \times}=-10 \mathrm{~mA}$ |  |  | -1.5 | v | Crystal inputs X1 and X2 do not have internal clamp diodes. |
| IIH | High-level input current | $\begin{aligned} V_{C C}=\max ; & V_{\mathbb{H}}=0.6 \mathrm{~V} \\ V_{\mathbb{I}} & =4.5 \mathrm{~V} \end{aligned}$ |  | 1 | $\begin{aligned} & 3.0 \\ & 50 \end{aligned}$ | ${ }_{\mu \mathrm{A}}^{\mathrm{mA}}$ | X 1 and X 2 <br> All other pins |
| ILL | Low-level input current | $\mathrm{V}_{\mathrm{CC}}=$ max; $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |  | $\begin{aligned} & -0.13 \\ & -0.67 \\ & -0.23 \end{aligned}$ | $\begin{gathered} -3 \\ -0.2 \\ -1.6 \\ -0.4 \end{gathered}$ | mA | $\begin{aligned} & \hline \frac{X 1 \text { and } X 2}{1 V 0-\overline{V 7}} \\ & \frac{10-115}{\text { HALT and } \overline{\text { RESET }}} \end{aligned}$ |
| Ios | Short circuit output current | $V_{C C}=\max ; V_{C R}=V_{C R H}$ (Note: At any time, no more than one output should be connected to ground.) | -30 |  | -140 | mA | All output pins |
| ICC | Supply current | $\mathrm{V}_{\mathrm{CC}}=$ max; $\mathrm{V}_{\mathrm{CR}}=\mathrm{V}_{\mathrm{CRH}}$ |  |  | 160 | mA |  |
| IREG | Regulator control | $V_{C C}=5.0 \mathrm{~V}$ | -14 |  | -21 | mA |  |
| ICR | Regulator current | $V_{C C}=\max$ |  |  | 230 | mA | $70^{\circ} \mathrm{C}$ |
|  |  |  |  |  | 265 | mA | $25^{\circ} \mathrm{C}$ |
|  |  |  |  |  | 290 | mA | $0^{\circ} \mathrm{C}$ |

NOTES:

1. Operating temperature ranges are guaranteed after thermal equilibrium has been 2. All voltages measured with respect to ground terminal. reached.

AC CHARACTERISTICS (Commercial Part) CONDITIONS: $V_{C C}=5 \mathrm{~V}( \pm 5 \%), V_{I N}=0 \mathrm{~V}$ or $3 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ LOADING: (See test circuits)

|  | PARAMETER (NOTE 1) | LIMITS (INSTRUCTION CYCLE TIME = 250 ns ) |  |  | LIMITS (INSTRUCTION CYCLE TIME > 250 ns) |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| TPC | Processor cycle time | 250 |  |  | 250 |  |  | ns |  |
| $T_{\text {TPP }}$ | X1 clock period | 125 |  |  | 125 |  |  | ns |  |
| ${ }^{\text {T }} \mathrm{CH}$ | X1 clock high time | 62 |  |  | 62 |  |  | ns |  |
| $\mathrm{T}_{\mathrm{CL}}$ | X1 clock low time | 62 |  |  | 62 |  |  | ns |  |
| TMCH | MCLK high delay | 31 | 42 | 52 | 31 | 42 | 52 | ns |  |
| $\mathrm{T}_{\mathrm{MCL}}$ | MCLK low delay | 31 | 42 | 52 | 31 | 42 | 52 | ns |  |
| TW | MCLK pulse width | 55 | 62 | 69 | $T_{4 Q}{ }^{-7}$ | $\mathrm{T}_{4} \mathrm{Q}$ |  | ns | Note 2 |
| $\mathrm{T}_{\text {AS }}$ | X1 falling edge to address stable | 50 | 63 | 80 | 50 | 63 | 80 | ns | Note 7 |

AC CHARACTERISTICS (Commercial Part) (Continued)

|  | PARAMETER (NOTE 1) | LIMITS (INSTRUCTION CYCLE TIME $=250 \mathrm{~ns}$ ) |  |  | LIMITS (INSTRUCTION CYCLE TIME > 250 ns) |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| TMAS | MCLK falling edge to address stable | 130 | 143 | 160 | $\begin{array}{c\|} \hline T_{1 Q}+T_{2} Q \\ +5 \\ \hline \end{array}$ | $\begin{array}{\|c} \hline \mathrm{T}_{1} \mathrm{Q}+\mathrm{T}_{2 \mathrm{Q}} \\ +18 \\ \hline \end{array}$ | $\begin{gathered} \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}} \\ +35 \end{gathered}$ | ns | Notes 2, 3, \& 7 |
| TIA | Instruction to address |  |  | 170 |  |  | $\mathrm{T}_{2} \mathrm{Q}^{+108}$ | ns | Notes 2, 3, \& 8 |
| TIVA | Input data to address |  |  | 105 |  |  | 105 | ns | Notes 3 \& 9 |
| TIS | Instruction set-up time (X1 rising edge) | -7 |  |  | -7 |  |  | ns | Note 10 |
| TMIS | MCLK falling edge to instruction stable |  |  | 20 |  |  | $\mathrm{T}_{1 Q^{-42}}$ | ns | Notes 2, 4, \& 10 |
| ${ }^{T} /{ }_{H}$ | Instruction hold time ( X 1 rising edge) | 45 |  |  | 45 |  |  | ns | Note 11 |
| $\mathrm{T}_{\text {MIH }}$ | Instruction hold time) (MCLK falling edge) | 60 |  |  | $\mathrm{T}_{1 Q^{-2}}$ |  |  | ns | Notes 2 \& 11 |
| TWH | $X 1$ falling edge to SC / WC rising edge | 40 | 49 | 58 | 40 | 49 | 58 | ns |  |
| TMWH | MCLK falling edge to $\mathrm{SC} / \mathrm{WC}$ rising edge | 125 | 130 | 135 | $\mathrm{T}_{1} \mathrm{Q}+\mathrm{T}_{2} \mathrm{Q}$ | $\begin{gathered} \hline \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}} \mathrm{Q} \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{T}_{1} \mathrm{Q}+\mathrm{T}_{2 \mathrm{Q}} \mathrm{Q} \\ +10 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | Note 2 |
| TWL | X 1 falling edge to SC/WC falling edge | 40 | 49 | 58 | 40 | 49 | 58 | ns |  |
| TMWL | MCLK falling edge to SC/WC falling edge | 5 | 7 | 15 | 5 | 7 | 15 | ns |  |
| TIBS | X 1 falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Input phase) | 48 | 60 | 70 | 48 | 60 | 70 | ns |  |
| TMIBS | MCLK falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Input phase) | 7 | 17 | 25 | 7 | 17 | 25 | ns |  |
| TIIBS | Instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (input phase) |  | 27 | 35 |  | 27 | 35 | ns |  |
| ${ }^{\text {T OBS }}$ | X 1 falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Output phase) | 48 | 60 | 70 | 48 | 60 | 70 | ns |  |
| TMOBS | MCLK falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Output phase) | 132 | 137 | 147 | $\begin{gathered} \mathrm{T}_{10}+\mathrm{T}_{2 Q} \\ +7 \end{gathered}$ | $\begin{gathered} \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}} \mathrm{Q} \\ +12 \\ \hline \end{gathered}$ | $\begin{gathered} T_{1} \mathrm{Q}+\mathrm{T}_{2 \mathrm{Q}} \mathrm{Q} \\ +22 \end{gathered}$ | ns | Note 2 |
| TIDS | Input data set-up time ( X 1 falling edge) | 25 | 16 |  | 25 | 16 |  | ns |  |
| $\mathrm{T}_{\text {MIDS }}$ | MCLK falling edge to input data stable |  | 65 | 55 |  | $\begin{gathered} \mathrm{T}_{1} \mathrm{Q}^{+} \mathrm{T}_{2 \mathrm{Q}} \mathrm{Q} \\ -60 \end{gathered}$ | $\begin{gathered} \mathrm{T}_{10}+\mathrm{T}_{20} \\ -70 \\ \hline \end{gathered}$ | ns | Notes 2 \& 5 |
| TIDH | Input data hold time ( X 1 falling edge) | 40 | 30 |  | 40 | 30 |  | ns |  |
| $\mathrm{T}_{\text {MDIH }}$ | Input data hold time (MCLK falling edge) | 125 | 112 |  | $\mathrm{T}_{1} \mathrm{Q}+\mathrm{T}_{2} \mathrm{Q}$ | $\begin{gathered} \hline \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}} \mathrm{Q} \\ -13 \\ \hline \end{gathered}$ |  | ns | Note 2 |
| TODH | Output data hold time ( X 1 falling edge) | 55 | 65 | 75 | 55 | 65 | 75 | ns |  |
| TMODH | Output data hold time (MCLK falling edge) | 11 | 20 | 25 | 11 | 20 | 25 | ns |  |
| TODS | Output data stable ( X 1 falling edge) | 74 | 84 | 94 | 74 | 84 | 94 | ns | Notes 12, 14, \& 15 |
| TMODS | Output data stable (MCLK falling edge) | 150 | 160 | 170 | $\begin{gathered} \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2} \mathrm{Q} \\ +25 \\ \hline \end{gathered}$ | $\begin{gathered} T_{1 Q}+T_{2 Q} \\ +35 \end{gathered}$ | $\begin{gathered} \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}} \\ +45 \end{gathered}$ | ns | Notes 2, 12, $14, \& 15$ |

AC CHARACTERISTICS (Commercial Part) (Continued)

|  | PARAMETER (NOTE 1) | LIMITS (INSTRUCTION CYCLE TIME = 250 ns) |  |  | LIMITS (INSTRUCTION CYCLE TIME > 250 ns ) |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| TDD | Input data to output data | 104 | 120 | 136 | 104 | 120 | 136 | ns | Notes 13 \& 15 |
| THS | $\overline{\text { HALT set-up time }}$ ( X 1 rising edge) | 0 |  |  | 0 |  | " | ns |  |
| TMHS | MCLK falling edge to HALT falling edge |  |  | 18 |  |  | $T_{1 Q}{ }^{-44}$ | ns | Notes 2 \& 6 |
| THH | $\overline{\text { HALT }}$ hold time ( X 1 rising edge) | 32 |  |  | 32 |  |  | ns |  |
| TMHH | $\overline{\text { HALT }}$ hold time (MCLK falling edge) | 50 |  |  | $\mathrm{T}_{1 Q} \mathrm{Q}^{-12}$ |  |  | ns | Note 2 |
| $\mathrm{T}_{\mathrm{ACC}}$ | Program storage access time |  |  | 80 |  |  |  | ns |  |
| TIO | I/O port output enable time ( $\overline{L B} / \overline{R B}$ to valid IV data input) |  |  | 30 |  |  |  | ns |  |

NOTES:

1. $X 1$ and $X 2$ inputs are driven by an external pulse generator with an amplitude of 1.5 volts; all timing parameters are measured at this voltage level.
2. Respectively, $T_{1 Q}, T_{2 Q}, T_{3 Q}$, and $T_{4 Q}$ represent time intervais for the first, second, third, and fourth quarter cycles.
3. Capacitive loading for the address bus is 150 picofarads
4. Same as TIS but referenced to falling edge of MCLK.
5. Same as TIDS but referenced to falling edge of MCLK.
6. Same as THS but referenced to falling edge of MCLK.
7. TAS is obtained by forcing a valid instruction and an I/O bus input to occur earlier than the specified minimum set-up time; the TAS parameter then represents the earliest time that the address bus is valid.
8. TIA is obtained by forcing a valid instruction input to occur earlier than the minimum set-up time.
9. TIVA is obtained by forcing a valid $1 / O$ bus input to just maet the minimum set-up time.
10. TMAIS represents the set-up time required by internal latches of the 8×300. In system applications, the instruction input may have to be valid before the worst-case set-up time in order for the system to respond with a valid I/O bus input that meets the I/O bus input set-up time (TIDS and TMIDS).
11. TIH represents the hold time required by internal latches of the $8 \times 300$. To generate proper LB/RB signals, the instruction must be held valid until the address bus changes.
12. TODS is obtained by forcing a valid $1 / O$ bus input to occur earlier than the $1 / O$ bus input set-up time (TIDS); this timing parameter represents the earliest time that the 1/O output data cen be valid.
13. TDD is obtained by forcing a valid $/ / \mathrm{O}$ bus input to just meet the minimum $1 / \mathrm{O}$ bus input set-up time; thus timing parameter represents the latest time that the I/O output data can be valid.
14. The minimum figure for theee parameters represents the earliest time that $1 / O$ bus output drivers of the $8 \times 300$ will turn on.
15. For TIDS $\geq 35 \mathrm{~ns}$, YODS or TMODS should be used to determine when the output data is stable.

## TEST CIRCUITS



DC CHARACTERISTICS (Military Part)
$\mathrm{S} 8 \times 300-1-40^{\circ} \mathrm{C} \leq \mathrm{TC} \leq 100^{\circ} \mathrm{C} V_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$
$\mathrm{S} 8 \times 300-2-20^{\circ} \mathrm{C} \leq \mathrm{TC} \leq 100^{\circ} \mathrm{C} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{1}$ | High level input voltage X 1 , X2 <br> All others |  |  | $\begin{aligned} & 0.6 \\ & 2.0 \end{aligned}$ |  |  | v |
| $\mathrm{V}_{\text {IL }}$ | Low level input voltage $\mathrm{X} 1, \mathrm{X} 2$ <br> All others |  |  |  | $\begin{aligned} & 0.4 \\ & 0.8 \end{aligned}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ |
| V IC | Input clamp voltage (Notes 1\&5) | $\begin{aligned} & V_{C C}=\min \\ & I_{I}=-10 \mathrm{~mA} \end{aligned}$ |  |  | -1.5 | v |
| $\mathrm{IIH}^{\text {H }}$ | High level input current $\mathrm{X}_{1}, \mathrm{X}_{2}$ <br> All others | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\max \\ & \mathrm{V}_{\mathrm{IH}}=0.6 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=\max \\ & \mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{aligned} & 3.0 \\ & 0.05 \end{aligned}$ | mA |
| IL | Low level input current X1, X2 | $\begin{aligned} & V_{C C}=\max \\ & V_{I L}=0.4 \mathrm{~V} \end{aligned}$ |  |  | -3.0 | mA |
|  | $\overline{\mathrm{IVO}}-\overline{\mathrm{IV7}}$ | $\begin{aligned} & V_{C C}=\max \\ & V_{\mathrm{IL}}=0.4 \mathrm{~V} \end{aligned}$ |  |  | -0.3 | mA |
|  | $10-115$ | $\begin{aligned} & V_{C C}=\max \\ & V_{\text {IL }}=0.4 \mathrm{~V} \end{aligned}$ |  |  | -1.6 | mA |
|  | $\overline{\text { HALT, }}$ RESET | $\begin{aligned} & V_{C C}=\max \\ & V_{\text {IL }}=0.4 \mathrm{~V} \end{aligned}$ |  |  | -0.4 | mA |
| VOL | Low level output voltage AO-A 12 <br> All others | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{min} \\ & \mathrm{~L}=4.25 \mathrm{~mA} \\ & \mathrm{VCC}_{\mathrm{CC}}=\mathrm{min} \\ & \mathrm{OL}=16 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & 0.55 \\ & 0.55 \end{aligned}$ | $\begin{gathered} \text { v } \end{gathered}$ |
| VOH | High level output voltage | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\min \\ \mathrm{IOH} & =-3 \mathrm{~mA} \end{aligned}$ | 2.4 |  |  | V |
| los | Short circuit output current (Note 2) | $\mathrm{V}_{\text {CC }}=$ max | -30 |  | -140 | mA |
| ICC | Supply current (Note 4) | $V_{C C}=\max$ |  |  | 160 | mA |
| Ireg | Regulator control | $V_{C C}=5.0 \mathrm{~V}$ | -14 |  | -21 | mA |
| ICR | Regulator current | $\mathrm{V}_{\text {CC }}=$ max |  |  | 285 | mA |
| ICR | Regulator current | $\begin{aligned} & \mathrm{TC} \geq 25^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=\max \end{aligned}$ |  |  | 330 | mA |
| $\mathrm{V}_{\mathrm{CR}}$ | Regulator voltage | $\begin{gathered} \mathrm{TC}<25^{\circ} \mathrm{C} \\ \text { (Note 3) } \end{gathered}$ |  | 3.1 |  | V |

## NOTES:

1. Crystal inputs $X_{1}$ and $X 2$ do not have clamp diodes.
2. Only one output may be grounded at a time.
3. Test each input one at a time.
4. From series-passed transistor under the following conditions:
$\mathrm{VCC}=$ Max, HALT $=$ RESET $=$ ADDRESS $=\mathrm{IVX}=0.0 \mathrm{~V}$, all other pins open.
5. Pin 37 only.
6. All voltages are with respect to ground terminal.
7. The operating temperature ranges are guaranteed after thermal equilibrium has been reached.
8. Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$.

AC CHARACTERISTICS (Military Part) CONDITIONS: $S 8 \times 300 \cdot 1-V_{C C}=5 V( \pm 5 \%)-40^{\circ} \mathrm{C} \leq T_{C} \leq 100^{\circ} \mathrm{C}$ $S 8 \times 300-2-V_{C C}=5 V( \pm 10 \%)-20^{\circ} \mathrm{C} \leq T_{C} \leq 100^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS (NOTES 1 \& 2) | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Clock: <br> TPC | Processor cycle time |  |  | 300 |  |  | ns |
| TCP | X1 clock period |  | 150 |  |  | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | X1 clock high time |  | 62 |  |  | ns |
| TCL | X1 clock low time |  | 62 |  |  | ns |
| Controls: THS |  |  | 0 |  |  | ns |
| $\mathrm{T}_{\mathrm{HH}}$ | $\overline{\text { HALT }}$ hold time ( X 1 rising edge) |  | 50 |  |  | ns |
| Instructions: TAS | X1 falling edge to address stable | $C L=100 \mathrm{pF}$ | 35 |  | 92 | ns |
| TIS | Instruction set-up time ( X 1 rising edge) |  | 0 |  |  | ns |
| $\mathrm{T}_{\mathrm{IH}}$ | Instruction hold time ( X 1 rising edge) |  | 50 |  |  | ns |
| TMCH | MCLK high delay | $\mathrm{XI}_{1}=2.0 \mathrm{~V}$ | 20 |  | 55 | ns |
| TMCL | MCLK low delay | $\mathrm{X1}=2.0 \mathrm{~V}$ | 20 |  | 55 | ns |
| TWH | X1 falling edge to SC/WC rising edge |  |  |  | 80 | ns |
| TWL | X1 falling edge to SC/WC falling edge |  |  |  | 80 | ns |
| TIIBS | Instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (input phase) |  |  |  | 52 | ns |
| TIBS | X 1 falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (input phase) |  | 24 |  |  | ns |
| TOBS | $X 1$ falling edge to $\overline{L B} / \overline{R B}$ (output phase) |  |  |  | 90 | ns |
| TIDS | Input data set-up time ( X 1 falling edge) |  | 36 |  |  | ns |
| TIDH | Input data hold time ( X 1 falling edge) |  | 50 |  |  | ns |
| TODS | Output data stable ( X 1 falling edge) |  |  |  | 125 | ns |
| TODH | Output data hold time ( X 1 falling edge) |  | 35 |  | 85 | ns |
| TACC | Instruction access time | Provided by worst case timing | 80 |  |  | ns |
| TIO | Data I/O access time | Provided by worst case timing | 40 |  |  | ns |

NOTES:

1. Operating temperature ranges are guaranteed after thermal equilibrium has been reached.
2. Unless otherwise noted $C L=300 \mathrm{pF}, \mathrm{VIN}=3 \mathrm{~V}$.

## TIMING CONSIDERATIONS (Commercial Part)

As shown in the "AC CHARACTERISTICS" table for this part, the minimum instruction cycle time is 25 ns , whereas, the maximum is determined by the on-chip oscillator frequency and can be any value the user chooses. With an instruction cycle time of 250 ns , the part can be characterized in terms of absolute values; these are shown in the first "LIMITS" column of the table. When the instruction cycle time is greater than 250 ns , certain parameters are cycle-time dependent; thus, these parameters are specified in terms of the
four quarter cycles ( $T_{1 Q}, T_{2 Q}, T_{3 Q}$, and $T_{4 Q}$ ) that make up one instruction cycle-see 8 X300 TIMING DIAGRAM. As the time interval for each instruction cycle increases (becomes greater than 250 ns ), the delay for all parameters that are cycle-time dependent is likewise increased. In some cases, these delays have a significant impact on timing relationships and other areas of systems design; subsequent paragraphs describe these timing parameters and reliable methods of calculation.

## 8X300 TIMING DIAGRAM



Timing parameters for the 8X300 are normally measured with reference to X1 or MCLK; those referenced to MCLK are prefaced with an " $M$ " in the mnemonic - TMAS, TMIH, and so on. To determine the timing relationship between a particular signal, say " $A$ " and MCLK, the user should, at all times, use the value specified in the table-DO NOT
calculate the value by adding or subtracting two or more parameters that are referenced to X 1 . When deriving timing relationships between two signals ( $A$ to $B$, etc.) by adding or subtracting the parameter values, the user must consistently use the same parameter reference-MCLK or X1.

From condition \#1 and with an instruction cycle time of 250 ns , the I/O port access time (TIO) can be calculated as follows:

TMIBS + TIO $\leq$ TMIDS
transposing, TIO $\leq$ TMIDS - TMIBS
substituting, TIO $\leq 55 \mathrm{~ns}-25 \mathrm{~ns}$
result, $\mathrm{TIO} \leq 30 \mathrm{~ns}$
Using 30 ns for TIO, the constraint imposed by condition \# 1 can also be used to calculate the minimum cycle time:

$$
\text { TMIBS + TIO } \leq \text { TMIDS }
$$

thus, $25 \mathrm{~ns}+30 \mathrm{~ns} \leq \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}}-70$ $25 \mathrm{~ns}+30 \mathrm{~ns} \leq 1 / 2$ cycle -70 therefore, the worst-case instruction cycle time is 250 ns . With subject parameters referenced to X 1 , the same calculations are valid:

$$
\text { TIBS }+ \text { TIO + TIDS } \leq 1 / 2 \text { cycle }
$$

thus, $70 \mathrm{~ns}+30 \mathrm{~ns}+25 \mathrm{~ns} \leq 1 / 2$ cycle therefore,
the worst-case instruction cycle time is again 250 ns . From condition \#2 and with an instruction cycle time of 250 ns , the program storage access time can be calculated:

$$
\text { TACC + TIIBS + TIO + TIVA } \leq 250 n s
$$

transposing, TACC $\leq 250$ ns - TIIBS - TIO -TIVA
substituting, TACC $\leq 250 \mathrm{~ns}-35 \mathrm{~ns}-30 \mathrm{~ns}-105 \mathrm{~ns}$
thus, TACC $\leq 80 \mathrm{~ns}$ hence, for an instruction cycle time of 250 ns , a program storage access time of 80 ns is implied. The constraint imposed by condition \#3 can be used to verify the maximum program storage access time:

$$
\text { TIA + TACC } \leq \text { Instruction Cycle }
$$

thus, TACC $\leq 250$ ns -170 ns
and, TACC $\leq 80 \mathrm{~ns}$, confirming that a program
storage access time of 80 ns is satisfactory.
For an instruction cycle time of 250 ns and a program storage access time of 80 ns (Condition \#2/Figure 4b), the instruction should be valid 10 ns before the falling edge of MCLK. This relationship can be derived by the following equation:

$$
\begin{aligned}
& 250 \mathrm{~ns}-\text { TMAS - TACC } \\
= & 250 \mathrm{~ns}-160 \mathrm{~ns}-80 \mathrm{~ns} \\
= & 10 \mathrm{~ns}
\end{aligned}
$$

it is important to note that, during the input phase, the beginning of a valid $\overline{L B} / \overline{R B}$ signal is determined by either the instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ delay (TIIBS) or the delay from the falling edge of MCLK to $\overline{L B} / \overline{R B}$ (TMIBS). Assuming the instruction is valid 10 ns before the falling edge of MCLK and adding the instruction-to-LB/RB delay (TIIBS) $=30 \mathrm{~ns}$ ), the $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signal will be valid 25 ns after the falling edge of MCLK. With a fast program storage memory and with a valid instruction more than 10 ns before the falling edge of MCLK - the $\overline{L B} / \overline{R B}$ signal will, due to the TMIBS delay, still be valid 25 ns after the falling edge of MCLK. Using a worstcase instruction cycle time of 250 ns , the user cannot gain a speed advantage by selecting a memory with faster access time. Under the same conditions, a speed advantage cannot be obtained by using an I/O port with fast access time (TIO) because the address bus will be stable 80 ns (TAS) after the beginning of the third quarter cycle - no matter how early the IV data input is valid.

## Internal Timing and Timing Relationships

All timing and timing-control signals of the 8X300 are generated by the oscillator and sequencer shown in Figure 5. The sequencer outputs direct and control all of the timing parameters specified in the TIMING DIAGRAM. Observe that each input quarter cycle bears a fixed relationship to X 1 via the propagation delay.

General and interactive timing relationships pertaining to $1 / O$ signals of the $8 \times 300$ are shown in Figure 6. Example-in the input phase, the switching point of the $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signal is caused by the worst-case delay from the instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ or from the beginning of the first internal quarter cycle to $\overline{L B} / \overline{R B}$; the two arrows pointing to the $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ transition indicate this "either/or" dependency. This information coupled with tabular values and the TIMING DIAGRAM provides the user with the wherewithal to calculate any and all system timing parameters.

## CLOCK CONSIDERATIONS

The on-chip oscillator and timing-generation circuits of the $8 \times 300$ can be controlled by any one of the following meihods:
Capacitor: if timing is not critical
Crystal: if precise timing is required
External Drive: if application requires that the $8 \times 300$ be synchronized with system clock
Capacitor Timing: A non-polarized ceramic or mica capacitor with a working voltage equal to or greater than 25 -volts is recommended. The lead lengths of capacitor should be approximately the same and as short as possible; also, the


Figure 5. Timing and Timing Control Signals of the $8 \times 300$
timing circuits should not be in close proximity to external sources of noise. For various capacitor ( $C_{x}$ ) values, the cycle time can be approximated as:

| $\mathbf{C}_{\mathbf{x}}$ (in pF) | APPROXIMATE CYCLE TIME |
| :---: | :---: |
| 100 | 300 ns |
| 200 | 500 ns |
| 500 | $1.1 \mu \mathrm{~s}$ |
| 1000 | $2.0 \mu \mathrm{~s}$ |



Figure 6. Timing Relationshipe of $8 \times 300$ I/O Signals

Crystal Timing: When a crystal is used, the on-chip oscillator operates at the resonant frequency ( $f_{0}$ ) of the crystal; the series-resonant quartz crystal connects to the 8X300 via pins 10 (X1) and 11 (X2). The lead lengths of the crystal should be approximately equal and as short as possible; also, the timing circuits should not be in close proximity to external sources of noise. The crystal should be hermetically sealed (HC type can) and have the foliowing electrical characteristics:
Type: Fundamental mode, series resonant impedance at Fundamental: 35 -ohms maximum Impedance at Harmonics and Spurs: 50 -ohms minimum


Figure 7. Clocking with a Pulse Generator

The resonant frequency ( $f_{0}$ ) of the crystal is related to the desired cycle time $(T)$ by the equation $f_{O}=2 / T$; for a cycle time of $250 \mathrm{~ns}, \mathrm{f}_{0}=8 \mathrm{MHz}$.

Using an External Clock: The $8 \times 300$ can be synchronized with an external clock by simply connecting appropriate drive circuits to the X 1 / X 2 inputs. Figure 7 shows how the on-chip oscillator can be driven from the complementary outputs of a pulse generator. In applications where the microcontroller must be driven from a master clock, the X1/X2 lines can be interfaced to TTL logic as shown in Figure 8.


Figure 8. Clocking with TTL.

## RESET Logic

The RESET line (pin 43) can be driven from a high (inactive) state to a low (active) state at any time with respect to the system clock, that is, the reset function is asynchronous. To ensure proper operation, the RESET line should be held low (active) for one full instruction time. When the line is driven from a high state to an active-low state, several events occur-the precise instant of occurrence is basically a function of the propagation delay for that particular event. As shown in the acompanying RESET timing diagram, these events are:

- The Program Counter and Address Register are set to an all-zero configuration and remain in that state as long as the RESET line is low. Other than PC and AR, resel does not affect other internal registers.
- The input/output (IV) bus goes three-state and remains in that mode as long as the RESET line is low.
- The Select Command and Write Command signals are driven low and remain inactive as long as the RESET line is low.
- The Left Bank/Right Bank signals are undefined for the period in which the RESET line is low.

During the time $\overline{R E S E T}$ is active-low, MCLK is inhibited; moreover, if the $\overline{R E S E T}$ line is driven low during the last two
quarter cycles, MCLK can be shortened for that particular machine cycle. When RESET line is driven high (inactive) -one-quarter to one full instruction cycle later-MCLK appears just before normal operation is resumed. The RESET/MCLK relationship is clearly shown by " $B$ " in the timing diagram. As long as the RESET line is active-low, the HALT signal (described next) is not sampled by internal logic of the $8 \times 300$.

## HALT Logic

The HALT signal is sampled via internal chip logic at the end of the first internal quarter of each instruction cycle. If, when sampled, the HALT signal is active-low, a halt is immediately executed and the current instruction cycle is terminated; however, the halt cycle does not inhibit MCLK nor does it affect any internal registers of the $8 \times 300$. As long as the HALT line is active-low, the SC and WC lines are low (inactive) and the input / output (IV) bus remains in the three-state mode of operation. The halt cycle continues until, when again sampled, the HALT line is found to be high; at this time, normal operation is resurned. Timing for the halt signal is shown in the accompanying diagram.

## RESET TIMING DIAGRAM



## HALT TIMING DIAGRAM



NOTES

1. The $\overline{\mathrm{HALT}}$ signal can switch from High to Low at any time during this interval
2. The $\overline{\text { HALT }}$ signal can switch from Low to High at any time during this interval.

Timing Descriptions:
$T_{\text {HS }}$-set-up time from HALT to $X 1$ (independent of instruction cycle time)
$\boldsymbol{T}_{H H}$-hold time from $\times 1$ to $\overline{\text { HALT }}$ (independent of instruction cycle time)
$T_{\text {MHS }}$-set-up time from MCLK to MALT (dependent upon instruction cycle time)
$T_{\text {MlH }}{ }^{-h o l d}$ time from MCLK to $\overline{\text { HALT }}$ (dependent upon instruction cycle time)

## VOLTAGE REGULATOR

All internal logic of the $8 \times 300$ is powered by an on-chip voltage regulator that requires an external series-pass transistor. Electrical specifications for the off-chip power transistor and a typical hook-up are shown in the accompanying diagram. To minimize lead inductance, the transistor should be as close as possible to the $8 \times 300$ package and the emitter should be ac-grounded via a 0.1 -microfarad ceramic capacitor.


## MICROCONTROLLER

## FEATURES

- Fetch, Decode, and Execute a 16-bit Instruction In a minimum of 200 nanoseconds (one machine cycle)
- Blt-oriented instruction set (addressable single-ormultiple blt subfields)
- Separate buses for Instruction, Instruction Address and Three-State I/O
- Thirteen 8-bit general-purpose working registers
- Source/destination architecture
- Blpolar low-power Schottky technology/TTL inputs and outputs
- On-chlp oscillator and timing generation
- Single +5V supply
- 0.9-in. 50-pin DIP


## PRODUCT DESCRIPTION

The Signetics 8X305 MicroController (Figure 1) is a highspeed bipolar microprocessor implemented with lowpower Schottky technology. In a single chip, the 8X305 combines speed, flexibility, and a bit-oriented instruction set. These features and other basic characteristics of the chip combine to provide cost-effective solutions for a broad range of applications. The $8 \times 305$ is particularly useful in systems that require high-speed bit manipulations - sophisticated controllers, data communications, very fast interface control, and other applications of a similar nature.
The $8 \times 305$ can fetch, decode, and execute a 16 -bit instruction word in a minimum of 200 nanoseconds. Within one instruction cycle, the 8 -bit data-processing path can be programmed to rotate, mask, shift, and/or merge single or multiple bit subfields and, in addition, perform an ALU operation; in the same instruction, an external data field can be input, processed, and output to a specified destination - likewise, single or multiple bit data fields can be internally moved from a given source to a given destination. To summarize, fixed or variable-length data fields can be fetched, processed, operated on by the ALU, and moved to a different location - all in a timeframe of 200 nanoseconds. To interface with I/O and program memory, the $8 \times 305$ uses a 13 -bit instruction address bus, a 16 -bit instruction bus, an 8 -bit bidirectional multiplexed I/O data/address bus and a 5-bit I/O control bus.
A wide selection of I/O devices, interface chips, and special-purpose parts are available for systems use. In most applications, the more powerful $8 \times 305$ is functionally interchangeable with its predecessor - the $8 \times 300$.

## ASSOCIATED DOCUMENTATION

Other documents directly relating to design and applications use of the $8 \times 305$ MicroController are:

- Product Capabilities Manual
- 8X305 Users Manual

These documents and other current literature (Data Sheets, Product Bulletins, Applications Notes, etc.) are available at all Signetics Sales and Service Offices - see rear cover of this data sheet for the office in your locality.

## PIN CONFIGURATION




Figure 1. Architecture and Pin Designations for $8 \times 305$ MicroController

|  |  |  |
| :---: | :---: | :---: |
| PIN NO. | IDENTIFIER | FUNCTION |
| 1 | VCR | Regulated voltage input from series-pass transistor (2N5320 or equivalent). |
| 2-9, 45-49 | $\mathrm{A}_{0}-\mathrm{A}_{12}$ | Program Address Lines: These active-high outputs permit direct addressing of up to 8192 words of program storage; $A_{12}$ is least significant bit. |
| 10, 11 | X1, X2 | Timing generator connections for a capacitor, a series resonant crystal, or an external clock source with complementary outputs. |
| 12 | GND | Ground. |
| 13-28 | $\mathrm{I}_{0}-\mathrm{I}_{15}$ | Instruction Lines: These active-high input lines receive 16 -bit instructions from program storage; $\mathrm{I}_{15}$ is least significant bit. |
| 29 | SC | Select Command: When high (binary 1), an address is being output on pins IV0 through $\overline{\mathrm{V} 7}$. |
| 30 | WC | Write Command: When high (binary 1), data is being output on pins $\overline{\mathrm{V} 0}$ through $\overline{\mathrm{V} 7}$. |
| 31 | $\overline{\text { LB }}$ | Left Bank Control: When low (binary 0), devices connected to the Left Bank are accessed. (Note. Typically, the $\overline{L B}$ signal is tied to the $\overline{M E}$ input pin of I/O periphera/s). |
| 32 | RB | Right Bank Control: When low (binary 0), devices connected to the Right Bank are accessed (Note. Typically, the $\overline{R B}$ signal is tied to the $\overline{M E}$ input pin of I/O periphera/s). |
| $\begin{gathered} 33-36, \\ 38-41 \end{gathered}$ | $\overline{\mathrm{IVO}}-\overline{\mathrm{IV} 7}$ | Interface Vector (Input/Output Bus) - these bidirectional active-low three-state lines communicate data and/or addresses to I/O devices and memory locations. A low voltage level equals a binary " 1 "; $\overline{\mathrm{VV7}}$ is Least Significant Bit. |
| 37 | $\mathrm{V}_{\mathrm{CC}}$ | +5V power supply. |
| 42 | MCLK | Master Clock: This active-high output signal is used for clocking I/O devices and/or synchronization of external logic. |
| 43 | RESET | When $\overline{\text { RESET }}$ input is low (binary 0), the $8 \times 305$ is initialized - sets Program Counter/Address Register to zero and inhibits MCLK. For the period of tim $\epsilon \overline{\mathrm{RESET}}$ is low, the Left Bank/Right Bank ( $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ ) signals are forced high asynchronously. |
| 44 | $\overline{\text { HALT }}$ | When $\overline{\text { HALT }}$ input is low (binary 0), internal operation of the $8 \times 305$ stops at the start of next instruction; MCLK is not inhibited nor is any internal register affected; however, both the Left Bank/Right Bank ( $\overline{\mathrm{LB} / \mathrm{RB}}$ ) signals are synchronously driven high during the first quarter of the instruction cycle time and remain high during the time HALT is low. |
| 50 | VR | Internally-generated reference output voltage for external series-pass regulator transistor. |

Figure 2. Designations and Descriptions for Pins of $8 \times 305$ MicroController.
ing 256 Input/Output locations and, with additional bank bits ( $\overline{\mathrm{LB}}, \overline{\mathrm{RB}}$ ), this number is expanded to 512 - each bank comprising 256 addressable locations. The addressable locations of each bank can be used in a variety of ways; a simple method of implementation is shown in Figure 3. When $\overline{\mathrm{LB}}$ is active low, the left bank is enabled and any one of 256 locations within the RAM memory can be accessed for input/output operations. A similar set of "enable/access" conditions are applicable to the right bank when $\overline{\mathrm{RB}}$ is active low.


Figure 3. Typical 8X305 System Hookup

BASIC OPERATIONS OF 8X305

## MOVE OPERATIONS



## ADD OPERATIONS



Same as MOVE operations, except source data is ADDed to contents of AUXiliary Register RO via the ALU; if appropriate, Overflow Register R10 (OVF) is also set.


## AND OPERATIONS



Same as MOVE operations, except source data is ANDed with contents of AUXiliary Register R0 via the ALU.


## EXCLUSIVE OR (XOR) OPERATIONS



Same as MOVE operations, except source data is Exclusively ORed with contents of AUXiliary Register RO via the ALU.


EXECUTE (XEC) OPERATIONS


NON-ZERO TRANSFER (NZT) OPERATIONS


TRANSMIT (XMIT) OPERATIONS


## JUMP (JMP) OPERATION



## Program Storage Interface

As shown in Figure 3, program storage is connected to output address lines $A_{0}$ through $A_{12}\left(A_{12}=L S B\right)$ and input instruction lines $I_{0}$ through $I_{15}$. An address output on $A_{0} / A_{12}$ identifies one 16 -bit instruction word in program storage. The instruction word is subsequently input on $I_{0} / I_{15}$ and defines the MicroController operation which is to follow - one instruction word equals one completed operation. Any TTL-compatible memory can be used for program storage provided the worst-case access time is compatible with the instruction cycle time used for the application -- see timing section for appropriate calculations.

## I/O Interface and Control

An 8-bit bidirectional I/O bus, referred to as the Interface Vector (IV) bus, provides a communication link between the MicroController and the two banks of I/O devices. The $\overline{\mathrm{LB}}$ (Left Bank) and $\overline{\mathrm{RB}}$ (Right Bank) control signals identify which bank is enabled; when both $\overline{L B}$ and $\overline{R B}$ are high (inactive), neither bank is enabled and the IV bus is inactive (three-state). A functional analysis of the Left and Right Bank signals is shown below:

## Data Processing

Basically, the data processing path of the $8 \times 305$ consists of the Rotate/Mask logic, the Arithmetic Logic Unit (ALU), the Shift/ Merge functions, on-chip memory (sixteen 8-bit registers), and the bidirectional IV bus interface with its associated driver circuits and internal latches. The onboard memory and the $\overline{\mathrm{V}}$ bus are connected to both inputs and outputs of the ALU via internal 8-bit data paths - see Figure 1. Inputs to the ALU are preceded by rightrotate and data-mask functions; the ALU output is followed by the left-shift and merge operations. Depending on the desired operation, any one or all of the functions (Rotate/Mask/Shift/Merge) can operate on 8 bits of data in a single instruction cycle. For a summary of all dataprocessing capabilities, refer to BASIC OPERATIONS OF THE 8X305 described earlier in this data sheet.

## Instruction Cycle

Each operation of the $8 \times 305$ is executed in a single instruction cycle. The instruction cycle is internally divided into four equal parts - each part being as short as 50 nanoseconds. Figure 4 shows the general functions that


Figure 4. Instruction Cycle and MCLK with: Crystal $=10 \mathrm{MHz}$ and Cycle Time $=200$ nanoseconds.
occur during each quarter cycle; specifics regarding minimum/maximum timing and other critical values are described later in this data sheet. During the first quarter cycle, a new instruction from program storage is input via $\mathrm{I}_{0} \mathrm{I}_{15}$ and decoded. If an I/O operation is indicated, new data is fetched from a specified internal register or via the $\overline{\mathrm{IV}}$ bus. At the end of the first quarter cycle, the new instruction is latched into the instruction register.
In the second quarter cycle, the I/O input data stabilizes and preliminary processing is completed; at the end of this quarter, the $\overline{\mathrm{V}}$ latches close and final processing can be accomplished, thus completing the input phase of the instruction cycle. During the third quarter cycle, the address for the next instruction is output to the instruction address bus, $\overline{\mathrm{V}}$ control signals are generated, and both data and destination are setup for the remainder of the output phase. During the fourth quarter cycle, a master clock signal (MCLK) generated by the $8 \times 305$ is used to latch either the I/O-enabling address or the I/O data into peripheral devices connected to the $\overline{\mathrm{V}}$ bus; MCLK can also be used to synchronize any external logic with timing circuits of the $8 \times 305$. To summarize the action, the first half of the instruction cycle deals primarily with input functions and the second half is mostly concerned with output functions.

## INSTRUCTION SET

## General Format and Operating Principles

The 16 -bit instruction word ( $I_{0}$ through $I_{15}$ ) from program storage is input to the instruction register (Figure 1) and is subsequently decoded to implement the events to occur during the current instruction cycle.

The general format for each instruction word is as follows:

| $\downarrow$ MSB |  |  |
| :---: | :---: | :---: |
| BIT POSITIONS $\rightarrow$ | 012 | 3456789101112131415 |
|  | OPCODE | OPERAND(S) |

The 3-bit operation code (OPCODE) define any one of eight classes of instructions; variations within each class are specified by the remaining thirteen operand bits. The eight instruction classes can be separated into two control areas - data and program; general functions within these areas are:


## Instruction Fields

As shown in Table 1, each instruction word consists of an operation code (OPCODE) field and from one to three operand fields. The possible operand fields are: Source (S), Destination (D), Rotate/Length (R/L), Literal (J), and Address (A). The OPCODE and operand fields are described in the paragraphs that follow the table.

Table 1. FUNCTIONAL DESCRIPTION OF INSTRUCTION SET


Table 1. FUNCTIONAL DESCRIPTION OF INSTRUCTION SET (Continued)


Table 1. FUNCTIONAL DESCRIPTION OF INSTRUCTION SET (Concluded)


Note:
$\mathrm{S}_{0}$ specifies the LSB of rotated input data field
$\mathrm{S}_{1}$ specifies the bank of $\overline{\mathrm{V}}$ bus from which source data will be input
$D_{0}$ specifies bit position in I/O device with which LSB of processed data will be aligned and
$D_{1}$ specifies the bank of $\overline{\mathrm{V}}$ bus which will be the destination.

Operations Code Field. The 3-bit OPCODE field specifies one of eight classes of 8X305 instructions; octal designations for this field and operands for each instruction class are shown in the preceding table.

Source (S) and Destination (D) Fields. The 5 -bit " $S$ " and " $D$ " fields specify the source and destination, respective-
ly, for whatever operation is defined by the OPeration CODE. The " S " and/or " $D$ " fields can specify an internal $8 \times 305$ register or any one-to-eight bit field within an I/O device; octal values and source/destination field assignments for all internal registers are shown in Table 2.

Table 2. OCTAL ADDRESSES AND SOURCE/DESTINATION FIELDS FOR 8X305 REGISTERS

| ADDRESS | REGISTER DESIGNATION | SOURCE | DESTI. NATION | ADDRESS | REGISTER DESIGNATION | SOURCE | DESTI. NATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $00_{8}$ | RO (AUX)-General purpose register | $X$ | X | $10_{8}$ | R10 (OVF-Overflow register) | X |  |
| 018 | R1-General purpose register | X | X | $11_{8}$ | R11-General purpose register | X | X |
| 028 | R2-General purpose register | X | X | 128 | R12-General purpose register (Note) | X | X |
| $03_{8}$ | R3-General purpose register | X | X | $13_{8}$ | R13-General purpose register (Note) | X | X |
| 048 | R4-General purpose register | $X$ | X | $14_{8}$ | R14-General purpose register | X | X |
| $05_{8}$ | R5-General purpose register | X | X | 158 | R15-General purpose register | X | X |
| $06_{8}$ | R6-General purpose register | X | X | $16_{8}$ | R16-General purpose register | X | X |
| $07_{8}$ | R7-Special purpose register (refer to next paragraph) | X | X | 178 | R17-Special purpose register (refer to next paragraph) | X | X |

Note:
R12 and R13 function as general purpose working registers for all operations except transmit (XMIT). During a transmit instruction where R12 or R13 is the destination, the 8 -bit " $J$ " field is immediately transferred to the $\bar{V}$ bus; for this operation, the contents of the designated register remain unchanged.

In instructions where R7 $8_{8}$ (IVL) or $\mathrm{R} 17_{8}$ (IVR) is specified as the destination, the 8 -bit value is output on the $\overline{\mathrm{IV}}$ bus as an I/O device address or memory location; register R7 selects the Left Bank and register R17 selects the Right Bank. The results are also stored into the specified internal register ( $\mathrm{R7} 7_{8}$ or $R 17{ }_{8}$ ) and may later be accessed as source data. When the $\overline{\mathrm{V}}$ bus is specified as a source and/or destination, the " $S$ " and " $D$ " fields are split into two parts, that is,

- Source $(S)=S_{1}, S_{0}$ and Destination (D) $=D_{1}, D_{0}$ where, $S_{0}$ specifies the LSB of rotated input data field $S_{1}$ specifies the bank of $\overline{I V}$ bus from which source data will be input
$\mathrm{D}_{0}$ specifies bit position in I/O device with which LSB of processed data will be aligned and
$D_{1}$ specifies the bank of $\overline{1 V}$ bus which will be the destination


Notes:

1. The field length of 0. to -8 bits is specified by the " $L$ " field.
2. For the Right Bank, $30_{8}-37_{8}$ perform equivalent $I / O$ functions.

Rotate (R) and Length (L) Field. The 3-bit R/L field performs one of two functions, specifying either the field length (L) for I/O operations or a right-rotate (R) for internal operations. For a given instruction, the specified function depends upon the contents of the Source (S) and Destination (D) fields.
When an internal register is specified by both the source and destination fields, the " $R$ " field is invoked and it specifies a right-rotate of the data specified in the " $S$ " field - see accompanying diagram. The source-register data (up to 8 bits) is right-rotated during the "input phase" of the instruction cycle (Figure 4) and this function is always performed prior to any ALU operation. (Note: The right-rotate function is implemented on the bus and not in the source register.)

## RIGHT-ROTATE FUNCTION

Bit Position $\rightarrow \begin{array}{llllllll}0 & 1 & 2 & 3 & 4 & 5 & 6 & 7\end{array}$


When either or both of the source and destination fields specify a variable-length I/O data field, the " $L$ " field specifies the length of the I/O data field - see following diagram. If the source field specifies an $\overline{\mathrm{V}}$ address $\left(20_{8}-37_{8}\right)$ and the destination field specifies an internal register $\left(00_{8}-07_{8}, 11_{8}-17_{8}\right)$, the " $L$ " field specifies the length of source data; the source data is formed by rightrotating the $\overline{\mathrm{V}}$ bus data according to the source address and then masking result as specified by the " $L$ " field. If length is less than 8 bits, all remaining bits are set to zero prior to processing data in the ALU. If the source field

- When the Source (S) field specifies a variable I/O data field, the literal value of the " J " field is a 5 -bit binary number.

A Field. The 13-bit " $A$ " field is an address field which allows the $8 \times 305$ to directly branch to any of the 8192 locations in Program Storage memory.

## Formation of Instruction Address

The Address Register and Program Counter are used to generate addresses for accessing an instruction from program storage. The instruction address is formed in one of the following ways:

- For all except the JMP, XEC, and a "satisfied" NZT instruction, the Program Counter is incremented by one and placed in the Address Register.
- For the JMP instruction, the 13-bit "A" field contained in the JMP instruction word replaces the contents of both the Address Register and the Program Counter.
- For the XEC instruction, the Address Register is loaded with bits from the Program Counter modified as follows:

XEC using $\overline{I V}$ Bus Data - low-order 5 bits of ALU output replaces counterpart bits in Address Register XEC using Data from Internal Register - low-order 8 bits of ALU output replaces counterpart bits in Address Register
The Program Counter is not modified for either of the above conditions.

- For a "satisfied" NZT instruction, the low-order 5 bits (NZT source is $\overline{\mathrm{V}}$ bus data) or low-order 8 bits (NZT source is an internal register) of both the Address Register and Program Counter are loaded with the literal value specified by the " J " field of instruction word.


## Data Addressing

The source and/or destination addresses of the data to be operated upon are specified as part of the instruction word. As shown earlier, source/destination addresses are specified using a 5 -bit code $\left(00_{8}-37_{8}\right)$. When the most significant octal digit is a " 0 " or " 1 ", the source and/or destination address is an internal register; if the most significant digit is a 2 or 3 , an $\overline{\mathrm{V}}$ bus operation is indicated -2 specifying a Left-Bank ( $\overline{\mathrm{LB}}$ ) operation and 3 specifying a Right-Bank ( $\overline{\mathrm{RB}}$ ) operation. The least significant octal digit ( 0 through 7 ) indicates either a specific internal register address or positioning information for the least significant bit when specifying $\overline{\mathrm{V}}$ bus data. Referring to Table 1, AUXiliary register RO $\left(00_{8}\right)$ is the implied source
of the second argument for the ADD, AND, and XOR operations. IVL register R7 and IVR register R17 (destination addresses $07_{8}$ and $17_{8}$, respectively) provide a means of routing enabling address information to $1 / O$ peripherals. With IVL or IVR specified as the destination address, data is placed on the $\overline{\mathrm{V}}$ bus during the output phase of the instruction cycle; simultaneously, a Select Command (SC) is generated to inform all I/O devices that information on the $\overline{\mathrm{IV}}$ bus is to be considered as an I/O address. Since the contents of IVL and IVR are preserved, either register may later be accessed as a source of data.

Control outputs $\overline{\mathrm{LB}}$ and $\overline{\mathrm{RB}}$ are used to partition I/O bus devices into two fields of 256 addresses. With $\overline{L B}$ in the active-low state and a source address of $20_{8}-27_{8}$, the left bank of I/O devices are enabled during the input phase of the instruction cycle. With $\overline{R B}$ in the active-low state and a source address of $30_{8}-37_{8}$, the right bank of devices are enabled. During the output phase, $\overline{L B}$ is low if the destination address is $07_{8}$ or $20_{8}-27_{8}$, whereas $\overline{R B}$ is low if the destination address is $17_{8}$ or $30_{8}-37_{8}$. Each address field ( $\overline{\mathrm{LB}}$ and $\overline{\mathrm{RB}}$ ) can have a different I/O device selected, that is, data can be transferred from a device in one bank to a device in the other in one instruction cycle.

## DESIGN PARAMETERS

Hardware design of an 8X305-based system largely consists of the following operations:

- Selecting and interfacing a Program Storage device ROM, PROM, etc.
- Selecting and interfacing input/output devices - RAM, Ports, and other 8 -bit addressable $1 / O$ devices.
- Choosing and implementing System Clock - Capaci-tor-Controlled, Crystal-Controlled, or Externally-Driven.
- Selection of an off-chip series-pass transistor.


## VOLTAGE REGULATOR

All internal logic of the $8 \times 305$ is powered by an on-chip voltage regulator that requires an external series-pass transistor. Electrical specifications for the off-chip power transistor and a typical hook-up are shown in the accompanying diagram. To minimize lead inductance, the transistor should be as close as possible to the 8X305 package and the emitter should be ac-grounded via a 0.1 microfarad ceramic capacitor.

All information required for easy implementation of these design requirements is provided under the following captions:

- Ordering Information
- Voltage Regulator
- DC Characteristics
- AC Characteristics
- Timing Considerations
- Clock Considerations
- HALT/RESET Logic


DC CHARACTERISTICS (Commercial Part) $4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature ( $T_{\text {STG }}$ ) ratings are from -65 to $+150^{\circ} \mathrm{C}$

| PIN | DESCRIPTION | RATING | UNIT | PIN | DESCRIPTION | RATING | UNIT |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | +7.0 | V | All other pins | Logic input voltage | 5.5 | V |
| $\mathrm{X} 1, \mathrm{X} 2$ | Crystal input voltage | 2.0 | V |  |  |  |  |


|  | PARAMETER | TEST CONDITIONS |  | LIMITS |  |  | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  |  | 4.75 | 5.0 | 5.25 | V |  |
| $\mathrm{V}_{1 H}$ | High level input voltage |  |  | $\begin{aligned} & 0.6 \\ & 2.0 \end{aligned}$ |  | $\begin{aligned} & 2.0 \\ & 5.5 \end{aligned}$ | V | $X 1$ and $X 2$ <br> All other pins |
| $\mathrm{V}_{\mathrm{IL}}$. | Low level input voltage |  |  |  |  | $\begin{aligned} & 0.4 \\ & 0.8 \end{aligned}$ | V | $X 1$ and $X 2$ <br> All other pins |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{mi}$ | $=-3 \mathrm{~mA}$ | 2.4 |  |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Low leve! output voltage | $\begin{aligned} v_{C C} & =m i \\ v_{C C} & =m i r \end{aligned}$ | $\begin{aligned} \mathrm{L} & =6 \mathrm{~mA} \\ & =16 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & 0.55 \\ & 0.55 \end{aligned}$ | V | $\mathrm{A}_{0}$ through $\mathrm{A}_{12}$ <br> All other outputs |
| $V_{C R}$ | Regulator voltage |  |  |  | $\begin{aligned} & 3.1 \\ & 2.9 \\ & \hline \end{aligned}$ |  | V | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{V}_{\text {IC }}$ | Input clamp voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{min}$ | $=-10 \mathrm{~mA}$ |  |  | - 1.5 | V | Crystal inputs X1 and X2 do not have internal clamp diodes |
| $\mathrm{I}_{\mathrm{H}}$ | High level input current | $V_{C C}=\max$ | $\begin{aligned} & V_{1 H}=0.6 \mathrm{~V} \\ & V_{1 H}=4.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{aligned} & 4.0 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mu \mathrm{~A} \end{aligned}$ | X 1 and X 2 <br> All other pins |
| ILI | L.ow-level input current | $v_{C C}=$ max | 0.4V |  |  | $\begin{gathered} -3 \\ -0.2 \\ -1.6 \\ -0.4 \end{gathered}$ | mA | $\begin{aligned} & \frac{\mathrm{X} 1}{} \text { and } \mathrm{X} 2 \\ & \frac{1 V 0}{-1 V 7} \\ & \frac{10-115}{\text { HALT }} \text { and } \overline{\text { RESET }} \end{aligned}$ |
| los | Short circuit output current | $\mathrm{V}_{\mathrm{CC}}=$ max; (No more than one connect | t any time, no put should be ground.) | -30 |  | - 140 | mA | All output pins |
| Icc | Supply current |  |  |  |  | $\begin{aligned} & 180 \\ & 195 \end{aligned}$ | mA | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \end{aligned}$ |
| $I_{\text {ReG }}$ | Regulator control |  |  | - 10 |  | -25 | mA | Max available base drive for series-pass transistor |
| $I_{\text {CR }}$ | Regulator current |  |  |  |  | $\begin{aligned} & 200 \\ & 230 \end{aligned}$ | mA | $\begin{aligned} & T_{A}=70^{\circ} \mathrm{C} \\ & T_{A}=0^{\circ} \mathrm{C} \end{aligned}$ |

Notes:

1. Operating temperature ranges are guaranteed after thermal equilibrium has been reached.
2. All voltages measured with respect to ground terminal.

AC CHARACTERISTICS (Commercial Part) CONDITIONS: $4.75 \mathrm{~V} \leqslant V_{C C} \leqslant 5.25 \mathrm{~V} ; 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$ LOADING: (See test circuits)

|  | PARAMETER (Note 1) | LIMITS (INSTRUCTION CYCLE TIME = 200ns) |  |  | LIMITS (INSTRUCTION CYCLE TIME > 200ns) |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| $\mathrm{T}_{\mathrm{PC}}$ | Processor cycle time | 200 |  |  | 200 |  |  | ns |  |
| $T_{C P}$ | X1 clock period | 100 |  |  | 100 |  |  | ns |  |
| $\mathrm{T}_{\mathrm{CH}}$ | X1 clock high time | 50 |  |  | 50 |  |  | ns |  |
| $T_{C L}$ | X1 clock low time | 50 |  |  | 50 |  |  | ns |  |
| TMCL | MCLK low delay | 15 |  | 40 | 15 |  | 40 | ns |  |
| ${ }^{T}$ W | MCLK pulse width | 40 |  | 60 | $\mathrm{T}_{4 Q}-10$ |  | $\mathrm{T}_{4 \mathrm{Q}}+10$ | ns | Note 2 |
| TMODO | Output driver turn on time MCLK falling edge | 125 |  | 145 | $\begin{gathered} T_{10}+ \\ T_{2 Q}+25 \end{gathered}$ |  | $\begin{gathered} T_{10}+ \\ T_{2 Q}+45 \end{gathered}$ | ns | Note 9 |

AC CHARACTERISTICS (Commercial Part) CONDITIONS: $4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V} ; 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ (Continued)

## LOADING:

(See test circuits)

| PARAMETER (Note 1) |  | LIMITS (INSTRUCTION CYCLE TIME = 200ns) |  |  | LIMITS (INSTRUCTION) CYCLE TIME > 200ns) |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| $T_{\text {DI }}$ | Output driver turn-on time (SC/WC rising edge) | 20 |  |  | 20 |  |  | ns | Note 10 |
| $\mathrm{T}_{\mathrm{DD}}$ | Input data to output data | 85 |  | 105 | 85 |  | 105 | ns |  |
| $\mathrm{T}_{\text {MHS }}$ | MCLK falling edge to $\overline{\text { HALT }}$ falling edge |  |  | 30 |  |  | T $\mathrm{T}_{10}-20$ | ns | Note 2 |
| $\mathrm{T}_{\text {MHH }}$ | $\overline{\text { HALT }}$ hold time (MCLK falling edge) | 65 |  |  | $\mathrm{T}_{10}+15$ |  | . | ns | Note 2 |
| $\mathrm{T}_{\text {ACC }}$ | Program storage access time |  |  | 60 |  |  |  | ns |  |
| $\mathrm{T}_{10}$ | I/O port output enable time ( $\overline{L R} / \overline{R B}$ to valide $\overline{\mathrm{V}}$ data input) |  |  | 30 |  |  |  | ns |  |
| TMAS | MCLK falling edge to address stable |  |  | 140 |  |  | $\begin{gathered} T_{1 Q}+ \\ T_{2 Q}+40 \end{gathered}$ | ns | Notes 2, 3 \& 4 |
| $\mathrm{T}_{\text {IA }}$ | Instruction to address |  |  | 140 |  |  | $\mathrm{T}_{2 \mathrm{a}}+90$ | ns | Notes 2, 3 \& 5 |
| TIVA | Input data to address |  |  | 85 |  |  | 85 | ns | Notes 3 \& 6 |
| $\mathrm{T}_{\text {MIS }}$ | MCLK falling edge to instruction stable |  |  | 30 |  |  | $\mathrm{T}_{10}-20$ | ns | Notes 2 \& 10 |
| $\mathrm{T}_{\text {MIM }}$ | Instruction hold time (MCLK falling edge) | 55 |  |  | $\mathrm{T}_{1 Q}+5$ |  |  | ns | Notes 2 \& 8 |
| TMWH | MCLK falling edge to SC/WC rising edge | 105 |  | 125 | $\begin{gathered} \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 Q}+5 \\ \hline \end{gathered}$ |  | $\begin{gathered} \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{20}+25 \end{gathered}$ | ns | Note 2 |
| $\mathrm{T}_{\text {MWL }}$ | MCLK falling edge to SC/WC falling edge | 5 |  | 15 | 5 |  | 15 | ns |  |
| $\mathrm{T}_{\text {MIBS }}$ | MCLK falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Input phase) | 10 |  | 25 | 10 |  | 25 | ns |  |
| $\mathrm{T}_{\text {IIBS }}$ | Instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Input phase) |  |  | 25 |  |  | 25 | ns |  |
| Tmobs | MCLK falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Output phase) | 115 |  | 145 | $\begin{array}{c\|} \mathrm{T}_{10}+ \\ \mathrm{T}_{2 \mathrm{Q}}+15 \\ \hline \end{array}$ |  | $\begin{gathered} T_{1 Q}+ \\ T_{2 Q}+45 \end{gathered}$ | ns | Note 2 |
| $\mathrm{T}_{\text {mids }}$ | MCLK falling edge to input data stable |  |  | 55 |  |  | $\begin{gathered} \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 Q}-45 \end{gathered}$ | ns | Note 2 |
| $\mathrm{T}_{\text {MIDH }}$ | Input data hold time (MCLK falling edge) | 115 |  |  | $\begin{gathered} \mathrm{T}_{1 \mathrm{Q}}+ \\ \mathrm{T}_{2 \mathrm{Q}}+15 \\ \hline \end{gathered}$ |  |  | ns | Note 2 |
| TMODH | Output data hold time (MCL.K falling edge) | 11 |  |  | 11 |  |  | ns |  |
| Tmods | Output data stable (MCLK falling edge) | 130 |  | 150 | $\begin{gathered} \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 Q}+30 \\ \hline \end{gathered}$ |  | $\begin{gathered} \mathrm{T}_{10}+ \\ \mathrm{T}_{2 \mathrm{Q}}+50 \end{gathered}$ | ns | Note 2 |

## NOTES:

1. X 1 and X 2 inputs are driven by an external pulse generator with an amplitude of 1.5 volts; all timing parameters are measured at this voltage level.
2. Respectively, $T_{1 Q}, T_{2 Q}, T_{3 Q}$, and $T_{4 Q}$ represent time intervals for the first, second, third, and fourth quarter cycles.
3. Capacitive loading for the address bus is $\mathbf{1 5 0}$ picofarads.
4. TMAS is obtained by forcing a valid instruction and an I/O bus input to occur earlier than the specified minimum set up time.
5. $T_{I A}$ is obtained by forcing a valid instruction input to occur earlier than the minimum set up time.
6. TIVA is obtained by forcing a valid I/O bus input to meet the minium set up time.
7. TMIS represents the setup time required by internal latches of the $8 \times 305$. In system applications, the instruction input may have to be valid before the worst-case set up time in order for the system to respond with a valid I/O bus input that meets the I/O bus input set up time ( $T_{I D S}$ and $T_{\text {MIDS }}$ ).
8. $T_{\text {MIH }}$ represents the hold time required by internal latches of the $8 \times 305$. To generate proper $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signals, the instruction must be held valid until the address bus changes.
9. The minimum figure for these parameters represents the earliest time that $/ / O$ bus output drivers of the $8 \times 305$ will turn on.
10. This parameter represents the latest time that the output drivers of the input device should be turned off.

TEST CIRCUITS


ABSOLUTE MAXIMUM RATINGS Storage Temperature ( $\mathrm{T}_{\text {STG }}$ ) ratings are from -65 to $+150^{\circ} \mathrm{C}$

| PIN | DESCRIPTION | RATING | UNIT | PIN | DESCRIPTION | RATING | UNIT |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | +7.0 | V | All other pins | Logic input pins | 5.5 | V |
| $\mathrm{X} 1, \mathrm{X} 2$ | Crystal input voltage | 2.0 | V |  |  |  |  |

DC CHARACTERISTICS (Military Part) $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{C}} \leq+125^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  |  | 4.5 | 5.0 | 5.5 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | High level input voltage |  | $\begin{aligned} & 0.6 \\ & 2.0 \end{aligned}$ |  | 2.0 | V | X 1 and X 2 <br> All other pins |
|  | Low level input voltage |  |  |  | $\begin{aligned} & 0.4 \\ & 0.8 \end{aligned}$ | V | X1 and X2 All other pins |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=\min ; \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 |  |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{min} ; \mathrm{I}_{\mathrm{OL}}=6 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{min} ; \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & 0.55 \\ & 0.55 \\ & \hline \end{aligned}$ | V | $A_{0}$ through $A_{12}$ All other outputs |
| $\mathrm{V}_{\mathrm{CR}}$ | Regulator voltage | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |  | $\begin{aligned} & 3.5 \\ & 3.1 \\ & 2.6 \end{aligned}$ |  | V | $\begin{aligned} & T_{C}=-55^{\circ} \mathrm{C} \\ & T_{C}=0^{\circ} \mathrm{C} \\ & T_{C}=125^{\circ} \mathrm{C} \end{aligned}$ |
| $V_{1 C}$ | Input clamp voltage | $V_{C C}=\min ; \mathrm{I}_{\mathrm{IN}}=-10 \mathrm{~mA}$ |  |  | -1.5 | V | Crystal inputs X1 and X2 do not have internal clamp diodes. |
| $\mathrm{I}_{\mathrm{H}}$ | High level input current | $\begin{array}{ll} V_{C C}=\max & V_{I H}=0.6 \mathrm{~V} \\ & V_{I H}=4.5 \mathrm{~V} \end{array}$ |  |  | $\begin{aligned} & 4.0 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{mA} \\ \mu \mathrm{~A} \end{gathered}$ | X 1 and X2 All other pins |
|  | Low-level input current | $V_{C C}=\max ; V_{\text {IL }}=0.4 \mathrm{~V}$ |  |  | $\begin{gathered} -3 \\ -0.3 \\ -1.6 \\ -0.4 \end{gathered}$ | mA | $\begin{array}{\|l} \hline \frac{\mathrm{X} 1 \text { and } \mathrm{X} 2}{\mathrm{IV0}-\overline{\mathrm{V} 7}} \\ \frac{10-115}{\mathrm{HALT}} \text { and } \overline{\text { RESET }} \end{array}$ |
| los | Short circuit output current | $\mathrm{V}_{\mathrm{CC}}=$ max; (Note: At any time, no more than one output should be connected to ground.) | -30 |  | -140 | mA | All output pins |
| $I_{\text {cc }}$ | Supply current | $V_{C C}=\max$ |  |  | $\begin{aligned} & 175 \\ & 205 \\ & \hline \end{aligned}$ | mA | $\begin{aligned} & \mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{C}}=-55^{\circ} \mathrm{C} \end{aligned}$ |
| $I_{\text {Reg }}$ | Regulator control | $\mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V}$ | -10 |  | -25 | mA | Max available base drive for series-pass transistor |
| $\mathrm{I}_{\mathrm{CR}}$ | Regulator current | $V_{C C}=\max$ |  |  | $\begin{aligned} & 180 \\ & 260 \\ & \hline \end{aligned}$ | mA | $\begin{aligned} & \mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{C}}=-55^{\circ} \mathrm{C} \end{aligned}$ |

## NOTES:

1. Operating temperature ranges are guaranteed after thermal equilibrium has been reached.
2. All voltages measured with respect to ground terminal.

Microcontroller
$8 \times 305$

AC CHARACTERISTICS (Military Part) CONDITIONS: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} ;-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$ LOADING: (See test circuits)

| PARAMETER (Note 1) |  | LIMITS (INSTRUCTION CYCLE TIME $=250 \mathrm{~ns}$ ) |  |  | LIMITS (INSTRUCTION) CYCLE TIME > 250ns) |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| $\mathrm{T}_{\mathrm{PC}}$ | Processor cycle time | 250 |  |  | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {cP }}$ | X1 clock period | 125 |  |  | 125 |  |  | ns |  |
| $\mathrm{T}_{\mathrm{CH}}$ | X1 clock high time | 62 |  |  | 62 |  |  | ns |  |
| $\mathrm{T}_{\mathrm{CL}}$ | X1 clock low time | 62 |  |  | 62 |  |  | ns |  |
| $\mathrm{T}_{\text {MCL }}$ | MCLK low delay | 15 |  | 40 | 15 |  | 40 | ns |  |
| $\mathrm{T}_{\mathrm{W}}$ | MCLK pulse width | 47 |  | 72 | $\mathrm{T}_{40}-15$ |  | $\mathrm{T}_{4 \mathrm{Q}}+10$ | ns | Note 2 |
| TMODO | Output driver turn-on time (MCLK falling edge) | 145 |  | 175 | $\begin{gathered} \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 \mathrm{Q}}+20 \end{gathered}$ |  | $\begin{gathered} T_{1 Q}+ \\ T_{2 Q}+50 \\ \hline \end{gathered}$ | ns | Note 9 |
| $T_{\text {DI }}$ | Output driver turn-on time (SC/WC rising edge) | 20 |  |  | 20 |  |  | ns | Note 10 |
| $\mathrm{T}_{\mathrm{DD}}$ | Input data to output data | 80 |  | 115 | 80 |  | 115 | ns |  |
| $\mathrm{T}_{\text {MHS }}$ | MCLK falling edge to $\overline{\text { HALT }}$ falling edge |  |  | 40 |  |  | $\mathrm{T}_{1 Q}-22$ | ns | Note 2 |
| $\mathrm{T}_{\text {MHH }}$ | $\overline{\text { HALT }}$ hold time (MCLK falling edge) | 80 |  |  | $\mathrm{T}_{10}+18$ |  |  | ns | Note 2 |
| $\mathrm{T}_{\text {ACC }}$ | Program storage access time |  |  | 90 |  |  |  | ns |  |
| $T_{10}$ | I/O port output enable time ( $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ to valid $\overline{\mathrm{IV}}$ data input) |  |  | 40 |  |  |  | ns |  |
| TMAS | MCLK falling edge to address stable |  |  | 160 |  |  | $\begin{array}{\|c\|} \hline \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 Q}+35 \\ \hline \end{array}$ | ns | Notes 2, 3 \& 4 |
| $\mathrm{T}_{\text {IA }}$ | Instruction to address |  |  | 160 |  |  | $\mathrm{T}_{2 \mathrm{Q}}+98$ | ns | Notes 2, 3 \& 5 |
| TIVA | Input data to address |  |  | 90 |  |  | 90 | ns | Notes 3 \& 6 |
| T MIS | MCLK falling edge to instruction stable |  |  | 40 |  |  | $\mathrm{T}_{10}-22$ | ns | Notes 2 \& 10 |
| $\mathrm{T}_{\text {MIH }}$ | Instruction hold time (MCLK falling edge) | 70 |  |  | $\mathrm{T}_{10}+8$ |  |  | ns | Notes 2 \& 8 |
| TMWH | MCLK falling edge to SC/WC rising edge | 127 |  | 154 | $\begin{gathered} \mathrm{T}_{10}+ \\ \mathrm{T}_{20}+2 \end{gathered}$ |  | $\begin{gathered} T_{1 Q}+ \\ T_{2 Q}+29 \\ \hline \end{gathered}$ | ns | Note 2 |
| TMWL | MCLK falling edge to SC/WC falling edge | 5 |  | 25 | 5 |  | 25 | ns |  |
| TMibs | MCLK falling edge to $\overline{L B} / \overline{R B}$ (Input phase) | 10 |  | 35 | 10 |  | 35 | ns |  |
| $\mathrm{T}_{\text {IIBS }}$ | Instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Input phase) |  |  | 30 |  |  | 30 | ns |  |
| TMOBS | MCLK falling edge to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (Output phase) | 140 |  | 170 | $\begin{gathered} T_{1 Q}+ \\ T_{2 Q}+15 \\ \hline \end{gathered}$ |  | $\begin{array}{\|c\|} \hline T_{1 Q}+ \\ T_{2 Q}+45 \\ \hline \end{array}$ | ns | Note 2 |
| $\mathrm{T}_{\text {MIDS }}$ | MCLK faling edge to input data stable |  |  | 75 |  |  | $\begin{gathered} \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 Q}-50 \\ \hline \end{gathered}$ | ns | Note 2 |
| $\mathrm{T}_{\text {MIDH }}$ | Input data hold time (MCLK falling edge) | 140 |  |  | $\begin{gathered} \mathrm{T}_{1 \mathrm{a}+} \\ \mathrm{T}_{2 \mathrm{a}}+15 \\ \hline \end{gathered}$ |  |  | ns | Note 2 |
| $\mathrm{T}_{\text {MODH }}$ | Output data hold time (MCLK falling edge) | 11 |  |  | 11 |  |  | ns |  |
| $\mathrm{T}_{\text {MODS }}$ | Output data stable (MCLK falling edge) | 150 |  | 180 | $\begin{gathered} \mathrm{T}_{1 \mathrm{Q}}+ \\ \mathrm{T}_{2 \mathrm{Q}}+25 \end{gathered}$ |  | $\begin{array}{\|c\|} \hline \mathrm{T}_{1 Q}+ \\ \mathrm{T}_{2 \mathrm{Q}}+55 \\ \hline \end{array}$ | ns | Note 2 |

NOTES:

1. $X 1$ and $X 2$ inputs are driven by an exsernal pulse generator with an amplitude of 1.5 volts; all timing parameters are measured at this voltage level.
2. Respectively, $T_{1 Q}, T_{2 Q}, T_{3 Q}$, and $T_{4 Q}$ represent time intervals for the first, second, third, and fourth quarter cycles.
3. Capacitive loading for the address bus is 150 picofarads.
4. $T_{\text {MAS }}$ is obtained by forcing a valid instruction and an I/O bus input to occur earlier than the specified minimum set up time.
5. $T_{I A}$ is obtained by forcing a valid instruction input to occur earlier than the minimum set up time.
6. TIVA is obtained by forcing a valid I/O bus input to meet the minium set up time.
7. $T_{\text {MIS }}$ represents the setup time required by internal latches of the $8 \times 305$. In system applications, the instruction input may have to be valid before the worst-case set up time in order for the system to respond with a valid $I / O$ bus input that meets the $\| O$ bus input set up time ( $T_{\text {IDS }}$ and $T_{\text {MIDS }}$ ).
8. $T_{\text {MIH }}$ represents the hold time required by internal latches of the $8 \times 305$. To generate proper $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signals, the instruction must be held valid until the address bus changes.
9. The minimum figure for these parameters represents the earliest time that $/ / \mathrm{O}$ bus output drivers of the $8 \times 305$ will turn on.
10. This parameter represents the latest time that the output drivers of the input device should be turned off.

## TIMING CONSIDERATIONS (Commercial Part)

As shown in the AC CHARACTERISTICS table for the commercial part, the minimum instruction cycle time is 200 nanoseconds; whereas, the maximum is determined by the on-chip oscillator frequency and can be any value the user chooses. With an instruction cycle time of 200 nanoseconds, the part can be characterized in terms of absolute values; these are shown in the first "LIMITS" column of the table. When the instruction cycle time is greater than 200 nanoseconds, certain parameters are cycle-time dependent; thus, these parameters are specified in terms of the four quarter cycles ( $T_{1 Q}, T_{2 Q}, T_{3 Q}$, and $\mathrm{T}_{4 \mathrm{Q}}$ ) that make up one instruction cycle - see $8 \times 305 \mathrm{TIM}$ ING DIAGRAM. As the time interval for each instruction cycle increases (becomes greater than 200 nanoseconds), the delay for all parameters that are cycle-time dependent is likewise increased. In some cases, these delays have a significant impact on timing relationships and other areas of systems design; subsequent paragraphs describe these timing parameters and reliable methods of calculation.

Timing parameters for the 8X305 are normally measured with reference to MCLK.

System determinants for the instruction cycle time are:

- Propagation delays within the $8 \times 305$
- Access time of Program Storage
- Enable time of the I/O port

Normally, the instruction cycle time is constrained by one or more of the following conditions:

Condition 1 - Instruction or MCLK to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (input phase) plus I/O port access time (TIO) $\leq$ IV data set up time (Figure 5a).
Condition 2 - Program storage access time (TACC) plus instruction to LB/RB (input phase) plus I/O port access time (TIO) plus IV data (input phase) to address $\leq$ instruction cycle time (Figure 5b).
Condition 3 - Program storage access time plus instruction to address $\leq$ instruction cycle time (Figure 5c).


Figure 5. Constraints of $8 \times 305$ Instruction Cycle Time

## 8X305 TIMING DIAGRAM



From condition \#1 and with an instruction cycle time of 200ns, the I/O port access time (TIO) can be calculated as follows:

TMIBS + TIO $\leq$ TMIDS
transposing, TIO $\leq$ TMIDS $=$ TMIBS
substituting, TIO $\leq 55 \mathrm{~ns}-25 \mathrm{~ns}$
result, $\mathrm{TIO} \leq 30 \mathrm{~ns}$
Using 30ns for TIO, the constraint imposed by condition \#1 can also be used to calculate the minimum cycle time:

$$
\text { TMIBS + TIO } \leq \text { TMIDS }
$$

thus, $25 \mathrm{~ns}+30 \mathrm{~ns} \leq \mathrm{T}_{1 \mathrm{Q}}+\mathrm{T}_{2 \mathrm{Q}}-45$
$25 n s+30$ ns $\leq 1 / 2$ cycle -45 therefore, the worst-case instruction cycle time is 200 ns . With subject parameters referenced to X 1 , the same calculations are valid:

TIBS + TIO + TIDS $\leq 1 / 2$ cycle
thus, $45 n s+30 n s+25 n s \leq 1 / 2$ cycle therefore, the worst-case instruction cycle time is again 200 ns . From condition \#2 and with an instruction cycle time of 200 ns , the program storage access time can be calculated:

$$
\text { TACC + TIIBS + TIO + TIVA } \leq 200 \mathrm{~ns}
$$

transposing, TACC $\leq 200 \mathrm{~ns}-$ TIIBS - TIO - TIVA
substituting, $\quad$ TACC $\leq 200 n s-25 n s-30 n s-85 n s$
thus, TACC $\leq 60 \mathrm{~ns}$ hence, for an instruction cycle time of 200 ns , a program storage access time of 60 ns is implied. The constraint imposed by condition \#3 can be used to verify the maximum program storage access time:

$$
\text { TIA }+ \text { TACC } \leq \text { Instruction Cycle }
$$

thus, TACC $\leq 200 \mathrm{~ns}-140 \mathrm{~ns}$
and, TACC $\leq 60 \mathrm{~ns}$, confirming that a program storage access time of 60 ns is satisfactory.
For an instruction cycle time of 200 ns an:d a program storage access time of 60 ns (Condition \#2/Figure 5b), the instruction should be valid at the falling edge of MCLK. This relationship can be derived by the following equation:

$$
\begin{aligned}
& 200 \mathrm{~ns}-\text { TMAS }- \text { TACC } \\
= & 200 \mathrm{~ns}-140 \mathrm{~ns}-60 \mathrm{~ns} \\
= & 0 \mathrm{~ns}
\end{aligned}
$$

It is important to note that, during the input phase, the beginning of a valid $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signal is determined by either the instruction to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ delay (TIIBS) or the delay from the falling edge of MCLK to $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ (TMIBS). Assuming the instruction is valid at the falling edge of MCLK and adding the instruction-to- $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ delay (TIIBS $=25 \mathrm{~ns}$ ), the $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signal will be valid 25 ns after the falling edge of MCLK. With a fast program storage memory and with a valid instruction before the falling edge of MCLK - the $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ signal will, due to the TMIBS delay, still be valid 25 ns after the falling edge of MCLK. Using a worst-case instruction cycle time of 200 ns , the user cannot gain a speed advantage by selecting a memory with faster access time. Under the same conditions, a speed advantage cannot be obtained by using an I/O port with fast access time (TIO) because the address bus will be stable

55 ns (TAS) after the beginning of the third quarter cycle - no matter how early the $\overline{\mathrm{IV}}$ data input is valid.

## CLOCK CONSIDERATIONS

The on-chip oscillator and timing-generation circuits of the $8 \times 305$ can be controlled by any one of the following methods:

Capacitor - if timing is not critical
Crystal - if precise timing is required
External Drive - if application requires that the 8X305 be driven from a system clock
Capacitor Timing. A non-polarized ceramic or mica capacitor with a working voltage equal to or greater than 25 volts is recommended. The lead lengths of capacitor should be approximately the same and as short as possible; also, the timing circuits should not be in close proximity to external sources of noise. For various capacitor $\left(C_{x}\right)$ values, the cycle time can be approximated as:

| $\mathbf{c}_{\mathrm{X}}$ (in pF) | APPROXIMATE CYCLE TIME |
| :---: | :---: |
| 100 | 300 ns |
| 200 | 500 ns |
| 500 | $1.1 \mu \mathrm{~s}$ |
| 1000 | $2.0 \mu \mathrm{~s}$ |

Crystal Timing. When a crystal is used, the on-chip oscillator operates at the resonant frequency ( $f_{0}$ ) of the crystal; the series-resonant quartz crystal connects to the 8 X305 via pins 10 (X1) and 11 (X2). The lead lengths of the crystal should be approximately equal and as short as possible; also, the timing circuits should not be in close proximity to external sources of noise. The crystal should be hermetically sealed (HC type can) and have the following electrical characteristics:

Type - Fundamental mode, series resonant Impedance at Fundamental - 35 ohms maximum
Impedance at Harmonics and Spurs - 50 ohms minimum
The resonant frequency ( $f_{0}$ ) of the crystal is related to the desired cycle time ( $T$ ) by the equation: $f_{o}=2 / T$; thus, for a cycle time of 200 nanoseconds, $f_{0}=10 \mathrm{MHz}$.

## HALT Logic

The $\overline{H A L T}$ signal is sampled via internal chip logic at the end of the first internal quarter of each instruction cycle. If, when sampled, the HALT signal is active-low, a halt is immediately executed and the current instruction cycle is terminated; however, the halt cycle does not inhibit MCLK nor does it affect any internal registers of the $8 \times 305$. As long as the HALT line is active-low, the SC and WC lines are low (inactive), the Left Bank ( $\overline{\mathrm{LB}}) /$ Right Bank $(\overline{\mathrm{RB}})$ signals are high (inactive), and the $\overline{\mathrm{V}}$ bus remains in the three-state mode of operation. Normal operation resumes at the next cycle in which HALT is high when sampled - see HALT TIMING DIAGRAM.

## HALT TIMING DIAGRAM



Notes:

1. The मALT aignal can switch from High to Low at any time during this interval.
2. The HALT signal can switch from Low to High at any time during this interval.

Timing Descriptions:
$\mathrm{T}_{\mathrm{HS}}$-set-up time from $\overline{\text { HALT }}$ to X 1 (independent of instruction cycle time)
$T_{H H}$-hold time from $\times 1$ to HALT (independent of instruction cycle time)
$T_{\text {MHS }}$-set-up time from MCLK to HALT (dependent upon instruction cycle time)
$\mathrm{r}_{\text {MAH }}$-hold time from MCLK to $\overline{\text { HALT }}$ (dependent upon inatruction cycle time)


Figure 7. Timing Relationships of $8 \times 305$ I/O Signals

Using an External Clock. The $8 \times 305$ can be synchronized with an external clock by simply connecting appropriate drive circuits to the $\mathrm{X} 1 / \mathrm{X} 2$ inputs. Figure 8 shows how the on-chip oscillator can be driven from the complementary outputs of a pulse generator. In applications where the MicroController must be driven from a master clock, the $\mathrm{X} 1 / \mathrm{X} 2$ lines can be interfaced to TTL logic as shown in Figure 9.


Figure 8. Clocking with a Pulse Generator


Figure 9. Clocking with TTL

## RESET Logic

$\overline{\text { RESET }}$ (pin 43) can be driven from a high (inactive) state to a low (active) state at any time with respect to the system clock, that is, the reset function is asynchronous. To ensure proper operation, $\overline{\operatorname{RESET}}$ must be held low (active) for one full instruction time. When the line is driven from a high state to an active-low state, several events occur - the precise instant of occurrence is basically a function of the propagation delay for that particular event. As shown in the RESET TIMING DIAGRAM, these events are:

- The Program Counter and Address Register are set to address zero and remain in that state as long as the $\overline{R E S E T}$ line is low. Other than PC and AR, RESET does not affect other internal registers.
- The input/output (IV) bus goes three-state and remains in that condition as long as the RESET line is low.
- The Select Command and Write Command signals are driven low and remain low as long as the $\overline{\text { RESET }}$ line is low.
- The Left Bank/Right Bank ( $\overline{\mathrm{LB}} / \overline{\mathrm{RB}}$ ) signals are forced high asynchronously for the period in which the $\overline{\text { RESET }}$ line is low.
During the time RESET is active-low, MCLK is inhibited; moreover, if the $\overline{\operatorname{RESET}}$ line is driven low during the last two quarter cycles, MCLK may be shortened for that particular machine cycle. When RESET line is driven high (inactive) - one quarter to one full instruction cycle later, MCLK appears just before normal operation is resumed. The $\overline{R E S E T} / M C L K$ relationship is clearly shown by " $B$ " in the timing diagram. As long as the RESET line is activelow, the HALT signal (described next) is not sampled by internal logic of the 8X305.

RESET TIMING DIAGRAM


## FEATURES

- Three prioritized interrupts
- Subroutine handling capabilities
- 4-level LIFO stack for return address storage
- Interrupt masking by software and hardware
- Stack full flag
- Directly compatible with 8X305 MicroController
- Bipolar ISL (Integrated Schottky Logic) and low-power Schottky technology
- Single +5 volt power supply
- 0.6 inch, 40 -pin DIP


## PRODUCT DESCRIPTION

The Signetics $8 \times 310$ Interrupt Control Coprocessor (ICC) supports the $8 \times 305$ MicroController in systems that are interrupt driven and those that require subroutine handling capabilities.

As shown in Figure 1, the ICC provides three prioritized interrupt request lines, INT 0 (highest priority), INT 1 and

INT 2. A low-to-high transition applied to any of these input lines latches in an interrupt request which may be serviced when sampled by the ICC once each instruction cycle of the MicroController. When an interrupt request is serviced, the ICC forces the MicroController to jump to one of three fixed locations in program memory; instruction addresses 4, 5, and 6 correspond to INT 0, INT 1 and INT 2. At each of these addresses, the user programs a JMP instruction to another address where the user's interrupt service routine begins.

During interrupt servicing, the ICC also stores the proper return address into a four deep, Last-In-First-Out (LIFO) stack. At the conclusion of the interrupt service routine, the user program instructs the ICC to return to the main program at the location previously stored in the stack. The return operation is implemented by coding a special RETURN instruction which is decoded directly off the instruction bus by the ICC. There are five such special instructions relating to interrupt and subroutine handling functions performed by the ICC. These instruction codes are all treated as non-operational instructions (NOPs) by the MicroController.


Figure 1. Typical System Connections Using ICC

An internal one-bit mask is used to inhibit interrupt servicing. Whenever the mask is set, the ICC does not respond to any pending interrupt requests; however, any requests remain latched for future servicing. The mask can be set and cleared either by the user program or automatically during certain ICC functions. The special instructions SET MASK and CLEAR MASK are provided for user control. The Interrupt Disable input also inhibits interrupt request servicing.
The ICC provides a facility for implementing subroutines in the user program. A special PUSH instruction directs the

ICC to store the return address into the stack in a manner similar to interrupt servicing. The jump to the subroutine, however, is performed by the user program. Subroutines may be nested (called from within other subroutines) depending on remaining vacancies in the four deep stack.
In general, the ICC adds some useful and very flexible facilities to the $8 \times 305$-based system. It offers both hardware and software capabilities that can improve efficiency and decrease program size. These features, from both a chip and system aspect, are described in subsequent paragraphs.

## 8X310 PACKAGE AND PIN DESIGNATIONS


## FUNCTIONAL OPERATION

## Basic Functions

The ICC performs the three general functions indicated below.

Function 1: Provides a means for the $8 \times 305$ MicroController to respond to interrupt requests by diverting the program flow of the $8 \times 305$ MicroController to the proper interrupt service routine or, in the case of a subroutine, the ICC stores the return address in the 4-level LIFO stack (Figure $2)$.
Function 2: Returns the user to the proper point in the main program for both interrupt and subroutine activities.
Function 3: Provides both automatic and programmed masking capabilities.

## Interrupt Requests and Priority Considerations

An interrupt is requested when any one of the ICC input pins INT 0, INT 1, or INT 2 undergoes a low-to-high transition; this request is temporarily stored in an internal edge-triggered latch that corresponds to the affected interrupt input. The interrupt request latches are part of the Priority and Mask Logic shown in Figure 2. Unless masked or otherwise disabled, the ICC samples these latches once each instruction cycle. Any or all of the latches may be set when sampled by the ICC; however, only the irterrupt of
highest priority will be serviced - the remaining interrupts will be held in queue. Thus, if INT 0, INT 1 and INT 2 simultaneously compete for service, INT 0 is the first to be serviced followed, in order, by INT 1 and INT 2; likewise, if INT 1 and INT 2 compete for service, INT 1, being of higher priority will be serviced first. The CLEAR INTERRUPT instruction resets all interrupt request latches without affecting an interrupt service routine that is already in progress.

The highest priority interrupt request will be serviced when sampled by the ICC provided interrupts in general are not inhibited and a previous interrupt of equal or higher priority is not currently being serviced. The general masking of interrupts is discussed later. To determine priorities, the ICC keeps track of any interrupt that is serviced until the corresponding service routine returns. A subsequent interrupt request may interrupt a service routine in progress only if it is of a higher priority than that of the current interrupt being serviced. If, for example, INT 1 is requested and serviced, then before its service routine finishes, a request on INT 0 can be serviced as a second level interruption. However, a request on INT 2 or a second request on INT 1 must wait until the original INT 1 service routine returns. The interrupt service routine that was interrupted will resume execution at the point of interruption when the higher priority service routine returns (i.e. in the same manner as when returning to the main program).


Figure 2. 8X310 Interrupt/Control Coprocessor - Functional Block Diagram

## Interrupt Servicing

Interrupts are sampled only at the conclusion of an instruction cycle while the next instruction is being fetched from Program Memory.
When an interrupt request is serviced, the following general steps are performed:

- Address of the instruction that would normally be executed next is pushed into the 4 -level LIFO Stack (Figure 2) for subsequent return to the main program.
- The ICC disables program storage and forces a JMP instruction onto the Instruction bus of the 8X305 MicroController. (Note: Because of timing considerations, the HALT signal is driven low to suspend operation of the MicroController for one instruction cycle; this permits the source of instruction data to change from program storage to the ICC without conflict.) The JMP instruction from the ICC transfers the MicroController to one of the three fixed program locations shown below. In each of these addresses, the user will normally store a JMP instruction to the interrupt service routine for that partic-
ular interrupt. Details of these operations are described later.

| INT 0 | Address 4 |
| :---: | :---: |
| INT 1 | Address 5 |
| INT 2 | Address 6 |

## Return from Interrupt Service Routine

Upon completion of the interrupt service routine, the user codes the special RETURN instruction. When executed, the ICC performs the following steps

- The return address is popped from the LIFO stack.
- The ICC disables program storage and forces a JMP instruction onto the MicroController instruction bus with the return address from the stack. (The HALT signal is driven low for one instruction cycle.)
- The JMP instruction from the ICC transfers the MicroController to the instruction that was about to execute at the time the interrupt was taken

A typical structure for a user program which handles interrupts is shown in the following example:

| Address |  | Instruction | Comment |
| :---: | :---: | :---: | :---: |
| 0 |  | (any) | First instruction executed after system reset |
| - |  | - |  |
| - |  | - |  |
| 3 |  | JMP MAIN | Jump around interrupt vector locations. |
| 4 |  | JMP SERVO | Service INT 0 interrupt. |
| 5 |  | JMP SERV1 | Service INT 1 interrupt. |
| 6 |  | JMP SERV2 | Service INT 2 interrupt. |
| 7 | MAIN | (any) | Continue main program. |
| $\bullet$ |  | - |  |
| - |  | - |  |
|  | SERVO | (any) | Begin INT 0 service routine. |
|  |  | - |  |
|  |  | - |  |
|  |  | MAIN R6,R6 | ICC RETURN instruction. End INT 0 service routine (resume main program execution). |
|  | SERV1 | (any) | Begin INT 1 service routine. |
| $\bullet$ |  | - |  |
| - |  | - |  |
|  |  | MOVE R6,R6 | RETURN from INT 1 service routine. |
|  | SERV2 | (any) | Begin INT 2 service routine. |
| $\bullet$ |  | - |  |
| - |  | - |  |
|  |  | MOVE R6,R6 | RETURN from INT 2 service routine. |

## Instruction Set

The five instructions shown in Table 1 allow the user to efficiently manage both the interrupt and subroutine capabilities of the ICC in an $8 \times 310 / 8 \times 305$-based system. When an ICC instruction appears in the program, it is inter-
preted as a NOP by the $8 \times 305$ but is captured and decoded by the ICC to perform the desired function. The capture-and-decode functions of the chip are automatic. Assembly and object codes for each ICC instruction are shown in Table 1.

Table 1. INSTRUCTION SET FOR ICC

| Instruction | Instruction Codes |  | $8 \times 305$ Operation | Description of ICC Operation |
| :---: | :---: | :---: | :---: | :---: |
|  | Assembler | Binary |  |  |
| SET MASK | MOVE R5,R5 | $\begin{array}{ll} l o=\text { MSB } \quad I_{15}=L S B \\ 100000101000 & 00101 \end{array}$ | NOP | When executed, sets interrupt mask, thus inhibiting all interrupt servicing. |
| CLEAR MASK | MOVE R4,R4 | 0000010000000100 | NOP | When executed, clears interrupt mask for all interrupts |
| RETURN | MOVE R6,R6 | 0000011000000110 | NOP | When executed returns program to address at top of LIFO stack. |
| PUSH | MOVE R3,R3 | 0000001100000011 | NOP | Pushes "address + 2" onto stack if PUSH is programmed on odd address in program memory and "address + 1 " if PUSH is programmed on even address. |
| CLEAR INTERRUPT | MOVE R2,R2 | 0000001000000010 | NOP | Clears all interrupt requests; an interrupt service routine that is in progress is unaffected. |

## Interrupt Masking Operations

Certain operations performed by the ICC and also some system considerations require that program execution not be interrupted for a specified interval of time. The servicing of interrupts by the ICC can be inhibited in a number of ways. Any time interrupts are inhibited, the ICC ignores any latched interrupt requests. However, the interrupt request latches are not cleared so that any previously pending requests remain latched. Also, during an interval when interrupt servicing is inhibited, any new interrupt signals received will get latched. As soon as interrupt servicing is enabled, any latched requests can be serviced on a priority basis.
The primary means of inhibiting interrupt servicing is the internal one-bit mask (latch). This mask can be set (to inhibit interrupts) or cleared under control of the user program using the special ICC instructions SET MASK and CLEAR MASK - See Table 1. With these instructions, segments of
the user program can be isolated so as to proceed without interruptions. Frequently, uninterruptable segments are needed at the very beginning of the user program (initialization routine) and at the beginning of, or throughout an interrupt service routine. To facilitate this, the ICC automatically sets the mask whenever the MicroController executes address zero (typically resulting from a system reset) and whenever the ICC services an interrupt. The ICC also automatically clears the mask after performing a RETURN operation from an interrupt service routine; a RETURN from a subroutine does not affect the status of the interrupt mask.

The Interrupt Disable (ID) input pin may also be used to inhibit interrupt servicing. Interrupt servicing remains disabled as long as a high level is applied to the input. The ID input has no effect, however, on the status of the internal interrupt mask.

The code for a typical subroutine call-and-return is shown in the following example.


## Stack Operation

The LIFO stack holds up to four 13-bit program addresses which allows the ICC to return from a subroutine or interrupt service routine. When all four stack locations are filled, the STack Full (STF) output pin is driven high and remains high until a RETURN (or reset) operation occurs. If an additional interrupt is serviced or subroutine called while the stack is full, the stack will overflow and the oldest return address will be overwritten and lost. That is, the stack retains the four most recent entries. After an overflow, the status of the STF output is not valid (until a reset operation occurs).

To prevent an interrupt from overflowing the stack, the user can connect the STF output directly to the Interrupt Disable (ID) input of the ICC. Then, even if the internal mask and priorities permit interrupt servicing, the interrupt request
must still wait for the most recent service routine or subroutine to return.
Because subroutine calling is controlled explicitly by the user software, the user can always ensure that subroutine nesting alone could not overflow the stack. However, care must be taken whenever calling a subroutine from within an interrupt service routine since the number of remaining stack locations may vary at the time the interrupt is taken. If, for example, three stack locations are already filled (STF is low) at the time an interrupt is serviced, then a subroutine call executed within the interrupt service routine would cause the stack to overflow and the earliest return address to be lost.

As mentioned earlier, whenever a RETURN operation is performed from an interrupt service routine, the internal interrupt mask is automatically cleared. A RETURN from a
subroutine, however, does not affect the status of the mask. To accomplish this, a flag bit is added to each of the four stack locations which records whether each address pushed into the stack is caused by an interrupt or a subroutine call. This flag is read during a RETURN operation to determine whether or not the interrupt mask is cleared. This allows interrupt servicing and subroutine calls to be intermixed in any order.

## Initialization

The ICC decodes address zero as a reset command to perform certain initialization functions. (Zero is the first address generated after the MicroController is reset.) Specifically, the instruction-bus drivers are placed in a high-impedance state, HALT output is set high, RD output is set low, and all interrupt request latches are cleared. The interrupt mask is set so that any initialization routine by the user will not be interrupted until a CLEAR MASK instruction (MOVE R4,R4) is executed. The LIFO stack is reset to an empty state and the STF output is set low.

## SYSTEM TIMING RELATIONSHIPS

## Interrupt Servicing

Interrupt servicing begins at the end of a MicroController instruction cycle when the $8 \times 305$ 's MCLK signal goes from low-to-high. Starting from this point, processing of the interrupt proceeds as follows:

From the rising edge of MCLK 1 :

- Interrupt mask is set to inhibit other interrupts.
- HALT output is driven low to stop internal operation of the 8X305 MicroController for one instruction cycle; MCLK is unaffected. ROM Disable (RD) output is driven high to disable program memory.
From the falling edge of MCLK 1 :
- Takes address of next instruction from address bus and pushes it onto the top of stack to be used as the return address to the main program.
From the rising edge of MCLK 2 :
- The ICC forces a JMP onto the instruction bus to one of three fixed vector addresses:

INT 0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Address 4
INT 1 .................................................. Address 5
INT 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Address 6

- Releases HALT (high) which allows the MicroControiler to complete the JMP to the above specified vector location in program memory.
From the rising edge of MCLK 3 :
- Instruction-bus drivers of the ICC are disabled.
- ROM Disable (RD) pin is cleared (low) enabling the program memory which resumes control of the Instruction bus.


## Return Operation

When the interrupt service routine or subroutine is completed, the RETURN instruction initiates the following sequence of events:
From the rising edge of MCLK 1 :

- Interrupts are temporarily inhibited through third MCLK cycle.
- HALT output is driven low to stop MicroController for one instruction cycle.
- RD output is set high to disable program memory.

From the rising edge of MCLK 2 :

- HALT output is driven high (cleared).
- A JMP instruction to address stored at top of LIFO stack is forced onto the Instruction bus by the ICC. (The stack is popped.)
From the rising edge of MCLK 3 :
- Instruction-bus drivers of the ICC are disabled.
- RD is cleared enabling the program memory.
- If returning from an interrupt service routine (condition recorded in extra stack bit) the interrupt mask is cleared; otherwise the mask remains unaffected.
Once the preceding return actions are completed, the $8 \times 305$ MicroController will resume execution of the instruction at the return address.


## APPLICATION HINTS

- When programming an interrupt service routine or subroutine, certain system operations typically need to be considered. In many interrupt-driven systems, a handshake signal is required to acknowledge the servicing of an interrupt request. The acknowledge signal may be transmitted by the interrupt service routine using a standard I/O port from the $8 \times 300$ Family.
- If the user wants to allow a higher priority interrupt request to interrupt a service routine, then the CLEAR MASK instruction should be programmed (perhaps after completing any critical operations)
- For both service routines and subroutines, the user may need to save the contents of some or all of the working registers of the MicroController so that operation of the main program is not upset. Registers may be written out to a working storage RAM such as $8 \times 350$ near the beginning of the routine, and restored from RAM just before returning to the main program.
- Certain subroutine calling techniques may be used to increase the efficiency of the user program. As shown in the following examples, a subroutine can automatically be repeated two, three or four times, if desired, without programming a loop.

| SUBROUTINE AUTOMATICALLY EXECUTESTWICE |  |  |  |
| :---: | :---: | :---: | :---: |
| Address | Instruction |  |  |
| $X$ (even) <br> $X+1$ (odd) | SUBR2 | MOVE R3,R3 <br> (start of subroutine) <br> MOVE R6,R6 | Push X+1 onto stack. <br> RETURN - First time jumps to $X+1$; second time jumps back to main program. |
| WUAROUTINE AUTOMATICALLY EXECUTES THREE TMES |  |  |  |
| $X$ (odd) <br> $X+1$ (even) <br> $x+2$ (odd) | SUBR3 | MOVE R3,R3 <br> MOVE R3,R3 <br> (start of subroutine) | Push $\mathrm{X}+2$ onto stack. <br> Push X+2 onto stack. |
| SUSROUTINE AUTOMATICALLY EXECUTESFOUR TIMES |  |  |  |
| $X$ (even) <br> $x+1$ (odd) <br> $X+2$ (even) <br> $x+3$ (odd) | SUBR4 | MOVE R3,R3 <br> MOVE R3,R3 <br> NOP <br> (start of subroutine) | Push $X+1$ onto stack. <br> Push $\mathrm{X}+3$ onto stack. |

- In a manner similar to the MicroController multi-way branch technique, one of several subroutines can be selected according to an index value.

SUBROUTINE CALI SELECTED BY VALUE IN R1

| Address | Instruction |  |  |
| :---: | :---: | :---: | :---: |
| $X$ (odd) |  | MOVE R3,R3 | Push $\mathrm{X}+2$ onto stack. |
| $x+1$ (even) |  | XEC TABLE (R1) | Execute JMP at TABLE + (R1) |
| $x+2$ (odd) |  | (any) | Subroutine returns here. |
|  |  | - |  |
| (any) | TABLE | JMP SUB0 | Call SUBO if R1 $=0$. |
|  |  | JMP SUB1 | Call SUB1 if R1 $=1$. |

COMMERCIAL: $V_{C C}=5.0 \vee( \pm 5 \%) ; 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}$
MILITARY: $\mathrm{VCC}_{C C}=5.0 \mathrm{~V}( \pm 10 \%) ; \mathrm{T}_{\mathrm{A}} \geq-55^{\circ} \mathrm{C}$
$\mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Rating | Unit | Parameter | Rating | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{C C}$ Power supply voltage | +7 | V DC | $V_{O}$ Off-state output voltage | +5.5 | $V_{D C}$ |
| $V_{\text {IN }}$ Input voltage | +5.5 | VDC | TSTG Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |


|  | Parameter | Test Conditions |  | Limits (Commercial) |  |  | Limits (Military) |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Voltage |  |  | 2.0 |  |  | 2.0 |  |  | V |
| VIL | Low Level Input Voltage |  |  |  |  | 0.8 |  |  | 0.8 | V |
| VOH | High Level Output Voltage | $\mathrm{V}_{\text {cc }}=$ Min.; | IOH $=-1.0 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
| VoL | Low Level Output Voltage | $V_{C C}=$ Min | COMMERCIAL: $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  | 0.55 |  |  |  | V |
|  |  |  | MILITARY: $\mathrm{IOL}=4.25 \mathrm{~mA}$ |  |  |  |  |  | 0.55 |  |
| $\mathrm{V}_{\mathrm{CL}}$ | input Clamp-Diode Voltage | $\mathrm{V}_{\text {CC }}=\mathrm{Min}$; $\mathrm{ICL}=-10 \mathrm{~mA}$ |  |  |  | -1.5 |  |  | -1.5 | $V$ |
| IH | High Level Input Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \mathrm{V}_{\mathrm{H}}=2.7 \mathrm{~V}$ |  |  |  | 100 |  |  | 100 | $\mu \mathrm{A}$ |
| IIL | Low Level Input Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max} ; \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |  |  |  | -550 |  |  | -700 | $\mu \mathrm{A}$ |
| los | Short Circuit Output Current | $V_{c c}=$ Max; $V_{O}=0 \mathrm{~V}$ |  | -15 |  | -80 | -15 |  | -80 | mA |
| Icc | Supply Current | $\mathrm{V}_{C C}=$ Max; $10-115=$ High -Z |  |  |  |  |  |  |  | mA |
|  |  | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ [2] |  |  |  | 200 |  |  |  |  |
|  |  | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  |  |  | 185 |  |  |  |  |
|  |  | $T_{A}=-55^{\circ} \mathrm{C}^{[2]}$ |  |  |  |  |  |  | 230 |  |
|  |  | $\mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C}$ |  |  |  |  |  |  | 170 |  |

AC ELECTRICAL CHARACTERISTICS
LOADING: See TEST LOADING CIRCUITS

COMMERCIAL: $V_{C C}=5.0 \mathrm{~V}( \pm 5 \%) ; 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$
MILITARY: $V_{C C}=5.0 \mathrm{~V}( \pm 10 \%) ; T_{A} \geq-55^{\circ} \mathrm{C}$
$\mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$

| Parameter | References |  | Test Conditions | Limits (Commercial) |  |  | Limits (Military) |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | From | To |  | Min | Typ | Max | Min | Typ | Max |  |
| Pulse Widths: twin Interrupt High | ${ }^{\text {IINT }}$ i | $\mathrm{IINT}_{i}$ |  | 30 |  |  | 30 |  |  | ns |
| twiL Interrupt Low | \\|INT ${ }_{i}$ | $\mathrm{IINT}_{i}$ |  | 35 |  |  | 35 |  |  | ns |
| twmH MCLK High | ¢MCLK | +MCLK | For all Functions | 40 |  |  | 47 |  |  | ns |
| Propagation Delays: tpRH RD High | 1MCLK | $\dagger$ ¢ ${ }^{\text {d }}$ | Interrupt or Return |  |  | 70 |  |  | 75 | ns |
| tprl R RD Low | 4MCLK | \RD | Interrupt or Return |  |  | 15 |  |  | 17 | ns |
| tPHL HALT Low | ¢MCLK | HALLT | Interrupt or Return |  |  | 70 |  |  | 87 | ns |
| tPHH HALTHigh | ¢MCLK | 4HALT | Interrupt or Return |  |  | 65 |  |  | 75 | ns |
| tPSH Stack Full High | IMCL.K | ASTF | Interrupt or Subroutine Call |  |  | 105 |  |  | 105 | ns |
| tpSL Stack Full Low | \$MCLK | ISTF | Return or Reset |  |  | 110 |  |  | 115 | ns |

## AC ELECTRICAL CHARACTERISTICS (CONTINUED)

| Parameter | References |  | Test Conditions | Limits (Commercial) |  |  | Limits (Military) |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | From | To |  | Min | Typ | Max | Min | Typ | Max |  |
| Setup Times: <br> tSIH Interrupt Input Setup ${ }^{3}$ ] | ${ }^{4} \mathrm{INT}_{i}$ | 4MCLK |  | 35 |  |  | 35 |  |  | ns |
| tSA Address Setup | $\mathrm{A}_{0}-\mathrm{A}_{13}$ | 4MCLK | Interrupt, Subroutine Call, or Reset | 0 |  |  | 0 |  |  | ns |
| tsc Instruction Setup ${ }^{(5)}$ | 10-15 | \$MCLK | All Commands | Note |  |  | ${ }_{5}^{\text {Note }}$ |  |  | ns |
| tsD Interrupt Disable | ID | 4MCLK |  | 30 |  |  | 30 |  |  | ns |
| Hold and Reset Recovery Times: <br> thil Interrupt Low Input Hold ${ }^{3}$ ] | 4MCLK | ${ }^{\text {A }} \mathrm{INT}$ i |  | 15 |  |  | 15 |  |  | ns |
| tha Address Hold | $\downarrow$ MCLK | $\mathrm{A}_{0-13}$ | Subroutine Call or Reset | 75 |  |  | 90 |  |  | ns |
| thC Instruction Hold | \$MCLK | 10-15 | All Commands | 55 |  |  | 55 |  |  | ns |
| thD Interrupt Disable Hold 3 ] | 4MCLK | ID |  | 25 |  |  | 25 |  |  | ns |
| tRI Interrupt Reset <br> Recovery${ }^{[4]}$ | +MCLK | ${ }_{\text {AINT }}$ i | Reset or Cancel <br> Command | 70 |  |  | 70 |  |  | ns |
| Output Enable/Disable Delays: toec Instruction Output Enable | 4MCLK | 10-15 | Interrupt or Return |  |  | 70 |  |  | 87 | ns |
| todc Instruction Output Disable | 4MCLK | 10-15 | Interrupt or Return |  |  | 40 |  |  | 47 | ns |

## Notes:

1. All electrical characteristics are guaranteed after power is applied and thermal equilibrium has been reached.
2. The 200 and 230 milliampere values are worst case over the entire temperature range for the Commercial and Military parts, respectively.
3. Parameters $t_{S I H}, t_{H I L}, T_{S D}$, and $t_{H D}$ are used only to determine whether an interrupt request will be serviced during the current or a subsequent instruction cycle. The INTi and ID inputs are asynchronous and transitions on either input may safely occur at any time with respect to MCLK. A low-to-high transition on $I N T_{i}$ occurring after tsin and before thil means only that it cannot be determined for sure whether or not the interrupt request will be honored during the current instruction cycle. Similarly, transitions on ID between tSD and tHD make it uncertain as to whether or not masking applies during the current instruction cycle.
4. When clearing interrupt requests (including a reset operation), any new low-to-high transitions appearing at the INT inputs that occur before tRI risk being cleared and therefore ignored; however, any transition after $t_{\text {RI }}$ is certain to be latched.
5. COMMERCIAL: tsc (minimum) $=15 \mathrm{~ns}-$ tPRL (actual).

MILITARY: tsc (minimum) $=17 \mathrm{~ns}-$ tPRL (actual).
(The required instruction enable time for the program memory depends on the sum of the tprL and tsc.)

## TEST SETUPS

RD, STF, and HALT Outputs -


10-115 Outputs (toec and tode) tpzh and tphz:

tpZL and tplz:
pin under test


## Notes:

1. $V_{\text {MEAS }}=1.5 \mathrm{~V}$ for all input signals and RD, STF, and HALT outputs.
2. For $\mathrm{l}_{0}^{-1} \mathrm{l}_{15}$ (toec): $\mathrm{V}_{\text {MEAS }}=1.5 \mathrm{~V}$

For $\mathrm{l}_{0-115}$ (todc): $\mathrm{V}_{\text {MEAS }}(\mathrm{tpLZ})=\mathrm{VOL}_{\mathrm{L}}+0.5 \mathrm{~V}$
$V_{\text {MEAS }}($ tpHZ $)=\mathrm{VOH}_{\mathrm{OH}}-0.5 \mathrm{~V}$

## TIMING DIAGRAMS

## INTERRUPT REQUEST TIMING:



INTERRUPT SERVICE TIMING:


## CLEAR INTERRUPT INSTRUCTION TIMING:



TIMING DIAGRAMS (Continued)


RETURN TIMING (FROM INTERRUPT OR SUBROUTINE):


RESET TIMING:


## BUS INTERFACE REGISTER ARRAY

## FEATURES

- 16-byte/2-port interface
- 8- or 16 -bit primary port (Host) interface (User selectable)
- 8 -bit secondary port interface
- Two 8-bit flag registers (handshake control)
- DMA or programmed I/O operation
- Two three-state bidirectional ports
- Secondary port is bus compatible with $8 \times 305$
- Single 5 V supply
- 40-pin package


## ARCHITECTURAL OVERVIEW

The Signetics $8 \times 320$ Bus Interface Register Array (Figure 1) is a dual-port RAM memory designed for use between a host processor and a peripheral processor. Specifically, the register array provides a convenient and economical interface between the $8 \times 305$ (or $8 \times 300$ ) Microcontroller (secondary port) and User's

Host System (primary port); the host can be almost any busoriented device-another processor, a minicomputer, or a mainframe computer. The host has 8 -bit (byte) or 16 -bit (word) access to the primary port; data can be read-from or written-into any memory location as determined by the primary-port address and control lines. The secondary port (8X305 bus) consists of eight input/output lines and four bus control !ines. To implement the secondary-port interface, an 8-bit memory location is addressed during one machine cycle and, during another cycle, data is read or written under control of the secondary ( $8 \times 305$ ) processor. Both primary and secondary ports feature three-state outputs and both ports are bidirectional.
Besides the convenience and economy of a two-port memory, the array also provides simple handshake control via two 8-bit flag registers, logic to facilitate DMA transfers, and a writeprotect feature for the primary port in both byte and word modes of operation.

## BLOCK DIAGRAM



Figure 1. Block Diagram of $8 \times 320$ Bus Interface Register Array

## N, I PACKAGE

| ORDER NUMBERS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| PIN No. | PARAMETER |  | FUNCTION |  |
| 1,20 | GND | Ground | Circuit ground. |  |
| 2 | DMAE | Direct Memory Access Enable | Enables primary port to facilitate DMA transfers; does not affect secondary port. |  |
| 3-18 | $\begin{aligned} & D 0_{A}-D 7_{A}^{\prime} \\ & D 0_{B}-D 7_{B} \end{aligned}$ | Primary Data Port | Sixteen 3-state lines used for data transfers to-and-from the primary data port; most significant bit is $\mathrm{D} 0_{\mathrm{B}}$ and least significant bit is $\mathrm{D} 7_{\mathrm{A}}$. |  |
| 19 | $\overline{\mathrm{ME}}$ | Master Enable | Enables secondary port when active low ( $\overline{M E}$ ). |  |
| 21 | MCLK | Master Clock | When MCLK is high, and $8 \times 320$ is enabled ( $\overline{M E}=$ Low), a register location may be either selected or written-into under control of SC and WC. |  |
| 22 | SC | Select Command | With SC high, WC low, MCLK high and $\overline{\mathrm{ME}}$ low, data on $\overline{\mathrm{VO}}$ through $\overline{\mathrm{VV7}}$ is interpreted as an address. If any one of the 16 register addresses $\left(60_{8}-77_{8}\right)$ matches that on the $/ / O$ (IV) bus, that particular register is selected and remains selected until another address on the same bank (i.e. $\overline{M E}=$ low) is output on the $1 / \mathrm{O}$ bus-at which time, the old register is deselected and a new register may or may not be selected. |  |
| 23 | WC | Write Command | With WC high, SC low, MCLK high, and $\overline{M E}$ low, the selected register stores contents of $\overline{\mathrm{VO}}-\overline{\mathrm{IV7}}$ as data. |  |
| 24-31 | $\overline{\text { V00-IV7 }}$ | Secondary Data Port | Eight 3 -state lines used to transfer data or $1 / 0$ address to-and-from the secondary data port; most significant bit is $\overline{\mathrm{V} O}$ and least significant bit is $\overline{\mathrm{V} 7}$. |  |
| 32 | ws | Write Strobe | When active high, data appearing at the primary port $\left(\mathrm{DO}_{A}-D 7_{A} / D 0_{B}-D 7_{B}\right)$ is stored in the register array if the primary port is in the write mode. |  |
| 33 | R/W | Read/Write Control | When this signal is high, primary port is in read mode; when signal is low, primary port is in write mode. |  |
| 34 | $\overline{\text { PIOE }}$ | Programmed I/O En able | When active low, primary port operates in programmed input/output mode with register to be read-from or written-into selected by AO-A3. |  |
| 35-38 | AO-A3 | Primary Port Address Select | Selects register or register-pair that primary port is to read-from or write-into. Most significant bit is A3; least significant bit is AO. |  |
| 39 | $B / \bar{W}$ | Byte/Word | When signal is high, the primary port operates in the byte ( 8 -bit) mode; when signal is low, the primary port operates in the word (16-bit) mode. |  |
| 40 | $\mathrm{V}_{\mathrm{CC}}$ | Power | +5 volts. |  |

All barred symbols ( $\overline{\text { DMAE, etc.) denote signals that are asserted (or active) when low }}$
(logical 0); signals that are not barred are asserted in the high state (iogical 1).

## OPERATING CHARACTERISTICS

## Memory Organization

Memory and address correlation for the 16 -register array is shown in Figure 2. From the primary port, the sixteen 8 -bit registers can be addressed in either (8-bit) or word (16-bit) format; in the word mode, the registers are addressed in pairs $08 / 18,28 / 3_{8}, 48 / 5_{8}, \ldots 14_{8} / 15_{8}$, and $168 / 17_{8}$. From the secondary
port, all registers are addressed in byte format-608 through 778. The memory consists of two 8-bit flag registers and fourteen 8 -bit general-purpose registers. The flag registers facilitate information transfers between the two ports and, in addition, they protect certain registers from being written into from the primary port.


Figure 2. Memory and Address Organization for the $8 \times 320$

Other than the Byte/ $\overline{\text { Word }}$ control line, specific operating characteristics of the primary port are controlled by two signals $\overline{\text { PIOE (Programmed I/O Enable) and DMAE (Direct Memory Ac- }}$ cess Enable). When $\overline{\text { PIOE }}$ is active (low) and DMAE is inactive (high), the primary port operates in the programmed I/O mode-refer to Table 3 ; in this mode of operation, the register to be read-from or written-into is determined by four address lines (A0 through A3) and the Byte/Word control line-see Figure 2 and Table 4. In the DMA mode of operation, A1, A2, and A3 are not used; data is read-from or written-into preassigned registers: bytes $16_{8}\left(76_{8}\right)$ and $17_{8}\left(77_{8}\right)$ for the byte mode of operation and bytes $14_{8}\left(74_{8}\right) / 15_{8}\left(75_{8}\right)$ and $16_{8}\left(76_{8}\right) / 17_{8}\left(77_{8}\right)$ for the word mode of operation. In both cases, switching between bytes 168 and 178 in the byte mode and $148 / 158$ and $16_{8} / 17_{8}$ in the word mode is controlled by A0 (the least significant address bit). Refer to Table 5.

Table 3. MODE CONTROL OF PRIMARY PORT

| MODE | $\overline{\text { PIOE }}$ | $\overline{\text { DMAE }}$ |
| :--- | :---: | :---: |
| Disabled (output) | 1 | 1 |
| Programmed I/O | 0 | 1 |
| DMA | X | 0 |

X = Don't Care

Table 4 defines programmed I/O operation of the primary port in terms of read/write functions and Byte/Word control. In the byte mode, data is read-from or written-into the even addresses ( $0_{8}$, $2_{8}, 48,6_{8}, 10_{8}, 128,148$, and $16_{8}$ ) via data lines $\mathrm{DO}_{A}$ through $\mathrm{D7}_{\mathrm{A}}$; data is read-from or written-into odd addresses $\left(1_{8}, 3_{8}, 5_{8}, 7_{8}\right.$, $11_{8}, 13_{8}, 15_{8}$, and $17_{8}$ ) via data lines $D_{B}$ through $D 7_{B}$. When $A 0$ is low (logical 0 ), even addresses are selected and when AO is high (logical 1), odd addresses are selected; thus, A0 is the LSB of a 4 -bit address. In the word mode, the state of AO is irrelevant, since both the odd and even bytes are, simultaneously, readfrom or written-into; thus, a register pair is selected by a 3-bit address, $A 1$ being the LSB.
In the DMA mode of operation with $\overline{\text { DMAE set to } 0 \text { and other con- }}$ ditions satisfied, data is directly transferred to-or-from specified memory locations under control of Byte $/ \bar{W} / 2$ rd,,$~ / \bar{W}$, and $A 0$. The state of the Byte/Word control line determines whether the data word is 8 bits or 16 bits. The AO address line correlates eight of

Table 4. PRIMARY PORT OPERATING IN PROGRAMMED I/O MODE

| MODE | $\mathbf{B / W}$ | AO | DOA-D7A $_{A}$ <br> (Even Addresses) | DOB $_{\mathbf{B}}-7_{\mathbf{B}}$ <br> (Odd Addresses) |
| :---: | :---: | :---: | :---: | :---: |
| Read | 0 (Word) | X | Stored Data | Stored Data |
| Read | 1 (Byte) | 0 | Stored Data | HI-Z |
| Read | 1 (Byte) | 1 | $\mathrm{HI}-Z$ | Stored Data |
| Write | 0 (Word) | $X$ | Write | Write |
| Write | 1 (Byte) | 0 | Write | No Change |
| Write | 1 (Byte) | 1 | No Change | Write |

$x=$ Dont Care
the sixteen data lines $\left(D 0_{A}-D 7_{A}\right.$ or $\left.D 0_{B}-D 7_{B}\right)$ with the proper byte/word location. Thus, in the word mode, the exchange of data between the memory and the primary port occurs via $D 0_{A}-D 7_{A}$ for bytes $14_{8}$ and $16_{8}$ and via $D 0_{B}-D 7_{B}$ for bytes $15_{8}$ and $17_{8}$. The byte mode of operation is similar, except that the unused eight lines are three-stated.

## FUNCTION AND CONTROL OF SECONDARY PORT

The secondary port provides an 8 -bit interface between the sixteen memory registers and the $8 \times 305$ (or other processor). As shown in Table 6, the secondary-port interface is controlled by five input signals and a status latch. The status latch is set when SC is high (MCLK high/ $\overline{M E}$ low) and a valid memory address $\left(60_{8}-778\right)$ is presented to the $8 \times 320$ via the secondary data port (IV0-IV7). The latch is cleared by internal logic when an invalid memory address is presented at the secondary port. In all read/write operations from the secondary port, the status latch acts like a master enable; data can be transferred only if the status latch is set.

Table 5. DMA OPERATION OF THE PRIMARY PORT

| MODE | BYTE/WORD | AO | $D 0_{A}-$ D7 ${ }_{\text {A }}$ | DOA ${ }^{-D 7} 7_{B}$ |
| :---: | :---: | :---: | :---: | :---: |
| Read | 0 (Word) | 0 | Data stored in byte 148 | Data stored in byte 158 |
| Read | 0 (Word) | 1 | Data stored in byte 168 | Data stored in byte 178 |
| Read | 1 (Byte) | 0 | Data stored in byte 168 | HI-Z |
| Read | 1 (Byte) | 1 | HI-Z | Data stored in byte ${ }^{178}$ |
| Write | 0 (Word) | 0 | Write to byte ${ }^{14} 8$ | Write to byte ${ }^{15} 8$ |
| Write | 0 (Word) | 1 | Write to byte 168 | Write to byte $17_{8}$ |
| Write | 1 (Byte) | 0 | Write to byte 168 | $\mathrm{HI}-\mathrm{Z}$ |
| Write | 1 (Byte) | 1 | $\mathrm{HI}-\mathrm{Z}$ | Write to byte $17_{8}$ |

Table 6. FUNCTIONAL CONTROL OF SECONDARY PORT

| $\overline{\text { ME }}$ | SC ${ }^{1}$ | WC ${ }^{1}$ | MCLK |  | STATUS LATCH | FUNCTION OF SECONDARY BUS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | X | X | Set | Output data from $8 \times 320$ memory to $8 \times 305$ |
| L | L | H | H | H | Set | Data from $8 \times 305$ is input and written-into a previously-selected memory location of the $8 \times 320$ (Note 2). |
| L | L | H | H | L | Set | With the primary port in the write mode ( $R / \bar{W}=0$ ), the secondary port is overridden and cannot write to the same register addressed by the pfimary port; however, the register addressed by the primary port can be read and any other register can be read-from or written-into from the secondary port (Note 2). |
| L | H | L | H | X | X | Data transmitted to the secondary port via the $\overline{\mathbb{V}}$ bus is interpreted as an address; if address is within range of $60_{8}-77_{8}$ the memory status latch is subsequently set. |
| L | L | H | L | X | X | Inactive |
| L | H | L | L | X | X | Inactive |
| L. | L | X | X | X | Not Set | Inactive |
| H | X | $x$ | X | X | X | Inactive |

Notes:

1. The SC and WC lines should never both be high at the same time; the $8 \times 305$ processor never generates this condition.
2. During read or write operations, the same register can be simultaneously addressed from either port. For any write operation by both ports on the same register, the primary port has priority; other than this, the $8 \times 320$ does not indicate error conditions or resolve conflicts.
3. $X=$ Don't Care.

DC CHARACTERISTICS $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C} ; 4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}$

| PARAMETER |  | TEST CONDITIONS ${ }^{1,2}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  |  | 4.75 | 5 | 5.25 | V |
| $V_{\text {IN }}(L)$ | Low level input voltage |  |  |  | 0.80 | v |
| $V_{\text {IN }}(H)$ | High level input voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} ; \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.55 | v |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} ; \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.40 |  |  | V |
| $\mathrm{v}_{\mathrm{CL}}$ | Input clamp voltage | $l_{1}=-5 \mathrm{~mA}$ |  |  | -1.00 | V |
| Icc | Supply current | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ (Both ports high -Z ) |  |  | 270 | mA |
| los | Short circuit output current ${ }^{3}$ | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ | -20 |  | -100 | mA |
| INN (L) | WC, MCLK, SC, \& $\overline{\text { ME }}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.50 \mathrm{~V}$ |  |  | -1.0 | mA |
| IIN (L) | $B / \bar{W}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.50 \mathrm{~V}$ |  |  | -1.6 | mA |
| INN(L) | AO-A3 | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.50 \mathrm{~V}$ |  |  | -1.0 | mA |
| IN (L) | $\overline{\text { DMAE }}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ |  |  | -800 | $\mu \mathrm{A}$ |
| IN (L) | WS, PIOE, \& R/W | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ |  |  | -400 | $\mu \mathrm{A}$ |
| IN (L) | IVO-IV7 | $V_{C C}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ |  |  | $\begin{gathered} -400 \\ \text { each line } \end{gathered}$ | $\mu \mathrm{A}$ |
| IIN (L) | $D 0_{A}-D 7_{A} / D O_{B}-D 7_{B}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ |  |  | $\begin{gathered} -400 \\ \text { each line } \end{gathered}$ | $\mu \mathrm{A}$ |
| $\operatorname{IN}(H)$ | WC, SC, MCLK, \& $\overline{\text { ME }}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{H}}=5.25 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| IN (H) | $B / \bar{W}$ | $V_{C C}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{H}}=5.25 \mathrm{~V}$ |  |  | 240 | $\mu \mathrm{A}$ |
| $\underline{I N}(H)$ | AO | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{H}}=5.25 \mathrm{~V}$ |  |  | 120 | $\mu \mathrm{A}$ |
| IN ( H ) | A1-A3 | $V_{C C}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{H}}=5.25 \mathrm{~V}$ |  |  | 60 | $\mu \mathrm{A}$ |
| IN (H) | DMAE | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{IH}}=5.25 \mathrm{~V}$ |  |  | 120 | $\mu \mathrm{A}$ |
| IN (H) | WS, PIOE, \& R/ $\bar{W}$ | $V_{C C}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{H}}=5.25 \mathrm{~V}$ |  |  | 60 | $\mu \mathrm{A}$ |
| IN ( H ) | $\overline{\mathrm{VO}}-\overline{\mathrm{VV7}}$ and $\mathrm{DO}_{A}-\mathrm{D7} \mathrm{~A}^{\prime} / \mathrm{DO} \mathrm{B}_{\mathrm{B}}-\mathrm{D7} \mathrm{~B}_{\mathrm{B}}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{H}}=5.25 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |

Notes:

1. Operating temperature ranges are guaranteed after terminal equilibrium has been reached.
2. All voltages are measured with respect to ground terminal
3. Short only one output at a time

## TEST CIRCUIT



Note:
$\mathrm{C}_{\mathrm{L}}$ includes jig and probe capacitance.

AC CHARACTERISTICS OF PRIMARY PORT $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C} ; 4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}$
Loading: See Test Circuit


| PARAMETER |  | FROM | то | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  | Typ | Max |  |
| $\mathrm{T}_{\text {A }}$ | Address Access Time |  | A3-A0 | $D 0_{A}-D 7_{A} / D 0_{B}-D 7_{B}$ |  |  | 45 | ns |
| $\mathrm{T}_{\text {CE }}$ | Primary port enable time | $\sqrt{\sqrt{\mathrm{PIOE}}}$ | $D 0_{A}-D 7_{A} / D 0_{B}-D 7_{B}$ |  |  | 30 | ns |
| $T_{C D}$ | Primary port disable time | $4 \overline{\mathrm{PIOE}}$ | $D 0_{A}-D 7_{A} / D 0_{B}-D 7_{B}$ |  |  | 35 | ns |
| T WSA | Address setup time | A3-A0 | tWS | 40 |  |  | ns |
| $\mathrm{T}_{\text {WHA }}$ | Address hold time | tWS | A3-A0 | 0 |  |  | ns |
| $T_{\text {WSD }}$ | Primary port data setup time | $D 0_{A}-D 7_{A} / D 0_{B}-D 7_{B}$ | tWS | 30 |  |  | ns |
| $\mathrm{T}_{\text {WHD }}$ | Primary port data hold time | tWS | $D 0_{A}-D 7_{A} / D 0_{B}-D 7_{B}$ | 0 |  |  | ns |
| $\mathrm{T}_{\text {wsc }}$ | Write mode control setup time | $\begin{aligned} & \frac{\overline{\mathrm{PIOE}}}{\overline{\mathrm{DMAE}}} \\ & \mathrm{R} / \overline{\mathrm{W}} \end{aligned}$ | $\begin{aligned} & \text { tws } \\ & \text { \$WS } \\ & \text { dWs } \end{aligned}$ | $\begin{aligned} & 30 \\ & 40 \\ & 30 \end{aligned}$ |  |  | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |
| $\mathrm{T}_{\text {WHC }}$ | Write mode control hold time | \$WS | $\overline{\text { PIOE }}$ $\overline{\text { DMAE }}$ R/ $\bar{W}$ | $\begin{aligned} & 10 \\ & 10 \\ & 10 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |
| $\mathrm{T}_{\text {WP }}$ | Write strobe pulse width |  |  | 25 |  |  | ns |
| $\mathrm{T}_{\mathrm{PD} 1}{ }^{1}$ | Primary port data delay | $D 0_{A}-D 7_{A} / D 0_{B}-\mathrm{D} 7_{B}$ | $\overline{\text { IV0-IV7 }}$ |  |  | 75 | ns |
| $\mathrm{T}_{\mathrm{PDD} 2}{ }^{2}$ | Primary port data delay from WS | 4WS | IV0-1V7 |  |  | 75 | ns |

## Notes

1. Measurement with Write Strobe set High and the control signals of the secondary port set for output data from the same register.
2. Measurement with primary port data stable and control signais of secondary port set for output data from the same register.


|  | PARAMETER | FROM | TO | LiMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| $t_{W}$ | MCLK pulse width |  |  | 30 |  |  | ns |
| $\mathrm{T}_{\text {SD1 }}$ | Data setup time | IV0-IV7 | $\downarrow$ MCLK | 35 |  |  | ns |
| $\mathrm{T}_{\text {SD2 }}$ | $\overline{\mathrm{ME}}$ setup time | $\overline{\mathrm{ME}}$ | $\downarrow$ MCLK | 30 |  |  | ns |
| $\mathrm{T}_{\text {SD3 }}$ | SC setup time | SC | $\downarrow$ MCLK | 30 |  |  | ns |
| $\mathrm{T}_{\text {SD4 }}$ | WC setup time | WC | +MCLK | 30 |  |  | ns |
| $\mathrm{T}_{\mathrm{HD1}}$ | Data hold time | $\downarrow$ MCLK | IV0-IV7 | 0 |  |  | ns |
| $\mathrm{T}_{\mathrm{HD2}}$ | $\overline{M E}$ hold time | ¢MCLK | $\overline{\mathrm{ME}}$ | 0 |  |  | ns |
| $\mathrm{T}_{\mathrm{HD3}}$ | SC hold time | \$MCLK | SC | 0 |  |  | ns |
| $\mathrm{T}_{\text {HD4 }}$ | WC hold time | \$MCLK | WC | 0 |  |  | ns |
| $\mathrm{T}_{\text {PD3 }}$ (Note) | IV propagation delay | $\overline{\mathrm{IV}}$ | $D 0_{A}-D 7_{A} / D 0_{B}-D 7_{B}$ |  |  | 45 | ns |
| $\mathrm{T}_{\text {OE }}$ | Output enable | $\overline{M E}, \mathrm{SC}$, or WC | IV0-IV7 |  |  | 30 | ns |
| $\mathrm{T}_{\mathrm{OD}}$ | Output disable | $\overline{M E}, \mathrm{SC}$, or WC | IV0-IV7 |  |  | 20 | ns |

Measured with MCLK = High and control signals of the primary port set for output data from the same register.

## FLOPPY DISK FORMATTER/CONTROLLER

## FEATURES

- Single or double density encoding/decoding
- On-chip data separator
- Programmable:

FM, MFM, and M2FM encoding/decoding Preamble Polarity
Data transfer rate
Address mark encoding/decoding
Sector length
Output port (7-bits disk command)
Input port (5-bits disk status)

- Write Precompensation with on/off control
- On-chip phase lock loop
- CRC generator with software-controlled error correction capabilities
- 40-pin package
- +5 volt operation


## PRODUCT DESCRIPTION

The Signetics $8 \times 330$ Floppy Disk Formatter/Controller is a monolithic peripheral device of the $8 \times 300$ Family. The
chip uses Bipolar-Schottky/I ${ }^{2}$ L-Technology and some very unique features to provide $8 \times 330$ customers with a competitive edge in both simple and complicated diskcontroller designs. The competitive advantage is measurable in terms of "systems parts count", "error correction capabilities", and "overall design concepts" that are applications oriented. Except for a crystal, a capacitor, an external transistor acting as a series-pass element for the on-chip voltage regulator, an active low-pass filter, and an optional off-chip voltage controlled oscillator (refer to Features and Option), the $8 \times 330$ contains all processing circuits and the required control logic to encode/decode double-density (MFM/M ${ }^{2} F M$ ) and single-density (FM) codes. Even the data-separation and write-precompensation logic are located on the chip; in addition, 16 -bytes of scratch-pad RAM are provided for storage of various control/status parameters.

OPTION: External Voltage Controlled Oscillator (VCO). For critical applications, window margins can be improved by as much as $6 \%$ with the use of an external VCO.

## BLOCK DIAGRAM



## 8X330 PACKAGE/PIN DESIGNATIONS



PIN NO. MNEMONIC \& DEFINITION

| 1,20 | GND | Ground |
| :--- | :--- | :--- |
| 2,3 | $\times 1, \times 2$ | Crystal inputs |

4 DW Data write

| 5 | $\overline{\text { DR }}$ | Data read | Negative-going pulses transmitted from the disk drive to a Schmitttrigger input of the $8 \times 330$; these pulses represent encoded data and clock from the disk media. |
| :---: | :---: | :---: | :---: |
| 6-12 | DC1-DC7 | Disk commands | Seven outputs from the $8 \times 330$ that allow general-purpose control, of one or more disk drives. |
| 13-17 | DS1-DS5 | Disk status | Five general-purpose Schmitttrigger inputs from the disk drive (or drives) that provide status information for the $8 \times 300$. |

PIN NO. MNEMONIC \& DEFINITION

$21 \quad \overline{M E} \quad$ Master enable When this input signal is active (low), the $8 \times 330$ can be accessed and enabled by the $8 \times 300$. (Refer to the $\overline{L B}$ and $\overline{R B}$ pinout discriptions of the $8 \times 300$ for further detail.)

22 MCLK Master clock When active high and with $\overline{M E}$ in the active-low state, this input signal provides a means whereby the I/O output from the $8 \times 300$ is interpreted as an enabling address (provided there is an address match) or as input data (if one of the $8 \times 330$ registers has already been selected).

23 SC Select command When this signal is active (high), the information output on pins IV0$\overline{1 V 7}$ of the $8 \times 300$ is interpreted as an address input by the $8 \times 330$.

24 WC Write command When this signal is active (high), the information output on pins $\overline{\mathrm{IVO}}-$ $\overline{\mathrm{IV7}}$ of the $8 \times 300$ is interpreted as input data by the $8 \times 330$.

25-32 $\overline{\text { IV0-IV7 }}$ Input/output Eight three-state input/output lines lines that provide bidirectional data transfers between the $8 \times 300$ and the enabled I/O device; $\overline{\mathrm{V} 7}$ is the Least Significant Bit.

33 PDN Pump down Open-collector output of on-chip output phase detector which indicates (by a negative-going, quantized, pulse-width modulated signal) that internal CCO frequency is too high.
34 PUP Pump up output Open-collector output of on-chip phase detector which indicates (by a negative-going, quantized, pulse-width modulated signal) that internal CCO frequency is too low
35 CCO Frequency Con- Variable input current from extrol Input for Cur-ternal low-pass filter that rent-Controlled controls the frequency Oscillator of the oscillator
36-37 C1. C2 Capacitor input
Inputs for capacitor that determines center frequency of the current-controlled oscillator

38 VCR Regulated supply DC voltage input from emit voltage ter of external series-pass transistor: this voltage powers internal logic of chip

39 VR Reference volt- Reference voltage output to base of series-pass transistor; this reference controls VCR.

Supply voltage +5 volt power

## SYSTEM INTERFACE

A typical floppy disk controller using an 8X300 microcontroller and the 8X330 is shown in Figure 2. The non-shaded portion of this particular configuration can service the command, status, and input/output requirements of two double-sided disk drives and, under software supervision, the system can read/write single-density (FM) or doubledensity (MFM/M2FM) codes. Interface requirements are simple-on one hand, consisting of the $8 \times 300$ microcontroller and, on the other, the two disk drives. All $8 \times 330$ control and data registers directly linked to the microprocessor interface (Figure 1) are addressable and appear to the $8 \times 300$ as simple I/O ports; a 13-bit address bus and a 16bit instruction bus provide communications between the $8 \times 300$ and up to 8 K of microprogram storage.
The disk-drive interface consists of seven (7) output control !ines (DC1-DC7), five (5) input status lines (DS1-DS5), a write gate ( $\overline{\mathrm{WG})}$, a data- write output ( $\overline{\mathrm{DW}}$ ), and a data-read input (DR). The twelve command/status lines are not dedicated;
thus, the user can assign system functions to best suit a given application. As shown in Figure 2, all control lines except $\overline{W G}$ are buffered to accommodate a reasonable distance between the controller and the disk media; the Write Gate, being a 40-milliampere output, requires no buffering.

As shown by the shaded part of Figure 2, the control and status lines can be expanded with peripheral hardware-the 8 T 32 (in this example) being only one method of implementation. Using this particular technique, one I/O port is totally dedicated to output control, whereas, the other port is totally dedicated to input status. With additional hardware and supporting software, the disk-drive system can be expanded without limit; however, from a point of being practical, five or six drives is sufficient for most applications. By using the programmable features of the $8 \times 330$, the user can emphasize and prioritize those system parameters that are most important-economics, reliability and/or speed.


Figure 2. Typical Interface Using an $8 \times 300$ Microcontroller

NOTE
When power is first applied to the $8 \times 330$, the Disk Command lines (DC1-DC7), the Write Gate (WG) output, and contents of Command/Status Register \#2 (CSR \#2) are set to 1 (high). The wakeup state of all other bits is undefined

## General-Purpose Register File

This general-purpose (scratch pad) memory is directly accessible by the $8 \times 300$ and is used to store system variables such as track address, sector address and other necessary parameters. The sixteen 8 -bit registers (1108$127_{8}$ ) provide sufficient on-chip memory to accommodate a minimum of two disk drives; the maximum number of drives that this non-dedicated memory file can support depends on several factors-system configuration, reliability requirements, economic constraints, and so on. Because of the on-chip file, all other system memory can be dedicated to the purpose of handling data to-and-from the disk media.


Figure 3. An Expanded View of the $8 \times 330 / 8 \times 300$ Interface

Command/Status Register \#1 (CSR 1/Address 1328)
The disk status (read) or disk-command (write) contents of this register are interpreted as follows; unless otherwise indicated, all bits of CSR 1 are read/write from the I/O bus.

## Bit 0 (Write Gate Enable)

Enables write gate output ( $\overline{W G} /$ pin 19) to disk drive(s)-the write gate ( $\overline{\mathrm{WG}}$ ) cannot be enabled unless the PF input pin (18) is high. When the WGE bit is set to 0 , the $\overline{W G}$ ouput pin is low (enabled); when WGE is set to 1 , the $\overline{W G}$ output is high (disabled). If the PF input goes low while the WG output is low, the $\overline{W G}$ output will go high and the Write Gate Enable bit is reset to 1 .

## Bit 1 (CRC Enable)

When set to 1 , permits internal CRC register to compute remainders on the data stream in either read or write modes of operation. When set to 0 , the CRC register becomes the source of data. A change in the CRC Enable bit does not become effective until the "next BYTRA flag appears" following the command bit change-refer to description of CSR 1/Bit 6.

## Bit 2 (Data Register Control)

When set to 0, contents of data register consists of interleaved data-and-clock bits; starting from the MSB (IV0) position, register contents are: Clock 1, Data 1, Clock 2, Data 2, Clock 3, Data 3, Clock 4, and Data 4. When writing an address mark, the appropriate data/clock pattern is loaded into the data register by the $8 \times 300$. Since each byte of data from the processor becomes an interleaved pattern (4-bits of data and 4 -bits of clock) in the $8 \times 330$ data register, two bytes from the processor are required to write each full byte of address mark to the drive-eight bit cells with each cell containing a possible data and/or clock transition, or a total of 16 bit positions. When writing address marks, the normal on-chip clock insertion circuitry of the 8X330 is inhibited; thus, the user is free to define any clock/data pattern for the address mark.

When reading address marks, the data register is loaded with data and clock representing four bit cells from the disk media. The information in the data register can then be compared with the expected address mark by the $8 \times 300$ on a nibble-by-nibble basis. When the DRC bit is set to 1 , the data register contains separated data (no clocks). A state change in this bit does not become effective until the "next BYTRA flag appears" following the state-change command.

## Bit 3 (Sync Enable)

The Sync Enable bit allows the on-chip data separator to obtain bit and byte synchronization; this bit also controls initialization of the CRC Register. With the 8X330 in Read mode and with Bit 3 set to 0 , bit synchronization occurs. The Preamble field is assumed to be all "zeroes" or all "ones" as determined by the Preamble Select bit (CSR 2/Bit 4).

When the proper number of preamble bytes, as determined by the disk-control program, have been found, the Sync Enable bit should be changed, under program direction, to
a 1. This puts the $8 \times 330$ in the Address-Mark search mode. Accordingly, all bits of the CRC Register are preset to 1, the BYte TRAnsfer flag is inhibited, and the 8X330 examines the data stream for an Address Mark. The Address Mark is detected by observing the data and clock bits to find a change in the normal Preamble pattern. Byte synchronization is achieved by assuming that the change occurred in the bit cell determined by two Bit Select bits (CSR 2/Bits 2 and 3).

When the pattern change is found indicating the start of an Address Mark, the $8 \times 330$ starts CRC computation and synchronizes BYTRA to the byte boundaries. Note that the $8 \times 330$ presumes an Address Mark by finding a change in the preamble pattern; however, it is up to the 8X300 to read the Address Mark and to establish its validity or non-validity.

In write mode, setting the Sync Enable bit to 0 presets all bits of the CRC Register to 1. Setting the Sync Enable bit to 1 allows CRC computation to begin at the next byte boundary.

## Bit 4 (Load Counter)

When set to 1 , transfers 8 -bits of data from Sector Length register and 1-bit (MSB) of data from Byte Counter (refer to next description) to 9 -bit Byte Counter. Loading of the 9-bit Byte Counter is effective one bit-cell time after the Load Counter bit is set to 1 . In both the read and write modes of operation, the Byte Counter is incremented by BYTRA. The Load Counter bit is self-clearing and always returns a 0 when read.

## NOTE

The Load Counter bit must be set one or more instruction cycles after setting the Byte Counter MSB, that is, bits 4 and 5 of CSR 1 cannot be set during th same instruction cycle.

## Bit 5 (Byte Counter MSB)

This bit is used to set and monitor the state of the ninth (MSB) bit in the Byte Counter; reading this bit always returns the current state of MSB in the Byte Counter. The MSB of the Byte Counter is set to the value of CSR 1/Bit 5 when the Load Counter bit (CSR 1/Bit 4) is asserted-refer to preceding description.

## NOTE

The Byte Counter MSB must be set one or more instruction cycles before the Load Counter bits-bits 4 and 5 of CSR 1 cannot be set during the same instruction cycle.

## Bit 6 (BYTRA)

During a disk read operation, the BYte TRAnsfer flag is automatically set to 0 when 8 -bits of information are transferred from the Data Shift Register to the Data Register -see Figure 1. During a disk write operation, BYTRA is automatically set to 0 when 8 -bits are transferred from the Data Register to the Data Shift Register. BYTRA (a read-
only bit) is reset to a 1 when the Data Register (address 1378) is selected by the user's program. During read/write operations, the 1-to-0 transition of the BYTRA flag increments the Byte Counter to keep count of bytes read or bytes written. All read-only bits of the $8 \times 330$ are designed to remain stable during the monitor period; thus, to read a status change of BYTRA, Disk-Status bit, the Byte Counter MSB, or other read-only bit requires a two-instruction loop similar to:

$$
\begin{array}{llcl}
\text { TEST } & \text { SEL } & \text { CSR } 1 & \\
& \text { NZT } & \text { BYTRA, } & \text { TEST }
\end{array}
$$

## Bit 7 (Disk Status 1)

Reflects state (0 or 1) of input DS1 (pin 17); this is a userdefinable read-only bit.

## note

A high input on any one of the Disk Status lines of the $8 \times 330$ is read by the $8 \times 300$ program as a logical 1 and a low input on the status tines is read as a logical 0.

## Command/Status Register \#2 (CSR 2/Address 1338)

The disk status (read) or disk-command (write) contents of this register are interpreted as follows:

## Bit 0 (Precompensation Enable)

This command bit determines whether or not precompensation is applied to the data stream being written onto the disk. When set to 0 , precompensation is inhibited. When set to 1 and with double-density encoding, write precompensation is applied to the following data/clock bit patterns:


## Bit 1 (Read Mode)

When set to 0 , the $8 \times 330$ reads data from the disk and transfers it to the Data Register; when set to 1, data from the Data Register is transferred to the disk, provided the Write Gate Enable bit (CSR1/Bit 0) is set to 1 . With WGE set to 0 and the Read Mode bit set to 1 , the current-controlled oscillator is forced to lock onto the crystal oscillator; this technique is used during a data-read operation to ensure rapid acquisition of the disk data.

## Bits 2,3 (Bit Selects 1 and 0)

Together with the Sync Enable (CSR 1/Bit 3), these two bits allow the user to establish byte boundaries for the data stream; this is done in the following way. After bit synchronization is established, and the preamble pattern is verified, the $8 \times 330$ looks for a change in the normal preamble pattern. As shown in the following truth table, Bit Select 1
(Bit 2) and Bit Select 0 (Bit 3) identifies the bit cell within the first nibble of the first Address-Mark byte in which the first deviation from the normal preamble is expected. BYTRA is always referenced to bit cell 0 .

| BS 0 | BS 1 | Bit Cell |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 |  |
| 0 | 1 | 1 |  |
| 1 | 0 | 2 |  |
| 1 | 1 |  | 3 |

## Bit 4 (Preamble Select)

This bit is used only for bit sychronization-refer to CSR 1/Bit 3. With Bit 1 of CSR 2 set to 0 (Read Mode) and the Preamble Select bit set to 0 , the preamble field is assumed to be all zeroes; with the Preamble Select it set to 1 , the preamble field is assumed to be all ones. In either case, preamble validity is determined by the $8 \times 300$.

## Bits 5,6 (E1 and E2)

Together, E1 and E2 select the encoding scheme used to write data on the disk-refer to truth table that follows.

| E1 | E2 | Encoding Scheme <br>  <br>  <br> 0 | 0 |
| :---: | :---: | :---: | :---: |
| 0 | 1 | FM |  |
| 0 | $x=$ don't care | M2FM |  |
|  |  |  |  |

## Bit 7 (1/2F)

This bit allows the data transfer rate to be changed without modification of the frequency-selective components in the data-separation logic; thus, differences in data transfer rates between standard-and-mini floppies can be accommodated via software-no component or other hardware changes. Assuming an 8 MHz crystal and with the $1 / 2 \mathrm{~F}$ bit set to 1 , the data transfer rate is 250 K -bits per second in the single-density (FM) mode and 500K-bits per second in the double-density (MFM/M2FM) mode. When set to 0 , the transfer rates are halved-125K-bits and 250K-bits, respectively. When using frequencies other than 8 MHz , the data transfer rate is determined as follows:

| Bit $7(1 / 2 F)$ | Single-Density (FM) | Double-Density (MFM/M2FM) |
| :---: | :---: | :---: |
| 0 | xtal freq | xtal freq |
|  | 64 | 32 |
| 1 | $x$ xtal freq | $\times$ xtal freq |
|  | 32 | 16 |

## Command/Status Register \#3 (CSR 3/Address 1348)

This register contains seven bits (Bit 0 through Bit 6) which determines the state of the disk-command outputs; writing to Bit 7 has no effect and reading Bit 7 always returns a zero. When a logical " 1 " is specified by the $8 \times 300$ program for a given disk-command line, a high will appear at the output of the 8X330 for that particular command line. Each bit and the output pin it controls are summarized below.

| Bit (CSR 3) |  | Control Function |  |
| :---: | :---: | :---: | :---: |
|  |  | Pkg Pin No. |  |
| 1 | DC1 Output |  | 12 |
| 2 | DC2 Output |  | 11 |
| 3 | DC3 Output |  | 10 |
| 4 | DC4 Output | 9 |  |
| 5 | DC5 Output | 8 |  |
| 6 | DC6 Output | 7 |  |
|  | DC7 Output | 6 |  |

## Command/Status Register \#4 (CSR 4/Address 1358)

This register contains four bits (Bit 0 through Bit 3) which reflect the state of the disk-status inputs to the $8 \times 330$; reading all other bits ( 4 through 7 ) always returns a zero. These read-only bits and the reflected status they represent are as follows; the information specified by notation for Bit 7/CSR 1 is applicable to these input lines.

| Bit (CSR 4) |  | Control Function |  |
| :---: | :---: | :---: | :---: |
|  | Pkg Pin No. |  |  |
| 1 | DS3 Input |  | 16 |
| 2 | DS4 Input |  | 15 |
| 3 | DS5 Input |  | 14 |
|  |  | 13 |  |

## Sector Length Register-Address 1368

This register contains the load value for the lower eight (LSBs) bits of the Byte Counter. Data is transferred from the Sector Length Register to the Byte Counter under control of Load Counter Bit in CSR 1. When the contents of this register are transferred to another location via a read or write commands, the original holding of data is not lost; thus, if the same data is to be used more than once, a repetitive read or write can be implemented without reloading the register.

## Data Register-Address 1378

Together with the Data Shift Register, the Data Register is used for bidirectional transfer of data between the 8X330 and the I/O bus. All transfers to-and-from this register are made in conjunction with Bit 6 (BYTRA-Byte Transfer Flag) of CSR 1. When the Data Register Control bit (CSR $1 /$ Bit 2 ) is set to 0 , the content of this register is interleaved with four bits of data and four bits of clock. When data is transferred from the Data Register to the Data Shift Register, the original content of the Data Register is not lost.

## Phase Lock Loop (PLL) and Data Separation Logic

An expanded view of the phase-lock loop and the dataseparation logic is shown in Figure 4. Basically, the PLL consists of two counters, a phase detector, and a feedback loop containing a low-pass filter (off-chip) that controls a phase-locked oscillator (CCO). In simplified form, the dataseparation logic consists of data flip-flops (pulse synchronizer) and other circuits required to separate data and clock transitions. In the read mode, the output of the phaselocked oscillator (CCO) is applied to the clock inputs of counter \#1, counter \#2, and the pulse synchronization circuits. Essentially, the frequencies of the two counters are identical (phase relationships may or may not be identical); to maintain proper frequencies and to continuously correct for any phase deviations, the following actions occur.

Preset values which represent, respectively, nominal midpoints of the clock and data windows are present at counter
\#2 and, when an output appears at the pulse synchronizer. these preset values are entered. The count sequence for both counters is from " 0 to F "; hence, the phase difference between Carry 1 (counter \#1) and Carry 2 (counter \#2) actually corresponds to any phase deviation between the CCO and the synchronized data from the disk. The phase detector measures the phase difference between the two carry inputs and produces a series of quantized pulses whose widths are proportional to the phase error at the end of each counting cycle. After integration by the low-pass filter, a current proportional to the phase error is applied to the current-controlled oscillator. Accordingly, the CCO is driven in a direction (pump-up or pump-down) to correct any phase difference between the synchronized disk data and the feedback-controlled clock. Phase detector characteristics for both single-and-double density formats are shown in Figures 5 and 6.


Figure 4. Simplified Block of Phase-Lock Loop


Figure 5. Phase Detector Characteristic for Single-Density (FM) Format


Figure 6. Phase Detector Characteristic for Double-Density (MFM/M2FM) Format

## Data Processing and Error-Check Functions

These functions of the $8 \times 330$ are summarized in Figures 7 and 8 . The read/write operations are software-controlled by previously-described bits of command/status registers

CSR1 and CSR2. For the sake of simplicity, control lines and much of the control logic associated with the data processing and error-check functions are omitted in the read/write diagrams.


Figure 7. Simplified Block of Data Processing and Error Check Functions-Write Mode


Figure 8. Simplified Block of Data Processing and Error Check Functions-Read Mode

DC CHARACTERISTICS $\quad V_{C C}=5 \mathrm{~V}( \pm 5 \%), \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | High level input voltage |  |  | 2.0 |  | $\mathrm{v}_{\mathrm{CC}}$ | v | For all inputs except $\mathrm{X} 1, \mathrm{X} 2$, $\mathrm{C} 1, \mathrm{C} 2, \mathrm{CCO}$, and $\mathrm{V}_{\mathrm{CR}}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Low level input voltage |  | -1.0 |  | 0.8 | v |  |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.75 | 5.0 | 5.25 | v | 5V ( $\pm 5 \%$ ) |  |
| $\mathrm{V}_{\text {CR }}$ | Regulator voltage | $\mathrm{V}_{C C}=5 \mathrm{~V}$ |  | 3.1 |  | v | From series-pass transistor |  |
| $\mathrm{V}_{\mathrm{CL}}$ | Input clamp voltage | $\begin{aligned} & V_{C C}=\operatorname{Min} \\ & I_{N}=-5 \mathrm{~mA} \end{aligned}$ | -1.0 |  |  | v | Inputs X1, X2, C1, C2, and CCO do not have internal clamp diodes. |  |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=\mathrm{Min} ; \\ & \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA} \end{aligned}$ | 2.7 |  |  | v | ```DC1 through DC7 (Pins 6-12) & DW (Pin 4)``` |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 |  |  | V | $\overline{\text { VO-IV7 (Pins 25-32) }}$ |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \\ & \mathrm{OL}=8 \mathrm{~mA} \end{aligned}$ |  |  | 0.5 | V | DC1 through DC7 (Pins 6-12); $\overline{\text { PUP, }} \overline{\text { PDN (Pins 33, 34); }} \overline{\mathrm{DW}}$ (Pin 4) |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.55 | V | $\overline{\mathrm{VO}}-\overline{\mathrm{IV7}}$ (Pins 25-32) |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{IOL}=40 \mathrm{~mA}$ |  |  | 0.55 | $v$ | $\overline{\mathrm{WG}}$ (Pin 19) |  |
| ICEX | Open-collector leakage current with output set to 1 . | $\begin{aligned} & \mathrm{V}_{\text {CC }}=\mathrm{Min} ; \\ & \mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }} \end{aligned}$ |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{WG}} \text { (Pin 19); } \overline{\mathrm{PUP}} \text { (Pin 34); } \\ & \overline{\mathrm{PDN}}(\text { Pin 33) } \end{aligned}$ |  |
| ${ }^{\prime} \mathrm{IH}$ | High level input current | $V_{C C}=M a x ; V_{I N}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { DS1-DS5 (Pins 13-17); } \\ & \overline{\operatorname{PF}} \text { (Pin 18); } \overline{\mathrm{DR}} \text { (Pin 5) } \end{aligned}$ |  |
|  |  |  |  |  | 40 | $\mu \mathrm{A}$ | $\overline{M E}$ (Pin 21); MCLK (Pin 22); SC (Pin 23); WC (Pin 24) |  |
|  |  | $\begin{aligned} & V_{C C}=M a x ; \\ & V_{I N}=5.25 \mathrm{~V} ; \\ & C C O(\text { Pin } 35) \text { input } \\ & \text { current }=0 \mathrm{~mA} \end{aligned}$ |  |  | 4 | mA | With C1 (Pin 36) under test, C2 (Pin 37) is open and, vice-versa. |  |
|  |  | $\begin{aligned} & V_{C C}=\text { Max; } V_{I N}=5.25 \mathrm{~V} \\ & C C O(\text { Pin } 35) \text { input } \\ & \text { current }=1 \mathrm{~mA} \end{aligned}$ |  |  | 2 | mA |  |  |
|  |  | $\begin{aligned} & V_{C C}=M a x ; \\ & V_{I N}=0.6 \mathrm{~V} \end{aligned}$ |  |  | 4 | mA | With X2 (Pin 2) under test, X1 (Pin 3) is open and, vice-versa. |  |
|  |  | $\mathrm{V}_{C C}=$ Max; $\mathrm{V}_{1 N}=4.5 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ | $\overline{\mathrm{VO}}$ - $\overline{\mathrm{VV7}}$ (pins 25-32) |  |
| $\mathrm{v}_{\text {cco }}$ | Input voltage for current-controlled oscillator | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> CCO input current <br> $($ Pin 35) $=300 \mu \mathrm{~A}$ |  | 750 |  | mV |  |  |

DC CHARACTERISTICS (Cont'd) $V_{C C}=5 \mathrm{~V}( \pm 5 \%), T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| IIL | Low level input current |  | $\begin{aligned} & V_{C C}=M a x ; \\ & V_{I N}=0.4 V \end{aligned}$ |  |  | -400 | $\mu \mathrm{A}$ | DS1-DS5 (Pins 13-17); <br> $\overline{\mathrm{PF}}$ (Pin 18); $\overline{\mathrm{DR}}$ (Pin 5) |
|  |  |  |  |  | -800 | $\mu \mathrm{A}$ | $\overline{M E}$ (Pin 21); MCLK (pin 22); SC (Pin 23); WC (Pin 24) |
|  |  |  |  |  | -4 | mA | $\mathrm{X} 1($ Pin 2$), \mathrm{X} 2(\operatorname{Pin} 3)$, with $\times 1$ under test, $X 2$ is open and, vice-versa. |
|  |  | $\begin{aligned} & V_{C C}=\operatorname{Max} \\ & V_{I N}=0.5 \mathrm{~V} \end{aligned}$ |  |  | -550 | $\mu \mathrm{A}$ | $\overline{\mathrm{VVO}}-\overline{\mathrm{IV7}}$ (Pins 25-32) |
| los | Output short-circuit current | $\begin{aligned} & V_{C C}=\text { Max; } \\ & \text { Output }=" 1 " ; V_{\text {OUT }}=" 0 " . \end{aligned}$ <br> (NOTE <br> At any time, no more than one output should be connected to ground) | -15 |  | -100 | mA | $\begin{aligned} & \text { DC1-DC7 (Pins 6-12) \& } \overline{D W} \\ & (\text { Pin 4) } \end{aligned}$ |
|  |  |  | -30 |  | -140 | mA | $\overline{\mathrm{V} 0}-\overline{\mathrm{IV7}}$ (Pins 25-32) |
| ${ }^{\text {I CC }}$ | (Pin 40) | $\mathrm{V}_{\text {CC }}=$ Max |  |  | 200 | mA |  |
| ${ }^{\text {I CR }}$ |  | $V_{C C}=$ Max |  |  | 250 | mA |  |
| Ireg | (Pin 39) | $\mathrm{V}_{C C}=5 \mathrm{~V} ; \mathrm{V}_{C R}=0 \mathrm{~V} \& \mathrm{~V}_{\mathrm{R}}=$ | -16 |  | -27 | mA |  |

## NOTES

1. Operating temperature ranges are guaranteed after thermal equilibrium has been reached.
2. All voltages measured with respect to ground terminal.
3. Uniess otherwise specified, each test requires that $V_{C R}$ be supplied through a series pass transistor as shown in the accompanying drawing


AC CHARACTERISTICS $V_{C C}=5 \mathrm{~V}( \pm 5 \%), T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| MNEMONIC | REFERENCE | INPUT | OUTPUT | Min | Typ | Max | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPD |  | $\square \overline{\mathrm{PF}}$ | WG |  |  | 60 ns | Refer to Note 3 and Test Loading Circuit \#1. |
| tpi |  | $\sqrt{\mathrm{MCLK}}$ | WG |  |  | 100 ns |  |
| tPD |  | $\sqrt{\mathrm{MCLK}}$ | $\overline{W G}$ |  |  | 100ns |  |
| ${ }^{\text {tPD }}$ |  | $\sqrt{\mathrm{MCLK}}$ | DC1-7 |  |  | 70ns | Refer to Note 3 and Test Loading Circuit \#2. |
| tPD |  | $\sqrt{\text { MCLK }}$ | DC 1-7 |  |  | 70ns |  |
| ${ }^{\text {tpw }}$ |  | 吅 |  | 50ns |  |  |  |
| $t_{\text {pw }}$ |  | $\overline{\mathrm{DR}}$ |  | 50ns |  |  |  |
| ${ }^{\text {tpw }}$ |  |  | 吅 $\sqrt{\text { DW }}$ |  |  |  | Note 1 |
| ${ }^{\text {tSETUP }}$ | 1 SC | Input on DS 1-5 |  | 55ns |  |  | Note 2 |
| ${ }^{\text {tSETUP }}$ | 1 wc | Input on DS 1-5 |  | 55ns |  |  | Note 2 |
| ${ }^{\text {t SETUP }}$ | $\overline{\mathrm{ME}}$ | Input on DS 1-5 |  | 55 ns |  |  | Note 2 |
| thOLD | 1 Sc | Input on DS1-5 |  | Ons |  |  | Note 2 |
| tHOLD | 1 WC | Input on DS 1-5 |  | Ons |  |  | Note 2 |
| thOLD | ME | Input on DS 1-5 |  | Ons |  |  | Note 2 |
| $\begin{aligned} & { }^{\mathrm{O} O E}-\overline{\mathrm{ME}} \\ & \mathrm{SC} \& \mathrm{WC} \end{aligned}$ |  |  | 1/O bus |  |  | 25 ns |  |
| $\begin{aligned} & \text { tOD - } \overline{\mathrm{ME}} \\ & \mathrm{SC} \& \mathrm{WC} \end{aligned}$ |  | $\overline{\mathrm{ME}}$ <br> SC <br> WC | $\begin{gathered} 1 / 0 \text { bus } \\ \text { (three-state) } \end{gathered}$ |  |  | 30ns |  |
| $t_{w}$ (MCLK pulse width) |  | MCLKL |  | 45 ns |  |  |  |
| ${ }^{\text {t }}$ SD (data setup time) | MCLK | 1/0 bus |  | 50ns |  |  |  |
| ${ }^{\text {t }} \mathrm{SD}$ (ME setup time) | MCLK | $\overline{M E}$ |  | 45 ns |  |  |  |
| tSD (SC setup time) | MCLK | SC |  | 45 ns |  |  |  |
| ${ }^{\text {t }}$ SD (WC setup time) | MCLK | WC |  | 45 ns |  |  |  |
| thD (data hoid time) | MCLK | 1/0 bus |  | Ons |  |  |  |

AC CHARACTERISTICS (Cont'd) $V_{C C}=5 \mathrm{~V}( \pm 5 \%), T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| MNEMONIC | REFERENCE | INPUT | OUTPUT | Min | Typ | Max |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| thD (ME hold <br> time) | MCLK | ME |  | Ons |  |  |  |
| thD (SC hold <br> time) | MCLK | SC |  | Ons |  |  |  |
| thD (WC hold <br> time) | MCLK | WC |  | Ons |  |  |  |

## NOTES

1. Write pulse width $=2 / \mathrm{FXTAL}$, that is, for 8 MHz crystal, $\mathrm{t}_{\mathrm{pw}}=250 \mathrm{msec}$ (typical)
2. Changes on DS 1-5 are not stored in read mode ( $\overline{M E}=0, S C=0$. and $W C=0$ )
3. During the period when MCLK is high, measurement is made with $\overline{M E}=$ Low, $S C=$ Low,
and $W C=$ High .

TEST LOADING CIRCUIT

CIRCUIT \# 2
CIRCUIT \#3


TIMING DIAGRAM


## CLOCK REQUIREMENTS

Crystal Oscillator. The on-chip crystal oscillator circuit is designed for operation using an external series-resonant quartz crystal; alternately the crystal oscillator can be driven with complementary outputs of a pulse generator or interfaced to a master clock source via TTL logic-see accompanying circuits. When a crystal is used, the on-chip oscillator operates at the resonant frequency (f.) of the crystal; the crystal connects to the $8 \times 330$ via pins 3 (X1) and 2 (X2). The lead lengths of the crystal should be approximately equal and as short as possible; also, avoid close proximity to all potential noise sources. The crystal should be hermetically sealed (HC type can) and have the following electrical characteristics:

Type: Fundamental mode, series resonant Impedance at Fundamental: 35-ohms maximum Impedance at Harmonics and Spurs: 50 -ohms minimum

When the crystal oscillator is externally-driven, typical waveforms are as follows:

## TYPICAL WAVE FORM



## Current-Controlled Oscillator (CCO).

A non-polarized ceramic or mica capacitor is recommended for the current-controlled oscillator. The capacitor connects to the $8 \times 330$ via pins 37 (C2) and 36 (C1); lead lengths of the capacitor should be approximately the same and as short as possible. When the input current to the CCO is near zero (maximum frequency), the capacitor value should be chosen so that the high-limit rest frequency of the oscillator does not exceed 24 MHz . If the rest frequency is higher than 24 MHz , synchronization of the CCO with the crystal oscillator just prior to the read operation, may be impeded. The curves in Figure 9 (current-versus-frequency) and Figure 8 (capacitance-versus-frequency) show how these design parameters affect operation of the CCO over a temperature range of $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$. A suitable test circuit for verification/validation of the current-controlled oscillator is also shown in Figure 10. Like the crystal oscillator, the CCO can be driven with the TTL output of a pulse generator or interfaced to a master clock via TTL logic-see accompanying diagrams.

## CLOCKING WITH OPEN-COLLECTOR TTL



## CLOCKING WITH PULSE GENERATOR




Figure 9. Current-versus-Frequency with: VCC $=\mathbf{5 V}$ and Capacitance $=\mathbf{2 5}$ Picofarads


Figure 10. Capacitance-versus-Frequency with: $V_{C C}=5 \mathrm{~V}, \mathrm{VCR}=\mathbf{2 . 5 V}$, and $\mathrm{I}=300 \mu \mathrm{~A}$

## VOLTAGE REGULATOR

All internal logic of the $8 \times 330$ is powered by an on-chip voltage regulator that requires an external series-pass transistor. Electrical specifications for the off-chip power transistor and a typical hook-up are shown in accompanying diagrams. To minimize lead inductance, the transistor should be as close as possible to the 8X330 package and the emitter should be ac-grounded via a 0.1-microfarad capacitor.

## TYPICAL HOOK-UP



| ELECTRICAL S <br> *PARAMETER | IFICATIONS CONDITIONS | LIMITS |
| :---: | :---: | :---: |
| $\mathrm{h}_{\text {fe }}$ | $\mathrm{V}_{\text {CE }}=2 \mathrm{~V}$ | >50 |
| Vbeon | $\mathrm{V}_{\mathrm{CE}}=5 \mathrm{~V} / \mathrm{IC}=500 \mathrm{~mA}$ | $<1 \mathrm{~V}$ |
| Vcesat | $\mathrm{IC}=500 \mathrm{~mA} / \mathrm{I}_{\mathrm{B}}=50 \mathrm{~mA}$ | $<0.5 \mathrm{~V}$ |
| BVCeo |  | $>8 \mathrm{~V}$ |
| $\mathrm{ft}_{t}$ |  | $>30 \mathrm{MHz}$ |

Medium power NPN silicon $\left(0^{\circ}<T_{A}<70^{\circ} \mathrm{C}\right)$ recommended parts: 2N5320, 2N5337

## 2048-BIT BIPOLAR RAM ( $256 \times 8$ )

Originally published by Signetics January 1984

## FEATURES

- On-chip address latches
- 3-state outputs
- Schottky clamped TTL
- Internal control logic for $8 \times 300$ system
- Directly interfaces with the $8 \times 300$ bipolar microprocessor with no external logic
- May be used on left or right bank


## APPLICATIONS

- $8 \times 300$ or $8 \times 305$ working storage


## DESCRIPTION

The $8 \times 350$ bipolar RAM is designed principally as a working storage element in an $8 \times 300$ based system. Internal circuitry is provided for direct use in 8X300 applications. When used with the $8 \times 300$, the RAM address and data buses are tied together and connected to the IV bus of the system.

The data inputs and outputs share a common $1 / O$ bus with 3 -state outputs.

The $8 \times 350$ is available in commercial and military temperature ranges. For the commercial temperature range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$ specify N8X350-F, and for the miltiary temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ specify S8X350-F.

## TYPICAL I/O STRUCTURE



PIN CONFIGURATION


## ABSOLUTE MAXIMUM RATINGS

|  | PARAMETER | RATING | UNIT |
| :---: | :---: | :---: | :---: |
| $V_{C C}$ | Supply voltage | +7 | Vdc |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage | +5.5 | Vdc |
|  | Output voltage |  | Vdc |
| $\mathrm{V}_{\mathrm{OH}}$ | High | +5.5 |  |
| $\mathrm{V}_{\mathrm{O}}$ | Off-state | +5.5 |  |
| $T_{A}$ | Temperature range |  | ${ }^{\circ} \mathrm{C}$ |
|  | Operating |  |  |
|  | Commercial | 0 to +75 |  |
|  | Military | -55 to +125 |  |
| Tstg | Storage | -65 to +150 |  |

TRUTH TABLE

| MODE | $\overline{\text { ME }}$ | SC | WC | MCLK | BUSSED DATA/ADDRESS LINES |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hold address Disable data out | 1 | X | X | X | High Z data out |
| Input new address | 0 | 1 | 0 | 1 | Address High Z |
| Hold address <br> Disable data out | 0 | $\cdots$ | 0 | 0 | High Z data out |
| Hold address Write data | 0 | 0 | 1 | 1 | Data in |
| Hold address Disable data out | 0 | 0 | 1 | 0 | High Z data out |
| Hold address Read data | 0 | 0 | 0 | X | Data out |
| Undefined state ${ }^{12}$ | 0 | 1 | 1 | 1 | - |
| Hold address ${ }^{12}$ Disable data out | 0 | 1 | 1 | 0 | High Z data out |

BLOCK DIAGRAM


DC ELECTRICAL CHARACTERISTICS2 ${ }^{2} 8 \times 350: 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}$
S8X350: $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}$

|  | PARAMETER | TEST CONDITIONS | N8X350 |  |  | S8x350 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | Input voltage Low ${ }^{1}$ High ${ }^{1}$ Clamp ${ }^{1,3}$ | $\begin{gathered} V_{C C}=\operatorname{Min} \\ V_{C C}=\operatorname{Max} \\ V_{C C}=M i n, \mathbb{I N N}_{N}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 |  | $\begin{gathered} .85 \\ -1.2 \end{gathered}$ | 2.0 |  | $\begin{gathered} .80 \\ -1.2 \end{gathered}$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ $\mathrm{VOH}_{\mathrm{OH}}$ | Output voltage Low ${ }^{1,4}$ High ${ }^{1.5}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{OL} & =9.6 \mathrm{~mA} \\ \mathrm{OH} & =-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | 2.4 |  | . 5 | V |
| $\begin{aligned} & \mathbb{I N L}_{1} \\ & \mathbb{I}_{\mathrm{H}} \end{aligned}$ | Input current Low High | $\begin{aligned} & V_{\mathbb{N}}=0.45 \mathrm{~V} \\ & V_{\mathbb{N}}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 25 \end{gathered}$ |  |  | $\begin{gathered} -150 \\ 50 \end{gathered}$ | $\mu \mathrm{A}$ |
| IO(OFF) <br> los | Output current High Z state Short circuit ${ }^{3,6}$ | $\begin{gathered} \overline{M E}=H i g h, V_{O U T}=5.5 \mathrm{~V} \\ \overline{M E}=H i g h, V O U T=0.5 \mathrm{~V} \\ S C=W C, \overline{M E}=\text { Low, } \\ V_{\text {OUT }}=0 \mathrm{~V}, \text { Stored High } \end{gathered}$ | -20 |  | $\begin{gathered} 40 \\ -100 \\ -70 \end{gathered}$ | -15 |  | $\begin{gathered} 60 \\ -100 \\ -85 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ <br> mA |
| ICC | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{7}$ | $V_{C C}=$ Max |  |  | 185 |  |  | 200 | mA |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Capacitance Input Output | $\begin{gathered} \overline{\mathrm{ME}}=\text { High }, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ \mathrm{~V}_{\text {IN }}=2.0 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{OUT}}=2.0 \mathrm{~V} \end{gathered}$ |  | $5$ |  |  | 5 8 |  | pF |

AC ELECTRICAL CHARACTERISTICS $2,9 \mathrm{~N} 8 \times 350: 0^{\circ} \mathrm{C} \leq T_{A} \leq+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V} \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ $\mathrm{S} 8 \times 350:-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}$

|  | PARAMETER | то | FROM | N8X350 |  |  | S8X350 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| $\begin{aligned} & \mathrm{T}_{\mathrm{E} 1} \\ & \mathrm{~T}_{\mathrm{E} 2} \end{aligned}$ | Enable time Output Output | Data out Data out | $\frac{\mathrm{SC}-}{\mathrm{ME}-}$ |  |  | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ |  |  | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | ns |
| $\begin{aligned} & T_{D 1} \\ & T_{D 2} \end{aligned}$ | Disable time Output Output | Data out Data out | $\frac{\mathrm{SC}+}{\mathrm{ME}+}$ |  |  | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ |  |  | $\begin{aligned} & 40 \\ & 40 \end{aligned}$ | ns |
| TW | Pulse width Master clock ${ }^{8}$ |  |  | 40 |  |  | 50 |  |  | ns |
| TSA <br> THA <br> TSD <br> THD <br> TS3 <br> $\mathrm{T}_{\mathrm{H} 3}$ <br> TS 1 <br> ${ }^{T} \mathrm{H} 2$ <br> TS2 <br> $\mathrm{T}_{\mathrm{H} 1}$ <br> TH4 | Setup and hold time <br> Setup time Hold time Setup time Hold time Setup time Hold time Setup time Hold time Setup time Hold time Hold time | MCLK- <br> Address MCLKData in MCLK$\overline{\mathrm{ME}}+$ MCLK-ME$\overline{\text { ME }}-$ SC- WC- | Address <br> MCLK - <br> Data in <br> MCLK -ME- <br> MCLK -$\overline{\mathrm{ME}}-$ MCLK-SC-,WC-MCLK-MCLK- | $\begin{gathered} 30 \\ 5 \\ 35 \\ 5 \\ 40 \\ 5 \\ 30 \\ 5 \\ 0 \\ 0 \\ 5 \\ 5 \end{gathered}$ |  |  | $\begin{gathered} 40 \\ 10 \\ 45 \\ 10 \\ 50 \\ 5 \\ 40 \\ 5 \\ 5 \\ 5 \\ 5 \\ 5 \end{gathered}$ |  |  | ns |

[^14]
## TIMING DIAGRAMS



NOTES

1. All voltage values are with respect to network ground terminal.
2. The operating ambient temperature ranges are guaranteed with transverse air flow exceeding 400 linear feet per minute and a 2 -minute warm-up.
Typical thermal resistance values of the package at maximum temperature are:
$\Theta_{J A}$ junction to ambient at 400 fpm air flow $-50^{\circ} \mathrm{C}$ /watt
$\Theta_{J A}$ junction to ambient - still air $-90^{\circ} \mathrm{C} /$ watt
$\Theta_{J A}$ junction to case $\cdot 20^{\circ} \mathrm{C} /$ watt
3. Test each pin one at a time
4. Measured with a logic low stored Output sink current is supplied through a resistor to $\mathrm{V}_{\mathrm{CC}}$
5. Measured with a logic high stored.
6. Duration of the short circuit should not exceed isecond.
7. ICC is measured with the write enable and memory enable inputs grounded, all other inputs at 4.5 V and the output open.
8. Minimum required to guarantee a Write into the slowest bit
9. Applied to the $8 \times 300$ based system with the data and address pins tied to the IV Bus.
10. $\mathrm{SC}+\overline{\mathrm{ME}}=1$ to avcid bus conflict.
11. $W C+\overline{M E}=1$ to avoid bus conflict.
12. The SC and WC outputs from the $8 \times 300$ are never at 1 simultaneously

## TIMING DEFINITIONS

TS1 Required delay between beginning of Master Enable low and falling edge of Master Clock.
TSA Required delay between beginaing of valid address and falling edge of Master Clock.
THA Required delay between falling edge of Master Clock and end of valid Address.
TH1 Required delay between falling edge of Master Clock and when Select Command becornes low.
TE1 Delay between beginning of Select Command low and beginning of valid data output on the IV Bus.
TD1 Delay between when select Command becomes high and end of valid data output on the IV Bus.
TH2 Required delay between falling edge of Master Clock and when Master Enable becomes low.
TE2 Delay between when Master Enable becomes low and beginning of valid data output on the IV bus.
TD2 Delay between when Master Enable becomes high and end of valid data output on the IV Bus.
TS2 Required delay between when Select Command or Write Command becomes low and when Master Enable becomes low.
Tw Minimum width of the Master Clock pulse.
Required delay between when Master Enable becomes low and falling edge of Master Clock.
TH3 Required delay between falling edge of Masier Clock and when Master Enable becomes high.
TSD Required delay between beginning of valid data input on the IV Bus and falling edge of Master Clock.
THD Required delay between falling edge of Master Clock and end of valid data input on the IV Bus.
TH4 Required delay between falling edge of Master Clock and when Write Command becomes low.

## VOLTAGE WAVEFORM



Measurements: All circuit delays are measured at the +1.5 V level of inputs and output.

TYPICAL 8X350 APPLICATION


## test load circuit



## Bipolar Ram (32X8)

Product Specification

## DESCRIPTION

The $8 \times 353$ is a 32 -byte RAM designed principally as a working storage element in 8X305-based systems. The 8X353 is ideal for applications requiring a relatively small amount of data storage and maximum I/O flexibility. Since the 8X353 takes up only 32 of 256 locations on a controller bank, this device allows single cycle, bank-to-bank data transfer and other implementations in which the user does not wish to dedicate an entire I/O bank to data storage. Contributing to the versatility of the $8 \times 353$ is a fast select feature which, when supplemented with extended micro-code, allows this device to be selected externally of the IV bus.

## FEATURES

- 32 bytes of storage
- 32 port addresses $\left(00_{8}-37_{8}\right)$
- 224 bank addresses available for other 8X305 peripherals
- Fast Select feature for use with extended micro-code
- On-chip address decoding
- Separate address input pins
- Direct interface
- Single 5V power supply
- 0.3 inch, Slim Line package
- 0.3 inch, CERDIP package

Originally published by Signetics January 1985

## PIN CONFIGURATION



## BLOCK DIAGRAM



## Product Specification

## PIN DESCRIPTION



## FUNCTIONAL OPERATION

The $8 \times 353$ is capable of performing two functions - write and read. These operations, and the control logic necessary for their execution, are described in the following text and summarized in Table 1. Typical timing relationships for write, read, and select cycles are shown in Timing Diagrams.

## Select Logic

Standard Select Cycle - Before a read or write can occur, the $8 \times 353$ must first be selected by either a standard select cycle or by Fast Select operation (see below). A standard select cycle is initiated when SC and

MCLK are high, and $\overline{M E}$ and WC are low. The three most significant bits on the $\overline{I V}$ bus are then compared with fixed internal values $\left(110_{2}\right.$ active low), and if identical, an internal select latch is activated (high) and the five bits of the memory address (pins AD7 - AD3) are loaded into an address latch.

As shown in Table 1, the $8 \times 353$ remains in the selected state until another select cycle is initiated, at which point the select latch and addresses are updated.
In situations where more than one RAM is required, the fixed internal values of IV0, IV1, and IV2 can be used as chip addresses. By
scrambling these pins, up to three RAMs can be selected from a single IV bus.

## Write/Read Operation

Write and read operations are possible only after the $8 \times 353$ has been selected by either a standard select cycle or by Fast Select operation. As shown in Table 1, data $1 / O$ is controlled by $\overline{M E}, \mathrm{SC}, \mathrm{WC}, \mathrm{MCLK}, \mathrm{FS}$, and the current state of the select latch.

After a data address has been latched, data is written to the specified memory location when MCLK and WC are high and $\overline{M E}$ is low; a read occurs when MCLK, WC, SC, and $\overline{M E}$ are low. In both cases, data is transmitted via the IV bus.

Table 1. Summary Of $8 \times 353$ Operation

| MODE | CONDITIONS |  |  |  |  |  | RESULTS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { ME }}$ | SC | WC | MCLK | $\overline{\text { FS }}$ | Select <br> Latch | $\begin{aligned} & \overline{\mathrm{IV}} \\ & \text { Bus } \end{aligned}$ | $\begin{aligned} & \overline{A D} \\ & \text { Bus } \end{aligned}$ | Data | Address Latch | Select <br> Latch |
| AuF | L | H | L | H | X | X | Input <br> (chip <br> address) | Input ${ }^{2}$ | Keep | Update ${ }^{2}$ | Update ${ }^{2}$ |
| $\mathrm{D}_{1}$ | L | L | H | H | H | H | Input | Ignore | Update | Keep | Keep |
| Dos | L | $L$ | L | L | H | H | Output | Ignore | Keep | Keep | Keep |
| AuF | L | S | L | H | $L$ | $x$ | Ignore | Input | Keep | Update | Keep |
| AuF | H | X | X | H | L | $x$ | Ignore | Input | Keep | Update | Keep |
| $\mathrm{D}_{\text {IF }}$ | L | L | H | H | L | $x$ | Input | Ignore | Update | Keep | Keep |
| D ${ }_{\text {OF }}$ | L | $L$ | L | L | L | $x$ | Output | Ignore | Keep | Keep | Keep |
| $\overline{M E}$ High | H | X | X | X | H | X | Ignore | Ignore | Keep | Keep | Keep |
| $\overline{\text { ME High }}$ | H | X | X | L | L | X | Ignore | Ignore | Keep | Keep | Keep |
| Dos w/o MCLK Low | L | L | L | H | H | X | Ignore | Ignore | Keep | Keep | Keep |
| Dos w/o select latch High | L | L | L | L | H | L | Ignore | Ignore | Keep | Keep | Keep |
| $D_{\text {IS }}$ w/o MCLK High | L | L | H | L | $x$ | X | Ignore | Ignore | Keep | Keep | Keep |
| $D_{\text {IS }}$ w/o select latch High | L | L | H | H | H | L | Ignore | Ignore | Keep | Keep | Keep |
| Aus w/o MCLK High | L | H | L | L | X | X | Ignore | Ignore | Keep | Keep | Keep |
| Not defined | X | H | H | X | X | X |  |  | Not defin |  |  |

NOTES:

1. $A_{\text {US }}=$ address update with standard select
$D_{\text {IS }}=$ data input with standard select
$\mathrm{D}_{\mathrm{OS}}=$ data output with standard select
AUF $=$ address update with fast select
$D_{\text {IF }}=$ data input with fast select
$\mathrm{D}_{\mathrm{OF}}=$ data output with fast select
2. Depending on IV bus data
3. Fast select Logic ( $\overline{\mathrm{FS}}$ ) given but is not used for $8 \times 305$ operation.
$X=$ Don't care

Product Specification
ABSOLUTE MAXIMUM RATINGS

| PARAMETER |  |  | RATING |
| :---: | :--- | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Power supply voltage | +7 | V dc |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage | +5.5 | V dc |
| $\mathrm{V}_{\mathrm{O}}$ | Off-state voltage | +5.5 | V dc |
| $\mathrm{T}_{\mathrm{STG}}$ | Storage temperature range | -65 to +150 | C |

DC ELECTRICAL CHARACTERISTICS $\mathrm{v}_{\mathrm{CC}}=5.0 \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS ${ }^{1}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{IH}}$ | High level input voltage |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low level input voltage |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\text { IV pins: } \begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min}, \\ \mathrm{I}_{\mathrm{OH}} & =-3.2 \mathrm{~mA} \end{aligned}$ | 2.4 |  |  | V |
| Vol | Low level output voltage | $\begin{aligned} \text { IV pins : } & V_{\mathrm{CC}}=\text { Min, } \\ \mathrm{I}_{\mathrm{OL}} & =16 \mathrm{~mA} \end{aligned}$ |  |  | 0.55 | V |
| $V_{1 C}$ | Input clamp voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-10 \mathrm{~mA}$ |  |  | -1.0 | V |
| IIH | High level input (or leakage) current | Address pins and control pins: $\begin{aligned} & V_{C C}=M a x, \\ & V_{I N}=4.5 \mathrm{~V} \end{aligned}$ |  |  | 100 | $\mu \mathrm{A}$ |
| IL | Low level input current | Address pins and control pins: $\begin{aligned} & V_{C C}=M a x, \\ & V_{\text {IN }}=.5 \mathrm{~V} \end{aligned}$ |  |  | -100 | $\mu \mathrm{A}$ |
| los | Short circuit output current | IV pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}^{2}$ | -30 |  | -140 | mA |
| lozh | High-Z state output current - high level | $\begin{aligned} \text { IV pins: } & V_{C C}=M a x, \\ V_{0} & =2.7 \mathrm{~V} \end{aligned}$ |  |  | 100 | $\mu \mathrm{A}$ |
| lozl | High-Z state output current - low level | $\begin{aligned} & \text { IV pins: } V_{\mathrm{CC}}=\mathrm{Max}, \\ & \mathrm{~V}_{0}=.5 \mathrm{~V} \end{aligned}$ |  |  | -200 | $\mu \mathrm{A}$ |
| lcc | Supply current | $\begin{aligned} & \text { All inputs: } V_{C C}=M a x, \\ & V_{I N}=0 V \end{aligned}$ |  |  | 200 | mA |

NOTES:

1. All voltages measured with respect to Ground terminal
2. At any time, no more than one output should be connected to ground.

Product Specification
AC ELECTRICAL CHARACTERISTICS $V_{C C}=5.0 \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 70^{\circ} \mathrm{C}$

| PARAMETER | REFERENCES |  | TEST CONDITIONS ${ }^{\mathbf{1 , 2 , 3}}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | From | To |  | Min | Typ | Max |  |
| Pulse width <br> $t_{\text {WMC }} \quad$ MCLK pulse width | $\uparrow$ MCLK | $\downarrow_{\text {MCLK }}$ | FS $=$ High; $\overline{M E}=$ Low | 35 |  |  | ns |
| Set-up times <br> tsivme IV set-up time | $\overline{\mathrm{IV}}$ | $\downarrow_{\text {MCLK }}$ | FS $=$ High; $\overline{M E}=$ Low | 40 |  |  | ns |
| $t_{\text {SADMC }}$ Address set-up time | $\overline{\text { AD }}$ | $\downarrow_{\text {MCLK }}$ | FS, SC = High; WC, $\overline{M E}=$ Low | 40 |  |  | ns |
| tSWCMC Write command set-up time | †wc | $\downarrow_{\text {MCLK }}$ | $\mathrm{FS}=$ High; $\mathrm{SC}, \overline{\mathrm{ME}}=$ Low | 60 |  |  | ns |
| tSSCMC Select command set-up time | $\uparrow$ SC | $\downarrow_{\text {MCLK }}$ | FS = High; $W C, \overline{M E}=$ Low | 55 |  |  | ns |
| tsMEMC $^{\text {S }}$ Master enable set-up time | $\downarrow \overline{\mathrm{ME}}$ | $\downarrow$ MCLK | FS $=$ High | 55 |  |  | ns |
| Hold times <br> thivme IV hold time | $\downarrow_{\text {MCLK }}$ | $\overline{\mathrm{V}}$ | $\mathrm{FS}=\mathrm{High} ; \overline{\mathrm{ME}}=$ Low | 5 |  |  | ns |
| $t_{\text {HADMC }}$ Address hold time | $\downarrow$ MCLK | $\overline{\mathrm{AD}}$ | FS, SC = High; WC, $\overline{M E}=$ Low | 5 |  |  | ns |
| $t_{\text {HWCMC }}$ Write command hold time | $\downarrow$ MCLK | $\downarrow$ WC | FS = High; SC, $\overline{M E}=$ Low | 3 |  |  | ns |
| $\mathrm{t}_{\text {HSCMC }}$ Select command hold time | $\downarrow$ MCLK | $\downarrow$ SC | FS = High; WC, $\overline{M E}=$ Low | 0 |  |  | ns |
| $t_{\text {HMEMC }}$ Master enable hold time | $\downarrow$ MCLK | $\uparrow \overline{M E}$ | FS = High; SC, WC = Low | 5 |  |  | ns |
| Output enable times <br> tedomc IV output enable time | $\downarrow_{\text {MCLK }}$ | $\overline{\mathrm{V}}$ | FS = High; $W C, \overline{M E}, \mathrm{SC}=$ Low |  |  | 30 | ns |
| tedowc IV output enable time | $\downarrow$ WC | $\overline{\mathrm{V}}$ | FS = High; MCLK, ME, SC = Low |  |  | 30 | ns |
| $\mathrm{t}_{\text {EDOSC }}$ IV output enable time | $\downarrow$ SC | IV | FS = High; MCLK, WC, $\overline{M E}=$ Low |  |  | 30 | ns |
| teDOME ${ }^{\text {a }}$ IV output enable time | $\downarrow \overline{\mathrm{ME}}$ | IV | FS = High; MCLK, WC, SC = Low |  |  | 30 | ns |
| Output disable times <br> tDDOMC IV output disable time | $\uparrow$ MCLK | IV | $\mathrm{FS}=$ High; $\mathrm{WC}, \overline{\mathrm{ME}}, \mathrm{SC}=$ Low $^{4}$ |  |  | 25 | ns |
| todowc IV output disable time | †wc | IV | FS $=$ High; $\mathrm{MCLK}, \overline{\mathrm{ME}}=$ Low $^{4}$ |  |  | 25 | ns |
| tpDosc IV output disable time | $\uparrow$ SC | $\overline{\mathrm{V}}$ | FS = High; MCLK, WC, $\overline{M E}=$ Low $^{4}$ |  |  | 25 | ns |
| tDDOME IV output disable time | $\uparrow \overline{\mathrm{ME}}$ | IV | FS $=$ High; MCLK, WC = Low ${ }^{4}$ |  |  | 25 | ns |

## NOTES:

1. Loading: see Test Loading Circuits
2. All inputs are driven between 0 and 3.0 volts.
3. Except for output disable times, all timing parameters are measured at 1.5 volts.
4. These parameters are measured with a capacitive loading of 50 pF and represent the output driver turn-off time. Disable times measured into a capacitive loading of 300 pF will be a maximum of 40 ns .

Product Specification
TMMING DIAGRAM

a. Standard Select Cycle Timing

b. Write/Read Cycle Timing

c. Output Enable/Disable Timing

Product Specification
TEST LOADING CIRCUIT


APPLICATIONS DIAGRAMS


Product Specification

## APPLICATIONS DIAGRAM (Continued)



## NOTES:

1. The control bus consists of MCLK, SC, WC and $\overline{M E}$.
2. The $8 \times 353$ can be selected using the FS pin instead of a normal select cycle. Since the flip-flop is clocked by the falling edge of MCLK, the data input to the flip-flop must have sufficient set-up time.

## ORDERING INFORMATION

N8X353N (Plastic)
N8X353F (CERDIP)
$8 \times 355$ LIFO Stack Memory (32X8)

## Product Specification

## DESCRIPTION

The $8 \times 355$ Last In/First Out (LiFO) stack memory is designed for use with the 8X305 Microcontroller; however, it can be easily adapted to other micro-processor-based systems. The 32-byte storage capacity of the chip can be expanded by cascading to form 8 -bit wide memories of any required depth. Typical applications are shown at the rear of this data sheet.
The $8 \times 355$ can be addressed by using standard IV bus control logic or, in highperformance systems, the instruction word of the Microcontroller can be extended and the $8 \times 355$ can be addressed in the fast-select mode. In the latter case, an address select cycle prior to each data access is omitted.

When used with the $8 \times 310$ interrupt Control Coprocessor, this enhanced throughput feature is very convenient for saving $8 \times 305$ internal registers during interrupt servicing. For either single or stack configurations, the 8X355 uses a fixed enabling address ( $130_{8}$ ), thus, once enabled, the memory can accept an uninterrupted stream of data.

## FEATURES

- 32 bytes of storage
- Cascadable LIFO operation
- Dedicated port address
- Fast select feature for use with extended microcode
- Three-state TTL outputs
- Single 5 -volt power supply
- 0.3-inch, Slim Line package

PIN CONFIGURATION


## BLOCK DIAGRAM



## Product Specification

## CASCADED CONFIGURATION



NOTE: For simplicity, this data sheet refers to the cascaded configuration shown above in which data is stacked from bottom to top; however, this configuration can be inverted (data stacked from top to bottom) without changing the overall logic of the $8 \times 355$

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 1 | FOUT | Full Output: When active (low), this output indicates that the $8 \times 355$ is full and no further writes can be accepted until at least one read operation is executed. On power up, FOUT is high and remains in this inactive state until the last memory location is written to. In a cascaded configuration, $\overline{\text { FOUT }}$ is tied to $\overline{\mathrm{FIN}}$ of the next higher LIFO chip in the stack. |
| 2 | $\overline{\mathrm{FIN}}$ | Full input: In cascaded configurations, an active (low) FIN signal indicates to a given LiFO chip that the next lower chip is full. When $\overline{\mathrm{FIN}}$ is inactive, the 8X355 cannot be accessed except for select and deselect cycles. In non-cascaded configurations, $\overline{\mathrm{FIN}}$ is usually forced low to enable reads and writes. |
| 3 | EOUT | Empty Output: When active (low), this output indicates that the $8 \times 355$ is empty, and further read operations cannot be accepted until at least one write operation is executed. EOUT is asserted in three situations: on power up, when $\overline{\mathrm{FIN}}$ is inhibited, and when a read is performed with the stack pointer set at 0 . In a cascaded configuration, EOUT is tied to EIN of the next lower LIFO chip of the stack. |
| 4 | $\overline{\text { EIN }}$ | Empty in: In cascaded configurations, an active (low) $\overline{E I N}$ signal indicates to a given LIFO chip that the next higher chip is empty. When EIN is inactive (high), the $8 \times 355$ will not respond to read operations; write operations are inhibited by $\overline{\text { FOUT }}$ (which is active), while selects and deselects are allowed. In non-cascaded configurations, $\overline{\mathrm{EIN}}$ is usually forced low to enable reads and writes. |
| 5 | $\overline{\text { RESET }}$ | Reset: When active (low), this input returns the 8X355 to empty, deselected status. In cascaded configurations, RESETs are normally tied together. |
| 6 | $\overline{\mathrm{FS}}$ | Fast Select: When active (low), this input temporarily allows read and write operations without performing a full select cycle. |
| 7 | $\overline{M E}$ | Master Enable: When active (low), this input indicates that the controller bank is active; otherwise, the $8 \times 355$ will not respond to any signal on the $\overline{\mathrm{V}}$ bus. |
| 8 | MCLK | Master Clock: A standard 8X355 clock input used for timing reference and system synchronization. |
| 9 | SC | Select Command: When active (high), this input indicates that data on the $\overline{\mathrm{V}}$ bus is to be interpreted as an address. |
| 10 | GND | Ground |
| 11 | WC | Write Command: When active (high), this signal indicates that data is being input from the $\overline{\mathrm{IV}}$ bus. |
| 12 to 19 | $\overline{\text { IV0 }}$ to TV7 | Interface Vector Bus: Active low, bidirectional, three-state signals which communicate I/O data and addresses. |
| 20 | $\mathrm{V}_{\mathrm{cc}}$ | Supply Voltage |

## Product Specification

## FUNCTIONAL OPERATION

The $8 \times 355$ performs two fundamental operations: write (push) and read (pop). These functions, along with the cascading capabilities and control logic of the device, are described below. Typical timing relationships for write, read, and select cycles are shown later

## Control Logic

Select Cycle - Before read or write operations can be executed, the $8 \times 355$ must be selected by either a standard select cycle or by Fast Select operation. With MCLK high, information entered on the $\overline{\mathrm{IV}}$ bus is either an address or input data, depending on the states of SC and WC. An active (high) SC signal indicates that $\overline{\mathrm{V}}$ bus data is to be interpreted as an address; this address is then compared with that of the LIFO chip $\left(130_{8}\right)$ If identical, the select latch becomes active (high) and the chip may be accessed for reads and writes. As shown in Table 1, the $8 \times 355$ remains in the selected state until another select cycle is initiated (MCLK $=\mathrm{S}-\mathrm{C}=[$ high $]$ ), at which point the latch is updated.

Fast Select - A Fast Select ( $\overline{\mathrm{FS}}$ ) pin is provided which allows the $8 \times 355$ to be accessed whether or not a select cycle has been executed with the proper address. Since $\overline{F S}$ is ORed with the output of the select latch, this input has no effect on latch operation. Note that the $8 \times 355$ is selected only while $\overline{F S}$ is low, and does not remain selected when $\overline{\mathrm{FS}}$ goes high unless a proper select cycle had
been performed during the time FS was low. When coupled with external logic, this feature makes it possible to quickly push or pop data without using an extra cycle to select the stack peripheral
Addressing - The $8 \times 355$ has a dedicated port address; however, the IV bus pins can be scrambled to obtain different addresses on a given bank. For example, a port designed with the address $130_{8}\left(01011000_{2}\right)$ can be made to respond to the address $230_{8}\left(10011000_{2}\right)$ simply by swapping the connections of the two most significant IV bus pins on a LIFO chip. Besides changing the enabling address, this pin swap has no effect on any other chip operation.

Reset - A reset pin is provided which empties and deselects the 8X355. When activated (low), the RESET signal sets the stack pointer to 0 , asserts $\overline{E O U T}$ (low), negates $\overline{\text { FOUT }}$ (high), and negates select latch output.

## Write/Read Operations

As shown in Table 1, the select latch, $\overline{I V}$ bus, and stack data are controlled by $\overline{\mathrm{ME}}, \mathrm{WC}, \mathrm{SC}$, MCLK, $\overline{F S}$ and the current state of the select latch.

To perform a read, the $8 \times 355$ must be selected, and MCLK, SC, WC and $\overline{M E}$ must be low; in cascaded configurations, the 8 X355 must also conform to status signal requirements (see Cascading Capabilities below). With these conditions satisfied, data is output on the $\overline{\mathrm{V}}$ bus and the stack pointer is decremented on the rising edge of MCLK.

A write is performed when MCLK and WC are high, $\overline{M E}$ and SC are low, and the $8 \times 355$ is selected. When these conditions (and any status signal conditions) are satisfied, the stack pointer is incremented on the rising edge of the MCLK, after which data is loaded onto the top of the stack.
In single configurations, $\overline{\mathrm{FIN}}$ and $\overline{\mathrm{EIN}}$ are usually forced low (grounded) to enable reads and writes. In cascaded configurations, the FIN signal of the lowest LIFO chip and the $\overline{E I N}$ signal of the highest LIFO chip are similarly grounded.

## Cascading Capabilities

To facilitate cascading, the $8 \times 355$ provides pins to detect and send signals indicating full or empty status. As described in PACKAGE AND PIN DESIGNATIONS, active FOUT and $\overline{\text { EOUT }}$ signals indicate, respectively, full and empty status. $\overline{\mathrm{FIN}}$ is then defined by $\overline{\text { FOUT }}$ of the LIFO chip below, and $\overline{E I N}$ is defined as EOUT of the LIFO chip above. Thus data is stacked continuously from bottom to top unless provisions are made with external logic and Fast Select.

Empty status signals are updated on the rising edge of MCLK, while full status signals are updated on the falling edge. As described in Table 2, these signals control read and write operations of the $8 \times 355$ - note that LIFO chip \#2 in the given configuration is used as the point of reference.

Table 1. General Operations

| CONDITIONS |  |  |  |  |  | RESULTS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{M E}$ | SC | WC | MCLK | $\overline{\text { FS }}$ | Select Latch | $\overline{\mathrm{IV}}$ Bus | Data | Select Latch |
| H | X | X | X | X | X | Ignore | Keep | Keep |
| L | L | L | L | L | $X^{\prime}$ | Output | Pop | Keep |
| L | L | L | L | H | L | Ignore | Keep | Keep |
| L | L | L | L | H | $H^{1}$ | Output | Pop | Keep |
| L | L | L | H | X | X | Not Defined |  |  |
| L | L | H | L | X | $x$ | Ignore | Keep | Keep |
| L | L | H | H | L | $\mathrm{X}^{2}$ | Input | Push | Keep |
| L | L | H | H | H | L | Ignore | Keep | Keep |
| L | L | H | H | H | $H^{2}$ | Input | Push | Keep |
| L | H | L | L | X | $X$ | Ignore | Keep | Keep |
| L | H | L | H | X | X | Input (Address) | Keep | Update |
| X | H | H | X | X | X | Not Defined |  |  |

[^15]
## Product Specification

Table 2. Status Signal Operations in a Typical Cascaded Configuration

| CONDITIONS |  |  |  | RESULTS |  |  |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EIN | FIN | EOUT | FOUT | EOUT | FOUT | Push | Pop |  |
| X | X | L | L | Not Possible |  |  |  | Empty and full status |
| L | L | L | H | Update | H | Yes | No | Top of data stack at top of \#1 |
| L | L | H | L | H | Update | No | Yes | Top of data stack at top of \#2 |
| L | L | H | H | Update | Update | Yes | Yes | Top of data stack within \#2 |
| X | H | X | X | L | H | No | No | Top of data stack below \#2 |
| H | L | X | H | Not Defined |  |  |  | \#2 not full and data in \#3 |
| H | L | H | L | H | L | No | No | Top of data stack above \#2 |

NOTES:
Status signals and Push/Pop operations reference LIFO chip \#2.
X = Don't Care


DC ELECTRICAL CHARACTERISTICS ( $V_{C C}=5 \mathrm{~V} \pm 5 \% / 10^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}$ )
absolute maximum ratings

| SYMBOL | PARAMETER | RATING | UNIT |
| :--- | :--- | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Power supply voltage | +7.0 | $\mathrm{~V}_{\mathrm{dc}}$ |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage | +5.5 | $\mathrm{~V}_{\mathrm{dc}}$ |
| $\mathrm{V}_{\mathrm{O}}$ | Off-state voltage | +5.5 | $\mathrm{~V}_{\mathrm{dc}}$ |
| $\mathrm{T}_{\mathrm{STG}}$ | Storage temperature range | -65 to 150 | ${ }^{\circ} \mathrm{C}$ |

## DESIGN RATINGS/TEST CONDITIONS

| SYMBOL | PARAMETER | TEST CONDITIONS ${ }^{1}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $V_{1 H}$ | High level input voltage |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low level input voltage |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\overline{\mathrm{V}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} / \mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $\overline{\mathrm{IV}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} / \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ EOUT \& FOUT: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} / \mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | $\begin{aligned} & 0.55 \\ & 0.55 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{16}$ | Input clamp voltage | $V_{C C}=\mathrm{Min} / \mathrm{I}_{\mathrm{IN}}=-10 \mathrm{~mA}$ |  |  | -1 | V |
| $\mathrm{I}_{\mathrm{IH}}$ | High level input current | All inputs except $\overline{\mathrm{V}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} / \mathrm{V}_{1 \mathrm{~N}}=4.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{1}$ | Low level input current | All inputs except $\overline{\mathrm{V}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} / \mathrm{V}_{\mathrm{IN}}=0.5 \mathrm{~V}$ |  |  | $-100$ | $\mu \mathrm{A}$ |
| los | Short circuit output current ${ }^{2}$ | $\overline{\mathrm{V}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ | -30 |  | -140 | mA |
| $\mathrm{I}_{\text {CEX }}$ | Open-collector leakage current | $\overline{\text { EOUT }} \& \overline{\text { FOUT }}=\mathrm{High} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} / \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{OZH}}$ | High-Z state output current (high level) | $\overline{\mathrm{V}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} / \mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {OzL }}$ | High-Z state output current (low level) | IV pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} / \mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {CC }}$ | Supply current | All inputs except $\overline{\mathrm{V}}$ pins: $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} / \mathrm{V}_{\mathbb{I N}}=0 \mathrm{~V}$ |  |  | 200 | mA |

NOTES:

1. All voltages measured with respect to ground terminal.

2 At any one time, no more than one output should be connected to ground.

## Product Specification

AC ELECTRICAL CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% / 10^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ )

| SYMBOL | PARAMETER | REFERENCES |  | TEST CONDITIONS ${ }^{1,2,3}$ | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | From | To |  | Min | Max |  |
| Pulse Widths: |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {wmi }}$ | MCLK pulse width | IMCLK | IMCLK | $\overline{F S} \& \overline{\text { RESET }}=\mathrm{High} ;$ $\overline{M E}, \overline{E I N} \& \overline{\text { FIN }}=$ Low | 35 |  | ns |
| $t_{\text {whs }}$ | Reset pulse width ${ }^{4}$ | , $\overline{\text { RESET }}$ | , $\overline{\text { RESET }}$ | $\overline{\mathrm{FS}}=\mathrm{High} ; \overline{\mathrm{ME}}, \overline{\mathrm{EIN}} \& \overline{\mathrm{FIN}}=$ Low | 60 |  | ns |
| Setup Times: |  |  |  |  |  |  |  |
| ${ }^{\text {tivam }}$ | $\overline{\mathrm{V}}$ setup time | IV | IMCLK | $\begin{aligned} & \overline{\overline{F S}} \& \overline{\text { RESET }}=\text { High; } \\ & \overline{M E}, \overline{E I N} \& \overline{\text { FIN }}=\text { Low } \end{aligned}$ | 40 |  | ns |
| ${ }^{\text {stw }}$ SMC | Write command setup time | IWC | IMCLK | $\begin{gathered} \overline{\operatorname{FS}} \& \overline{\operatorname{RESET}}=\text { High; } \\ \mathrm{SC}, \overline{\mathrm{ME}, \overline{E I N} \& \overline{\mathrm{FIN}}=\text { Low }} \end{gathered}$ | 60 |  | ns |
| $\mathrm{tsscmc}^{\text {c }}$ | Select command setup time | ISC | IMCLK | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=\mathrm{High} ;$ WC, $\overline{M E}, \overline{E I N} \& \overline{F I N}=$ Low | 55 |  | ns |
| $\mathrm{t}_{\text {SMEMC }}$ | Master enable setup time | IME | IMCLK | $\begin{aligned} & \overline{\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}}=\text { High; } \\ & \overline{\mathrm{EIN}} \& \overline{\mathrm{FIN}}=\text { Low } \end{aligned}$ | 55 |  | ns |
| Hold Times: |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {HIVMC }}$ | IV hold time | IMCLK | IV | $\begin{aligned} & \overline{\text { FS }} \& \overline{\text { RESET }}=\text { High; } \\ & \overline{M E}, \overline{\text { EIN }} \& \overline{\text { FIN }}=\text { Low } \end{aligned}$ | 5 |  |  |
| $\mathrm{t}_{\text {HMEMC }}$ | Master enable hold time | IMCLK | $1 \overline{M E}$ | $\begin{aligned} & \overline{\overline{F S}} \& \overline{\text { RESET }}=\text { High; } \\ & \overline{\mathrm{EIN}} \& \overline{\mathrm{FIN}}=\text { Low } \end{aligned}$ | 5 |  | ns |
| $\mathrm{t}_{\text {HSCMC }}$ | Select command hold time | IMCLK | ISC | $\begin{gathered} \overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=\text { High; } \\ \mathrm{WC}, \overline{\mathrm{ME}}, \overline{\mathrm{EIN}} \& \overline{\mathrm{FIN}}=\text { Low } \end{gathered}$ | 0 |  |  |
| $\mathrm{t}_{\text {HWCMC }}$ | Write command hold time | IMCLK | IWC | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=$ High; $S C, \overline{M E}, \overline{E I N} \& \overline{F I N}=$ Low | 3 |  | ns |
| Enable/Disable Times: |  |  |  |  |  |  |  |
| $t_{\text {eivuc }}$ | $\overline{\mathrm{V}}$ output enable time | IWC | IV | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=$ High; SC, $\overline{\mathrm{ME}}$, MCLK, $\overline{E I N} \& \overline{\text { FIN }}=$ Low |  | 30 | ns |
| $t_{\text {Eivsc }}$ | $\overline{\mathrm{V}}$ output enable time | ISC | IV | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=$ High; WC, $\overline{\mathrm{ME}}$, MCLK, EIN \& FIN = Low |  | 30 | ns |
| $t_{\text {eivme }}$ | $\overline{\text { IV output enable time }}$ | / $\overline{M E}$ | IV | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=$ High; $\mathrm{WC}, \mathrm{SC}$, MCLK, EIN \& FIN = Low |  | 30 | ns |
| $t_{\text {EIVFS }}$ | $\overline{\text { IV output enable time }}$ | $1 \overline{F S}$ | IV | $\begin{gathered} \overline{\text { RESET }}=\text { High, WC, } \mathrm{SC}, \overline{\text { ME }}, \\ \text { MCLK, } \overline{\mathrm{EIN}} \& \overline{\mathrm{FIN}}=\text { Low } \end{gathered}$ |  | 35 | ns |
| tivwc | IV output disable time | IWC | IV | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=$ High; SC,$\overline{\mathrm{ME}}$, MCLK, EIN \& FIN $=$ Low ${ }^{5}$ |  | 25 | ns |
| $\mathrm{t}_{\text {Divsc }}$ | $\overline{\mathrm{V}}$ output disable time | ISC | IV | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=$ High; WC, $\overline{\mathrm{ME}}$, MCLK, EIN \& $\overline{\text { FIN }}=$ Low $^{5}$ |  | 25 | ns |
| $t_{\text {divme }}$ | $\overline{\mathrm{V}}$ output disable time | $1 \overline{M E}$ | IV | $\overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=\mathrm{High} ; \mathrm{WC}, \mathrm{SC}$, MCLK, $\overline{\text { EIN }} \& \overline{\text { FIN }}=$ Low $^{5}$ |  | 25 | ns |
| toives | $\overline{\mathrm{IV}}$ output disable time | $1 \overline{F S}$ | IV | $\overline{\mathrm{RESET}}=$ High; WC, SC, $\overline{\mathrm{ME}}$, MCLK, EIN \& $\overline{\text { IN }}=$ Low $^{5}$ |  | 30 | ns |

## TEST LOADING CIRCUITS



Product Specification
AC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 5 \% / 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}\right)$ (continued)

| SYMBOL | PARAMETER | REFERENCES |  | TEST CONDITIONS ${ }^{1,2,3}$ | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | From | To |  | Min | Max |  |
| Propagation Delays: |  |  |  |  |  |  |  |
| $t_{\text {Peomi }}$ | Empty output propagation delay; both high-to-low and low-to-high transitions | IMCLK | EOUT | $\begin{gathered} \overline{\mathrm{FS}} \& \overline{\mathrm{RESET}}=\text { High; WC, SC, } \\ \overline{\mathrm{ME}, \overline{E I N}} \& \overline{\mathrm{FIN}}=\text { Low } \end{gathered}$ |  | 40 | ns |
| $\mathrm{t}_{\text {tPFOMC }}$ | Full output propagation delay; both high-to-low and low-to-high transitions | IMCLK | $\overline{\text { FOUT }}$ | $\begin{gathered} \overline{\mathrm{FS}} \& \overline{\overline{\text { RESET }}=\text { High } ; S C \overline{\mathrm{ME}},} \\ \overline{\mathrm{EIN}} \& \overline{\mathrm{FIN}}=\text { Low } \end{gathered}$ |  | 45 | ns |
| Stack Timing: |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {NOPOP }}$ | Maximum spurious read (or pop) time ${ }^{6}$ | ISC or IWC | $\begin{aligned} & t \overline{M E} \text { or } \\ & t \overline{F S} \end{aligned}$ | MCLK = Low |  | 15 | ns |
| $\mathrm{t}_{\text {POP }}$ | Minimum read (or pop) time $^{7}$ | Setup read condition (see truth table) | Stack popped |  | 40 |  | ns |

NOTES:

1. Loading - see TEST LOADING circuits.
2. All inputs are driven between 0.0 and 3.0 volts; input timing parameters are measured at 1.5 volts.
3. Except for output disable times, all output timing parameters are measured at 1.5 volts.
4. Resetting the part initializes EOUT and $\overline{\text { FOUT, }}$, respectively, te low and high states and three-states the $\overline{\mathrm{V}}$ bus; all of these conditions occur within the minimum $\overline{R E S E T}$ pulse width.
5. These parameters are measured with a capacitive loading of 50 picofarads and represent the output driver turn-off time. Disable times measured into a capacitive loading of 300 picofarads do not exceed 40 nanoseconds, except for FS which is 45 nanoseconds.
6. This parameter represents the maximum time a Read (Pop) condition can be logically asserted, that is, as a decoding transient, without popping the stack.
7. This parameter represents the minimum time a Read (Pop) condition must be logically asserted to pop the stack.

OVERALL TIMING


## LIFO Stack Memory (32X8)

Product Specification
ENABLE TIMING


DISABLE TIMING


STACK TIMING DIAGRAM


IMPLEMENTATION OF FULL/EMPTY STATUS OUTPUT, AND USER-CONTROLLER FAST SELECT \& RESET


## Product Specification

## IMPLEMENTATION OF CASCADED 8X335's



## 8X360

## MEMORY ADDRESS DIRECTOR

## FEATURES

- Address control for working storage
- 16-bit addressing capability
- Byte and word addressing support
- Automatic increment and decrement
- 11 Address and word-count registers
- Reduces number of $8 \times 305$ instructions required


## PRODUCT DESCRIPTION

The $8 \times 360$ Memory Address Director (MAD) is a high-performance member of the $8 \times 300$ Family that generates sequential memory addresses to facilitate the transfer of data to and from memory. The MAD provides a highly-efficient and cost-effective
solution for DMA and other applications requiring large workingstorage memories and high-speed data transfers. Once initialized with such information as starting address, ending address, byte count, address increment, address decrement, etc., the 8X360 performs all bookkeeping chores automatically and all address-management software is off-loaded from the processor. The $8 \times 360$ can be addressed by conventional means or by extended microcode; system status is available to the user via $1 / 0$ pins.

ORDERING INFORMATION
N8X360N, N8X360I, S8X3601

BLOCK DIAGRAM OF $8 \times 360$


## 8X360 APPLICATIONS



## 8-BIT LATCHED BIDIRECTIONAL I/O PORT

## FEATURES

- Two bidirectional 8-bit busses
- Independent bus operation (user-bus priority for data entry)
- User data input synchronous with respect to MCLK
- Three-state TTL outputs with high-drive capabilities
- Power-up to predetermined logic state
- Directly compatible with $8 \times 305$ (or 8X300) MicroControllers
- Single +5 V supply
- 0.4 inch 24-pin DIP


## PRODUCT DESCRIPTION

The 8X371 I/O Port is a bidirectional device designed for use as an interface element in systems that use TTL-

## 8X371 PACKAGE and PIN DESIGNATIONS

| N, I PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |
| 004 4 |  |  |  |
| UD3 5 - 区r 20 IV4 |  |  |  |
| UD2 $\square^{6}$ - |  |  |  |
| UD1 7 ¢ $\times$ ¢ 0 |  |  |  |
| UDO 8 I ${ }^{\text {I }}$ - $17 \mathrm{~V} \overline{\mathrm{~V} 1}$ |  |  |  |
| $\overline{\mathrm{UOC}} 9$ ¢ ¢ 16 ivo |  |  |  |
| UIC 10 L $\quad$ ¢ 15 wc |  | $\bar{c} 10$ | 15 WC |
| $\begin{aligned} & \overline{M E} 11 \\ & \text { GND } 12 \end{aligned}$ |  |  | 14) $\overline{\mathrm{PC}}$ |
|  |  |  | 13 MCLK |
| top View |  |  |  |
| ORDER NUMBERS |  |  |  |
| N8x371N, N8×3711 <br> S8×371/883B, S8X371/883C |  |  |  |
| PIN. NO. | IDENTIFIER | R FUNCTION |  |
| 1-8 | UD7-UD0 | Three-state, bidirectional User Data UD bus: UDO and corresponds to $\overline{\mathrm{IVO}}$. |  |
| 9 | UOC | User Output Control-active low input to enable data output to UD0-UD7. |  |
| 10 | UTC | User Input Control--active low input to enable data input from UDO-UD7. |  |
| 11 | $\overline{M E}$ | Master Enable-active low input to enable the IV bus for data input, or data output; UD-bus operations are unaffected. |  |
| 12 | GND | Ground. |  |
| 13 | MCLK | Master Clock-active high input from MicroController used to strobe data into data latches from the IV and UD buses. |  |
| 14 | $\overline{\mathrm{RC}}$ | Read Control-active low input to enable data output to $\overline{\text { IV0-IV7. }}$ |  |
| 15 | WC | Write Command-active high input from MicroController to enable the writing of data into the data latches from the IV bus provided $\overline{U I C}$ is not low. |  |
| 16-23 | $\overline{\text { IV0-IV7 }}$ | Interface Vector :Input/Output Bus -three-state, bidirectional. MicroController data bus: IVO corresponds to UDO. |  |
| 24 | VCC | +5 V power supply. |  |

compatible busses. Typically, the $8 \times 371$ is used with the 8X305 MicroController and its associated Interface Vector (IV) bus; however, it can also be used with the $8 \times 300$ MicroController or an equivalent microprocessor. The $8 \times 371$ is functionally the same and pin-for-pin compatible with the older $8 T 31 / 8 \times 31$ but features improved performance and increased drive current. As shown in the logic diagram of Figure 1, the $8 \times 371$ consists of eight identical data latches-bits 0 through 7. The latches are accessed from either of two 8-bit busses-the MicroController (IV bus) and the user data (UD bus). Separate controls are provided for each bus and both busses operate independently, except when both attempt to input data at the same time; in such situations, the user bus always has priority. A Master Enable ( $\overline{\mathrm{ME}}$ ) input is available for additional control over the $\overline{\mathrm{IV}}$ bus. The data latches are transparent, in that, while either bus is enabled for input, all input-data transitions are propagated to the other bus, if enabled for output.


Figure 1. Logic Diagram for $8 \times 371$ I/O Port

Table 2. INPUT/OUTPUT CONTROL OF IV BUS

| $\overline{M E}$ | $\overline{R C}$ | WC | MCLK | $\overline{U I C}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :--- |
| OF IV BUS |  |  |  |  |  |$]$| L | L | L |
| :---: | :---: | :--- |
| X | X | Output Data |
| L | $X$ | $H$ |
| $H$ | $H$ | Input Data |
| L | H | L |
| X | H | X |
| Inactive |  |  |
| H | $X$ | $H$ |
| L | Inactive |  |

outputs can control the $\overline{M E}$ inputs for two banks of $1 / O$ devices, thus acting as a ninth address bit. If more than one I/O Port (including the addressable parts-8X372, 8X376, $8 \times 382$, etc.) are to be connected to the same bank ( $\overline{L B}$ or $\overline{\mathrm{RB}}$ ) of the MicroController, selection of each $8 \times 371$ must be accomplished with external control logic to avoid bus conflicts.

## Bus Logic Levels

Data written into the I/O port from either bus will appear inverted when read from the other bus. Data written into either bus will not be inverted when read from the same bus. (Note. A logic " 1 " in MicroController software corresponds to a high level on the UD bus even though the $\overline{I V}$ bus is inverted.) The $8 \times 382$ wakes up in the unselected state with all data bits latched at the "logic 1" level (UD bus outputs high if enabled).

## DC ELECTRICAL CHARACTERISTICS

COMMERCIAL: $4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ MILITARY: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$

ABSOLUTE MAXIMUM RATINGS

| PARAMETER | RATING | UNIT |  |
| :--- | :--- | :---: | :---: |
| VCC | Power supply voltage | +7 | Vdc |
| $V_{\text {IN }}$ | Input voltage | +5.5 | Vdc |
| TSTG | Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |


| PARAMETER |  | TEST CONDITIONS | LIMITS (COMMMERCIAL) |  |  | LIMITS (MILITARY) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |
| VCC | Supply Voltage |  |  | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Voltage |  | 2.0 |  |  | 2.0 |  |  | V |
| VIL | Low Level Input Voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{CL}}$ | Input Clamp Voltage | $V_{C C}=\operatorname{Min} ; I_{1}=-10 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| IIH | High Level Input Current ${ }^{1}$ | $V_{C C}=M a x ; V_{1 H}=2.7 \mathrm{~V}$ |  | 5 | 100 |  | 5 | 100 | $\mu \mathrm{A}$ |
| IIL | Low Level Input Current ${ }^{1}$ | $\mathrm{V}_{\text {CC }}=\mathrm{Max} ; \mathrm{V}_{\text {IL }}<0.5 \mathrm{~V}$ |  | -350 | -550 |  | -350 | -550 | $\mu \mathrm{A}$ |
| VoL | Low Level Output Voltage IV Bus ( $\overline{\mathrm{IVO}}-\mathrm{IV7}$ ) User Bus (UD4-UD7) | $\mathrm{VCC}=\mathrm{Min}: 1 \mathrm{OL}=16 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
|  |  | $\mathrm{VCC}^{\text {c }}=\mathrm{Min} ; ~ I O L=24 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
| VOH | High Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; 1 \mathrm{IOH}=-3.2 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
| los | Short Circuit Output Current3 $\overline{\mathrm{IV}}$ Bus (IV0-IV7) UD Bus (UD4-UD7) | $V_{C C}=$ Max | -20 |  |  | -20 |  |  | mA |
|  |  | $V_{C C}=$ Max | -10 |  |  | -10 |  |  | mA |
| ICC | Supply Current | $V C C=M a x ; \overline{M E}=\overline{U O C}=V_{C C}$ |  | 90 | 150 |  | 90 | 150 | mA |

## Notes

1. The input current includes the Three-state leakage current of the output driver on the data lines
2. Only one output may be shorted at a time.

## AC ELECTRICAL CHARACTERISTICS (Cont'd)

COMMERCIAL: $4.75 \leq V_{C C} \leq 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}$
MILITARY: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$
LOADING: See TEST LOADING CIRCUITS

| PARAMETER | REFERENCES |  | TEST CONDITIONS | LIMITS (Commercial) |  |  | LIMITS (military) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FROM | TO |  | Min | Typ | Max | Min | Typ | Max |  |
| Pulse Widths: <br> $t_{W 1} \quad$ Clock High | ¢MCLK | $\downarrow$ MCLK |  | 35 |  |  | 35 |  |  | ns |
| $t_{\text {W2 }} \quad$ User Input Control | ปUIC | $\uparrow$ UIC | MCLK $=$ High | 35 |  |  | 35 |  |  | ns |
| Propagation Delays: <br> $t_{\text {PD } 1}$ UD Propagation Delay | UD | $\overline{\mathrm{IV}}$ | $\begin{aligned} & \text { MCLK }=\text { High } \\ & \overline{\mathrm{RC}}=\overline{\mathrm{W}}=\overline{\mathrm{ME}}=\overline{\mathrm{UCI}}=\text { Low } \end{aligned}$ |  |  | 30 |  |  | 30 | ns |
| $\mathrm{t}_{\text {PD2 }}$ UD Clock Delay | ^MCLK | IV | $\begin{aligned} & \mathrm{UD}=\text { Stable; } \\ & \overline{\mathrm{RC}}=\mathrm{WC}=\overline{\mathrm{ME}}=\overline{\mathrm{UIC}}=\text { Low } \end{aligned}$ |  |  | 50 |  |  | 50 | ns |
| $t_{\text {PD3 }}$ UD Input Delay | $\downarrow$ UIC | IV | $\begin{aligned} & \mathrm{UD}=\text { Stable } ; \text { MCLK }=\text { High } \\ & \overline{\mathrm{RC}}=\mathrm{WC}=\overline{\mathrm{ME}}=\text { Low } \end{aligned}$ |  |  | 50 |  |  | 50 | ns |
| $t_{\text {PO4 }}$ $\overline{\text { IV Data }}$ <br>  Propagation Delay | IV | UD | $\begin{aligned} & \mathrm{MCLK}=\mathrm{WC}=\overline{\mathrm{UIC}}=\text { High; } \\ & \overline{\mathrm{ME}}=\overline{\mathrm{UOC}}=\overline{\mathrm{RC}}=\text { Low } \end{aligned}$ |  |  | 45 |  |  | 45 | ns |
| $\mathrm{t}_{\text {PD5 }}$ $\overline{\mathrm{IV}}$ Data <br>  Clock Delay | ^MCLK | UD | $\begin{aligned} & \mathrm{WC}=\overline{\mathrm{UIC}}=\mathrm{High} ; \overline{\mathrm{V}}=\text { Stable } \\ & \overline{\mathrm{ME}}=\overline{\mathrm{UOC}}=\overline{\mathrm{RC}}=\text { Low } \end{aligned}$ |  |  | 55 |  |  | 55 | ns |
| Output Enable Timing: <br> $t_{\text {OE1 }}$ UD Output Enable | ปUOC | UD | $\overline{U I C}=\mathrm{High}$ |  |  | 30 |  |  | 30 | ns |
| $\mathrm{t}_{\text {OE2 }}$ UD Input Recovey | $\uparrow \overline{\text { UIC }}$ | UD | $\overline{\text { UOC }}$ = Low |  |  | 30 |  |  | 30 | ns |
| $\mathrm{t}_{\text {OE3 }}$ $\overline{\mathrm{V}}$ Data <br>  Master Enable | $\downarrow \overline{M E}$ | $\overline{\mathrm{V}}$ | $W C=\overline{\mathrm{RC}}=$ Low |  |  | 22 |  |  | 25 | ns |
| $\mathrm{t}_{\mathrm{OE} 4} \quad \overline{\bar{V}} \text { Data }$ | $\downarrow \overline{R C}$ | $\overline{\mathrm{V}}$ | $W C=\overline{M E}=$ Low |  |  | 25 |  |  | 25 | ns |
| $\mathrm{t}_{\text {OE5 }}$ $\overline{\mathrm{IV}}$ Data <br>  Write Recovery | IWC | $\overline{\mathrm{V}}$ | $\overline{\mathrm{RC}}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |
| Output Disable Timing: <br> toD1 UD Output Disable | $\uparrow \overline{U O C}$ | UD | $\overline{\text { UIC }}=\mathrm{High}$ |  |  | 25 |  |  | 25 | ns |
| $\mathrm{t}_{\mathrm{OD} 2} \quad$UD Input <br> Override | $\downarrow$ UIC | UD | $\overline{\mathrm{UOC}}=$ Low |  |  | 30 |  |  | 30 | ns |
| toD3 $^{1} \quad \overline{\text { IV Data }}$  <br>  Master Disable | $\uparrow \overline{M E}$ | $\overline{\mathrm{V}}$ | $\mathrm{WC}=\overline{\mathrm{RC}}=$ Low |  |  | 20 |  |  | 20 | ns |
| toD4 $^{1}$ $\overline{\mathrm{IV}}$ Data <br>  Read Disable | $\uparrow \overline{R C}$ | $\overline{\mathrm{IV}}$ | $W C=\overline{M E}=$ Low |  |  | 20 |  |  | 20 | ns |
| $\mathrm{t}_{\mathrm{OD} 5} \quad \overline{\mathrm{~V}}$ Data  <br>  Write Override | †WC | IV | $\overline{\mathrm{RC}}=\overline{\mathrm{ME}}=$ Low |  |  | 20 |  |  | 20 | ns |
| Setup Time: | UD | \MCLK | $\overline{U I C}=$ Low | 15 |  |  | 15 |  |  | ns |
| $\mathrm{t}_{\text {S2 }}$ UD Setup Time | UD | $\uparrow$ UIC | MCLK = High | 15 |  |  | 15 |  |  | ns |
| ${ }^{t_{\text {S3 }}}$User Input Control <br> Setup Time | $\downarrow$ UIC | $\downarrow$ MCLK |  | 25 |  |  | 25 |  |  | ns |
| $\mathrm{t}_{\text {S4 }}$ $\overline{\mathrm{V}}$ Data <br>  Setup Time | $\overline{\mathrm{V}}$ | $\downarrow$ MCLK | $W C=\overline{U I C}=$ High; $\overline{M E}=$ Low | 35 |  |  | 35 |  |  | ns |
| $\mathrm{t}_{\mathrm{S} 5^{2}} \quad \overline{\mathrm{IV}}$ Master Enable  <br>  Setup Time | $\downarrow \overline{\mathrm{ME}}$ | \MCLK | $W C=\overline{U I C}=\mathrm{High}$ | 30 |  |  | 30 |  |  | ns |
| ${ }^{t_{\text {S6 }} \quad \overline{\text { IV }} \text { Write Control }}$Setup Time | †WC | $\downarrow$ MCLK | $\overline{\mathrm{ME}}=\mathrm{Low} ; \overline{\mathrm{UIC}}=\mathrm{High}$ | 30 |  |  | 30 |  |  | ns |

AC ELECTRICAL CHARACTERISTICS (Cont'd)


Notes:
. These parameters are measured with a capacitive loading of 50 pf and represent the output driver turn-off time
If $\overline{M E}$ is to be high (inactive), it must be setup before the rising edge and held after the falling edge of MCLK to avoid unintended writing into or selection of the I/O port.


Figure 2. Timing Diagram

## TEST LOADING CIRCUITS



## APPLICATIONS

In some applications, performance of a MicroController system can be enhanced by using the $8 \times 371$ I/O Port instead of an addressable $8 \times 372$ port. Using a technique referred to as Extended Microcode or Fast IV Select, the address select cycles which normally precede a read or write operation when using an $8 \times 372$ can be eliminated by use of the $8 \times 371$.

This technique is often used in bit slice microprocessor designs and involves widening the program memory beyond the normal 16-bit requirement of the MicroController. The extra bits are used as enable signals for the 8X371 ports. Thus, the $8 \times 371$ is enabled during the instruction cycle in
which it is required for input/output operations. Since the software overhead of separate address select cycles is eliminated, the overall system performance is improved.

As shown in the accompanying diagram, the program memory is extended by two bit positions ( $\mathrm{D}_{16}$ and $\mathrm{D}_{17}$ ), permitting any one of four $8 \times 371$ ports to be enabled during those instructions that perform input/output operations. Because of timing considerations, latches must be used to hold the Extended Microcode through the end of the instruction cycle. A decoder is used to obtain four enable signals from the two extra bits. The decoder outputs are ORed with the $\overline{L B}$ output of the $8 \times 305$; thus, all four I/O ports are placed on the Left Bank of the $\overline{\mathrm{V}}$ bus.

I/O PORT SELECTION USING EXTENDED MICROCODE


## FEATURES

- Two bidirectional 8-bit busses
- Independent bus operation (user-bus priority for data entry)
- User data input synchronous (8X372) or asynchronous (8X376) with respect to MCLK
- Programmed MicroController port address
- Three-state TTL outputs with high-drive capabilities
- Power-up to predetermined logic state
- Directly compatible with $8 \times 305$ or 8X300 MicroControllers
- Single +5 V supply
- 0.4 inch 24-pin DIP


## PRODUCT IDENTITY

8×372-Synchronous, three-state, bidirectional I/O port with programmed address.
8×376-Asynchronous, three-state, bidirectional 1/O port with programmed address.

## PRODUCT DESCRIPTION

Each of these I/O ports is an addressable device designed for use as a bidirectional interface element in systems that use TTL-compatible busses. Typically, these I/O ports are used with the $8 \times 305$ MicroController and its associated Interface Vector ( $\overline{\mathrm{V}}$ ) bus; however, either port can also be used with the $8 \times 300$ MicroController or an equivalent
microprocessor. The $8 \times 372$ and $8 \times 376$ are funtionally the same and pin-for-pin compatible with their respective counterparts, the $8 T 32 / 8 \times 32$ and $8 T 36 / 8 \times 36$; however, the new parts feature better performance, increased drive current, and improved programming procedures.
As shown in the logic diagram of Figure 1, each I/O port consists of eight identical data latches-bits 0 through 7. These latches are accessed through either of two 8-bit busses-one connecting to the MicroController $\overline{\mathrm{IV}}$ bus) and the other to the user system UD bus). Separate controls are provided for each bus and both busses operate independently, except when both attempt to input data at the same time. In such situations, the user bus always has priority. The data latches are transparent, in that, while either bus is enabled for input, all transitions in input data are propagated to the other bus, if enabled for output.

Both the $8 \times 372$ and $8 \times 376$ are available with preprogrammed addresses $0_{10}$ through $255_{10}$ ); either device can be fieldprogrammed over the same address range. Input/output operations can begin once the I/O port is selected and appropriate control signals are generated. Port selection is implemented by putting the I/O port address ( $0_{10}-255_{10}$ ) on the $\overline{I V}$ bus; once selected, the I/O port remains selected until a different "port address" is put on the bus. Thus, software overhead is minimized. Data is accessible on the UD bus at all times. A Master Enable $\overline{\mathrm{ME}}$ input, which is typically connected to the Left Bank $\overline{\mathrm{LB}}$ or Right Bank ( $\overline{\mathrm{RB}}$ ) output of the MicroController, provides the capability of organizing the $\overline{\mathrm{V}}$ bus into two separate and independent banks of $\mathrm{I} / \mathrm{O}$ devices.

## N, I PACKAGE



| PIN. NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 1-8 | UDT-UDO | Three-state bidirectional User Data UD bus UDO corresponds to $\overline{\mathrm{IVO}}$ |
| 9 | $\overline{U O C}$ | Use, Output Contiol- active low input to enable data output 10 UDO-UD7 |
| 10 | UIC | Uset Input Control - active low input to enable data input from UDO-UDT |
| 11 | $\overline{M E}$ | Master Enable active low input to snade the $\overline{I V}$ bus for data input data output. of $\bar{V}$ address selection deselection UD-bus operations are unatfected |
| 12 | GND | Giound |
| 13 | MCLK | Maste, Clock -..active high input from MicioControllet used to stione data into data latches from the $\overline{I V}$ bus and for the synchionous $8 \times 372$ from the UD bus MCLK also synchronizes $\bar{V}$ address selection |
| 14 | SC | Select Command active high input from MicroController to enable $\overline{\mathbb{V}}$ address input from the $\overline{\mathrm{V}}$ bus for device selection |
| 15 | WC | Wite Command -.- active high input from MicroControllet to enable the writing of data into the data tatches from the IV bus provided UIC is not low |
| 16.23 | $\overline{\text { IVO-IV7 }}$ | Intertace Vector Input Output Bus intee-state bidrectional MicroControllet data bus $\overline{\mathrm{V} O}$ corresponds to UDO |
| 24 | Vir | 5 V powe: supply |



Figure 1. Logic Diagram for $8 \times 372 / 8 \times 376$ I/O Ports

## FUNCTIONAL OPERATION

## UD Bus Control

As shown in Table 1, the User Data , UD bus interface is controlled by the $\overline{U I C}$ and $\overline{U O C}$ inputs. For the $8 \times 372$, data input from the UD bus is written synchronously with MCLK, that is, with UIC low, information is written into the data latches only when MCLK is high. In the case of the 8X376, data input is asynchronous, in that, with UIC low, data is latched in without regard to the level of MCLK. Note. To avoid the possibility of processor error when using the asynchronous $8 \times 376$. the $\bar{I}$ bus should not be read during the time the data latches are changing due to user input. Output drivers on the UD bus are enabled when UOC is low and $\overline{U I C}$ is high.

Table 1. INPUT/OUTPUT CONTROL OF UD BUS

| UIC | $\overline{U O C}$ | MCLK | FUNCTION OF UD BUS |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | $8 \times 372$ | $8 \times 376$ |
| H | L | X | Output data | Output data |
| L | X | H | Input data | Input data |
| L | X | L | Inactive | Input data |
| H | H | X | Inactive | Inactive |

## IV Bus Control

Input/output control of the $\overline{\mathbb{V}}$ bus is shown in Table 2; this bus is controlled by SC, WC, $\overline{M E}$, MCLK and the current state of the internal address selection latch. AS shown in Table 2, $\overline{\text { UIC }}$ is required to indicate priority of the UD bus for data input operations. The selection latch in the I/O port stores the result of the most recent $\overline{\mathrm{V}}$ address selection. The latch is set when the internally preprogrammed address of the port matches the address on the $\overline{\mathbb{V}}$ bus during an address-selection operation (SC = MCLK $=\mathrm{High} / \mathrm{WC}=$ Low). The latch is cleared when the two 8 -bit address patterns are in disagreement. The $\overline{I V}$ bus can transfer data only when the selection latch is set. As shown in the APPLICATION DIAGRAM, the MicroController Left Bank $(\overline{\mathrm{LB}})$ and Right Bank $(\overline{\mathrm{RB}})$ outputs can control the $\overline{\mathrm{ME}}$ inputs for two banks of I/O devices, thus, acting as a ninth address bit.

## Table 2. INPUT/OUTPUT CONTROL OF IV BUS

| $\overline{M E}$ | SC | WC | MCLK | UIC | SELECTION LATCH | FUNCTION OF IV BUS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | $X$ | X | Set | Output Data |
| L | L | H | H | H | Set | Input Data |
| L | H | L | H | X | X | Input Address* |
| $L$ | H. | $H$ | $H$ | 4 | 8 | Impor data and address* |
| L | H | H | H | L | $x$ | Input Address* |
| L | X | H | L | X | X | Inactive |
| L | H | X | L | X | $x$ | Inactive |
| L | L | H | H | L | X | Inactive |
| L | L | X | X | X | Not Set | Inactive |
| H | X | X | X | X | X | Inactive |

$X=$ don't care

* Selection latch is updated
Data is written into the data latches of a selected device from the $\bar{V}$ bus when WC, MCLK, and $\overline{U I C}$ are all high and
$\overline{M E}$ is iow. To prevent data-input conflicts, inputs from the $\overline{I V}$ bus are inhibited when $\overline{U I C}$ is low; under all other conditions, the $\overline{I V}$ and UD busses operate independently. Output drivers on the $\overline{\mathbb{V}}$ bus of a selected device are enabled when ME, WC, and SC are all low and the address selection latch is set. With SC and WC both high shaded entry of Table 2, the bit pattern present on $\overline{\mathrm{V} 0}-\overline{\mathrm{IV} 7}$ is interpreted as both input data and IV address. Provided UIC is high, the data is latched into the data latches whether or not the l/O port has been previously selected. If the preprogrammed address of the $1 / O$ port matches the bit pattern on $\overline{\mathrm{VO}}-\overline{\mathrm{IV7}}$ when SC and WC are both high, the selection latch is set; otherwise, it is reset. Note. The MicroController never diives both SC and WC high at the same time.


## Bus Logic Levels

Data written into the I/O port from either bus will appear inverted when read from the other bus. Data written into either bus will not be inverted when read from the same bus. (Note. A logic " 1 " in MicroController software corresponds to a high level on the UD bus even though the $\overline{I V}$ bus is inverted. Both the $8 \times 372$ and $8 \times 376$ wakeup with the address selection latch in the unselected state and all data bits latched at the "logic 1 " level UD bus outputs high if enabled

## ADDRESS PROGRAMMING AND ADDRESS PROTECT

## Programming Procedures

Both $8 \times 372$ and $8 \times 376$ can be programmed to respond to any address within a range of $0_{10}$ through 25510 . In an unprogrammed state, low level $: \leq 0.8 \mathrm{~V}$, inputs on all $\overline{\mathrm{V}}$ bus lines (address 25510 ) will select the device. To program a given address bit to match a high level ( $\geq 2.0 \mathrm{~V}$ ) input on the corresponding IV pin (a logical " 0 " to the MicroController), the counterpart UD-bus pin must be pulsed according to Table 3 and the following procedures:

Step 1: Set all control inputs to the inactive state$\overline{U I C}=\overline{U O C}=\overline{M E}=V_{C C}$ and $S C=W C=$ MCLK = GND; leave the UD and IV bus pins open.
Step 2: Increase $V_{C C}$ to $V_{C C P}$.
Step 3: After $V_{C C}$ has stabilized, apply a single programming pulse Figure 2 ; to the user-bus bit that corresponds to the desired high-level IV address bit. The 1/O port is programmed from the user bus UDO-UD7 ; for addressing from the MicroController bus IV0-IV7.

Step 4: Return $V_{c c}$ to 0 -volts. Note. If the programming of all address bits is completed in less than 1 -second. $V_{c c}$ can remain at 9.0 -volts for the required interval of time.
Step 5: $\quad$ Step 1 through 3 are applicable to the programming of each address bit that requires a high-level $\overline{I V}$ match.

Table 3. PROGRAMMING SPECIFICATIONS

| PARAMETERS | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  | Min | Typ | Max |  |
| VCCP - Programming supply <br> voltage: <br> Address |  |  |  |  |
| Protect | 8.75 | 9.0 | 9.25 | V |
| Maximum time VCCP >5.25V |  |  | 1.0 | Sec |
| Programming voltage: <br> Address | 8.75 | 9.0 | 9.25 | V |
| Protect | 8.75 |  | 9.25 | V |
| Programming current: |  |  | 5 | mA |
| Address |  |  | 50 | mA |
| Protect <br> time: Programming pulselrise <br> Address |  |  |  |  |
| Protect | 10 |  | 100 | $\mu \mathrm{~S}$ |
| t $\omega$-Programming pulse width | 0.5 |  | 100 | $\mu \mathrm{~S}$ |



Figure 2. Address Programming Pulse
Step 6: To verify that the address is properly programmed, return Vcc to +5 V , set $\overline{\mathrm{VVO}}-\overline{\mathrm{IV7}}$ to the desired (inverted) binary address pattern, set $\overline{M E}=W C=$ Low and $S C=$ MCLK $=$ High. If
there are no programming errors, subsequent data written from $\overline{\text { IV0 }}-\overline{\mathrm{IV7}}, \mathrm{WC}=$ High , will appear inverted on UD0-UD7.

## Address Protect

After programming the I/O Port, steps should be taken to isolate the address circuits and make these circuits permaently immune to further change.
Step 1: $\quad$ Set $\mathrm{V}_{C C}$ and all control inputs to 0-volts (VCC $=\overline{\mathrm{UIC}}=\overline{\mathrm{UOC}}=\overline{\mathrm{ME}}=\mathrm{SC}=\mathrm{WC}=\mathrm{MCLK}=0 \mathrm{~V}$ ); $\overline{\mathrm{VO}}-\overline{\mathrm{IV7}}=$ open circuit.
Step 2: Taking one pin at a time, apply a protect programming pulse (Figure 3) to each userbus bit (UDO-UD7)-refer to Table 3 for $\mathrm{min} / \mathrm{max}$ specifications pertaining to voltage and current.


Figure 3. Protect Programming Pulse
Step 3: Verify that the address circuits for each bit is isolated by applying 9 -volts, in turn, to each user-bus pin (UDO-UD7) and measuring less than 200 microamperes of input current. (Note. Setup conditions are the same as those in Step 1.)

## DC ELECTRICAL CHARACTERISTICS

COMMERCIAL: $4.75 \mathrm{~V} \leq \mathrm{V}_{C C} \leq 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq \mathrm{TA}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ MILITARY: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$

ABSOLUTE MAXIMUM RATINGS

| PARAMETER | RATING | UNIT |  |
| :--- | :--- | :---: | :---: |
| $V_{C C}$ | Power supply voltage $^{3}$ | +7 | $V_{d c}$ |
| $V_{\text {IN }}$ | Input voitage ${ }^{3}$ | +5.5 | $V_{d c}$ |
| $T S T G$ | Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |


| PARAMETER |  | TEST CONDITIONS | LIMITS (COMMERCIAL) |  |  | LIMITS (MILITARY) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage |  |  | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | V |
| V IH | High Level Input Voltage |  | 2.0 |  |  | 2.0 |  |  | V |
| VIL | Low Level Input Voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{C L}$ | Input Clamp Voltage | $V_{C C}=M i n ; I_{1}=-10 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{I}_{1 \mathrm{H}}$ | High Level Input Current ${ }^{1}$ | $\mathrm{V}_{C C}=\mathrm{Max} ; \mathrm{V}_{\text {IH }}=2.7 \mathrm{~V}$ |  | 5.0 | 100 |  | 5.0 | 100 | $\mu \mathrm{A}$ |
| IIL | Low Leve! Input Current ${ }^{1}$ | $\mathrm{V}_{\text {CC }}=\mathrm{Max} ; \mathrm{V}_{\text {IL }}=0.5 \mathrm{~V}$ |  | -350 | -550 |  | -350 | -550 | $\mu \mathrm{A}$ |
| VOL | Low Level Output Voltage IV Bus (IVO-IV7) User Bus (UD0-UD7) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.55 |  | 0.55 | V |  |
|  |  | $\mathrm{V}_{C C}=\mathrm{Min} ; \mathrm{IOL}=24 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
| VOH | High Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{IOH}=-3.2 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
| los | Short Circuit Output Current² $\overline{\text { IV }}$ Bus (IVO-IV7) UD Bus (UDO-UD7) | $V_{C C}=\operatorname{Max}$ | -20 |  |  | -20 |  |  | mA |
|  |  | $V_{C C}=$ Max | -10 |  |  | -10 |  |  | mA |
| ICC | Supply Current | $\mathrm{V}_{C C}=\mathrm{Max} ; \overline{\mathrm{ME}}=\overline{\mathrm{UOC}}=\mathrm{V}_{\text {cc }}$ |  | 90 | 150 |  | 90 | 150 | mA |

NOTES:

1. The input current includes the Three-state leakage current of the output driver on the data lines.
2. These limits do not apply during address programming.

## aC ELECTRICAL CHARACTERISTICS

COMMERCIAL: $4.75 \mathrm{~V} \leq \mathrm{V}_{C C} \leqslant 5.25 \mathrm{~V} .0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$
MILITARY: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C}=\mathrm{TC} \leq 125^{\circ} \mathrm{C}$
LOADING: See TEST LOADING CIRCUITS

| PARAMETER | REFERENCES ${ }^{1}$ |  | TEST CONDITIONS | LIMITS (COMMERCIAL) |  |  | LIMITS (military |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FROM | TO |  | Min | Typ | Max | Min | Typ | Max |  |
| Pulse Widths: <br> twi Clock High | 4 MCLK | , MCLK |  | 35 |  |  | 35 |  |  | ns |
| tw2 User Input Control | †UIC | UIC | MCLK $=$ High | 35 |  |  | 35 |  |  | ns |
| Propagation Delays: <br> tpD1 UD Propagation Dełay | UD | IV | $\begin{aligned} & \mathrm{MCLK}=\mathrm{High} \\ & S C=\overline{W C}=\overline{M E}=\overline{U I C}=L O W \end{aligned}$ |  |  | 30 |  |  | 30 | ns |
| tPD2 UD Clock Delay (8X732 only) | 4MCLK | IV | $\begin{aligned} & U D=\text { Stable; } \\ & S C=W C=\overline{M E}=\overline{U I C}=\text { LoW } \end{aligned}$ |  |  | 50 |  |  | 50 | ns |
| tPD3 UD Input Delay | \UIC | IV | $\begin{aligned} & U D=\text { Stable } ; M C L K=\text { High; } \\ & S C=W C=\overline{M E}=\text { Low } \end{aligned}$ |  |  | 50 |  |  | 50 | ns |
| tpD4 $\overline{\mathrm{V}}$ Data Propagation Delay | IV | UD | $\begin{aligned} & \mathrm{MC} L K=W C=\overline{U I C}=\text { High; } \\ & \overline{M E}=\overline{U O C}=S C=\text { Low } \end{aligned}$ |  |  | 45 |  |  | 45 | ns |
| tpos $\overline{\text { IV }}$ Data Clock Delay | f MCLK | UD | $\begin{aligned} & \overline{W C}=\overline{U I C}=\text { High; } \bar{V}=\text { Stable, } \\ & \overline{M E}=\overline{U O C}=S C=\text { Low } \end{aligned}$ |  |  | 55 |  |  | 55 | ns |
| Output Enable Timing: <br> toE: UD Output Enable | \UOC | UD | $\overline{\text { UIC }}=$ High |  |  | 30 |  |  | 30 | ns |
| toe2 UD Input Recovery | +UIC | UD | $\overline{\mathrm{UOC}}=$ Low |  |  | 30 |  |  | 30 | ns |
| toe3 $\overline{\mathrm{IV}}$ Data Master Enable | $\downarrow \overline{M E}$ | IV | $W C=S C=$ Low |  |  | 22 |  |  | 25 | ns |
| toes $\overline{\mathrm{IV}}$ Data Write Recovery | +WC | IV | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |
| toew $\begin{gathered}\overline{I V} \text { Data } \\ \text { Select Recovery }\end{gathered}$ | $\downarrow$ ¢C | IV | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |
| Output Disable Timing: toD1 UD Output Disable | AUOC | UD | $\overline{U I C}=\mathrm{High}$ |  |  | 25 |  |  | 25 | ns |
| tOD2 UD input Override | ఫUIC | UD | $\overline{\mathrm{UOC}}=$ Low |  |  | 30 |  |  | 30 | ns |
| tod3 ${ }^{2}$ IV Data Master Disable | $4 \overline{M E}$ | IV | $W C=S C=$ Low |  |  | 20 |  |  | 20 | ns |
| toD4 ${ }^{2}$ IV Data Write Override | 4WC | IV | $S C=\overline{M E}=$ Low |  |  | 20 |  |  | 20 | ns |
| $\begin{array}{ll} \text { toD5 } 2 & \overline{\mathrm{IV}} \text { Data } \\ & \text { Select Override } \end{array}$ | 4SC | IV | $W C=\overline{M E}$ Low |  |  | 20 |  |  | 20 | ns |
| Setup Times: $\begin{aligned} & \text { Is } 1 \quad \text { UD Clock Setup } \\ & \\ & \text { Time }(8 \times 372 \text { only) } \end{aligned}$ | UD | \$MCLK | $\overline{\text { UiC }}$ = Low | 15 |  |  | 15 |  |  | ns |
| ts? UD Control Setup Time | UD | 4 UIC | MCLK = High | 15 |  |  | 15 |  |  | ns |
| ts3 User Input Control Setup Time ( $8 \times 372$ only) | IUIC | \$MCLK |  | 25 |  |  | 25 |  |  | ns |
| $\begin{array}{ll}\text { ts4 } & \overline{\text { IV }} \text { Data } \\ & \text { Setup Time }\end{array}$ | $\bar{N}$ | \$MCl.K | $\begin{aligned} & W C=\text { High or } S C=\text { High } ; \\ & \frac{M E}{M E}=\text { Low } ; U I C=\text { High } \end{aligned}$ | 35 |  |  | 35 |  |  | ns |
| ts 5.3 IV Master Enable Setup Time | \$ME | \$MCLK | $W C=H i g h$ or $S C=H i g h$; $\overline{U I C}=\mathrm{High}$ | 30 |  |  | 30 |  |  | ns |
| ts6 IV Write Control Setup Time | 4 WC | \$MCLK | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low; $\overline{U I C}=\mathrm{High}$ | 30 |  |  | 30 |  |  | ns |

## AC ELECTRICAL CHARACTERISTICS (Cont'd)

| PARAMETER | REFERENCES |  | TEST CONDITIONS | LIMITS (COMMERCIAL) |  |  | LIMITS (MILITARY) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FROM | TO |  | Min | Typ | Max | Min | Typ | Max |  |
| ts7 $\bar{V}$ Select Control Setup Time | 4SC | \$MCLK | $W C=\overline{M E}=$ Low | 30 |  |  | 30 |  |  | ns |
| Hold Times: $\begin{aligned} & \text { tH1 UD Clock Hold } \\ & \text { Time ( } 8 \times 372 \text { only) } \end{aligned}$ | \$MCLK | UD | $\overline{\text { UIC }}=$ Low | 15 |  |  | 15 |  |  | ns |
| tH2 UD Control Hold Time | QUIC | UD | MCLK $=$ High | 15 |  |  | 15 |  |  | ns |
| th3 User Input Control Hold Time (8X372 only) | \$MCLK | 4UIC |  | 0 |  |  | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{H} 4} \quad \overline{\mathrm{~V}}$ Data Hold Time | †MCLK | IV | $\begin{aligned} & W C=H i g h \text { or } S C=H i g h ; \\ & M E=L o W, U I C=H i g h \end{aligned}$ | 5 |  |  | 5 |  |  | ns |
| th5 $^{3}$ IV Master Enable Hold Time | \$MCLK | $4 \overline{M E}$ | $\begin{aligned} & W C=\text { High or } S C=H i g h ; \\ & \overline{U I C}=H i g h \end{aligned}$ | 0 |  |  | 0 |  |  | ns |
| th6 $\overline{\text { IV }}$ Write Control Hold Time | \$MCLK | $\downarrow$ WC | $S C=\overline{M E}=$ Low; $\overline{U I C}=$ High | 0 |  |  | 0 |  |  | ns |
| tin $\bar{V}$ Select Control Hold Time | ゅMCLK | \SC | $W C=\overline{M E}=$ Low | 0 |  |  | 0 |  |  | ns |

## Notes:

1. All measurements to the $\overline{\mathbb{V}}$ bus assumes the address selection latch is set.
2. These parameters are measured with a capacitive loading of 50 pf and represent the output driver turn-off time
3. $11 \overline{M E}$ is to be high (inactive), it must be setup before the rising edge and held after the falling edge of MCLK to avoid unintended writing into or selection of the $1 / O$ port.


Figure 2. Timing Diagram

## TEST LOADING CIRCUITS



## APPLICATIONS

One way of using I/O Ports in a microprocessor-based system is shown in the following application diagram; there are many other ways of implementing 1/O functions with these parts, both singly and in combination. By proper control of the $\overline{U T C}$ and $\overline{\mathrm{UOC}}$ lines, the user can implement
bidirectional data transfers, exercise system control, and/or read system status. In the concept shown here, I/O Port \#1 is setup for bidirectional data transfers and I/O Ports \#2 and \#3, respectively, serve as dedicated output and input devices.


## ADDRESSABLE/BIDIRECTIONAL I/O PORT WITH PARITY

## FEATURES

## - Two bidirectional 8-bit busses

- Independent bus operation (user bus priority for data entry)
- Parity generate/check logic with:

Odd/Even parity select
Strobed error flag output

- Synchronous data input
- Programmable MicroController port address
- Three-state TTL outputs (for all except parity error flag)
- High drive capabilities
- Power-up to predetermined state
- Directly compatible with 8X305 MicroController
- Single +5 V supply
- 0.6 inch, 28-pin DIP


## PRODUCT DESCRIPTION

The Signetics $8 \times 374$ is an addressable 8 -bit I/O Port that features on-chip parity generate/check logic. The $8 \times 374$ port is designed for applications that require an 8 -bit bidirectional interface element with parity-generate and paritycheck capabilities. Typically, the $8 \times 374$ is used with the 8X305 MicroController and its associated Interface Vector (IV) bus.

Originally published by Signetics January 1984
As shown in the logic diagram of Figure 1, the $8 \times 374$ consists of eight identical latches, bits 0 through 7. These latches are accessed through either of two 8-bit busses, one connecting to the MicroController (IV bus) and the other to the user system (UD bus). Separate controls are provided for each bus and both busses operate independently, except when both attempt to input data at the same time. In such situations, the user bus always has priority. The data latches are transparent, in that, while either bus is enabled for input, all transitions in input data are propagated to the other bus, if enabled for output. The data latch in Figure 1 is common to both busses, that is, data traveling from the IV bus to the UD bus, or vice-versa, is latched and applied to the parity generate/check logic. The parity-bit latch is interfaced to the UD bus and latches the parity bit. The user can implement the parity features of the chip by simply selecting odd or even parity via the Parity SeLect (PSL) input pin. When data is output to the UD bus, a parity bit is generated and appended to each byte of data; for incoming data parity is checked and the result is transmitted to an error-flag latch. The status of the latch $0=$ no parity error $/ 1=$ parity error) is reflected by the Error Flag (EF) output pin. Operation of the error-flag latch is controlled by the Error Flag Hold (EFH) signal. With EFH low, the operation is transparent; when high the contents of the latch are frozen to avoid false errors while data latches are changing.

## 8X374 PACKAGE AND PIN DESIGNATIONS




Figure 1. Logic Diagram for $8 \times 374$ I/O Port

The $8 \times 374$ is available with either preprogrammed addresses ( 010 to 25510 ) or unprogrammed; the device can be fieldprogrammed over the same address range as the preprogrammed port. Input/Output operations to the MicroController bus can begin once the $8 \times 374$ enabling address has been selected and appropriate control signals from the IV bus are generated. Port selection is implemented by putting the $8 \times 374$ address ( $0_{10}$ to $255_{10}$ ) on the IV bus. Once selected, the I/O port remains selected until a different port address is put on the bus.
With appropriate control inputs, data is accessible on the UD bus at all times. A Master Enable (ME) input, which is typically connected to the Left Bank (LB) or Right Bank (RB) output of the MicroController, provides the capability of organizing the IV bus into two separate and independent banks of I/O devices.

## FUNCTIONAL OPERATION

## UD Bus Control

As shown in Table 1, the User Data (UD) bus and parity-bit interface are controlled by the UIC and UOC inputs. Data from the UD bus is written synchronously with MCLK, that is with UIC low, information is written into the data latches only when MCLK is high. Output drivers on the UD bus are enabled when UOC is low and UIC is high.

Table 1. INPUT/OUTPUT CONTROL OF UD BUS

|  |  |  | Function of UD Bus |  |
| :---: | :---: | :---: | :--- | :--- |
| UIC | UOC | MCLK | 8-Bit Data Bus | Parity Bit |
| H | L | X | Output data | Output parity |
| L | X | H | Input data | Input parity |
| L | X | L | Inactive | Inactive |
| H | H | X | Inactive | Inactive |

X = Don't Care.

## IV Bus Control

Input/Output control of the IV bus is shown in Table 2; this bus is controlled by SC, WC, ME, MCLK and the current state of the internal address selection latch. As shown in Table 2, UIC is required to indicate priority of the UD bus for data input operations. The selection latch in the I/O port stores the result of the most recent IV address selection. The latch is set when the internally preprogrammed address of the port matches the address on the IV bus during an address-selection operation (SC $=$ MCLK $=$ High; ME $=$ WC $=$ Low). The latch is cleared when the two 8-bit address patterns are in disagreement. The IV bus can transfer data only when the selection latch is set. As shown in the APPLICATION DIAGRAM, the 8X305 Left Bank (LB) and Right Bank (RB) outputs can control the ME inputs for two banks of I/O devices, thus, acting as a ninth address bit.

Table 2. INPUT/OUTPUT CONTROL OF IV BUS

| ME | SC | wC | MCLK | UIC | Selection <br> Latch | Function <br> of IV Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | X | X | Set | Output Data |
| L | L | H | H | H | Set | Input Data |
| L | H | L | H | X | X | Input |
| L | X | H | L | X | X | Inactive |
| L | H | X | L | X | X | Inactive |
| L | L | H | H | L | X | Inactive |
| L | L | X | X | X | Not Set | Inactive |
| H | X | X | X | X | X | Inactive |

$\mathrm{X}=$ Don't Care.
*Selection latch is updated.

Data is written into the data latches of a selected device from the IV bus when WC, MCLK and UIC are all high and ME is low. To prevent data-input conflicts, inputs from the IV bus are inhibited when UIC is low; under all other conditions, the IV and UD busses operate independently. Output drivers on the IV bus of a selected device are enabled when ME, WC, and SC are all low and the address selection latch is set.

## Parity Generate/Check Logic

The Parity Bit (PB) pin provides both parity-generate and parity-check capabilities according to user data bus controls. With UIC low (active), a parity check is performed on the input data stream; with UOC low (active) and UIC high, the $8 \times 374$ generates the parity-bit for the output data stream. The user can select odd or even parity via the Parity SeLect (PSL) input control, $1=$ even parity and $0=$ odd parity. As data and parity are input to the data latches and the parity-bit latch from the UD bus and PB line (Figure 1), parity errors (if any) are continuously detected by the paritycheck logic. Parity error status enters the error flag latch (if enabled) and appears at the EF output pin. The error latch can be strobed by the Error Flag Hold (EFH) control to latch in valid error status; otherwise, the error flag is transparent to the user. (Note: If the sytem uses less than eight data bits, keeping zeros in unused data latches preserves proper parity operation.)

## Bus Logic Levels

Data written into the I/O port from either bus will appear inverted when read from the other bus. Data written into either bus will not be inverted when read from the same bus. (Note: A logic " 1 " in MicroController software corresponds to a high level on the UD bus even though the IV bus
is inverted.) The $8 \times 374$ wakes up with the address selection latch in the unselected state, all data bits latched at the "logic 1" level (UD bus outputs high if enabled), and the EF output high.

## ADDRESS PROGRAMMING AND ADDRESS PROTECT

## Programming Procedures

The $8 \times 374$ can be programmed to respond to any address within a range of $0_{10}$ through 25510 . In an unprogrammed state, low level ( $\leq 0.8 \mathrm{~V}$ ) inputs on all IV bus lines (address 25510 ) will select the device. To program a given address bit to match a high level $(\geq 2.0 \mathrm{~V}$ ) input on the corresponding IV pin (a logical " 0 " to the MicroController), the counterpart UD-bus pin must be pulsed according to Table 3 and the following procedures:

Step 1: Set all control inputs to the inactive state, UIC = $U O C=M E=V C C$ and $S C=W C=M C L K=0 V$; leave the UD and IV bus pins open.

Table 3. PROGRAMMING SPECIFICATIONS

| Parameters | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  | Min. | Typ. | Max. |  |
| VCCP - Programming supply voitage: Address | 8.75 | 9.0 | 9.25 | V |
| Protect |  | 0 |  | V |
| Maximum Time $\mathrm{V}_{C C}>5.25 \mathrm{~V}$ |  |  | 1.0 | sec |
| Programming voltage: Address | 8.75 | 9.0 | 9.25 | V |
| Protect | 8.75 |  | 9.25 | V |
| Programming current: Address |  |  | 5 | mA |
| Protect |  |  | 50 | mA |
| $\mathrm{t}_{\mathrm{r}}$ - Programming puise rise time: <br> Address | 10 |  | 100 | $\mu \mathrm{S}$ |
| Protect | 10 |  | 100 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{w}}$ - Programming pulse width | 0.5 |  | 1.0 | ms |

## Step 2: Increase Vcc to Vccp.

Step 3: After VCC has stabilized, apply a single programming pulse (Figure 2) to the user-bus bit that corresponds to the desired high-level IV address bit. The I/O port is programmed from the user bus (UD0-UD7) for addressing from the MicroController bus (IV0-IV7).
Step 4: Return VCC to 0 volts. (Note: If the programming of all address bits is completed in less than one second, Vcc can remain at $V_{C C P}$ for the required interval of time.)

Step 5: Step 1 through Step 3 are applicable to the programming of each address bit that requires a high-level IV match.
Step 6: To verify that the address is properly programmed, return $\mathrm{V}_{\mathrm{CC}}$ to +5 V and set IV0-IV7 to the desired address pattern (inverted). Set ME $=W C=$ Low and $S C=$ MCLK $=$ High to select the programmed I/O port. With ME = SC = Low and WC $=$ MCLK $=$ High, write an 8 -bit pattern to the port. If there are no programming errors, the transmitted data pattern will appear inverted at UDO-UD7 of selected port.


Figure 2. Address Programming Pulse

## ADDRESS PROTECT

After programming the I/O Port, optional steps can be taken to isolate the fuse circuits and to make these circuits permanently immune to further change.
Step 1: Set $V_{C C}$ and all control inputs to 0 volts; $V_{C C}=$ UIC $=\mathrm{UOC}=\mathrm{ME}=\mathrm{SC}=\mathrm{WC}=\mathrm{MCLK}=0 \mathrm{~V}, \mathrm{IVO-IV7}=$ open circuit.
Step 2: Taking one pin at a time, apply a protect programming pulse (Figure 3) to each user-bus bit (UD0-UD7). Refer to Table 3 for $\mathrm{min} /$ max specifications pertaining to voltage and current.

Step 3: Verify that the address circuits for each bit are isolated by applying VCCP, in turn, to each user-bus pin (UD0-UD7) and measuring less than 200 microamperes of input current. (Note: Setup conditions are the same as those in Step 1.)


Figure 3. Protect Programming Pulse

ABSOLUTE MAXIMUM RATINGS

## DC ELECTRICAL CHARACTERISTICS

COMMERCIAL: $V_{C C}=5 \mathrm{~V}( \pm 5 \%) ; T_{A} \geq 0^{\circ} \mathrm{C}$

$$
T_{A} \leq 70^{\circ} \mathrm{C}
$$

MILITARY: $V_{C C}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{T}_{\mathrm{A}} \geq-55^{\circ} \mathrm{C}$
$\mathrm{TC} \leq 125^{\circ} \mathrm{C}$

| Parameter | Rating | Unit |  |
| :--- | :--- | :---: | :---: |
| VCC | Power supply <br> voltage 3! | +7 | V DC |
| VIN | Input voltage ${ }^{33}$ | +5.5 | V DC |
| TSTG | Storage temperature <br> range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |


| Parameter |  | Test Conditions | Limits(Commercial) |  |  | $\begin{aligned} & \text { Limits } \\ & \text { (Military) } \end{aligned}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |
| Vcc | Supply Voltage |  |  | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High Level Input Voltage |  | 2.0 |  |  | 2.0 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| VCL | Input Clamp Voltage | $V_{C C}=\operatorname{Min} ; I_{1}=-10 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| IIH | High Level Input Current ${ }^{1 /}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \mathrm{V}_{\mathrm{IH}}=2.7 \mathrm{~V}$ |  | 5.0 | 100 |  | 5.0 | 250 | $\mu \mathrm{A}$ |
| IIL | Low Level Input Current ${ }^{11}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max; $\mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ |  | -350 | -550 |  | -350 | -550 | $\mu \mathrm{A}$ |
| Vol | Low Level Output Voltage IV Bus (IV0-IV7) | $\mathrm{VCC}=\mathrm{Min} ; \mathrm{lOL}=16 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
|  | User Bus (UD0-UD7) and PB | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{lOL}^{2}=24 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
|  | $E F$ | $\mathrm{V}_{C C}=\mathrm{Min} ; \mathrm{IOL}=8 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
| V OH | High Level Output Voltage EF | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{IOH}^{\text {a }}=-1 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{IOH}=-3.2 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
| los | Short Circuit Output Current ${ }^{(2)}$ iV Bus (ㅈV0-IV7) | $V_{C c}=$ Max | -20 |  |  | -20 |  |  | mA |
|  | UD Bus (UDO-UD7) | $\mathrm{VCc}=$ Max | -10 |  |  | -10 |  |  | mA |
| Icc | Supply Current | $\mathrm{V}_{C C}=\mathrm{Max} ; \overline{\mathrm{ME}}=\overline{\mathrm{UOC}}=\mathrm{V}_{C C}$ |  | 90 | 150 |  | 90 | 160 | mA |

## Notes:

1. The input current includes the high-Z leakage current of the output drivers ( $\overline{\mathrm{IVO}}-\mathrm{IV7}$, UDO-UD7) on the data lines
2. Only one output may be shorted at a time for testing purposes.
3. These limits do not apply during address programming.

## AC ELECTRICAL CHARACTERISTICS

COMMERCIAL: VCC $=5 \mathrm{~V}( \pm 5 \%) ; \mathrm{T}_{\mathrm{A}} \geq 0^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$
MILITARY: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 10 \%) ; \mathrm{T}_{\mathrm{A}} \geq-55^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$
LOADING: See TEST LOADING CIRCUITS

| Parameter |  | References |  | Test Conditions[ ${ }^{1]}$ | Limits (Commercial) |  |  | Limits (Military) |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | From | To |  | Min | Typ | Max | Min | Typ | Max |  |
| Pulse Widths: |  | 4MCLK | *MCLK |  | 35 |  |  | 35 |  |  | ns |
| tw2 | User Input Control | $\downarrow$ UIC | 4 UIC | MCLK $=$ High | 35 |  |  | 35 |  |  | ns |
| Propagation Delays: <br> tPD1 UD Propagation <br> Delay |  | UD | IV | $\begin{aligned} & \text { MCLK }=\text { High } \\ & \text { SC }=W C=\overline{M E}=\overline{U I C}= \\ & \text { Low } \end{aligned}$ |  |  | 40 |  |  | 40 | ns |
| tPD2 | UD Clock Delay | AMCLK | $\overline{\mathrm{V}}$ | $\begin{aligned} & \mathrm{UD}=\text { Stable; } \\ & \mathrm{SC}=\mathrm{WC}=\overline{\mathrm{ME}}=\overline{\mathrm{UIC}}= \\ & \text { Low } \end{aligned}$ |  |  | 50 |  |  | 50 | ns |
| tPD3 | UD Input Delay | +UIC | $\overline{\mathrm{V}}$ | $\begin{aligned} & \text { UD = Stable; } \\ & M C L K=H i g h ; \\ & S C=W C=\overline{M E}=\text { Low } \end{aligned}$ |  |  | 50 |  |  | 50 | ns |
| tPD4 | IV Data Propagation Delay | $\overline{\mathrm{V}}$ | UD | MCLK $=W C=\overline{U I C}=$ High; <br> $\overline{\mathrm{ME}}=\overline{\mathrm{UOC}}=\mathrm{SC}=$ Low |  |  | 45 |  |  | 45 | ns |
| tPD5 | IV Data Clock Delay | AMCLK | UD | $\begin{aligned} & W C=\overline{U I C}=\text { High; } \\ & \overline{I V}=\text { Stable }, \\ & \overline{M E}=\overline{U O C}=S C=\text { Low } \end{aligned}$ |  |  | 55 |  |  | 55 | ns |
| tpde | Error Flag Propagation Delay | UD, PB | EF | $\begin{aligned} & \text { MCLK }=\text { High; } \\ & \overline{U I C}=E F H=\text { Low } \end{aligned}$ |  |  | 55 |  |  | 55 | ns |
| tPD7 | Parity Generate Propagation Delay | IV | PB | $\begin{aligned} & \mathrm{MCLK}=\mathrm{WC}=\overline{\mathrm{UIC}}= \\ & \text { High; } \overline{\mathrm{UOC}}=\overline{\mathrm{ME}}=\text { LoW } \end{aligned}$ |  |  | 55 |  |  | 55 | ns |
| tPD8 | Error Flag Strobe Delayl3! | dEFH | EF |  |  |  | 20 |  |  | 20 | ns |
| Ouiput toe: | Enable Timing: <br> UD Output Enable | \UOC | UD, PB | $\overline{\text { UIC }}=\mathrm{High}$ |  |  | 30 |  |  | 30 | ns |
| toez | UD Input Recovery | AUIC | UD, PB | $\overline{\text { UOC }}$ = Low |  |  | 30 |  |  | 30 | ns |
| toe 3 | IV Data Master Enable | +ME | $\overline{\mathrm{V}}$ | WC = SC = Low |  |  | 22 |  |  | 25 | ns |
| toe 4 | IV Data Write Recovery | *WC | $\overline{\mathrm{V}}$ | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |
| toes | IV Data Select Recovery | +SC | $\overline{\mathrm{V}}$ | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |

## AC ELECTRICAL CHARACTERISTICS (Continued)

| Parameter | References |  | Test Conditions ${ }^{[1]}$ | Limits (Commercial) |  |  | Limits (Military) |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | From | To |  | Min | Typ | Max | Min | Typ | Max |  |
| Output Disable Timing: toD1 UD Output Disable | $4 \cup 0 \mathrm{C}$ | UD, PB | $\overline{\text { UIC }}=\mathrm{High}$ |  |  | 25 |  |  | 25 | ns |
| tod2 UD Input Override | $\sqrt{\text { UIC }}$ | UD, PB | $\overline{\mathrm{UOC}}=$ Low |  |  | 30 |  |  | 30 | ns |
| ${ }^{\text {tod }}$ IV $\overline{\text { V }}$ Data Master Disable | $\stackrel{\text { AE }}{ }$ | IV | $W C=S C=$ Low |  |  | 20 |  |  | 20 | ns |
| toD4 IV Data Write Override | 4WC | $\overline{\mathrm{V}}$ | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 20 |  |  | 20 | ns |
| toD5 IV Data Select Override | 4SC | IV | $\mathrm{WC}=\overline{\mathrm{ME}}=$ Low |  |  | 20 |  |  | 20 | ns |
| Setup Times: ts1 UD Clock Setup Time | UD, PB | *MCLK | $\overline{\text { UIC }}=$ Low | 15 |  |  | 15 |  |  | ns |
| tS2 UD Control Setup Time | UD, PB | $\stackrel{\text { UIC }}{ }$ | MCLK $=$ High | 15 |  |  | 15 |  |  | ns |
| ts3 User Input Control Setup Time | $\sqrt{\text { UIC }}$ | *MCLK |  | 25 |  |  | 25 |  |  | ns |
| tS4 IV Data Setup Time | IV | +MCLK | $\begin{aligned} & W C=\text { High or } S C=\text { High; } \\ & \overline{M E}=\text { Low } ; \overrightarrow{U I C}=\text { High } \end{aligned}$ | 35 |  |  | 35 |  |  | ns |
| $\mathrm{t}_{\mathrm{S}}{ }^{2 i}$ IV Master Enable Setup Time | † $\overline{M E}$ | †MCLK | $\begin{aligned} & W C=\text { High or } S C=\text { High; } \\ & \overline{U I C}=\text { High } \end{aligned}$ | 30 |  |  | 30 |  |  | ns |
| ts6 $\begin{aligned} & \overline{\mathrm{V}} \text { Write Control } \\ & \text { Setup Time }\end{aligned}$ | 4WC | ¢MCLK | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low; $\overline{\mathrm{UIC}}=\mathrm{High}$ | 30 |  |  | 30 |  |  | ns |
| ts7 $\bar{V}$ Select Control Setup Time | 4SC | *MCLK | $W C=\overline{M E}=$ Low | 30 |  |  | 30 |  |  | ns |
| Hold Times: <br> th1 UD Clock Hold Time | +MCLK | UD, PB | $\overline{U I C}=$ Low | 15 |  |  | 15 |  |  | ns |
| ${ }^{\text {th2 }}$ 2 UD Control Hold Time | $4 \overline{U I C}$ | UD, PB | MCLK = High | 15 |  |  | 15 |  |  | ns |
| $t^{t} \mathrm{H} 3$ User Input Control Hold Time | *MCLK | $\overline{4 U I C}$ |  | 0 |  |  | 0 |  |  | ns |
| ${ }^{\text {tH4 }}$ IV Data Hold Time | *MCLK | IV | $\begin{aligned} & W C=\text { High } \text { or } S C=\text { High; } \\ & \overline{M E}=\text { Low }, \overline{U I C}=\text { High } \end{aligned}$ | 5 |  |  | 5 |  |  | ns |
| ${ }^{\text {th }}{ }^{\prime 2}{ }^{2 /}$ IV Master Enable Hold Time | +MCLK | $4 \overline{M E}$ | $\begin{aligned} & W C=\text { High or } S C=\text { High; } \\ & \frac{U I C}{}=\text { High } \end{aligned}$ | 0 |  |  | 0 |  |  | ns |
| tH6 $\begin{aligned} & \text { IV Write Control } \\ & \text { Hold Time }\end{aligned}$ | +MCLK | +WC | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low; $\overline{\mathrm{UIC}}=$ High | 0 |  |  | 0 |  |  | ns |
| ${ }^{\mathrm{t}} \mathrm{H} 7 \quad \overline{\mathrm{~V}}$ Select Control Hold Time | +MCLK | 1SC | $W C=\overline{M E}=$ Low | 0 |  |  | 0 |  |  | ns |

## Notes:

1. All measurements to the $\overline{I V}$ bus assumes the address selection latch is set.
2. If $\overline{\mathrm{ME}}$ is to be high (inactive), it must be setup before the rising edge and held after the falling edge of MCLK to avoid unintended writing into or selection of the I/O port.
3. Parameters are measured by holding $\overline{U I C}=$ High and $M C L K=$ Low and changing the state of the PSL input before each EFH pulse.

TIMING DIAGRAMS


TEST LOADING CIRCUITS
(TV BUS

## APPLICATIONS

As shown in the following diagram, the $8 \times 374$ can be used with other $1 / O$ ports to provide a complete range of input/ output functions. By proper control of the UIC and UOC lines, the user can perform bidirectional data transfers,
exercise system control, read system status and. by using the $8 \times 374$, implement a bidirectional parity-controlled data stream. To use the parity capabilities, the user need only select even or odd parity ( $\mathrm{PSL}=1$ or 0 ) and connect the PB pin to the system parity bit. The EFH and EF pins can be wired according to system requirements.

## APPLICATIONS DIAGRAM



## 4-INPUT/4-OUTPUT ADDRESSABLE I/O PORT

## FEATURES

- Bidirectional 8-bit MicroController (IV) bus
- User bus-four input bits and four output bits
- Independent bus operation
- Synchronous user data input
- Programmed MicroController port address
- Three-state TTL outputs with high-drive capabilities
- Power-up to predetermined logic state
- Directly compatible with $8 \times 305$ or $8 \times 300$ MicroControllers
- Single +5 V supply
- 0.4 inch 24-pin DIP


## PRODUCT DESCRIPTION

The $8 \times 382$ I/O Port is an addressable, three-state device designed for use as an interface element in systems that use TTL-compatible busses. Typically, the 8X382 is used with the $8 \times 305$ MicroController and its associated Interface Vector (IV) bus; however, it can also be used with the 8X300 MicroController or an equivalent microprocessor. The $8 \times 382$ is functionally the same and pin-for-pin compatible with the older $8 \times 42$; however, the new port features better performance, increased drive current, and improved programming procedures.
As shown in the logic diagram of Figure 1, the 1/O port
consists of eight data latches-bits 0 through 7. These latches are accessed through either of two busses-an 8-bit bidirectional IV bus connected to the MicroController and a User Data (UD) bus consisting of four dedicated inputs (bits UDO through UD3) and four dedicated outputs (bits UD4 through UD7). All eight bits may be read from or four data bits (IV4-IV7) can be written into via the IV bus; eight bits of 1/O address can be written from the $\overline{\mathrm{V}}$ bus. Separate controls are provided for each bus and both busses operate independently. The I/O data latches are transparent, in that, when either bus is enabled for input, all transitions in input data are propagated to the other bus, if that bus in enabled for output.
The 8X382 is available with preprogrammed addresses ( $0_{10}$ through $255_{10}$ ); it can also be field-programmed over the same address range. Input/output operations can begin once the I/O port is selected and appropriate control signals are generated. Port selection is implemented by
 selected, the I/O port remains selected until a different "port address" is put on the bus. Thus, software overhead is minimized. Data is accessible on the UD bus at all times. A Master Enable ( $\overline{\mathrm{ME}}$ ) input, which is typically connected to the Left Bank ( $\overline{\mathrm{LB}}$ ) or Right Bank ( $\overline{\mathrm{RB}}$ ) output of the MicroController, provides the capability of organizing the $\overline{\mathrm{V}}$ bus into two separate and independent banks of I/O devices.

## 8X382 PACKAGE and PIN DESIGNATIONS




Figure 1. Logic Diagram for $8 \times 382$ I/O Port

## FUNCTIONAL OPERATION

## UD Bus Control

As shown in Table 1, the User Data-bus interface is controlled by the UIC and $\overline{U O C}$ inputs. Data input to UDOUD3 is synchronous with MCLK, that is, with UIC low, information is written into the data latches only when MCLK is high. The output drivers of UD4-UD7 bus are enabled when $\overline{U O C}$ is low
Table 1. INPUT/OUTPUT CONTROL OF UD BUS

| UIC | UOC | MCLK | FUNCTION OF UD BUS |  |
| :---: | :---: | :---: | :--- | :--- |
|  |  |  | UD0-UD3 | UD4-UD7 |
| $H$ | L | X | Inactive | Output Data |
| L | X | H | Input Data | Inactive |
| L | X | L | Inactive | Inactive |
| $H$ | $H$ | X | Inactive | Inactive |

$x=$ don't care

## IV Bus Control

Input/output control of the $\overline{I V}$ bus is shown in Table 2; this bus is controlled by SC, WC, ME, MCLK and the current state of an internal address selection latch. The address selection latch in the I/O port stores the result of the most recent $\bar{V}$ address selection. The latch is set when the internally preprogrammed address of the port matches the address on the $\overline{\mathrm{V}}$ bus during an address-selection operation ( $\mathrm{SC}=$ MCLK $=$ High/WC=Low). The latch is cleared when the two 8-bit address patterns are in disagreement. The $\overline{\mathrm{V}}$ bus can transfer data only when the selection latch is set. The MicroController Left Bank ( $\overline{\mathrm{LB}}$ ) and Right Bank ( $\overline{\mathrm{RB}}$ ) outputs can control the $\overline{M E}$ inputs for two banks of I/O devices, thus, acting as ninth address bit.
Data is written into the data latches of a selected device from the $\overline{\mathrm{V}}$ bus when $W C=$ MCLK $=$ High and $\overline{M E}=$ Low. Output drivers on the $\overline{\mathrm{V}}$ bus of the device with the address latch set are enabled with $\overline{M E}, W C$, and SC low. With SC and WC both high (shaded entry of Table 2), the bit pattern present on $\overline{\mathrm{IVO}}-\mathrm{IV7}$ is interpreted as both input data $\overline{(\mathrm{IV} 4-\mathrm{IV7}}$ only) and TV address. The data in $\overline{\mathrm{V} 4}-\overline{\mathrm{IV7}}$ is latched in whether or not the I/O port has been previously selected. If the preprogrammed address of the I/O port matches the bit pattern on $\overline{\mathrm{VO}}-\overline{\mathrm{IV7}}$ when SC and WC are both high, the selection latch is set; otherwise, it is reset. (Note. The MicroController never drives both SC and WC high at the same time.)
Table 2. INPUT/OUTPUT CONTROL OF IV BUS

| $\overline{M E}$ | SC | WC | MCLK | $\begin{aligned} & \text { SEL. } \\ & \text { LATCH } \end{aligned}$ | FUNCTION OF IV BUS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | X | Set | Output Data |
| L | L | H | H | Set | Input Data (IV4-IV7 only) |
| L | H | L | H | $x$ | Input Address* |
| L | H | H | 4 | X | input Data (V/4.V7 ony) and aduress*. |
| L | X | H | L | $X$ | Inactive |
| L | H | X | L | X | Inactive |
| L | L | X | X | Not set | Inactive |
| H | X | X | X | X | Inactive |

## Bus Logic Levels

Data written into the I/O port from either bus will appear inverted when read from the other bus. Data written into either bus will not be inverted when read from the same bus. (Note. A logic " 1 " in MicroController software corresponds to a high level on the UD bus even though the IV bus is inverted). The 8X382 wakes up in the unselected state with all data bits latched at the "logic 1 " level (UD bus outputs high if enabled).

## ADDRESS PROGRAMMING AND ADDRESS PROTECT

## Programming Procedures

The $8 \times 382$ can be programmed to respond to any address within a range of 010 through 25510 . In an unprogrammed state, low level ( $\leq 0.8 \mathrm{~V}$ ) inputs on all IV bus lines (address 25510) will select the device. To program a given address bit to match a high level ( $\geq 2.0 \mathrm{~V}$ ) input on the corresponding $\overline{\mathrm{V}}$ pin (a logical " 0 " to the MicroController), the counterpart UD-bus pin must be pulsed according to Table 3 and the following procedures:

Step 1: Set all control inputs to the inactive state$\overline{U T C}=\overline{U O C}=\overline{M E}=V_{C C}$ and $S C=W C=$ MCLK = GND; leave the UD and IV bus pins open.
Step 2: Increase $\mathrm{V}_{\mathrm{CC}}$ to $\mathrm{V}_{\mathrm{CCP}}$.
Step 3: After $\mathrm{V}_{\mathrm{CC}}$ has stabilized, apply a single programming pulse (Figure 2) to the user-bus bit that corresponds to the desired high-level $\overline{\mathrm{V}}$ address bit. The I/O port is programmed from the user bus (UDO-UD7) for addressing from the MicroController bus (IVO-IV7).

Table 3. PROGRAMMING SPECIFICATIONS

| PARAMETERS | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  | Min | Typ | Max |  |
| VCCP - Programming supply <br> voltage: <br> Address |  |  |  |  |
| Protect | 8.75 | 9.0 | 9.25 | V |
| Maximum time VCCP $>5.25 \mathrm{~V}$ |  |  | 1.0 | Sec |
| Programming voltage: <br> Address | 8.75 | 9.0 | 9.25 | V |
| Protect | 8.75 |  | 9.25 | V |
| Programming current: |  |  | 5 | mA |
| Address |  |  | 50 | mA |
| Protect | 10 |  | 100 | $\mu \mathrm{~S}$ |
| trome Programming pulseirise <br> time: <br> Address | 10 |  | 100 | $\mu \mathrm{~S}$ |
| Protect | 0.5 |  | 1.0 | mS |

Step 4: Return Vcc to 0-volts. (Note. If the programming of all address bits is completed in less than 1 -second, Vcc can remain at 9.0 -volts for the required interval of time.)

Step 5: Steps 1 through 3 are applicable to the programming of each address bit that requires a high-level IV match.
Step 6: To verify that the address is properly programmed, return $\mathrm{V}_{\mathrm{CC}}$ to +5 V , set $\overline{\mathrm{V} 0}-\overline{\mathrm{IV7}}$ to the desired (inverted) binary address pattern, set $\overline{M E}=W C=$ Low and $S C=$ MCLK $=$ High. If there are no programming errors, subsequent data written from $\overline{\text { V44-IV7 }}, \mathrm{WC}=\mathrm{High}$, will appear inverted on UD4-UD7.


Figure 2. Address Programming Pulse

## Address Protect

After programming the I/O Port, steps should be taken to isolate the address circuits and make these circuits permanently immune to further change.

Step 1: $\quad$ Set $V_{C C}$ and all control inputs to 0 -volts $V_{C C}$ $=\overline{U I C}=\overline{U O C}=\overline{\mathrm{ME}}=\mathrm{SC}=W C=\mathrm{MCLK}=$ $\mathrm{GND}=0.0 \mathrm{~V} ; \overline{\mathrm{IVO}}-\overline{\mathrm{IV} 7}=$ open circuit.

Step 2: Taking one pin at a time, apply a protect programming pulse (Figure 3 ) to each userbus bit UDO-UD7:-refer to Table 3 for $\mathrm{min} / \mathrm{max}$ specifications pertaining to voltage and current.

Step 3: Verify that the address circuits for each bit is isolated by applying 9 -volts, in turn, to each user-bus pin (UDO-UD7) and measuring less than 200 microamperes of input current. (Note. Setup conditions are the same as those in Step 1.)


Figure 3. Protect Programming Pulse

## DC ELECTRICAL CHARACTERISTICS

COMMERCIAL: $4.75 \mathrm{~V} \leq \mathrm{V}_{C C} \leq 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}$ MILITARY: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{C}} \leq 125^{\circ} \mathrm{C}$

## ABSOLUTE MAXIMUM RATINGS

| PARAMETER | RATING | UNIT |  |
| :--- | :--- | :---: | :---: |
| $V_{C C}$ | Power supply voltage 3 | +7 | Vdc |
| $V_{\text {IN }}$ | Input voltage ${ }^{3}$ | +5.5 | $V_{d C}$ |
| TSTG | Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |


| PARAMETER |  | TEST CONDITIONS | LIMITS (COMMERCIAL) |  |  | LIMITS (MILITARY) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |
| VCC | Supply Voltage |  |  | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{1} \mathrm{H}$ | High Level Input Voltage |  | 2.0 |  |  | 2.0 |  |  | V |
| VIL | Low Level Input Voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{V}_{\text {CL }}$ | Input Clamp Voltage | $V C C=M i n ; ~ I I=-10 m A ~$ |  |  | -1.5 |  |  | -1.5 | V |
| I/H | High Level Input Current ${ }^{1}$ | $\mathrm{V}_{\text {CC }}=\mathrm{Max} ; \mathrm{V}_{\text {IH }}=2.7 \mathrm{~V}$ |  | 5.0 | 100 |  | 5.0 | 100 | $\mu \mathrm{A}$ |
| IIL | Low Level Input Current1 | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \mathrm{V}_{\text {IL }}=0.5 \mathrm{~V}$ |  | -350 | -550 |  | -350 | -550 | $\mu \mathrm{A}$ |
| IOZH | High-Z State Output CurrentHigh Level4 |  |  |  | 100 |  |  | 100 | $\mu \mathrm{A}$ |
| IOZL | High-Z State Output CurrentLow Level4 | $\mathrm{VCC}=\mathrm{Max} ; \mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}$ |  |  | -100 |  |  | -100 | $\mu \mathrm{A}$ |
| VoL | Low Level Output Voltage iv Bus (ivo-IV7) <br> - User Bus (UD4-UD7) | $V \mathrm{VCC}=\mathrm{Min} ; 1 \mathrm{LL}=16 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
|  |  | $V_{C C}=\mathrm{Min} ; 1 \mathrm{~L}=24 \mathrm{~mA}$ |  |  | 0.55 |  |  | 0.55 | V |
| VOH | High Level Output Voltage | $\mathrm{VCC}=\mathrm{Min} ; \mathrm{IOH}^{\prime}=-3.2 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
| los | Short Circuit Output Current2 iv Bus (ivo-IV7) <br> UD Bus (UD4-UD7) | $V_{C C}=\mathrm{Max}$ | -20 |  |  | -20 |  |  | mA |
|  |  | $V_{C C}=$ Max | -10 |  |  | -10 |  |  | mA |
| ICC | Supply Current | $V_{C C}=\mathrm{Max} ; \overline{\mathrm{ME}}=\overline{\mathrm{UOC}}=\mathrm{V}_{C C}$ |  | 90 | 150 |  | 90 | 150 | mA |

Notes:

1. The input current includes the Three-state leakage current of the output driver on the data lines.
2. These limits do not apply during address programming.
3. Only one output may be shorted at a time.
4. Applies only to pins UD4-UD7

AC ELECTRICAL CHARACTERISTICS
COMMERCIAL: $4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$
MILITARY: $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V},-55^{\circ} \mathrm{C} \leq \mathrm{TC} \leq 125^{\circ} \mathrm{C}$
LOADING: See TEST LOADING CIRCUITS

| PARAMETER | REFERENCES ${ }^{1}$ |  | TEST CONDITIONS | LIMITS (COMMERCIAL) |  |  | LIMITS (MLIITARY) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FROM | TO |  | Min | Typ | Max | Min | Typ | Max |  |
| Pulse Widths: <br> tw1 Clock High | 4MCLK | ¢MCLK |  | 35 |  |  | 35 |  |  | ns |
| twa User Input Control | गUIC | 4 UIC | MCLK High | 35 |  |  | 35 |  |  | ns |
| Propagation Delays: <br> tPD1 UD Propagation Delay | UD03 | $\overline{\mathrm{V}} \mathrm{V}_{3}$ | MCLK High SC WC $\overline{M E} \overline{\text { UIC Low }}$ |  |  | 30 |  |  | 30 | ns |
| tpd2 UD Clock Delay | 4 MCLK | $\overline{V_{0}} 3$ | UD 0 . 3 Stable: MCLK High; SC WC $\overline{M E} \overline{U I C}$ Low |  |  | 50 |  |  | 50 | ns |
| tpD3 UD Input Delay | गUIC | $\overline{\mathrm{V}} \mathrm{V}_{3}$ | UD0. 3 Stable: MCLK High; SC WC $\overline{M E}$ Low |  |  | 50 |  |  | 50 | ns |
| $\begin{array}{ll} \hline \text { tpD4 } & \overline{\text { IV Data }} \\ & \text { Propagation Delay } \end{array}$ | $\bar{V}_{4.7}$ | $U^{\prime} \mathrm{S}_{4} 7$ | MCLK WC High; $\overline{M E} \overline{U O C} \cdot S C$ Low |  |  | 45 |  |  | 45 | ns |
| tpD5 $\bar{V}$ Data Clock Delay | 4MCLK | UD 4.7 | $\overline{\mathrm{I}}_{4} 7$ Stable: WC:High: $\overline{M E} \overline{U O C}$ SC Low |  |  | 55 |  |  | 55 | ns |
| Output Enable Timing: toE1 UD Output Enable | गUOC | $\mathrm{UD}_{4.7}$ |  |  |  | 30 |  |  | 30 | ns |
| toes$\overline{\text { IV }}$ Data <br> Master Enable | $\downarrow \overline{M E}$ | IV | WC $=$ SC = Low |  |  | 22 |  |  | 25 | ns |
| toes $\quad \overline{\text { V }}$ Data | *WC | $\overline{\mathrm{V}}$ | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |
| toewIV Data <br> Select Recovery | $\downarrow$ SC | IV | $\mathrm{WC}=\overline{\mathrm{ME}}=$ Low |  |  | 25 |  |  | 25 | ns |
| Output Disable Timing: toD1 UD Output Disable | $4 \overline{U O C}$ | UD 4.7 |  |  |  | 25 |  |  | 25 | ns |
| toD3 ${ }^{2} \quad \overline{\text { VV }}$ Data Master Disable | $4 \overline{M E}$ | iv | $\mathrm{WC}=\mathrm{SC}=$ Low |  |  | 25 |  |  | 25 | ns |
| $\begin{array}{ll} \text { toD5 }^{2} & \overline{\text { IV }} \text { Data } \\ & \text { Write Override } \end{array}$ | 4 Wc | IV | $\mathrm{SC}=\overline{\mathrm{ME}}=$ Low |  |  | 20 |  |  | 20 | ns |
| toD6 $^{2}$ $\overline{\mathrm{~V}}$ Data <br> Select Override  | 4 sc | iv | $\mathrm{WC}=\overline{\mathrm{ME}}=$ Low |  |  | 20 |  |  | 20 | ns |
| Setup Times: <br> ts1 UD Clock Setup Time | $\mathrm{UD}_{0 \cdots 3}$ | \MCLK | $\overline{\text { UIC }}=$ Low | 15 |  |  | 15 |  |  | ns |
| ts2 UD Control Setup Time | UD0.3 | पUIC | MCLK \% High | 15 |  |  | 15 |  |  | ns |
| ts3 User Input Control Setup Time | \UIC | \$MCLK |  | 25 |  |  | 25 |  |  | ns |
| ts4 $\bar{V}$ Data <br>  Setup Time | IV | \$MCLK | $\begin{aligned} & \mathrm{WC}=\text { High or } \mathrm{SC}=\text { High; } \\ & \overline{\mathrm{ME}}=\text { Low }: \end{aligned}$ | 35 |  |  | 35 |  |  | ns |
| $\mathrm{ts5}^{3} \quad$$\overline{\mathrm{IV}}$ Master Enable <br> Setup Time | $\downarrow \overline{M E}$ | \$MCLK | WC $=$ High or SC $=$ High | 30 |  |  | 30 |  |  | ns |
| ts6 $\quad \overline{\mathrm{V}}$ Write Control Setup Time | 4 Wc | \$MCLK | $S C=\overline{M E}=$ Low; | 30 |  |  | 30 |  |  | ns |
| ts7$\overline{\text { IV }}$ Select Control <br> Setup Time | 4sc | \$MCLK | $W C=\overline{M E}$ Low | 30 |  |  | 30 |  |  | ns |

## AC ELECTRICAL CHARACTERISTICS (Cont'd)

| PARAMETER | REFERENCES |  | TEST CONDITIONS | LIMITS (COMMEACIAL) |  |  | LIMITS (mLITARY) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FROM | TO |  | Min | Typ | Max | Min | Typ | Max |  |
| Hold Times: <br> th1 UD Clock Hold Time | \$MCLK | UD | $\overline{\text { UIC }}=$ Low | 15 |  |  | 15 |  |  | ns |
| the $2 \quad \begin{gathered}\text { UD Control } \\ \text { Hold Time }\end{gathered}$ | АUIC | UD | MCLK $=\mathrm{High}$ | 15 |  |  | 15 |  |  | ns |
|  | \$MCLK | 4 UIC |  | 0 |  |  | 0 |  |  | ns |
| th4 Data Hold Time | \#MCLK | IV | $\begin{aligned} & \mathrm{WC}=\text { High or } S C=\text { High } ; \\ & \overline{M E}=\text { Low } \end{aligned}$ | 5 |  |  | 5 |  |  | ns |
| th5 $^{3} \quad$Master Enable <br> Hold Time | \$MCLK | $4 \overline{M E}$ | WC $=$ High or $\mathrm{SC}=$ High; | 0 |  |  | 0 |  |  | ns |
| $\begin{aligned} & \text { tH6 } \begin{array}{l} \text { IV Write Control } \\ \text { Hold Time } \end{array} \end{aligned}$ | 4MCLK | \$WC | $S C=\overline{M E}=$ Low | 0 |  |  | 0 |  |  | ns |
| th7 $\overline{\bar{V}}$ Select Control | 4 MCLK | $\downarrow$ ¢C | $\mathrm{WC}=\stackrel{\text { ME }}{ }=$ Low | 0 |  |  | 0 |  |  | ns |

Notes:

1. All measurements to the IV bus assumes the address selection latch is set.
2. These parameters are measured with a capacitive loading of $50 \rho f$ and represent the output driver turn-off time.
3. If $\overline{M E}$ is to be high cinactive !, it must be setup before the rising edge and held after the falling edge of MCLK to avoid unintended writing into or selection of the I/O port.


Figure 4. Timing Diagrams

## TEST LOADING CIRCUITS



## APPLICATIONS

When compared to other MicroController ports in the $8 \times 370$ series, the $8 \times 382$ has some unique features that provide real design advantages in certain applications. Connection of the I/O port to the MicroController is simple and straightforward in that like pin names are tied together. The system designer must also decide on which bank of the MicroController to place the $8 \times 382$ and then connect the $\overline{\mathrm{ME}}$ pin of the port to either the $\overline{\mathrm{LB}}$ Left Bank or $\overline{\mathrm{RB}}$ Right Bank) of the MicroController.

The $8 \times 382$ is unique because it can be used for both dedicated input and output operations. In the system
shown below, the user interface requires nine (9) dedicated inputs and eleven (11) dedicated outputs. Observe that by using an $8 \times 382$, the problem is solved by three devices, whereas, four $8 \times 372$ ports are required for the same solution.
Another important use of the $8 \times 382$ is in implementing a handshake interface. Since both input and output bits reside in the same port, I/O operations can be performed without port re-addressing. Users may also find the $8 \times 382$ an advantage in the layout of Printed Circuit boards, since random control/status signals can be grouped within the same device position.


Figure 5. Logic Diagram for 8X382 I/O Port

## Signetics

Microprocessor Products

## DESCRIPTION

The Signetics $8 \times 401$ Microcontroller is a very high-speed bipolar microprocessor implemented with internal ECL technology. The 8X401 Microcontroller combines speed, flexibility, and a bit-oriented instruction set to accommodate many sophisticated applications. It excels in systems that require high-speed bit or byte manipulations, such as high-speed controllers and data communications.

The 8X401 can fetch, execute, and generate the next instruction address for a 20 -bit instruction in a minimum of 150 ns. Within one instruction cycle, the $8 \times 401$ can be programmed to input, right-rotate and mask single or multiple bit subfields, perform an ALU operation, left-rotate, merge the subfield into the destination, and output.
To interface with program memory, the $8 \times 401$ uses a 13-bit address bus and a 20 -bit instruction bus. An 8 -bit bidirectional data/address bus, and an 1/O control and timing bus is used to access external peripheral devices.

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 64-pin CERAMIC | N8X4011 |
| DIP 900 Mil Wide |  |

## FEATURES

- Fetches and executes all instructions in a minimum of 150ns
- Bit manipulation-oriented instruction set
- Separate buses for instruction, instruction address and I/O
- Sixteen 8-bit registers
- On-chip interrupt control
- TTL compatible I/O
- Single +5 V supply
- 0.9-inch 64-pin DIP, 68-pin plastic leaded chip carrier
- Two user-definable status flags
- Single TTL clock input
- Three independent I/O banks
- On-board control sequencer
- On-chip subroutine capabilities
- Fixed instruction set - 32 instructions
- Complete development support


## Product Specification

PIN CONFIGURATION

|  |  |
| :---: | :---: |
| GND 1 | 64 Vcc |
| AO 2 | 63 cr |
| ${ }^{2} 13$ | 62 IR |
| A2 4 | 61 NZ |
| ${ }^{4} 5$ | 60 PS |
| ${ }^{4} 4$ | 59 si |
| ${ }^{45} 7$ | 58 CP |
| ${ }^{46} 8$ | 57 SCR |
| ${ }^{4} 9$ | 56 HALT |
| A8 10 | 55 RESET |
| A9 11 | 54] awc |
| A10 12 | 53 MCLK |
| A11 13 | 52 vcc |
| A 12 | $51{ }^{\text {daO }}$ |
| NM1 15 | 50 DA1 |
| $\underline{\text { INT }} 16$ | $49 \mathrm{DA2}$ |
| GND 17 | $488 \overline{\mathrm{DA}^{3}}$ |
| 10.18 | 47 GND |
| 119 | [46] $\overline{\mathrm{DA}}$ |
| 12.20 | $45 \mathrm{DA5}$ |
| 13.21 | $44 . \overline{\text { DA6 }}$ |
| 14.22 | 43 DA7 |
| 15 23 | 42 wc |
| 16 24 | 41] sc |
| 17.25 | 40 C |
| 18.26 | 39 E |
| 19 | $38{ }^{\text {A }}$ |
| 110 | 37-19 |
| 1112 | 36 148 |
| 112 | 35 117 |
| 113 | (34)116 |
| 11432 | [33)15 |
|  | coosgeos |

BLOCK DIAGRAM OF THE 8X401


## PIN DESCRIPTION

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 1, 17, 47 | GND | Ground. |
| 2-14 | A12-A0 | Program Address Lines: These active-high outputs permit direct addressing of up to 8192 locations of program storage; AO is LSB. |
| 15 | $\overline{\mathrm{NMI}}$ | Non-Maskable Interrupt: The falling edge of this active-low input pin generates a nonmaskable interrupt. |
| 16 | $\overline{\text { INT }}$ | Interrupt: This active-low input pin is tested during the fourth quarter of each instruction cycle. If an interrupt is indicated and if interrupts are enabled, the address of the next instruction that was to be executed is stored onto the program counter stack before the interrupt is serviced. |
| 18-37 | 119-10 | Instruction Lines: These active-high input lines receive 20 -bit instructions from program storage; 10 is LSB. |
| 38 | $\overline{\mathrm{A}}$ | Bank A: When low, devices connected to bank A are accessed. (Note: Typically, the A signal is tied to the $\overline{\mathrm{ME}}$ input pin of I/O peripherals.) |
| 39 | $\bar{B}$ | Bank B: When low, devices connected to bank B are accessed. (Note: Typically, the B signal is tied to the $\overline{\mathrm{ME}}$ input pin of 1/O peripherals.) |
| 40 | $\overline{\mathrm{C}}$ | Bank C: When low, devices connected to bank C are accessed. (Note: Typically, the $C$ signal is tied to the $\overline{\mathrm{ME}}$ input pin of I/O peripherals.) |
| 41 | SC | Select Control: When high, an address is being output on pins $\overline{\text { DA7 }}$ through $\overline{\text { DAO }}$. |
| 42 | WC | Write Control: When high, data is being output on pins $\overline{\mathrm{DA7}}$ through $\overline{\mathrm{DAO}}$. |
| $\begin{aligned} & 43-46 \\ & 48-51 \end{aligned}$ | $\overline{\text { DA7 }}-\overline{\text { DAO }}$ | Data Address Bus: These active-low, bidirectional, three-state lines are used for $1 / \mathrm{O}$; $\overline{\mathrm{DAO}}$ is L.SB. |
| 52, 64 | $\mathrm{V}_{\mathrm{CC}}$ | +5 V power supply. |
| 53 | MCLK | Master Clock: This active-high output signal is used to strobe data into data peripherals for clocking I/O devices and/or synchronization of external logic. MCLK is active-high in the fourth quarter cycle. |
| 54 | RWC | Read/Write Clock: This active-high output signal is used for synchronization of external logic and is active-high during the third and fourth quarter cycles. |
| 55 | RESET | Reset: The $\overline{\text { RESET }}$ input pin is used to initialize the $8 \times 401$. |
| 56 | HALT | Halt: The $\overline{\text { HALT }}$ input is sampled during the first quarter cycle of each instruction cycle. When the HALT input is low, the instruction cycle is not executed. |
| 57 | $\overline{\text { SCR }}$ | Slow Clock Request: This active-low control input is sampled during the first quarter cycle of each instruction. When $\overline{\mathrm{SCR}}$ is asserted, it will cause the current instruction to be executed at half of the normal clock rate. This control input is necessary to accommodate 1/O devices that cannot operate at the $8 \times 401$ 's full speed, without having to continuously run the $8 \times 401$ at half speed. |
| 58 | CP | Clock Pulse: Each $8 \times 401$ quarter cycle will correspond to one full cycle of the clock pulse. |
| 59 | SI | Status Input: The value of the SI pin during the fourth quarter cycle is transferred to SI bit in the status register. |
| 60 | PS | Programmable Status: The programmable status pin is controlled entirely by the user program. |
| 61 | NZ | Non-Zero: The NZ bit of the status register is reflected on this pin. |
| 62 | IR | Interrupt Receivable: The IR pin indicates whether an interrupt applied at any point in time will be serviced. Interrupts are receivable when the interrupt mask (status register, bit 0) is clear and the stack is not full ( $\mathrm{IM}=0$ and $\mathrm{SF}=0$ ). |
| 63 | CY | Carry: Carry bit from R10 is output on this pin. |

## Microcontroller

## SMALL SYSTEM <br> CONFIGURATION

The system hookup shown on the next page, although of the simplest form, provides a fundamental example of the $8 \times 401$ Microcontroller and compatible peripheral relationships. As shown, the $8 \times 401$ can directly address up to 8 K locations of program storage.

Each of the three bank pins ( $\overline{\mathrm{A}}, \overline{\mathrm{B}}$, or $\overline{\mathrm{C}}$ ) are capable of uniquely addressing 256 input/ output locations via the Data Address bus ( $\overline{\mathrm{DA}} \overline{\mathrm{D}}-\overline{\mathrm{DAO}}$ ).

The addressable locations for each bank can be used in a variety of ways. The hookup shown below is just one method of implementation.

When a particular bank signal is asserted, that bank is enabled and any one of 256 locations on that bank can be accessed for input/output operations.

## PROGRAM STORAGE

## INTERFACE

As shown in the $8 \times 401$ small system hookup, program memory is connected to output address lines $A 12$ through $A 0(A O=L S B)$ and input instruction lines 119 through 10 ( $10=\mathrm{LSB}$ ). An address output on A12-A0 identifies one 20-bit instruction word in program memory. The program memory outputs an instruction word on $119-10$ which defines the microcontroller operation which is to follow. One instruction word equals one com-
pleted operation. Any TTL-compatible memory can be used for program storage, provided the worst-case access time is compatible with the instruction cycle time used for the application. See timing section for appropriate calculations.

I/O INTERFACE AND CONTROL
The Data Address (DA) bus is an 8-bit bidirectional I/O bus which provides a communication link between the 8X401 and the three banks of the I/O devices. The $\bar{A}$ (A bank), $\bar{B}$ ( B bank), and $\overline{\mathrm{C}}$ ( C bank) control signals identify which bank is enabled. When all three banks go high (inactive), neither bank is enabled and the DA bus is inactive (threestate). A functional analysis of the three bank signals is shown below:

| A | B | C | FUNCTION |
| :---: | :---: | :---: | :--- |
| Low | Low | Low | This state is not <br> generated by the <br> 8X401. |
| Low | High | High | Enable A bank <br> devices. |
| High | Low | High | Enable B bank <br> devices. |
| High | High | Low | Enable C bank <br> devices. |
| High | High | High | Disable all devices; <br> DA bus is three- <br> state |

Both data and I/O address information are multiplexed on the DA bus. The SC (Select Command) and WC (Write Command) signals distinguish between data and I/O address information as shown in the table below. Although the table shows bank A only, the same conditions apply to banks B and C.

| BANK <br> A | SC | WC | FUNCTION |
| :---: | :--- | :--- | :--- |
| High | Low | Low | DA bus is three- <br> state and not <br> looking for input <br> data. |
| Low | Low | Low | The DA bus is <br> reading input data. |
| Low | Low | High | Data is being <br> output. |
| Low | High | Low | Address is being <br> output. |
| $X$ | High | High | This condition is <br> never generated. |



## DATA PROCESSING

The data processing section of the $8 \times 401$ consists of a number of logical subsections. In order of processing, the data sees the right rotator, the ALU, the left rotator, and the merge circuits. Data sources and destinations can be various on-chip registers, the bidirectional DA bus, or immediate subfields. The data processing paths are shown below.

## DATA REGISTERS

## General-Purpose Storage

There are 13 source/destination general-purpose registers available on the $8 \times 401$. Three of these registers, specifically Registers $0, B$, and $F$, have other special functions in addi-
tion to being general purpose. A summary of the registers is listed below:

- R0 (Auxiliary Register) - Register 0 is also used as the implied second operand for two operand instructions (ADD, ADD with CARRY, XOR, AND). The primary operand is specified in the source field of the instruction word and the AUX register is the implied second operand. Prior to performing arithmetic or logical operations (other than the IMMEDIATE operation), it is assumed that RO contains the appropriate data. In order to reduce the possibility of erroneous results and to minimize the number of instructions required to transfer a right-justified second operand
into the $A U X$, the left-rotate and merge functions are inhibited when specifying the AUX as a destination address. This allows subfields from any internal register or I/O bank to be transferred to the AUX with the subfield LSB rightjustified and unspecified bits set to zero.
- R1 through RA - These 10 addresses specify general-purpose, on-chip storage registers.
- RB - Register B is also used as the implied source for the XEC instruction.
- RF - Register F is also used as the implied destination for the XOR IMMEDIATE and AND IMMEDIATE instruction classes.



## Enabled I/O Addresses

These three registers (RC RD, and RE) always contain the address of the most recently enabled I/O device for each of the three I/ O banks. When register $C, D$, or $E$ is the specified destination address, the destination data is sent to both the on-chip register and the corresponding bank on the DA bus. The relationship between the register addresses and I/O banks is shown below:

| REGISTER | BANK |
| :---: | :---: |
| C | A |
| D | B |
| E | C |

When these registers are specified as a destination address, the $L$ field must be set to 0 (full 8 -bit operation). Also, note that registers $C, D$, and $E$ may not be used with the XMIT 5 or ADD IMMEDIATE 5 instructions.

## Carry

Register 10 contains the Carry bit. Bit position 0 (LSB) is the Carry bit, and positions one through seven are always zero. The Carry bit is updated each time an ADD, ADD IMMEDIATE, or ADD WITH CARRY instruction is performed. When specifying address 10 as a destination, only bit 0 (the Carry bit) will be written to. Data written to the Carry bit will be the LSB of the right-rotated data after any specified operation.
When the Carry register is the explicit destination of any ADD instruction, it will contain the carry resulting from the add operation rather than the LSB of the sum. Carry can also be affected via the Return and Set Carry or Return and Clear Carry instructions.

## Status Register

This address specifies the current condition of the $8 \times 401$ system. The status register may be either a source or destination; however, certain bits in the status register are readonly. Four status outputs are available on $8 \times 401$ pins. They are NZ (Not Equal to Zero), PS (Programmable Status), IR (Interrupts Receivable), and Carry (R10, bit 0). The IR pin goes high when the interrupt mask is clear and the stack is not full. The IR output is updated during the 4th quarter cycle. The following descriptions define the bits within the status register.
Bit 0: (IM) - This bit represents the interrupt Mask control. When IM is set, the interrupt is inhibited. This bit is set automatically by a response from a standard or non-maskable interrupt, or RESET. IM can also be set or cleared by a write to the status register.
Bit 1: (NZ) - This bit is set whenever the ALU output data is not equal to zero after any of the following instructions: MOVE, ADD, AND, XOR, ADD IMMEDIATE, AND IMMEDIATE, XOR IMMEDIATE, or ADD WITH CAR-

RY. NZ can also be written to directly when specified in the destination field. This operation will negate and take priority over the normal setting by the ALU output. NZ is not affected after an XMIT instruction, or after a write to R17.

Bit 2: (PS) - This is the Programmable Status bit. The contents are reflected on the PS output pin. This status is controlled entirely by the user program.

Bits 3 and 4: (UFO, UF1) - These two bits represent user flags and have no assigned functions. They can be used as 1-bit internal flags and are entirely under control of the user program.
Bit 5: (SI) - This bit reflects the state of the status input pin. This read-only bit is updated during the 4 th quarter cycle.

Bits 6 and 7: (SE, SF) - These read-only bits indicate Stack Empty and Stack Full, respectively. The bits are updated during the 3rd quarter cycle within the instruction that alters the stack status.

## INSTRUCTION WORD (See Table 3)

Operations Code Field - The 4-bit opcode specifies one of 16 classes of instructions. Some instructions require two additional subopcode fields, $X$ and XS. Variations and interpretations are displayed in Table 2.

Source (S) and Destination (D) Fields The 5 -bit ' $S$ '" and " $D$ ' fields specify the source and destination, respectively, for the operation that is defined by the opcode. The 'S" and/or "D' fields specify an internal $8 \times 401$ register or a variable length field from an I/O device. Hexadecimal values and source/destination field assignments for all internal registers are shown in Table 1.
When RC-RE (banks A, B, or C, respectively) are specified as the destination, the data is output onto the DA bus using the specified bank. The data is also stored in the specified register and may be later accessed as source data.
Rotate ( $R$ ) and Length (L) Fieids - The R field is used in conjunction with the $L$ field to define the desired data within a register or I/ O device. The source data is right-rotated prior to ALU operations, such that the bit specified by the R field is right-justified. The $L$ field specifies the number of bits of data to be used for the operation. After the ALU operation, the data is left-rotated back to the original position prior to merging the data in the destination register.

When the $L$ field specification is 0 (indicating a full 8-bit operation), the left-rotate is sup-
pressed. This allows byte rotate operations to be performed. The left-rotate is also suppressed when the destination is register 0 . This is the AUX register and is used as the implied second operand in certain instructions.

It should also be noted that subfields are defined at the ends of a register; for example, bit positions $1,0,7$, and 6 constitute a contiguous 4-bit subfield.

Data Field - The data field holds data that can be processed directly from the instruction word.

## LEFT-ROTATE OVERRIDE BLOCK

Register addresses 18-1F are destination only and are used to independently control left rotation of data prior to storage in the destination. Specifying 18-1F as a destination causes the data to be returned to the source address.

In order to move a processed subfield within the same register but in different bit positions (the LSB of the contiguous subfield can vary), it is necessary to independently specify the LSB for both the source and destination. The order of operation is as follows:

- Register or I/O source data is rightrotated as specified by the " $R$ " field. Along with the "L" field, the subfield data is defined.
- Subfield data is processed via the ALU.
- Data is left-rotated 0-7 bits, depending on the corresponding register addresses $18-1 \mathrm{~F}$ as specified in the destination field rather than using the " $R$ " field.
- After left-rotation the specified subfield is merged into those bits of the original source data. The unspecified bits of the original source data remain unchanged.
- Result is stored in the register address specified by the source field.

Note that the left-rotate is always inhibited if the " $L$ "' field is zero. Also, addresses 18-1F may not be used in the destination field for the XMIT or ADD IMMEDIATE instructions. The destination addresses and corresponding left-rotate values are shown in Table 2.

## DA BUS CONTROL BLOCK

Register addresses 11-16 are used by the $8 \times 401$ to access $1 / 0$ devices for either a source or destination specified within the instruction. Register addresses 13, 15, and 16 specify banks $A, B$, and $C$, respectively, whereas addresses 11,12 , and 14 specify bank pairs $A B, C A$, and $B C$, respectively (Table 4). One bank of each pair is known as the preferred bank. The preferred banks for
pairs $A B, C A$, and $B C$ are banks $A, C$, and $B$, respectively. The first letter from each bank pair can serve as a mnemonic aid as to which bank is the preferred bank. Having a preferred bank is simply a method of determining which bank to read when an instruction would otherwise indicate that two banks should be read at once.

When used as a source, the appropriate I/O bank is enabled and data is read from the activated I/O device on that bank. The I/O device may have been activated by a previous address select instruction where registers C-E were the specified destination. If a bank pair (addresses 11, 12, or 14) is specified as a source, only data from the preferred bank of that pair will be read in.
When addresses 11-16 are specified as the destination address, the destination data is sent to the DA bus. The Write Control (WC) signal goes high, indicating data (as opposed to an address) is on the DA bus and is to be written to the activated I/O device on the selected bank(s).

When addresses 11-16 are specified as the destination and the " $L$ " field is not zero, the following statements apply: If the source is a register and the destination is a single bank, the bank will be read (or the preferred bank of a bank pair will be read) to obtain the data required to perform the merge operation. The result is that processed data from the specified suofield of the source register is returned to that selected field of the destination bank and any bits outside of the specified subfield will be loaded with unprocessed data from the 1/O device just read. If the destination is a bank pair, the data from the procedure just described is sent to both banks. Below is an example of the outcome of an ADD instruction with Length $=4$, Rotate $=2$, Source $=$ R1, and Destination = R11 (bank pair $A B$ ).


Source register R1. Note specified subfield from $L=4$ and $R=2$.
$R 1+R 0$


Add R1 with R0 (AUX). Result after left-rotate.

Bank A


Bank A


Result after merge. Data put out on both banks A and B .

If, however, the specified source is a bank or bank pair, any unspecified bits will contain unprocessed data from the source I/O device. Below is an example of the outcome with Source $=$ R14 (bank pair BC) and Destination = R13 (bank A).

## Example 2:



Read Preferred bank B of BC. Note specified subfield from $L=4$ and $R=2$.

Bank B+RO


Bank A
 bits contain original source data.

## PROGRAM COUNTER STACK

The $8 \times 401$ stack is capable of saving up to four return addresses for subroutines and interrupts. Addresses are pushed onto the stack as a result of a call or a maskable or non-maskable interrupt. Addresses are popped from the stack as a result of an unconditional RETURN, a satisfied conditional RETURN, or a Pop Stack and Jump instruction. The status of the stack (whether empty, full, or neither) is available from the SE and SF flags in the status register and the Interrupts Receivable (IR) output pin.

## INTERRUPTS

## Interrupt (INT)

The interrupt input is tested once each instruction cycle, during the fourth quarter cycle (see Figure 1). When the interrupt input is taken low and is enabled, the address of the next instruction is pushed onto the program counter stack.
Program flow is transferred to address 2 for the start of the service routine (Figure 2). This is accomplished by inserting a dummy instruction cycle after the interrupt is accepted.
The interrupt mask bit (R17, bit 0 ) is set automatically as part of the interrupt response.

The Interrupts Receivable (IR) pin indicates whether an interrupt applied at any point in time will be serviced. Interrupts are receivable when the interrupt mask is clear and the stack is not full ( $\mathrm{IM}=0$ and $\mathrm{SF}=0$ ).

## Non-Maskable Interrupt ( $\overline{\text { NMI }}$ )

The function of the non-maskable interrupt is similar to the standard interrupt, except that the interrupt receivable status has no effect on its operation and the address jumped to is 1 rather than 2 (Figure 2). Address 1 should contain an unconditional JUMP to the start of the NMI service routine. An NMI is triggered by a falling edge on the $\overline{\mathrm{NMI}}$ input. The interrupt mask is set to prevent normal interrupts from interfering with the NMI service routine. Note that it may not always be possible to recover from an NMI , since the condition of the interrupt mask prior to the NMI is not known, and the NMI response may overflow the stack.

## SLOW CLOCK REQUEST ( $\overline{\text { SCR }}$ )

This control input is sampled during the first quarter cycle of each instruction along with the instruction data. If the input is low, it will cause the current instruction to be executed at half of the normal clock rate. The purpose of this function is to facilitate accesses to $1 / 0$ devices that cannot operate at the $8 \times 401$ 's
full speed, without the need to run the $8 \times 401$ continuously at half speed.

## HALT

The $\overline{\text { HALT }}$ input is sampled during the first quarter cycle of each instruction. If the HALT input is low, the instruction cycle is not executed. The MCLK continues to operate normally (high every fourth quarter cycle), even though program execution has ceased. When the HALT input goes high, program execution will resume at the next falling edge of MCLK. The DA bus is also inactive during a

HALT operation. Like MCL.K, RWC continues to operate during a HALT operation.

## RESET LOGIC

The RESET pin is used to initialize the $8 \times 401$. When RESET is low, the address outputs (A12-A0) are high impedance, the stack pointer is set to the top of the stack (empty), MCLK is inhibited, RWC is low, and the interrupt mask (bit 0 , register 17) is set.

When RESET is released, the address outputs all go low (program address 0 ). A dummy instruction cycle occurs to allow time to fetch
the first instruction from program storage at address 0 . Only MCLK, RWC, and the address bus are in operation during the dummy cycle. The first active instruction cycle will begin following the first MCLK after RESET is released. The instruction at address 0 should be an unconditional jump to the beginning of the main program (which may be proceeded by a power-up sequence to initialize the system (Figure 2).
If $\overline{\text { RESET }}$ is applied during program execution, its effect is immediate. That is, if MCLK is high, it may be prematurely terminated by RESET.

Table 1. Hexadecimal Addresses and Source/Destination Specification

| ADDRESS | DESIGNATION | S | D | ADDRESS | DESTINATION | S | D |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | R0 (AUX) - General Purpose ${ }^{1}$ | X | X | 10 | R10-Carry ${ }^{6}$ | X | X |
| 01 | R1 - General Purpose | X | $x$ | 11 | R11-Bank Access Command (Bank Pair AB) | $x$ | $x$ |
| 02 | R2 - General Purpose | X | X | 12 | R12 - Bank Access Command (Bank Pair CA) | X | X |
| 03 | R3 - General Purpose | X | X | 13 | R13-Bank Access Command (Bank A) | $x$ | x |
| 04 | R4-General Purpose | X | X | 14 | R14 - Bank Access Command (Bank Pair BC) | $x$ | x |
| 05 | R5 - General Purpose | $X$ | X | 15 | R15 - Bank Access Command (Bank B) | X | X |
| 06 | R6-General Purpose | X | X | 16 | R16-Bank Access Command (Bank C) | $\chi$ | $x$ |
| 07 | R7 - General Purpose | $x$ | $x$ | 17 | R17-Statu ${ }^{4}$ | X | $x$ |
| 08 | R8 - General Purpose | X | X | 18 | R18 - Suppress Left-Rotate ${ }^{5}$ |  | X |
| 09 | R9 - General Purpose | X | X | 19 | R19 - Left-Rotate 1 Place ${ }^{5}$ |  | $x$ |
| OA | RA - General Purpose | X | X | 1 A | R1A - Left-Rotate 2 Places ${ }^{5}$ |  | $x$ |
| OB | RB - General Purpose ${ }^{2}$ | X | $x$ | 1B | R1B - Left-Rotate 3 Places ${ }^{5}$ |  | $x$ |
| OC | RC - Address Reg (Bank A) | X | X | 1 C | R1C - Left-Rotate 4 Places ${ }^{5}$ |  | $x$ |
| OD | RD - Address Reg (Bank B) | X | X | 1D | R1D - Left-Rotate 5 Places ${ }^{5}$ |  | $X$ |
| OE | RE - Address Reg (Bank C) | X | X | 1E | R1E - Left-Rotate 6 Places ${ }^{5}$ |  | $X$ |
| OF | RF - General Purpose ${ }^{3}$ | X | X | 1F | R1F - Left-Rotate 7 Places ${ }^{5}$ |  | X |

## NOTES:

1. Also used as implied second operand for two operand instructions.
2. Also used as implied source for XEC instructions.
3. Also used as implied destination for XOR IMMEDIATE and AND IMMEDIATE instructions.
4. Certain bits in the status register are read-only. (See Status Register within text.)
5. The result is returned to the register address specified by the source field.
6. Carry register, bit 0 is the carry bit. Bits $1-7$ are always set to zero.

Table 2. Various of Instruction Types

| INSTRUCTION TYPE | VARIATION | OPCODE | X | XS | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MOVE | MOV | 0000 | - | - | MOVE |
| ADD | ADD <br> ADC <br> AD8 <br> AD5 | $\begin{aligned} & 0001 \\ & 0101 \\ & 1000 \\ & 1001 \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \\ & \text { - } \end{aligned}$ | ADD <br> ADD with CARRY <br> ADD IMMEDIATE 8 <br> ADD IMMEDIATE 5 |
| AND | AND AN8 AN5 | $\begin{aligned} & 0010 \\ & 1010 \\ & 1011 \end{aligned}$ | - | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | AND <br> AND IMMEDIATE 8 AND IMMEDIATE 5 |
| XOR | $\begin{aligned} & \text { XOR } \\ & \text { XR8 } \\ & \text { XR5 } \end{aligned}$ | $\begin{aligned} & 0011 \\ & 1100 \\ & 1101 \end{aligned}$ |  | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | Exclusive-OR <br> Exclusive-OR IMMEDIATE 8 <br> Exclusive-OR IMMEDIATE 5 |
| XEC | XEC | 0100 | - | - | EXECUTE |
| XMIT | $\begin{aligned} & \text { XT8 } \\ & \text { XT5 } \end{aligned}$ | $\begin{aligned} & 0110 \\ & 0111 \end{aligned}$ |  | - | Transmit IMMEDIATE 8 Transmit IMMEDIATE 5 |
| RETURN | RIF NS <br> RIF S <br> RIF NC <br> RIF C <br> RIF Z <br> RIF NZ <br> PSJ <br> RTN <br> RCC <br> RSC | $\begin{aligned} & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \\ & 1110 \end{aligned}$ | $\begin{aligned} & 000 \\ & 001 \\ & 010 \\ & 011 \\ & 100 \\ & 101 \\ & 110 \\ & 111 \\ & 111 \\ & 111 \end{aligned}$ |  | RETURN IF SI $=0$ <br> RETURN IF $\mathrm{SI}=1$ <br> RETURN IF CARRY $=0$ <br> RETURN IF CARRY $=1$ <br> RETURN IF ALU $=0$ <br> RETURN IF ALU $\neq 0$ <br> POP STACK and JUMP <br> RETURN <br> RETURN and CLEAR CARRY <br> RETURN and SET CARRY |
| JUMP | JIF NS JIF S JIF NC JIF C JIF Z JIF NZ JSR <br> JMP | 1111 <br> 1111 <br> 1111 <br> 1111 <br> 1111 <br> 1111 <br> 1111 <br> 1111 | $\begin{aligned} & 000 \\ & 001 \\ & 010 \\ & 011 \\ & 100 \\ & 101 \\ & 110 \\ & 111 \end{aligned}$ | - | JUMP IF SI = 0 <br> JUMP IF SI $=1$ <br> JUMP IF CARRY $=0$ <br> JUMP IF CARRY $=1$ <br> JUMP IF ALU $=0$ <br> JUMP IF ALU $\neq 0$ <br> JUMP to SUBROUTINE JUMP |

Instruction Set Overview: The $8 \times 401$ instruction set is summarized in Table 2. Subsets of each instruction type are grouped together showing the variations of each instruction type. The hardware and software descriptions can be found in the data operations section.

## Table 3. 8X401 Instruction Formats

1. Format for the MOVE, ADD, XOR, and ADD with Carry Instructions:

| TII | T | T T | T | T I |
| :---: | :---: | :---: | :---: | :---: |
| OPCODE | $\mathbf{L}$ | SQURCE | R | DESTINATION |

2. Format for the XMIT 8 and ADD Immediate 8 instruction:

| T T 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

3. Format for the XMIT 5 and ADD Immediate 5 Instruction:

| OPCODE | $\mathbf{L}$ | DESTINATION | $\mathbf{R}$ | DATA5 |
| :---: | :---: | :---: | :---: | :---: | :---: |

4. Format for the AND Immediate 8, and XOR Immediate 8 Instruction:

5. Format for the AND Immediate 5 and XOR Immediate 5 Instruction:

| OPCODE | L | SOURCE | R | \| |
| :---: | :---: | :---: | :---: | :---: |

6. Format for the JUMP, Subroutine Jump, Conditional Jump, and Conditional Return Instruction:

| OPCODE | $\mathbf{x}$ | $\begin{aligned} & \text { T T T } \mid ~ \\ & \text { ADDRESS } \end{aligned}$ |
| :---: | :---: | :---: |

7. Format for the Unconditional Return, Return and Set Carry, and Return and Clear Carry Instruction:

8. Format for the XEC Instruction:

| OPCODE | $T_{L}^{\top}$ | ADDRESS |
| :---: | :---: | :---: |

Table 4. I/O Acess Register

| REGISTER | INPUT <br> BANK | OUTPUT <br> BANK |
| :---: | :---: | :---: |
| 11 | A | A \& B |
| 12 | C | C \& A |
| 13 | A | A |
| 14 | B | B \& C |
| 15 | B | B |
| 16 | C | C |



Figure 1. Instruction Cycle and MCLK with: Clock Input $=\mathbf{2 6 . 6 7 M H z}$ and Cycle Time $=150 \mathrm{~ns}$

## DATA OPERATIONS OF THE 8X401 (See Tables 2 and 3)

MOVE, ADD, AND, XOR, ADD with CARRY

| SOURCE | PRE-ALU | ALU | POST-ALU | DESTINATION |
| :---: | :---: | :---: | :---: | :---: |
| R0-R17 as specified by ' S ' field of instruction. | Right rotate as specified by " $R$ " field of instruction. | Perform appropriate ALU operation. (Note 1) | Left-rotate and mask as specified by the " $R$ " and "L" fields of instruction. | R0-R17 as specified by the "Destination" field of instruction. (Notes 2 \& 3) |

MOVE, ADD, AND, XOR, ADD with CARRY (Using left-rotate override R18-R1F)

| SOURCE | PRE-ALU | ALU | POST-ALU | DESTINATION |
| :---: | :---: | :---: | :---: | :---: |
| R0-R17 as specified by " S " field of instruction. | Right-rotate as specified by "R" field of instruction. | Perform appropriate ALU operation. (Note 1) | Left-rotate and mask as specified by the " D " and " $L$ " fields of instruction. (Note 4) | When R18-R1F are specified in the " $D$ " field, data is returned to the address specified in the "Source" field. |

XMIT 8 (XT8), ADD IMMMEDIATE 8 (AD8), AND IMMEDIATE 8 (AN8), XOR IMMEDIATE 8 (XR8)

| SOURCE | PRE-ALU | ALU | POST-ALU | DESTINATION |
| :---: | :---: | :---: | :---: | :---: |
| One to eight bit constants from data field of instruction and register/ address specified by either the source or destination field. | NOP. | Perform appropriate ALU operation. (Note 5) | Mask as specified by the " L " field. | XT8, AD8: Results are sent to register/address, starting from LSB, specified by the destination field of the instruction word. <br> AN8, XR8: Results are sent to RF, starting from LSB. |

XMIT 5 (XT5), ADD IMMMEDIATE 5 (AD5), AND IMMEDIATE 5 (AN5), XOR IMMEDIATE 5 (XR5)


ALL CONDITIONAL AND UNCONDITIONAL RETURNS


ALL CONDITIONAL JUMPS, POP STACK AND JUMP (PSJ), and JUMP (JMP)

| ADDRESS REGISTER | PROGRAM COUNTER | STACK |
| :---: | :---: | :---: |
| Conditional Jumps: If condition is true. $A R=$ instruction word address, else $A R=P C+1$. PSJ and JMP: AR $=$ instruction word address. | $P C=A R$. | Conditional Jumps: NOP. <br> PSJ: POP stack. <br> JMP: NOP. |

## DATA OPERATIONS OF THE 8X401 (CONTINUED)

CALL (JSR), INTERRUPT (INT), NON-MASKABLE INTERRUPT (NMI)

| ADDRESS REGISTER | STACK | PROGRAM COUNTER |
| :---: | :---: | :---: |
| JSR: $A R=$ instruction address. | PUSH PC + 1. (Note 6) | $P C=A R$. |
| INT: $A R=$ address 2. NTM: $A R=$ address 1. |  |  |

## XEC

| ADDRESS REGISTER | PROGRAM COUNTER |
| :---: | :---: | :---: | :---: |
| Right-most $L$ bits of RB merged into corresponding bits <br> in instruction address  PC not updated. |  |

## NOTES:

1. ALU Descriptions:

MOVE: $\quad$ No operation
ADD: $\quad$ - Source data ADDed to contents of auxiliary register (RO-AUX). Carry bit set if carry is generated at MSB of selected data field. NZ status bit set if specified bits are not zero after ALU add.
AND: $\quad$ Source data ANDed to contents of AUX register. NZ status bit updated accordingly.
XOR: $\quad$ Source data Exclusive-ORed with contents of AUX register. NZ status bit set accordingly.
ADD with CARRY: • Sum is formed from source data. AUX register, and carry bit (register 10, bit 0). Carry and NZ status bits are set when appropriate.
2. Left-rotate is suppressed when destination is RO (AUX).
3. When address registers RC, RD and RE are specified in the destination, source data will also go out on banks A, B, C, respectively. The L-field should be zero (a full 8-bit operation) to ensure duplication of the two outputs.
4. A left-rotate of $0-7$ bits will correspond to R18-R1F as specified in the "Destination" field of instruction word.
5. ALU Descriptions:

XMIT:

- Input constants from the instruction word to specified destination. NZ flag is not updated when an XMIT is performed: however, NZ can be written to by an XMIT if R17 bit 1 is within the destination field.
ADD IMMEDIATE: - Instruction word data is ADDed to data specified by destination fied. The carry bit is set if a carry is generated at the MSB of the selected data field. NZ status bit is updated to reflect the value of "L" bits of data after the addition.
AND IMMEDIATE: - Instruction word data is ANDed to data specified by source field. Returning the destination data to RF allows the operation to be performed without destroying the original data field. This will facilitate testing of data for certain pre-defined values while still preserving the original data for other uses. NZ status bit updated accordingly. Unspecified bits in RF remain unchanged.
XOR IMMEDIATE: - Same as AND IMMEDIATE, except the logical operation performed is Exclusive-OR.

6. Note that the stack operation is show before the PC in the CALL and INTERRUPT formats. This is because the stack is actually in operation in cycle 3, and the PC is updated in cycle 4 (see Figure 1). In fact, for the Call (JSR) instruction and interrupt servicing, cycle order is important for the user to understand the current status of the PC. The other instructions are in reverse order for visual simplicity in keeping with block diagram flow, and cycle order is irrelevant.


- The RESET VECTOR, LOCATED AT ADDRESS 0, WHLL BE AN UNCONDITIONAL JUMP TO THE BEGINNING OF THE MAIN PROGRAM.
- THE NON-MASKABLE INTERRUPT (NWI) VECTOR, LOCATED AT ADDRESS 1 , IS A JUMP TO THE NMI SERVSERVICE ROUTINE.
- located at address 2 IS The routine that SERVICES INTERRUPT (INT) CALLS.

Figure 2. Typical $\mathbf{8 \times 4 0 1}$ System Memory Map

## Thermal Junction Temperature vs Airflow

The ceramic package used for the $8 \times 401$ has no heat sink and a $\theta_{\mathrm{ja}}$ rating of $30.5^{\circ} \mathrm{C} / \mathrm{W}$ in still air. Currently, to ensure operation at 150 ns , the junction temperature of the devices must be kept below $115^{\circ} \mathrm{C}$. The maximum power dissipation at that junction temperature will be 2.4 W so that airflow will be required for full commercial range operation. The $\theta_{\mathrm{ja}}$ versus Airflow curve is drawn here:


DC ELECTRICAL CHARACTERISTICS Commercial Part $4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}^{1}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.75 | 5.0 | 5.25 | V |  |
| $\mathrm{V}_{\mathrm{iH}}$ | High level input voltage |  | 2.0 |  |  | V |  |
| $\mathrm{V}_{\text {LI }}$ | Low level input voltage |  |  |  | 0.8 | V |  |
| VOH | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{IOH}=-3 \mathrm{~mA}$ | 2.4 |  |  | V | $\overline{\mathrm{DAO}}$ through $\overline{\mathrm{DA}}, \mathrm{MCLK}$, $S C, W C, A B, B B, C B$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  |  | V | All others |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 | V | $\overline{\text { DAO }}$ through $\overline{\mathrm{DAT}}, \mathrm{MCLK}$, RWC, SC, WC, $\bar{A}, \bar{B}, \bar{C}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V | A0 through A12, PS, NZ, CY, IR |
| $\mathrm{V}_{\text {IC }}$ | Input clamp voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{N}}=-10 \mathrm{~mA}$ |  |  | -1.5 | V |  |
| $\mathrm{I}_{\mathrm{H}}$ | High level input current | $\mathrm{V}_{\mathrm{CC}}=$ Max, $\mathrm{V}_{1}=2.7$ |  |  | 20 | $\mu \mathrm{A}$ |  |
| ILL | Low level input current | $\mathrm{V}_{\text {CC }}=$ Max, $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -400 | $\mu \mathrm{A}$ |  |
| lozh | Off-state output current, high level voltage applied | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ | $\overline{\text { DAO }}$ through $\overline{\mathrm{DA}}$ |
| lozl | Off-state output current low level voltage applied | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -400 | $\mu \mathrm{A}$ | $\overline{\text { DAO }}$ through $\overline{\text { DA7 }}$ |
| los | Short circuit output current $^{2}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | -30 |  | -140 | mA |  |
| Icc | Supply Current | $V_{C C}=$ Max |  |  | 500 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$; Cold start $^{3}$ |
|  |  |  |  |  | 430 | mA | $\mathrm{T}_{J}=115^{\circ} \mathrm{C}$ |

NOTES:

1. 64 Pin CDIP, Airflow required for full Commercial operation. (A plastic 64 Pin DIP with internal heat sink is currently under development which will not have this requirement.) See above for thermal characteristics.
2. Not more than one output should be tested at a time.
3. Guaranteed by Correlation to $I_{C C}$ measured at $25^{\circ} \mathrm{C}$.

AC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V}+5 \%, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 70^{\circ} \mathrm{C}\right)^{1}$

| SYMBOL | PARAMETER | 150ns CYCLE |  |  | > 150ns CYCLE |  |  | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| $t_{\text {PC }}$ | Processor cycle time | 150 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CP}}$ | Clock pulse period | 37.5 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock pulse high time | 15 |  |  |  |  |  | ns | See Note 2 |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock pulse low time | 15 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{MCL}}$ | CP1 to MCLK low |  |  | 30 |  |  |  | ns | See Note 2 |
| $\mathrm{t}_{\mathrm{MCH}}$ | CP4 to MCLK high |  |  | 40 |  |  |  | ns |  |
| $t_{W}$ | MCLK pulse width | 25 | 31 | 38 | T4Q-12 |  | T4Q | ns |  |
| $\mathrm{t}_{\text {RWCL }}$ | CP1 to RWC low |  | 34 | 40 |  |  |  | ns |  |
| $t_{\text {RWCH }}$ | CP3 to RWC high |  |  | 40 |  |  |  | ns |  |
| $t_{\text {RWCW }}$ | RWC pulse width | 65 | 75 | 80 | $\begin{gathered} \mathrm{T} 3 \mathrm{Q}+\mathrm{T} 4 \mathrm{Q} \\ -10 \end{gathered}$ |  | $\begin{array}{\|c\|} \hline T 3 Q+T 4 Q \\ +5 \\ \hline \end{array}$ | ns |  |
| $\mathrm{t}_{\text {AS }}$ | CP2 to address stable |  |  | 52 |  |  |  | ns |  |
| $t_{\text {MAS }}$ | MCLK to address stable |  |  | 62 |  |  | T1Q + 24 | ns |  |
| $t_{\text {IS }}$ | Instruction setup to CP1 | 0 |  |  |  |  |  | ns | See Note 3 |
| $\mathrm{t}_{\text {MIS }}$ | Instruction setup to MCLK | 25 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{H}}$ | Instruction hold from CP2 | 20 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{MIH}}$ | Instruction hold from MLCK | 25 |  |  | T1Q-12 |  |  | ns |  |
| $\mathrm{tsCH}^{\text {S }}$ | CP3 to SC rising edge |  |  | 45 |  |  |  | ns |  |
| $t_{\text {MSCH }}$ | MCLK to SC rising edge |  |  | 95 |  |  | $\begin{gathered} \hline T 1 Q+T 2 Q \\ +20 \end{gathered}$ | ns |  |
| $\mathrm{t}_{\mathrm{WCH}}$ | CP3 to WC rising edge |  |  | 55 |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{MWCH}}$ | MCLK to WC rising edge |  |  | 105 |  |  | $\left\|\begin{array}{c} T 1 Q+T 2 Q \\ +20 \end{array}\right\|$ | ns |  |
| $t_{W L}$ | CP1 to SC/WC falling edge |  |  | 35 |  |  |  | ns | See Note 4 |
| $t_{\text {MWL }}$ | MCLK to SC/WC falling edge | 0 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {IBSL }}$ | CP1 to input phase bank signal falling edge |  |  | 60 |  |  |  | ns |  |
| $\mathrm{t}_{\text {MIBSL }}$ | MCLK to input phase bank signal falling edge |  |  | 33 |  |  |  | ns |  |
| tIBSH | CP3 to input phase bank signal rising edge |  |  | 45 |  |  |  | ns |  |
| $t_{\text {MIBSH }}$ | MCLK to input phase bank signal rising edge |  |  | 95 |  |  | $\begin{array}{c\|} \hline T 1 Q+T 2 Q \\ +20 \\ \hline \end{array}$ | ns |  |
| $t_{\text {OBSL }}$ | CP3 to output phase bank signal falling edge |  |  | 53 |  |  |  | ns |  |
| $t_{\text {MOBSL }}$ | MCLK to output phase bank signal falling edge |  |  | 105 |  |  | $\begin{gathered} \mathrm{T} 1 \mathrm{Q}+\mathrm{T} 2 \mathrm{Q} \\ +30 \end{gathered}$ | ns |  |
| $t_{\text {OBSH }}$ | CP1 to output phase bank signal rising edge |  |  | 46 |  |  |  | ns |  |
| $\mathrm{t}_{\text {MOBSH }}$ | MCLK to output phase bank signal rising edge | 0 |  | 20 |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{IDS}}$ | Input data setup to CP3 | -3 |  |  |  |  |  | ns |  |
| $t_{\text {MIDS }}$ | Input data setup to MCLK | -50 |  |  | $\begin{gathered} 25-\mathrm{T} 1 \mathrm{Q} \\ -\mathrm{T} 2 \mathrm{Q} \end{gathered}$ |  |  | ns |  |
| $\mathrm{tI}_{\text {IDH }}$ | Input data hold from CP3 | 28 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {MIDH }}$ | Input data hold from MCLK | 78 |  |  | $\begin{gathered} \mathrm{T} 1 \mathrm{Q}+\mathrm{T} 2 \mathrm{Q} \\ +3 \end{gathered}$ |  |  | ns |  |
| $\mathrm{t}_{\mathrm{ODH}}$ | Output data hold from CP1 | 35 |  | 55 |  |  |  | ns |  |
| $\mathrm{t}_{\text {MODH }}$ | Output data hold from MCLK | 10 |  | 25 |  |  |  | ns |  |

AC ELECTRICAL CHARACTERISTICS (CONTINUED) $\left(V_{C C}=5 \mathrm{~V}+5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}\right)^{1}$

| SYMBOL | PARAMETER | 150ns CYCLE |  |  | > 150ns CYCLE |  |  | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| tods | CP3 to output data stable |  |  | 70 |  |  |  | ns |  |
| $\mathrm{t}_{\text {MODS }}$ | MCLK to output data stable |  |  | 120 |  |  | $\begin{gathered} T 1 Q+T 2 Q \\ +45 \end{gathered}$ | ns |  |
| $t_{\text {d }}$ | SC/WC rising edge to output driver turn on | 18 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{HS}}$ | Halt setup to CP2 | 0 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {MHS }}$ | Halt setup to MCLK | -10 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{HH}}$ | 'Halt hold from CP2 | 50 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {MHH }}$ | Halt hoid from MCLK | 60 |  |  | T1Q + 22 |  |  | ns |  |
| $\mathrm{t}_{\text {SIS }}$ | Status input setup to CP1 | 10 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {MSIS }}$ | Status input setup to MCLK | 40 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {SIH }}$ | Status input hold from CP1 | 20 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {MSIH }}$ | Status input hold from MCLK | 0 |  |  |  |  |  | ns |  |
| tsCRS | SCR setup to CP1 | 0 |  |  |  |  |  | ns |  |
| $t_{\text {MSCRS }}$ | SCR setup to MCLK | 25 |  |  |  |  |  | ns |  |
| tsCRH | SCR hold from CP2 (Slow CP2) | 20 |  |  |  |  |  | ns | See Diagram for CP2 |
| TMSCRH | SCR hold from MCLK | 63 |  |  | ST1Q-12 |  |  | ns | Slow T1Q |
| $t_{\text {INTS }}$ | INT setup to CP1 | 10 |  |  |  |  |  | ns |  |
| IMINTS | INT setup to MCLK | 40 |  |  |  |  |  | ns |  |
| $\mathrm{t}_{\text {INTH }}$ | INT hold from CP1 | 10 |  |  |  |  |  | ns |  |
| tMINTH | INT hold from MCLK | -10 |  |  |  |  |  | ns |  |
| ${ }^{\text {tcru }}$ | CP4 to CY update |  |  | 60 |  |  |  | ns |  |
| imcyu | MCLK to CY update |  |  | -10 |  |  | 28-T4Q | ns |  |
| tnzu | CP4 to NZ update |  |  | 60 |  |  |  | ns |  |
| $t_{\text {MNZU }}$ | MCLK to NZ update |  |  | -5 |  |  | $33-T 4 Q$ | ns |  |
| trau | CP4 to IR update |  |  | 75 |  |  |  | ns |  |
| $t_{\text {MIRU }}$ | MCLK to IR update |  |  | 20 |  |  | $58-\mathrm{T} 4 \mathrm{Q}$ | ns |  |
| tpsu | CP4 to PS update |  |  | 60 |  |  |  | ns |  |
| ${ }_{\text {IMPSU }}$ | MCLK to PS update |  |  | -10 |  |  | 28-T4Q | ns |  |
| $t_{A C C}$ | Program memory access time (address stable to valid instruction) |  |  | 60 |  | $\begin{array}{r} T 2 Q+T 3 Q \\ +T 4 Q-52 \end{array}$ |  |  | ns |
| 40 | I/O port output enable time (bank signal to valid data on bus) |  |  | 24 |  |  | $\begin{gathered} \hline \mathrm{T} 1 \mathrm{Q}+\mathrm{T} 2 \mathrm{Q} \\ -51 \\ \hline \end{gathered}$ | ns |  |
| tpw | Reset pulse width | 150 |  |  | $t_{\text {PC }}$ |  |  | ns |  |
| $t_{\text {NMIW }}$ | NMI puise width | 50 |  |  |  |  |  | ns |  |
| $t_{\text {NMIS }}$ | NM1 setup to CP2 | 15 |  |  |  |  |  | ns | See Note 5 |
| $t_{\text {MNMIS }}$ | NMI setup to MCLK | 10 |  |  |  |  |  | ns | See Note 5 |

## NOTES:

1. Inputs swing between $O V$ and $3 V$. All outputs are measured at 1.5 V with loading as specified in the test circuits.
2. CP1, CP2, CP3, and CP4 refer to the clock pulse that causes the first, second, third, and fourth $8 \times 401$ quarter cycles, respectively. Parameters referenced to MCLK, CP1, CP2, CP3, and CP4 are measured to the falling edge of those signals. T1Q, T2Q, T3Q, and T4Q represent time intervals for the first, second, third, and fourth $8 \times 401$ quarter cycles, respectively. Duty cycle can be from $40 \%$ to $60 \%$.
3. Instructions must be setup before CP1.
4. $\mathrm{t}_{\text {WLL }}$ represents $\mathrm{t}_{\mathrm{SCL}}$ and $\mathrm{t}_{\text {WCL }}$. $\mathrm{t}_{\text {MWL }}$ represents $\mathrm{t}_{\text {MSCL }}$ and $\mathrm{t}_{\text {MWCL }}$
5. This guarantees NMI is serviced in the current cycle.

## TEST CIRCUIT



## MAIN TIMING DIAGRAM



## Microcontroller

TIMING SUPPLEMENT: STATUS


TIMING SUPPLEMENT: RESET


## Microcontroller

TIMING SUPPLEMENT: $\overline{\text { HALT }}$


TIMING SUPPLEMENT: $\overline{\text { INT }}$


## Microcontroller

TIMING SUPPLEMENT: $\overline{\text { NMI }}$


TIMING SUPPLEMENT: $\overline{\text { SCR }}$


## Signetics

## Microprocessor Products

## DESCRIPTION

The 8 X450 is a 256 -byte RAM designed primarily as a working storage element for $8 \times 305$ based systems. The $8 \times 450$ can be used as a dedicated RAM or in groups of RAMs to form a customized memory stack.

FEATURES

- 256-byte RAM
- Two modes of operation
- Paged RAM capability
- On-chip address latches
- Directly bus compatible with the 8X305 microcontroller
- 24-pin slim line package
- Single +5-volt supply

ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 24-Pin Ceramic DIP 400 Mil Wide | N8×4501 |

PIN CONFIGURATION


## 8X450 BLOCK DIAGRAM



## FUNCTIONAL OPERATION

The $8 \times 450$ can be used in either of two operating modes - conventional DA select or fast select. Each mode supports either single or multiple RAM applications. The mode of operation is selected by the MS pin.
Conventional $\overline{D A}$ Select ( $M S=1$ ) When MS is tied high, the conventional $\overline{D A}$ addressing mode is selected; in this mode, the $8 \times 450$ data and address lines are tied together. For applications that use a single RAM, the chip select ( $\overline{\mathrm{CS}}$ ) input is grounded. To prevent bus contention in applications that use multiple RAMs, the $\overline{\mathrm{CS}}$ input is driven by an external source. Examples of both configurations (single and multiple RAMs) are shown in the Application Diagrams at the rear of this data sheet. Control signals and operating conditions for conventional $\overline{\mathrm{DA}}$ addressing are summarized in Table 1.

Fast Select Operations ( $\mathbf{M S}=\mathbf{0}$ ) When MS is tied low, the fast select addressing mode is invoked; in this mode, the 8X450 address lines are driven by an external source and the $8 \times 450$ data lines are tied to the $8 \times 305 \overline{\mathrm{~V}}$ bus. The $\overline{\mathrm{CS}}$ input is treated exactly the same as in conventional $\overline{\mathrm{DA}}$ addressing; examples of single and multiple RAM configurations are shown at the rear of this data sheet. Control signals and operating conditions for fast select addressing are summarized in Table 2.

## PIN CONFIGURATION AND DECRIPTIONS

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :--- |
| $1-8$ | D7 - D0 | Bidirectional data bus, D0 is LSB |
| 9 | $\overline{\mathrm{CS}}$ | Chip Select, active low |
| 10 | $\overline{\text { ME }}$ | Master Enable, active low |
| 11 | WC | Write Control, active high |
| 12 | GND | Ground |
| 13 | SC | Select Control, active high |
| 14 | MS | Mode Select |
| 15 | MCLK | Master Clock, active high |
| $16-23$ | AO-A7 | Address lines, A0 is LSB |
| 24 | V $_{\text {CC }}$ | Power supply |

Table 1. Conventional $\overline{\mathrm{DA}}$ Select ( $M S=1$ )

| SC | WC | $\overline{\text { ME }}$ | MCLK | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | Read from RAM |
| 0 | 0 | 1 | $X$ | None |
| 0 | 1 | 0 | 1 | Write data to RAM |
| 0 | 1 | 1 | 1 | None |
| 1 | 0 | 0 | 1 | Conventional $\overline{\mathrm{DA}}$ select (write address to RAM) |
| 1 | 0 | 1 | 1 | None |

NOTES:

1. Other states are not generated by the $8 \times 305$ and are not defined for operation in this mode. 2. Table 1 is valid only if the chip select ( $\overline{\mathrm{CS}}$ ) is low; if $\overline{\mathrm{CS}}$ is high, the $8 \times 450$ is disabled.

Table 2. Fast Select ( $M S=0$ )

| SC | WC | $\overline{\text { ME }}$ | MCLK | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | Read from RAM |
| 0 | 0 | 1 | 0 | None |
| $X$ | $X$ | 1 | 1 | Write address to RAM |
| 0 | 1 | 0 | 1 | Write data to RAM |

NOTES:

1. Other states are not generated by the $8 \times 305$ and are not defined for operation in this mode. 2. Table 2 is valid only if the chip select $(\overline{\mathrm{CS}})$ is low. If $\overline{\mathrm{CS}}$ is high, the $8 \times 450$ is disabled.

## RAM

SINGLE RAM CONFIGURATION (CONVENTIONAL $\overline{\mathrm{DA}}$ SELECT)


MULTIPLE RAM CONFIGURATION (CONVENTIONAL $\overline{\mathrm{DA}}$ SELECT)


SINGLE RAM CONFIGURATION (FAST SELECT)


MULTIPLE RAM CONFIGURATION (FAST SELECT)


RAM

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL | PARAMETER | RATING | UNIT |
| :--- | :--- | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Power supply voltage | +7 | $\mathrm{~V}_{\mathrm{DC}}$ |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage | +5.5 | $\mathrm{~V}_{\mathrm{DC}}$ |
| $\mathrm{V}_{\mathrm{O}}$ | Output off-state voltage | +5.5 | $\mathrm{~V}_{\mathrm{DC}}$ |
| $\mathrm{T}_{\text {STG }}$ | Storage temperature range | -65 tc +150 | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS ( $\left.\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}+5 \%, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 70^{\circ} \mathrm{C}\right)$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{C C}$ | Supply voltage |  | 4.75 | 5.00 | 5.25 | V |
| $\mathrm{V}_{\text {IL }}$ | Low level input voltage |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High level input voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage | $V_{C C}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.7 |  |  | V |
| V IC | Input clamp voltage | $V_{C C}=\operatorname{Min}, \mathrm{l}_{1} \mathrm{~N}=-10 \mathrm{~mA}$ |  |  | -1.5 | V |
| IIL | Low level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.4 | mA |
| $\mathrm{I}_{\mathrm{H}}$ | High level input current | $V_{C C}=$ Max, $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| lozl | High-Z output current (Low Level) | $\mathrm{V}_{\mathrm{CC}}=$ Max, $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -0.4 | mA |
| IOZH | High-Z output current (High Level) | $V_{C C}=$ Max, $V_{O}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| los | Short circuit output current | $V_{C C}=M a x+0.5, V_{O}=0.5 \mathrm{~V}$ | -30 |  | -140 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |  |  | 220 | mA |

## NOTE:

*Not more than one output should be tested at a time.

AC ELECTRICAL CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}+5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$ )

| SYMBOL | PARAMETER | REFERENCES |  | TEST CONDITIONS | LIMITS |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | From | To |  | Min | Max |  |
| Pulse Widths |  |  |  |  |  |  |  |
| twMC | MCLK pulse width | $\uparrow$ MCLK | $\downarrow$ MCLK |  | 35 |  | ns |
| Setup Times |  |  |  |  |  |  |  |
| $t_{\text {SCS }}$ | Setup time for $\overline{\mathrm{CS}}$ | $\downarrow \overline{\mathrm{CS}}$ | $\uparrow$ MCLK |  | 0 |  | ns |
| tssc | Setup time for SC | $\uparrow \mathrm{SC}$ | $\uparrow$ MCLK |  | 15 |  | ns |
| tswc | Setup time for WC | $\uparrow W C$ | $\uparrow$ MCLK |  | 15 |  | ns |
| tsME | Setup time for $\overline{\mathrm{ME}}$ | $\uparrow \overline{\mathrm{ME}}$ | $\uparrow$ MCLK |  | 0 |  | ns |
| ${ }_{\text {t }}^{\text {SAD }}$ | Setup time for address | A7-A0 | $\uparrow$ MCLK |  | 0 |  | ns |
| $t_{S D}$ | Setup time for data | $\overline{\mathrm{DA}}$ Bus Active | $\uparrow$ MCLK |  | 0 |  | ns |
| Hold Times |  |  |  |  |  |  |  |
| $\mathrm{thCS}^{3}$ | Hold time for $\overline{\mathrm{CS}}$ | $\downarrow$ MCLK | $\uparrow \overline{\mathrm{CS}}$ |  | 0 |  | ns |
| $\mathrm{t}_{\text {HSC }}$ | Hold time for SC | $\downarrow$ MCLK | $\downarrow$ SC |  | 0 |  | ns |
| $\mathrm{t}_{\text {HWC }}$ | Hold time for WC | $\downarrow$ MCLK | $\downarrow$ WC |  | 0 |  | ns |
| $t_{\text {HME }}$ | Hold time for $\overline{\mathrm{ME}}$ | $\downarrow$ MCLK | $\uparrow \overline{\mathrm{ME}}$ |  | 0 |  | ns |
| $t_{\text {HAD }}$ | Hold time for address | $\downarrow$ MCLK | A7-A0 |  | 10 |  | ns |
| $t_{\text {HD }}$ | Hold time for data | $\downarrow$ MCLK | $\overline{\mathrm{DA}}$ Bus Tri-Stated |  | 5 |  | ns |
| Enable Times |  |  |  |  |  |  |  |
| $t_{\text {ECS }}$ | Enable time for $\overline{\mathrm{CS}}$ | $\downarrow \overline{\mathrm{CS}}$ | $\overline{\mathrm{DA}}$ Bus Active | $\overline{M E}, \mathrm{SC}, \mathrm{WC}, \mathrm{MCLK}=$ Low |  | 30 | ns |
| $t_{\text {EME }}$ | Enable time for $\overline{\mathrm{ME}}$ | $\downarrow \overline{\mathrm{ME}}$ | $\overline{\mathrm{DA}}$ Bus Active | $\overline{\mathrm{CS}}, \mathrm{SC}, \mathrm{WC}, \mathrm{MCLK}=$ Low |  | 30 | ns |
| $t_{\text {ESC }}$ | Enable time for SC | $\downarrow$ SC | $\overline{\mathrm{DA}}$ Bus Active | $\overline{\mathrm{CS}}, \overline{\mathrm{ME}}, \mathrm{WC}, \mathrm{MCLK}=$ Low |  | 30 | ns |
| tewc | Enable time for WC | $\downarrow$ WC | $\overline{\mathrm{DA}}$ Bus Active | $\overline{\mathrm{CS}}, \overline{\mathrm{ME}}, \mathrm{SC}, \mathrm{MCLK}=$ Low |  | 30 | ns |
| Disable Times |  |  |  |  |  |  |  |
| tocs | Disable time for $\overline{\mathrm{CS}}$ | $\uparrow \overline{\mathrm{CS}}$ | $\overline{D A}$ Bus Tri-Stated | $\overline{M E}, \mathrm{SC}, \mathrm{WC}, \mathrm{MCLK}=$ Low |  | 40 | ns |
| t DME | Disable time for $\overline{\mathrm{ME}}$ | $\uparrow \overline{\mathrm{ME}}$ | $\overline{\text { DA }}$ Bus Tri-Stated | $\overline{\mathrm{CS}}, \mathrm{SC}, \mathrm{WC}, \mathrm{MCLK}$ = Low |  | 40 | ns |
| $t_{\text {DSC }}$ | Disable time for SC | $\uparrow$ SC | $\overline{\mathrm{DA}}$ Bus Tri-Stated | $\overline{\mathrm{CS}}, \overline{\mathrm{ME}}, \mathrm{WC}, \mathrm{MCLK}=$ Low |  | 40 | ns |
| $t_{\text {DWC }}$ | Disable time for WC | $\uparrow$ WC | $\overline{\mathrm{DA}}$ Bus Tri-Stated | $\overline{\mathrm{CS}}, \overline{\mathrm{ME}}, \mathrm{SC}, \mathrm{MCLK}=$ Low |  | 40 | ns |

## NOTES:

1. All inputs swing between OV and 3 V .
2. All outputs are measured at 1.5 V with loading specified in TEST CIRCUIT.
3. $\overline{C S}$ must be active for at least one complete $8 \times 305$ instruction cycle.

## 8X450 TIMING



ENABLE AND DISABLE TIMING DIAGRAM


## TEST CIRCUIT



## Signetics

8X470 I/O Port

## Product Specification

## Microprocessor Products

## DESCRIPTION

The $8 \times 470$ 1/O Port (Figure 1) is a fuseprogrammable device designed to interface a user system with a Signetics 8X401 Microcontroller. The 8X470 has three internal registers - a data register and two status registers. The data register is shared between the two systems, while each system has its own dedicated status register. The 8X470 can be programmed to provide a bidirectional or unidirectional user interface with the user data entry being either synchronous or asynchronous with the 8X401.

FEATURES

- Two independent 8-bit busses
- Fast polling
- Directly bus-compatible with the 8X401, 8X305 Microcontrollers
- 256 Data Addresses
- Separate Controller and User status registers
- 16 Status Addresses
- Positionable Controller Status Register output
- Bidirectional or unidirectional I/O capability
- Synchronous or asynchronous user data entry
- Conventional $\overline{D A}$ or Fast select addressing techniques
- 24-pin slimline package
- Single +5 V supply


## PIN CONFIGURATION




Figure 1. 8X470 Block Diagram

PIN DESCRIPTION

| PIN | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 1-8 | UDO - UD7 | User port data lines. Active high. |
| 9 | $\overline{\mathrm{OC}}$ | Output Control: An active low signal which controls reading into the I/O port from the UD bus. |
| 10 | $\overline{\text { İ }}$ | Input Control: An active low signal which controls writing into the I/O port from the UD bus. |
| 11 | $\overline{M E}$ | Master Enable: The $\overline{M E}$ pin depends upon the addressing mode for its function. <br> Conventional $\overline{D A}$ select: $\overline{M E}$ is an active low signal which allows read or write or address operations from the $\overline{D A}$ bus. <br> Fast select: $\overline{M E}$ is an active high signal which allows the controller status register to be read on the $\overline{\mathrm{DA}}$ bus. |
| 12 | GND | Ground. |
| 13 | MCLK | Master Clock: Input from the 8X401. |
| 14 | SC | Select Command: The SC pin depends upon the addressing mode for its function. <br> Conventional $\overline{\mathrm{DA}}$ select: An active high signal which compares the $8 \times 401 \overline{\mathrm{DA}}$ bus and the address. <br> An address match selects the $8 \times 470$. <br> Fast select: SC is an active high signal which outputs the contents of the data register on the $\overline{\mathrm{DA}}$ bus while clearing the control status register. |
| 15 | WC | Write Command: An active high signal which controls the writing of data into the I/O port from the 8X401 $\overline{D A}$ bus. |
| 16-23 | $\overline{\text { DA7 }-\overline{D A O}}$ | Controller Data/Address ( $\overline{\mathrm{DA}}$ ) lines. Active low. |
| 24 | $\mathrm{V}_{\mathrm{CC}}$ | +5V power supply. |

In a typical system configuration (Figure 2), the $8 \times 470$ connects to the $8 \times 401$ Microcontroller via the Data/Address ( $\overline{\mathrm{DA}}$ ) bus; the $8 \times 470$ is linked to the user system via the User Data (UD) bus. To facilitate interbus communications and to implement handshaking operations, a dedicated status register is assigned to each bus. The status registers can be polled at full speed to optimize throughput and to prevent errors in data transmissions. The $8 \times 470$ can be addressed from the $\overline{D A}$ bus in either of two ways - by the conventional microcontroller software-select cycle or by fast select methods.

## $\overline{D A}$ BUS INTERFACE

The 8X470 interfaces to the 8X401 Microcontroller through an 8 -bit inverted three-state Data/Address ( $\overline{\mathrm{DA}}$ ) bus and four control signals (SC, WC, ME and MCLK). The status registers are accessible through the $\overline{\mathrm{DA}}$ bus
interface. For conventional select operation, both the data and controller status register addresses can be fuse programmed. Also, the controller status can be programmed to appear at any or all $\overline{\mathrm{DA}}$ bit locations. For time critical operations, the $8 \times 470$ can be fuse programmed for fast select operations.

## UD BUS INTERFACE

The $8 \times 470$ interfaces to a user system through an 8 -bit UD bus and two control signals ( $\overline{\mathrm{IC}}$ and $\overline{\mathrm{OC}}$ ). If the user and the $8 \times 401$ attempt to input data to the I/O port at the same time, the user will have priority. Both the data register and the user status register are accessible through the UD bus interface. The $8 \times 470$ UD interface can be fuse programmed for synchronous or asynchronous data entry.

## Data Entry

Data entry into the $8 \times 470$ from the user bus can be fuse programmed to be either synchronous or asynchronous. Synchronous data input to the data latches occurs when MCLK is high. Asynchronous data input is independent of MCLK. For further details, see the $\overline{\mathrm{IC}}$ fuse bank section.

## MODE A

The user data lines are bidirectional or input only. See the $\overline{\mathrm{IC}}$ and SC fuse bank sections for further details.

## MODE B

The user data lines are output or input only. See the $\overline{\mathrm{C}}$ and SC fuse bank sections for further details.

## STATUS REGISTERS

The $8 \times 470$ has two status registers; the User and Controller status registers. These registers can be used for handshaking between


Figure 2. Typical System Configuration
the $8 \times 401$ and the User Data Bus. A register is set by a write from one bus and cleared by reading the data register from the opposite bus.

## User Status Register

The User Status register is set by any write from the $\overline{\mathrm{DA}}$ bus and cleared by reading the data register from the UD bus. The user status register is available on UD7 only. The output of the user status is controlled by $\overline{\mathrm{IC}}$ and $\overline{O C}$ user port control lines. See the $\overline{I C}$ bank for further details.

## Controller Status Register

The Controller Status register is set by any write from the UD bus and cleared by reading the data register from the $\overline{D A}$ bus. The Controller Status register can be accessed by either a fast select or a conventional $\overline{D A}$ select. For conventional select methods, the controller status register address can be fuse programmed to be any one of the addresses $\mathrm{FO}-\mathrm{FF} \mathrm{F}_{16}$. The programming of this address is discussed in the $\overline{\mathrm{ME}}$ and $\overline{\mathrm{IC}}$ fuse bank sections. The Controller Status register can also be programmed to appear at any or all $\overline{\mathrm{DA}}$ bit locations, enhancing the polling process of multiple $8 \times 470$ I/O ports.

## POLLING

The Controller Status register address and output location can be fuse programmed to allow multiple $8 \times 470 \mathrm{I} / \mathrm{O}$ ports to be polled in a single cycle. The $8 \times 470$ 1/O ports to be polled are programmed with a common Controller Status address, with each status register output available on a different $\overline{\mathrm{DA}}$ line to prevent a bus contention. The $8 \times 401$ Microcontroller can poll a maximum of eight $8 \times 470$ I/O ports in a single cycle, obtaining up to eight bits of status information. The 8X401 Microcontroller's subfield manipulation capability can then be used to isolate a single $8 \times 470$ status bit, simplifying the polling procedure and improving the overall system throughput. Figure 3 shows a typical configuration of eight $8 \times 470 \mathrm{I} / \mathrm{O}$ ports polled in a single cycle.

## ADDRESSING MODES

The $8 \times 470$ can be addressed by a microcontroller through either Fast Select or Conventional $\overline{D A}$ select techniques.

## Conventional DA Select

The $8 \times 470$ must be preselected through a conventional $\overline{\mathrm{DA}}$ select cycle before either
the data or status registers can be accessed by a Microcontroller. During a conventional $\overline{\mathrm{DA}}$ select cycle, the $8 \times 470$ compares the address on the $\overline{\mathrm{DA}}$ bus to the data and status addresses. If either address matches the $\overline{\mathrm{DA}}$ address, the appropriate $8 \times 470$ latch is set, enabling the port for a data transfer or a polling cycle. Table 1 shows the conventional select operation of the $8 \times 470 \overline{\mathrm{DA}}$ interface.

## Fast Select

A fast select cycle is ideal for time critical applications which require port selection and data transfer in a single clock cycle. Additional bits in the 8X401 instruction word are used to execute a fast select cycle. It should be noted that the $8 \times 470 \mathrm{SC}$ input is not driven by the $8 \times 401$ SC output and could introduce a minor operational limitation. For an 1/O address select instruction, the 8X401 will output a $\overline{D A}$ address and assert SC. However, a fast select configured 8X470 will also drive the $\overline{D A}$ bus, and a bus contention will result. To avoid this contention, the $8 \times 470$ should not be fast selected during any I/O address select instruction. Figure 4 shows a typical fast select configuration. Table 2 shows the fast select operation of the $8 \times 470 \overline{\mathrm{DA}}$ bus interface operation.


Table 1. Conventional $\overline{\mathrm{DA}}$ Operation

| $\overline{\text { ME }}$ | sC | WC | MCLK | ADDRESS <br> LATCH | STATUS <br> LATCH | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| L | L | L | X | SET | CLEAR | Output data, clear CONTROLLER <br> STATUS |
| L** | L | H | H | SET | CLEAR | Input 8X401 data, set USER STATUS |
| L | H | L | H | X | X | Compare enable address |
| H | X | X | X | X | X | High impedance |
| L | L | L | X | CLEAR | SET | Output CONTROLLER STATUS |
| L | L | H | X | CLEAR | SET | High impedance |
| L | L | H | L | X | X | High impedance |
| L | H | L | L | SET | X | High impedance |
| L | L | L | X | CLEAR | CLEAR | High impedance |

## NOTE:

**If the user and the $8 \times 401$ attempt to input data to the I/O port at the same time, the user will overwrite the $8 \times 401$ (user priority).

Table 2. Fast Select Operation

| $\overline{M E}$ | SC | WC | MCLK | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| L | H | H | H | Input 8X401 data, set USER STATUS |
| L | H | L | X | Output data, clear CONTROLLER STATUS |
| H | L | L | X | Output CONTROLLER STATUS |
| H | H | X | X | Inactive |
| L | L | X | X | Inactive |

Table 3. 8X470 Fuse Mnemonics

| BANK | PROGRAMMABLE <br> FUSES | PROGRAMMED FUNCTION |
| :---: | :---: | :--- |
| SC | UD0 - UD7 | Input Only |
| WC | UD0 - UD7 | Controller Data Address (CDAO - CDA7) |
| $\overline{\mathrm{ME}}$ | UD0 - UD7 | Controller Status Location (CSL0 - CLS7) |
| $\overline{\mathrm{IC}}$ | UD0 - UD3 | Controller Status Address (CSAO - CSA3) |
| $\overline{\mathrm{IC}}$ | UD4 | Fast Select |
| $\overline{\mathrm{IC}}$ | UD5 | Bidirectional Disable |
| $\overline{\mathrm{IC}}$ | UD6 | Asynchronous Input |

## Fuses

The $8 \times 470$ has four programmable fuse banks, namely the SC, WC, ME and $\overline{\mathrm{C}}$ banks. Each bank is selected by its namesake pin, i.e. the SC pin selects the SC fuse bank, the WC pin selects the WC fuse bank, etc. Each bank has eight fuses, except the IC bank, which only has seven. These fuse banks govern different modes of operation, and by selecting the appropriate fuse and fuse bank, the $8 \times 470$ can be configured for the modes of operation as mentioned earlier. (See Figure 5 for an illustration of the fuse banks.) The mnemonics for the fuses are listed in Table 3.


Figure 5. Fuse Bank Summary

## IC BANK

## CSAO - CSA3

The first four fuses of the $\overline{\mathrm{IC}}$ bank (UDO-UD3) program the four least significant bits of the Controller Status address (CSAO-3). The four most significant bits of the Controller Status address are always a 1. An unprogrammed (unblown) CSA fuse is a logic 1 from the $\overline{D A}$ bus, and a programmed (blown) CSA fuse is a logic 0 from the $\overline{D A}$ bus. The Controller Status register can be assigned any one of the addresses FO-FF ( $00-0 \mathrm{~F}$ on the $\overline{\mathrm{DA}}$ bus). In an unprogrammed part, the status register will be assigned address FO.


Figure 4. Typical Fast Select Configuration

## Fast Select Fuse

The Fast select fuse programs the addressing mode; i.e., Fast or Conventional $\overline{\mathrm{DA}}$ select. In an unprogrammed part, Conventional $\overline{D A}$ select is selected.

## Bidirectional Disable Fuse

The bidirectional disable fuse selects either Mode A or Mode B operation. In an unpro grammed part, Mode A is selected. Modes A and $B$ are defined more fully in the SC fuse bank.

## Asynchronous Input Fuse

The asynchronous input fuse selects the user data entry mode; synchronous or asynchronous. In an unprogrammed part, data is entered synchronously with MCLK.

See Table 4 for a summary of the $\overline{\mathrm{C}}$ bank.

## SC Bank

The SC bank has two possible configurations, Mode A and Mode B, as selected by the bidirectional disable fuse. Mode $A$ allows bidirectional and input only UD ports; Mode B allows output only and input only UD ports. Input only UD ports are output only from the $\overline{\mathrm{DA}}$ bus, all other types of UD ports (bidirectional and output only) are bidirectional from the $\overline{\mathrm{DA}}$ bus at the same bit location. (See Figure 6.)

## Mode A

Mode A is selected when the bidirectional disable fuse is unblown, configuring the unprogrammed SC bank for bidirectional operations. (See Table 5.) The user would then blow the needed input only fuses to disable the bidirectional capability of that UD line, making it input only. This line is input only from the UD bus and output oniy from the $\overline{D A}$ bus. (See Example 1.) Table 6 gives the Mode A operation of the $8 \times 470$ user interface.

Table 5. Mode A Bus Operation

| INPUT ONLY <br> FUSE <br> ''N'' | UD ''N'' | $\overline{\text { DA }}$ 'N'' |
| :---: | :---: | :---: |
| Unblown | B | B |
| Blown | 1 | O |

1 = input only
$\mathrm{O}=$ Output only
$B=$ Bidirectional

Table 4. $\overline{\mathrm{IC}}$ Fuse Bank Summary

| UD PIN | FUNCTION | UNBLOWN FUSE | BLOWN FUSE |
| :---: | :--- | :--- | :--- |
| UD0 - UD3 | Controller Status <br> Address | Logic 1 from the $\overline{\mathrm{DA}}$ <br> bus | Logic 0 from the $\overline{\mathrm{DA}}$ <br> bus |
| UD4 | Addressing mode | Conventional $\overline{\text { DA }}$ Select | Fast Select |
| UD5 | Bidirectional disable | Mode A | Mode B |
| UD6 | Data entry | Synchronous | Asynchronous |



Example 1. Mode A Unprogrammed and Programmed Configurations


Table 6. Mode A Operation (See Note)

| BIDIRECTIONAL |  |  | INPUT ONLY |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O C}$ | $\overline{\text { IC }}$ | Function | $\overline{\text { OC }}$ | $\overline{\mathrm{I}}$ | Function |
| L | L | High impedance | L | L | High impedance |
| L | H | Output data, clear user status | L | H | High impedance ( $\mathrm{UD7} 7=\mathrm{V}_{\mathrm{OH}}$ ) |
| H | L | Input user data, set controller status | H | L. | Input user data, set controller status |
| H | H | High impedance (UD7 = User Status) | H | H | High impedance (UD7 = User Status) |

NOTE:
This table should only be used if the bidirectional fuse is unblown. For UD lines where the input only fuse is blown, use the input only side; else use the bidirectional side.

Mode B
Mode B is selected when bidirectional disable fuse is blown, configuring the unprogrammed SC bank for output only operation from the UD bus. (See Table 7.) The user would then blow the needed input only fuses to disable the output only capability of that UD line, making it input only. The line is input only from the UD bus and output only from the $\overline{D A}$ bus. (See Example 2). Table 8 gives the Mode B operation of the 8X470 user interface.
Table 7. Mode B Bus Operation

| INPUT ONLY <br> FUSE <br> ''N'' | UD 'N'" | $\overline{\text { DA }}$ 'N' ${ }^{\prime}$ |
| :---: | :---: | :---: |
| Unblown | O | B |
| Blown | 1 | O |

$1=$ input only
$\mathrm{O}=$ Output only
$B=$ Bidirectional

## WC Bank

The WC fuses (CDAO-CDA7) are used to program the Data Address for Conventional $\overline{D A}$ select operations. An unprogrammed WC fuse requires a logic 1 at its $\overline{D A}$ bit location to produce an address match. A blown fuse requires a logic 0 at its $\overline{D A}$ bit location to produce an address match. The user can then program the data address to be any one of the addresses $00-F F$. An unprogrammed $8 \times 470$ recognizes a $\overline{D A}$ address of FF (00 within the $8 \times 401$ ) as a data address match. See Example 3.

## Example 3. Controller Data Register Address



DF06160S

## $\overline{\text { ME }}$

The $\overline{M E}$ fuse (CSLO-CSL7) bank positions the output of the Controller Status bit at any unblown UD fuse at the same bit location on the $\overline{D A}$ side. In an unprogrammed part, the Controller Status output will appear on all eight $\overline{D A}$ lines. See Example 4.

## PROGRAMMING

Flowchart 1 summarizes the $8 \times 470$ programmable features by their function and program-

## Example 2. Mode B Unprogrammed and Programmed Configurations



Table 8. Mode B Operation (See Note)

| OUTPUT ONLY |  |  | INPUT ONLY |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O C}$ | $\overline{\text { IC }}$ | Function | $\overline{O C}$ | $\overline{\text { IC }}$ | Function |
| L | L | Output data, clear User Status | L | L | Input user data, set Controller Status |
| L | H | Output data, clear User Status | L | H | High impedance (UD7 $=\mathrm{V}_{\mathrm{OH}}$ ) |
| H | L | High impedance ( ${ }^{\text {UD7 }}=\mathrm{V}_{\mathrm{OH}}$ ) | H | L | Input user data, set Controller Status |
| H | H | High impedance (UD7 = User Status) | H | H | High impedance (UD7 = User Status) |

NOTE:
Table 7 should only be used if the bidirectional fuse has been blown. For UD lines where the input only fuse is blown, use the input only side; else use the output only side.

## Example 4. Controller Status Output Location


DF06170S
ming configuration. Flowchart 1 can be used before programming as a guide for mapping the fuses that need to be blown, to configure an $8 \times 470$ I/O port for a particular configuration. After the features have been mapped, the programming procedure can begin. Each bank is programmed in a similar manner, with one exception, the $\overline{\mathrm{IC}}$ fuse bank. The $\overline{\mathrm{IC}}$ fuse bank has two added considerations; when being programmed, any input to UD7 should be removed, and the fuse at UD7 should not be programmed. Fuses can be verified when all programming as been completed or just after a fuse has been programmed. During verification, a blown fuse acts as a high impedance and an unblown fuse acts as a VOL.

Thus, programming the $8 \times 470$ I/O port can be broken down into three stages:
(1) Pre-Programming
a. Decide what features the $8 \times 470$ is to have.
b. Use Flowchart 1 to determine which fuses need to be blown.
c. Map the fuses to be blown onto a diagram, like the one shown below, by darkening the squares where fuses are to be blown.
(2) Programming

Use 'map' to blow fuses using the programming procedure.
(3) Verify

Verify that the fuses blown correspond to the map, using the verification procedure.

For an example, see Programming Example.


DF06180S


## Programming Sequence

$v_{f}=10 \mathrm{~V}$

1) $V_{C C}=5 \mathrm{~V}, \overline{\mathrm{ME}}, \mathrm{SC}, \overline{\mathrm{IC}}=\mathrm{V}_{\mathrm{OL}}$ (initial conditions).
2) $\overline{\mathrm{C}}=\overline{\mathrm{OC}}=V_{O L}$.
3) $U D O-U D 7=V_{O L}$.
4) Raise WC to $V_{f}$ (programming data address).
5) Raise $V_{C C}$ to $V_{f}$.
6) Raise UD lines $0-7$ one at a time where a fuse is to be blown.
7) Lower $V_{C C}$ to 5 V .
8) Raise $\overline{O C}$ to $V_{f}$.
9) Verify blown fuses on UDO - UD7. These act as open collector outputs during verification. An intact fuse is indicated by a $V_{O L}$, a blown fuse by a high impedance.
10) Lower $\overline{O C}$ to $V_{\mathrm{OL}}$.
11) Lower WC to $V_{O L}$.
12) Raise $\overline{M E}$ to $V_{f}$ (programming status bit position).
13) Repeat steps 5 through 10 above.
14) Lower $\overline{M E}$ to $V_{O L}$.
15) Raise $S C$ to $V_{f}$ (programming data bit direction).
16) Repeat steps 5 through 10 above.
17) Lower SC to VoL-
18) Remove any input from UD7.
19) Raise $\overline{O C}$ to $V_{\mathrm{OH}}$.
20) Raise $\overline{\bar{C}}$ to $V_{f}$ (programming status address and miscellaneous functions).
21) Repeat steps 5 through 10 above, but do not raise UD7 in step 6.
22) Lower $\overline{\mathrm{IC}}$ to $V_{\mathrm{OL}}$.
23) Lower $\overline{\mathrm{OC}}$ to $\mathrm{V}_{\mathrm{OL}}$.
24) Remove power $\left(\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}\right)$.

## Programming Verification Sequence

## $V_{f}=10 \mathrm{~V}$

1) $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \overline{\mathrm{ME}}, \mathrm{SC}, \overline{\mathrm{C}}=\mathrm{V}_{\mathrm{OL}}$ (initial conditions).
2) $\overline{\mathrm{C}}=\overline{\mathrm{O}}=V_{\mathrm{OL}}$.
3) $U D O-U D 7=V_{O L}$.
4) Raise WC to $V_{f}$ (verifying data address).
5) Raise $\overline{O C}$ to $V_{f}$.
6) Verify blown fuses on UDO - UD7. These act as open collector outputs during verification. An intact fuse is indicated by a $V_{O L}$ and a blown fuse by a high impedance.
7) Lower $\overline{\mathrm{OC}}$ to $\mathrm{V}_{\mathrm{OL}}$.
8) Lower WC to $V_{O L}$.
9) Raise $\overline{M E}$ to $\mathrm{V}_{\mathrm{f}}$ (verifying status bit position).
10) Repeat steps 5 through 7 above.
11) Lower $\overline{M E}$ to $V_{\mathrm{OL}}$.
12) Raise $S C$ to $V_{f}$ (verifying bit direction).
13) Repeat steps 5 through 7 above.
14) Lower $S C$ to $V_{O L}$.
15) Raise $\overline{\bar{C}}$ to $V_{f}$ (veritying status address and miscellaneous functions).
16) Repeat steps 5 through 7 above.
17) Lower $\overline{\mathrm{C}}$ to $V_{\mathrm{OL}}$.
18) Remove power ( $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ ).

## Pre-programming Example

Stage 1—Pre-programming
(a) Features Desired

|  | Conventional $\overline{\text { DA }}$ <br> Addressing Mode: <br> select |
| :--- | :--- |
| Controller Data | 42 (within the |
| address: | $8 \times 401$ ) |
| Controller Status | FO (within the |
| address: | $8 \times 401$ ) |
| Controller Status | $\overline{\text { DAO, } \overline{\text { DA7 }}}$ |
| Output Location: |  |
| Mode of Operation: | A |
|  | UDO, UD2, UD4, |
| Input only UD lines: | UD6 |
| Data Entry: | Synchronous |

(b)The shaded areas of Flowchart 1 indicate the selections from pat ' $a$ ' which require a blown fuse.

(c) Map


## Programming Example - Stages 2 and 3

| INITIAL CONDITIONS ( $\mathbf{V}_{\mathbf{f}}=\mathbf{1 0 V}$ ) <br> 1. $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \overline{\mathrm{ME}}, \mathrm{SC}, \overline{\mathrm{C}}=\mathrm{V}_{\mathrm{OL}}$ (initial conditions). <br> 2. $\overline{\mathrm{C}}=\overline{\mathrm{OC}}=\mathrm{V}_{\mathrm{OL}}$. <br> 3. $\mathrm{UDO}-\mathrm{UD7}=\mathrm{V}_{\mathrm{OL}}$. | 8X470 CONFIGURATION AFTER PROGRAMMING SEQUENCE |
| :---: | :---: |
| DATA ADDRESS <br> 4. Raise $W C$ to $V_{f}$. <br> 5. Raise $V_{C C}$ to $V_{f}$. <br> 6. Raise UD1 to $\mathrm{V}_{\mathrm{OH}}$ to blow a fuse. Repeat of UD6. <br> 7. Lower $V_{C C}$ to 5 V . <br> 8. Raise $\overline{O C}$ to $V_{f}$. <br> 9. Verify that the fuses at UD1 and UD6 are blown. A blown fuse acts like a high impedance and an intact fuse acts like a $V_{O L}$. <br> 10. Lower $\overline{\mathrm{OC}}$ to $\mathrm{V}_{\mathrm{OL}}$. <br> 11. Lower WC to $\mathrm{V}_{\mathrm{OL}}$. |  |
| CONTROLLER OUTPUT LOCATION <br> 12. Raise $\overline{M E}$ to $V_{f}$. <br> 13. Repeat steps 5-10 above for UD1-UD6. <br> 14. Lower $\overline{M E}$ to $\mathrm{V}_{\mathrm{OL}}$. |  |
| DATA BIT DIRECTION <br> 15. Raise $S C$ to $V_{f}$. <br> 16. Repeat steps 5-10 above for UDO, UD2, UD4, UD6. <br> 17. Lower SC to $\mathrm{V}_{\mathrm{OL}}$. |  |

## I／O Port

Table 9．Programming Examples

| CONFIGURATION LSB MSB UD Bits： 01234567 |  | DATA ENTRY | ADDRESSING MODE | CONTROLIER STATUS POSITIOM | CONTROLLER STATUS ADDRESS （within the $8 \times 4011$ | CONTROLLER <br> DATA <br> ADUPESS <br> （within the $8 \times 401)$ | MODE <br> OF OPETS－ AT：ON |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Example 1 | UD：В В В В В В В В <br> $\overline{\mathrm{DA}}: \mathrm{B}$ В В В В В В В | Synchronous | Conventional $\overline{D A}$ Select | DAO－DA： | H0）（Hex） | （u）（Hex） | A |
| Example 2 | $\begin{array}{lllllllll}\text { UD：} & B & B & B & B & B & B & B & B \\ \overline{D A}: & B & B & B & B & B & B & B & B\end{array}$ | Synchronous | Fast Select | $\overline{\mathrm{DAO}}, \overline{\mathrm{DAF}}$ | x | X | A |
| Example 3 | $\begin{array}{l\|llllllll} U D: & \mid & B & \mid & B & \mid & B & \mid & B \\ \overline{D A} & O & B & O & B & O & R & O & B \end{array}$ | Synchronous | Fast Select | $\overline{\text { DAO }}$ ，$\overline{\text { DA }}$ | X | x | A |
| Example 4 | UD：OOOOOOOO <br> $\overline{D A}: B$ B B B B B B B | X | Conventional $\overline{D A}$ Select | $\overline{\text { DAO }}, \overline{\text { DA }}$ | F0（Hex） | 42 （Hex） | B |
|  | UD： 1 1 1 1 $O$ $O$ $O$ $O$ <br> $\overline{D A}:$ $O$ $O$ $O$ $O$ $B$ $B$ $B$ $B$ | Asynchronous | Conventional $\overline{D A}$ Select | $\overline{\mathrm{DAO}}, \overline{\mathrm{DA}} \mathbf{7}$ | F0（Hex） | 42 （Hex） | $B$ |

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL | PARAMETER | FATING | UNIT |
| :--- | :--- | :---: | :---: |
| $V_{C C}$ | Power supply voltage | +7 | $V_{D C}$ |
| $V_{I N}$ | Input voltage | +5.5 | $V_{D C}$ |
| $V_{O}$ | Off－state voltage | +5.5 | $V_{D C}$ |
| $T_{\text {STG }}$ | Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 24－Pin Plastic DIP 400 Mil Wide | N8 $\times 470 \mathrm{~N}$ |

DC ELECTRICAL CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}+5 \% ; 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}\right)$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\text {IL }}$ | Low level input voltage | $V_{C C}=\operatorname{Min}$ |  |  | 0.8 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | High level input voltage | $V_{C C}=$ Max | 2.0 |  |  | V |
| $\mathrm{V}_{\text {OL }}$ | Low level output voltage | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \text { from } \overline{\mathrm{DA}} \text { bus } \\ & \mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA} \text { from UD bus } \end{aligned}$ |  |  | 0.55 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.5 |  |  | V |
| $\mathrm{V}_{\mathrm{CL}}$ | Input clamp voltage | $V_{C C}=$ Min, $I_{\text {IN }}=-10 \mathrm{~mA}$ |  |  | -1.5 | $\checkmark$ |
| IIL | Low level input current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.4 | mA |
| $I_{1 / 2}$ | Low level input current for $\overline{\mathrm{IC}}, \overline{\mathrm{ME}}, \mathrm{SC}$ | $V_{C C}=\operatorname{Max}, V_{1}=0.4 \mathrm{~V}$ |  |  | -0.7 | mA |
| $I_{1 H}$ | High level input current | $V_{C C}=$ Max, $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| lozl | High-Z output current (low level) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -0.4 | mA |
| $\mathrm{l}_{\mathrm{OZH}}$ | High-Z output current (high level) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| los | Short circuit output current | $V_{C C}=\operatorname{Min}$ | -30 |  | -140 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply current | $V_{C C}=M a x$ |  |  | 220 | mA |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.75 | 5.00 | 5.25 | V |

DC FUSING CHARACTERISTICS

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{F}}$ | Fusing voltage | Applies to $\mathrm{V}_{\mathrm{CC}}, \mathrm{SC}, \mathrm{WC}, \overline{\mathrm{ME}}$ and $\overline{\mathrm{IC}}$ only | 9.5 |  | 11.5 | V |
| $I_{\text {FB }}$ | Fuse bank current | $\overline{\mathrm{ME}}$ or SC or $\mathrm{WC}, \overline{\mathrm{IC}}=11.5 \mathrm{~V}$ <br> (Only one bank at a time can equal 11.5 V ) |  |  |  | mA |
| $I_{\text {CCF }}$ | Fusing current | $V_{C C}=11.5 \mathrm{~V}, \overline{\mathrm{ME}}$ or SC or WC or $\overline{\mathrm{C}}=11.5 \mathrm{~V}$ (Only one bank at a time can equal 11.5 V ) |  |  |  | mA |

## TEST LOADING CIRCUITS



## AC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V}+5 \% ; 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}\right.$ ) (See Note 1)

| SYMBOL | PARAMETER | REFERENCES |  | TEST CONDITIONS | Limits |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | From | To |  | Min | Max |  |
| Pulse Widths: |  |  |  |  |  |  |  |
| ${ }^{\text {twme }}$ | MCLK pulse width |  |  | CS = MS = Low | 25 |  | ns |
| ${ }_{\text {twic }}$ | $\overline{\mathrm{C}} / \overline{\mathrm{OC}}$ puise width |  |  | $\overline{M E}$ - High | 25 |  | ns |
| Propagation Delays: |  |  |  |  |  |  |  |
| tpudda | Propagation delay from UD to $\overline{\mathrm{DA}}$ | UD | $\overline{\text { DA }}$ |  |  | 35 | ns |
| $\mathrm{t}_{\text {PICDA }}$ | Propagation delay from $\overline{\mathrm{C}}$ to $\overline{\mathrm{DA}}$ | $\overline{\mathrm{C}} \downarrow$ | $\overline{\text { DA }}$ |  |  | 35 | ns |
| $\mathrm{t}_{\text {PMCDA }}$ | Propagation delay from MCLK to $\overline{\mathrm{DA}}$ | MCLK $\uparrow$ | $\overline{\mathrm{DA}}$ |  |  | 35 | ns |
| tpdaud | Propagation delay from $\overline{\mathrm{DA}}$ to UD | $\overline{\mathrm{DA}}$ | UD |  |  | 35 | ns |
| tpmcud | Propagation delay from MCLK to UD | MCLK $\uparrow$ | UD |  |  | 35 | ns |
| Setup Times: |  |  |  |  |  |  |  |
| $\mathrm{tssc}^{\text {c }}$ | Setup time for SC | SC $\uparrow$ | MCLK $\uparrow$ |  | 5 |  | ns |
| tswc | Setup time for WC | wc $\uparrow$ | MCLK $\uparrow$ |  | 5 |  | ns |
| $\mathrm{t}_{\text {SME }}$ | Setup time for $\overline{\mathrm{ME}}$ | $\overline{\text { ME }} \downarrow$ | MCLK $\uparrow$ |  | 5 |  | ns |
| $t_{\text {SDA }}$ | Setup time for $\overline{\mathrm{DA}}$ | $\overline{\text { DA }}$ | MCLK $\uparrow$ |  | 0 |  | ns |
| $\mathrm{t}_{\text {IIC }}$ | Setup time for $\overline{\bar{C}} / \overline{\mathrm{OC}}$ | $\overline{\mathrm{C}} \downarrow$ | MCLK $\uparrow$ |  | 0 |  | ns |
| tsudic | Setup time to enable $\overline{\overline{\mathrm{C}}}$ | UD | $\overline{\mathrm{IC}} \downarrow$ |  | 0 |  | ns |
| Hold Times: |  |  |  |  |  |  |  |
| $\mathrm{thsc}^{\text {c }}$ | Hold time for SC | MCLK $\downarrow$ | Sc $\downarrow$ |  | 0 |  | ns |
| $t_{\text {HWC }}$ | Hold time for WC | MCLK $\downarrow$ | WC $\downarrow$ |  | 0 |  | ns |
| $\mathrm{thME}^{\text {He}}$ | Hold time for $\overline{\mathrm{ME}}$ | MCLK $\downarrow$ | $\overline{\mathrm{ME}} \uparrow$ |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{HIC}}$ | Hold time for $\overline{\mathrm{CO}} / \overline{\mathrm{OC}}$ | MCLK $\downarrow$ | $\overline{\mathrm{C}} \uparrow$ |  | 0 |  | ns |
| $\mathrm{t}_{\text {HUDIC }}$ | Hold time for between $\overline{\mathrm{C}}$ and UD | $\overline{\mathrm{C}} \uparrow$ | UD |  | 15 |  | ns |
| $t_{\text {HDA }}$ | Hold time for $\overline{\mathrm{DA}}$ bus | MCLK $\downarrow$ | DA |  | 10 |  | ns |

Enable Times:

| $\mathrm{t}_{\text {EIC }}$ | Enable time for $\overline{\mathrm{C}}$ | $\overline{\bar{C}} \uparrow$ | UD output |  | 24 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| teme | Enable time for $\overline{\mathrm{ME}}$ | $\overline{\mathrm{ME}} \downarrow$ | $\overline{\mathrm{DA}}$ | SC = WC = Low | 24 | ns |
| $\mathrm{t}_{\text {ESC }}$ | Enable time for SC | SC $\downarrow$ | $\overline{\text { DA }}$ | $\mathrm{WC}=\overline{\mathrm{ME}}=$ Low | 24 | ns |
| tewc | Enable time for WC | WC $\downarrow$ | $\overline{\mathrm{DA}}$ | $\mathrm{SC}=\overline{\mathrm{ME}}$ Low | 24 | ns |
| $t_{\text {ESIC }}$ | Enable time for user status | $\overline{\mathrm{C}} \uparrow$ | UD7 |  | 24 | ns |
| $\mathrm{t}_{\text {FESC }}$ | Enable time for data in the fast select mode | sc $\uparrow$ | $\overline{\text { DA }}$ |  | 24 | ns |
| $t_{\text {feme }}$ | Enable time for the controller status in the fast select mode | $\overline{M E} \uparrow$ | $\overline{\mathrm{DA}}$ |  | 24 | ns |

Disable Times: (see note 2)

| tolc | Disable time for $\overline{\mathrm{C}}$ | $\overline{\bar{C}} \downarrow$ | UD bus tri-stated |  |  | 45 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| t ${ }_{\text {dME }}$ | Disable time for $\overline{\mathrm{ME}}$ | $\overline{\mathrm{ME}} \uparrow$ | $\overline{\overline{D A}}$ bus tri-stated |  |  | 40 | ns |
| tosc | Disable time for SC | SC $\uparrow$ | $\overline{\overline{D A}}$ bus tri-stated |  |  | 40 | ns |
| $t_{\text {DWC }}$ | Disable time for WC | WC $\uparrow$ | $\overline{\overline{D A}}$ bus tri-stated |  |  | 40 | ns |
| $t_{\text {DSIC }}$ | Disable time for user status | $\overline{\bar{C}} \mathrm{I}$ | UD7 tri-stated |  |  | 40 | ns |
| ${ }^{\text {t }}$ fDSC | Disable time for data in the fast select mode | Sc $\downarrow$ | $\overline{\overline{D A}}$ bus tri-stated |  |  | 40 | ns |
| ${ }_{\text {t }}^{\text {FDME }}$ | Disable time for controller status in the fast select mode | $\overline{\mathrm{ME}} \downarrow$ | $\overline{\mathrm{DA}}$ bus tri-stated |  |  | 40 | ns |

NOTES:

1. Input levels swing from 0 V to 3 V with Outputs measured at 1.5 V .
2. These parameters are measured with a capacitive loading of 100 pF .

## 1/O Port

8X470 Timing for the Conventional DA Select Addressing Mode


8xate Timing for the Fast Select Addressing Mode


Enable and Disable Timing at the DA Ports


## Enable and Disable Timing at the UD Ports



## $8 \times 470$ Timing-Propagation Delays, Pulse Widths and Hold Times



## 8X470 Fuse Coding Sheet

This coding sheet is intended to assist in determining the fuse coding of an $8 \times 470$ Programmable I/O Port for a particular application. Use of this sheet requires some prior knowledge of the $8 \times 470$ fuse-programmable functions. Refer to the 8X470 Data Sheet for more information. To produce a fuse code, simply follow the steps below. Some of the information will start out in binary form, and must later be converted to hexadecimal. The chart at the right is provided to simplify the conversion process.

1. For conventional (DA bus) port selection, choose a Controller Data Address in the range of 0 to FF hexadecimal. Write the address in the space to the right. If Fast Select will be used, enter 00.
2. Pick the Controller Status Locations. Write a 1 in those positions where status should NOT appear and 0 in the other positions.
3. Select any bit positions that are to be programmed as input only. Write a 1 in any positions that should be input only, 0 in the other positions.
4. For conventional (DA bus) port selection, choose the Controller Status Address in the range of F0 to FF hexadecimal. Write the bottom digit ( 0 to F ) of the address in the space to the right. If Fast Select mode will be used, enter a 0.
5. If the $8 \times 470$ will be used in the Fast Select mode (as opposed to the conventional select mode), enter a 1 in the space to the right, otherwise enter a 0.
6. If the $8 \times 470$ will be used in the directional mode (Mode B) rather than the bidirectional mode (Mode A), enter a 1 in the space to the right, otherwise enter a 0.
7. If it is desired that data be written to the $8 \times 470$ from the User Bus asynchronously with respect to MCLK, enter a 1 in the space to the right, otherwise a 0 should be entered.
8. Copy the data from lines 4 through 7 into the boxes to the right. As noted, the first bit is always a zero. The four bits plus the single hex digit form one byte of programming data.
9. Copy the data from lines 1 to 3 and 8 into the spaces on the right, converting any binary data to hexadecimal. This is the data that is required to order or field-program an 8×470.
Binary to Hex Conversion
$0000-0$
$0001-1$
$0010-2$
$0011-3$
$0100-4$
$0101-5$
$0110-6$


| Fuse Code: <br> WC |  |  |  |  | $\underline{M E} \quad \underline{\text { SC }}$ | $\underline{I C}$ |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: |
|  | - | - | - |  |  |  |

## 8-BIT LATCHED BIDIRECTIONAL I/O PORT

## FEATURES

- Dual bidirectional ports
- Independent port operation (User-port priority for data entry)
- User data input synchronous
- At power-up, User-port outputs are high and Microprocessor-port outputs are high-Z
- Three-state TTL outputs for high-drive capabilities
- Directly compatible with $8 \times 300$ Microcontroller
- Single +5V supply


## PRODUCT DESCRIPTION

The 8T31 is an 8-bit bidirectional data register designed to function as Input/Output interface elements in microprocessor systems.

Each part contains eight clocked data latches that are accessible from either a microprocessor port or a user port. Separate I/O control is provided for each port. The two ports operate independently, except that when both are attempting to input data into the data latches, the User port (UDO-UD7) has priority. The master enable (ME) signal enables or disables the microprocessor bus regardless of the state of the other inputs but has no effect on the user bus.

A unique feature of these parts is their ability to start up in a predetermined state. If the clock is maintained at a level of less than 0.8 volts until the power supply reaches 3.5 volts, all bits of the user port will wakeup at a "logic 1 '" level and those of the microprocessor port will wakeup in the high-impedance state.

## LOGIC DIAGRAM



## PIN CONFIGURATION



## PIN DESIGNATION

| PIN | SYMBOL | NAME AND FUNCTION | TYPE |
| :---: | :---: | :---: | :---: |
| 1-8 | UD0-UD7: | User Data I/O Lines. Bidirectional data lines to communicate with user's equipment. | Acitve high three-state |
| 16-23 | IV0-IV7: | Microprocessor Bus. Bidirectional data lines to communicate with controlling digital system. | Active low three-state |
| 10 | $\overline{\mathrm{BIC}}$ : | Input Control. User input to control writing into the I/O Port from the user data lines. | Active low |
| 9 | $\overline{\mathrm{BOC}}$ : | Output Control. User input to control reading from the I/O Port onto the user data lines. | Active low |
| 11 | $\overline{\mathrm{ME}}$ : | Master Enable. System input to enable or disable all other system inputs and outputs. It has no effect on user inputs and outputs. | Active low |
| 15 | WC: | Write Command. When WC is high, stores contents of IVO-IV7 as data. | Active high |
| 14 | $\overline{\mathrm{RC}}$ | Read Command. When RC is low, data is presented on IVO-IV7. | Active low |
| 13 | MCLK | Master Clock. Input to strobe data into the latches. See function tables for details. | Active high |
| 24 | $\mathrm{V}_{\mathrm{CC}}$ : | 5 V power connection. |  |
| 12 | GND: | Ground. |  |

Table 1. USER PORT CONTROL FUNCTION

| $\overline{\text { BIC }}$ | $\overline{\text { BOC }}$ | MCLK | USER DATA BUS FUNCTION |
| :---: | :---: | :---: | :---: |
| H | L | X | Output Data |
| L | X | H | Input Data |
| H | H | X | Inactive |

$H=$ High Level $L=$ Low Level $X=$ Don't care

Table 2. MICROPROCESSOR PORT CONTROL FUNCTION

| $\overline{\text { ME }}$ | $\overline{\mathrm{AC}}$ | wc | MCLK | BIC | MICROPROCESSOR BUS FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | X | X | Output Data |
| L | X | H | H | H | Input Data |
| X | H | L | X | X | Inactive |
| X | X | H | $x$ | L | Inactive |
| H | X | X | X | X | Inactive |

## USER DATA BUS CONTROL

The activity of the user data bus is controlled by the $\overline{\mathrm{BIC}}$ and $\overline{\mathrm{BOC}}$ inputs as shown in Table 1.

The user data input is a synchronous function with MCLK. A low level on the $\overline{\mathrm{BIC}}$ input allows data on the user data bus to be written into the data latches only if MCLK is at a high level. A low level on the BIC input allows data on the user data bus to be latched regardless of the level of the MCLK input.

To avoid conflicts at the data latches, input from the microprocessor port is inhibited when BIC is at a low level. Under all other conditions the 2 ports operate independently.

## MICROPROCESSOR BUS CONTROL

As is shown in Table 2, the activity of the microprocessor port is controlled by the $\overline{M E}$, RC, WC and $\overline{\mathrm{BIC}}$ inputs, as well as the state of an internal status latch. $\overline{\mathrm{BIC}}$ is included to show user port priority over the microprocessor port for data input.

## BUS OPERATION

Data written into the 8T31 from one port will appear inverted when read from the other port. Data written into the 8 T 31 from one port will not be inverted when read from the same port.

DC ELECTRICAL CHARACTERISTICS $V_{C C}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified.

| PARAMETER | TEST CONDITIONS |  | LIMITS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |

NOTES

1. The input current includes the three-state/open collector leakage current of the output driver on the data lines.
2. Only one output may be shorted at a time.

## PARAMETER MEASUREMENT INFORMATION





AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leq T A \leq 70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$


NOTES

1. Data delays referenced to the clock are valid only if the input data is stable at the arrival of the clock and the hold time requirement is met.
2. Set up and hold times given are for "normal" operation. $\overline{\mathrm{BIC}}$ setup and hold times are for a user write operation. RC setup and hold times are for an I/O Port select operation. ME and WC setup and hold times are for a microprocessor bus write operation.
3. Times are referenced to MCLK

## VOLTAGE WAVEFORMS

SETUP AND HOLD TIMES


## 8-BIT LATCHED ADDRESSABLE BIDIRECTIONAL I/O PORT

## FEATURES

- Independent port operation (user-port priority for data entry)
- User data input available as synchronous (8T32) or as asynchronous (8T36)
- User data bus available with three-state (8T32, 8T36)
- At power-up, user-port outputs are high and microprocessor-port outputs are high-z; status latch (from address compare) is also cleared at power-up
- Three-state TTL outputs for high-drive capabilities
- Directly compatible with $8 \times 300$ microcontroller
- Single +5 V supply


## PRODUCT IDENTITY

8T32- Three-state, field-programmable (addresses 0-255), synchronous user port.
8 T 36 -Three-state, field-programmable (addresses 0-255), asynchronous user port

## PRODUCT DESCRIPTION

8T32/8T36. Each of these I/O Bytes is an addressable and bi-directional register designed for use as an interface element in any system with TTL-compatible buses. (Note. Since these I/O Bytes are frequently used with the 8X300 Microcontroller and its associated Interface Vector bus, the 8T32-8T36 family of parts are commonly called IV Bytes.) Each I/O Byte contains eight identical data latches (Bits 0 through 7); the latches are accessed from either of two 8 -bit ports-one port connecting to the microprocessor ( $8 \times 300$ ) and the other port connecting to the user device.

Separate controls are provided for each port and the two ports operate independently, except when both attempt to input data at the same time; in this case, the user port bus has priority.

The address of each I/O Byte is fieldprogrammable and the microprocessor port is accessed when a valid address is received; the user port is accessible at all times. A selected Byte is automatically deselected when the address of another I/O Byte is sensed on the address/data bus. A Master Enable (ME) input is available for use as a ninth address bit, allowing direct access to 512 I/O Bytes without address decoding.

A unique feature of these parts is their ability to start up in a predetermined state. If the clock is maintained at a level of less than 0.8 volts until the power supply reaches 3.5 volts, all bits of the user port will wakeup at a "logic 1 "' level and those of the microprocessor port will wakeup in the high-impedance state.

PIN CONFIGURATION


A stock of 8T32s and 8T36s with addresses " 1 "' through " 10 ' are maintained in inventory; with a longer lead time, a small quantity of address " 11 " through " 50 " are also available.

TYPICAL BLOCK DIAGRAM


## PIN DESCRIPTION

| PIN | SYMBOL | NAME AND FUNCTION | TYPE |
| :---: | :---: | :---: | :---: |
| 1-8 | UD0-UD7: | User Data I/O Lines. Bidirectional data lines to communicate with user's equipment. Either tristate or open collector outputs are available. | Active high |
| 16-23 | $\overline{\mathrm{VO}}-\overline{\mathrm{IV7}}$ : | Microprocessor Bus. Bidirectional data lines to communicate with controlling digital system (microprocessor). | Active low three-state |
| 10 | $\overline{\mathrm{BIC}}$ : | Input Control. User input to control writing into the $1 / \mathrm{O}$ Port from the user data lines. | Active low |
| 9 | $\overline{\mathrm{BOC}}$ : | Output Control. User input to control reading from the 1/O Port onto the user data lines. | Active low |
| 11 | $\overline{\mathrm{ME}}$ : | Master Enable. System input to enable or disable all other system inputs and outputs. It has no effect on user inputs and outputs. | Active low |
| 15 | WC: | Write Command. When WC is high and SC is low, I/O Port, if selected, stores contents of $\overline{\mathrm{IV} 0}-\overline{\mathrm{IV7}}$ as data. | Active high |
| 14 | SC: | Select Command. When SC is high and WC is low, data on $\overline{\mathrm{V} 0}-\overline{\mathrm{V} 7}$ is interpreted as an address 1/O Port selects itself if its address is identical to $\mu \mathrm{P}$ bus data; it de-selects itself otherwise. | Active high |
| 13 | MCLK | Master Clock. Input to strobe data into the latches. See function tables for details. | Active high |
| 24 | VCC: | 5 V power connection. |  |
| 12 | GND: | Ground. |  |

Table 1. USER PORT CONTROL FUNCTION

| $\overline{B I C}$ | $\overline{\text { BOC }}$ | MCLK | USER DATA BUS FUNCTION |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | 8 T32 | 8 T 36 |
| H | L | x | Output Data | Output Data |
| L | x | H | Input Data | Input Data |
| L | x | L | Inactive | Input Data |
| H | H | x | Inactive | Inactive |

$H=$ High Level $L$ = Low Level $X=$ Don't care

Table 2. MICROPROCESSOR PORT CONTROL FUNCTION

| ME | SC | WC | MCLK | BIC | STATUS <br> LATCH | I/OPOPT <br> FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | $X$ | $X$ | SET | Output Data |
| L | L | $H$ | $H$ | $H$ | SET | Input Data |
| L | $H$ | L | $H$ | $X$ | $X$ | Input Address |
| L | $H$ | $H$ | $H$ | L | $X$ | Input Address |
| L | $H$ | $H$ | $H$ | $H$ | $X$ | Input Data andAddress |
| L | $X$ | $H$ | L | $X$ | $X$ | Inactive |
| L | $H$ | $X$ | $L$ | $X$ | $X$ | Inactive |
| L | L | $H$ | $H$ | L | $X$ | Inactive |
| L | L | $X$ | $X$ | $X$ | Not Set | Inactive |
| $H$ | $X$ | $X$ | $X$ | $X$ | $X$ | Inactive |

## USER DATA RUS

The activity of the user data bus is con trolled by the $\overline{\mathrm{BIC}}$ and $\overline{\mathrm{BOC}}$ inputs as shown in Table 1.

For the 8T32, user data input is a synchronous function with MCLK. A low level on the $\overline{B I C}$ input allows data on the user data bus to be written into the data latches only if MCLK is at a high level. For the 8T36, user data input is an asynchronous function. A low level on the $\overline{B I C}$ input allows data on the user data bus to be latched regardless of the level of the MCLK input. Note that when the 8 T 36 , is used with the 8×300 Microcontroller, care must be taken to insure that the Microprocessor bus is stable when it is being read by the $8 \times 300$ Microcontroller.

To avoid conflicts at the Data Latches, input from the Microprocessor Port is inhibited when $\overline{B I C}$ is at a low level. Under all other conditions the two ports operate independently

## MICROPROCESSOR

 BUS CONTROLAs is shown in Table 2, the activity of the microprocessor port is controlled by the $\overline{M E}$, SC, WC, and BIC inputs, as well as the state of an internal status latch. $\overline{B I C}$ is inciuded to show user port priority over the microprocessor port for data input.

Each I/O Port's status latch stores the resuit of the most recent I/O Port select; it is set when the I/O Port's internal address matches the Microprocessor Bus. It is cleared when an address that differs from the internal address is presented on the Microprocessor Bus.

In normal operation, the state of the status latch acts like a master enable; the microprocessor port can transier data only when the status latch is set.

When SC and WC are both high, data on the Microprocessor Bus is accepted as data, whether or not the $1 / O$ Port was selected. The data is also interpreted as an address. The 1/O Port sets its select status if its address matches the data read when SC and WC were both high; it resets its select status otherwise.

## BUS OPERATION

Data written into the l/O Port from one port will appear inverted when read from the other port. Data written into the I/O Port from one port will not be inveried when read from the same port.

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 5 \%$


- Applies for 8 T32.
$\dagger$ Applies for 8T36.
$\square$ Times are referenced to MCLK for 8T32, and are referenced to BIC for 8T36.


## NOTES:

1. Data delays referenced to the clock are valid only if the input data is stable at the arrival of the clock and the hold time requirement is met.
2. Set up and hold times given are for "normal" operation. BIC setup and hold times are for a user write operation. SC setup and hold times are for I/O Port select operation. $\overline{\text { ME }}$ setup and hold times are for both IV write and select operations.

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2.0 |  | 5.5 | V |
| VIL | Low-level input voltage |  | -1.0 |  | . 8 | V |
| $\mathrm{V}_{\mathrm{CL}}$ | Input clamp voltage | $\mathrm{I}_{1}=-5 \mathrm{~mA}$ |  |  | -1.0 | V |
| $\mathrm{IIH}^{\text {H}}$ | High-level input current ${ }^{1}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=5.25 \mathrm{~V} \end{aligned}$ |  | <10 | 100 | $\mu \mathrm{A}$ |
| ILL | Low level input current ${ }^{1}$ | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IL}}=.5 \mathrm{~V} \end{gathered}$ |  | $-350$ | -550 | $\mu \mathrm{A}$ |
| VOL | Low-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  |  | . 55 | V |
| V OH | High-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{IOH}=-3.2 \mathrm{~mA} \end{aligned}$ | 2.4 |  |  | V |
| los | Short-circuit output current ${ }^{2}$ UD bus IV bus | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 10 \\ & 20 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Icc | Supply current | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |  | 100 | 150 | mA |

NOTES

1. The input current includes the Three-state/Open Collector leakage current of the output driver on the data lines.
2. Only one output may be shorted at a time.
3. These limits do not apply during address programming

## TEST LOAD CIRCUIT (OPEN COLLECTOR OUTPUTS)



NOTE: $\mathrm{C}_{\mathrm{L}}$ includes fixture capacitance.

Absolute Maximum Ratings:
Supply voitage ${ }^{3}$.............. 7V
Input voltage ${ }^{3} \quad . . . . . . .$. .... 5.5 V

TEST LOAD CIRCUIT (THREE-STATE OUTPUTS)


NOTE: $C_{L}$ includes fixture capacitance.

## VOLTAGE WAVEFORMS



## VOLTAGE WAVEFORMS (Cont'd)

| DATA DELAY TIMES Input Data Reference | DATA DELAY TIMES Clock Referenced |
| :---: | :---: |
| gETUP AND HOLD TIMES | OUTPUT ENABLE AND DISABLE TIMES (Three-State Outputs) <br> Waveform \#1 is for an output with internal conditions such that the output is Low when the three-state driver is enabled. Waveform \#2 is for the opposite condition. |

## ADDRESS PROGRAMMING

The I/O Port is manufactured such that an address of all high levels ( $>2 \mathrm{~V}$ ) on the Microprocessor Bus inputs matches the Port's internal address. To program a bit so a lowlevel input ( $<0.8 \mathrm{~V}$ ) matches, the following procedure should be used:

1. Set all control inputs to their inactive state ( $\overline{\mathrm{BIC}}=\overline{\mathrm{BOC}}=\overline{\mathrm{ME}}=\mathrm{V}_{\mathrm{CC}}, \mathrm{SC}=\mathrm{WC}=$ MCLK = GND). Leave all Microprocessor Bus I/O_pins open.
2. Raise $\mathrm{V}_{\mathrm{CC}}$ to $7.75 \mathrm{~V} \pm .25 \mathrm{~V}$.
3. After $\mathrm{V}_{\mathrm{Cc}}$ has stabilized, apply a single programming pulse to the user data bus bit where a low-level match is desired. The voltage should be limited to 18 V ; the current should be limited 75 mA . Apply the pulse as shown in Figure 1.
4. Return $\mathrm{V}_{\mathrm{CC}}$ to OV . (Note 1).
5. Repeat this procedure for each bit where a low-level match is desired.
6. Verify that the proper address is programmed by setting the Port's status latch (IV0-IV7 $=$ desired address, $\overline{\mathrm{ME}}=\mathrm{WC}=$ $L, S C=M C L K=H$ ). If the proper address has been programmed, data presented at the $\mu \mathrm{P}$ bus will appear inverted on the user bus outputs. (Use normal $\mathrm{V}_{\mathrm{CC}}$ and input voltage for verification.)

After the desired address has been programmed, a second procedure must be followed to isolate the address circuitry. The procedure is:


Figure 1


Figure 2

1. Set $\mathrm{V}_{\mathrm{CC}}$ and all control inputs to OV . $\left(\mathrm{V}_{\mathrm{CC}}=\right.$ $\overline{\mathrm{BIC}}=\overline{\mathrm{BOC}}=\overline{\mathrm{ME}}=\mathrm{SC}=\mathrm{WC}=\mathrm{MCLK}$ $=0 \mathrm{~V}$ ). Leave all Microprocessor Bus I/O pins open.
2. Apply a protect programming pulse to every user data bus pin, one at a time. The voltage should be limited to 14 V ; the current should be limited to 150 mA . Apply the pulse as shown in Figure 2.
3. Verify that the address circuitry is isolated by applying 7 V to each user data bus pin and measuring less than 1 mA of input current. The conditions should be the same as in step 1 above. The rise time on the verification voltage must be slower than $100 \mu \mathrm{~s}$.

## PROGRAMMING SPECIFICATIONS ${ }^{1}$



## NOTE

[^16]
## APPLICATIONS

Figure 3 shows some of the various ways to use the I/O Port in a system. By controlling the $\overline{B I C}$ and $\overline{B O C}$ lines, the device may be used for the input and output of data, control, and status signals. I/O Port 1 functions bidirectionally for data transfer and I/O Port 2 provides a similar function for discrete status and control lines. I/O Ports 3 and 4 serve as dedicated output and input ports, respectively.


Figure 3

## Product support

$8 \times 300$ family (product support) ..... 709
8X300KT1SK ..... 711
8X305 (ICEPACK) ..... 731
8X300/8X305 (development data) ..... 733
8X330 (ECC application note) ..... 735
$\qquad$


## SUPPORT FACILITIES

The 8X300 Family is strongly supported with Development Systems, Support Software, Applications, Training and Documentation. Together, this support provides the user with a powerful set of tools to evaluate, design, debug, and implement a simple or complex system.

## DEVELOPMENT SYSTEMS

EZ-PRO (Manufactured by American Automation)

- Universal Development System
- Relocating macroassembler
- Full speed in-circuit emulator/debugger
- Maximum memory support
$8 \times 305$ ICEPACK (Manufactured by Sigen Corp.)
- Full speed in-circuit emulator/debugger
- RS-232 interface to CP/M or Intellec
- 4 K word memory/8-bit extended microcode
- Low cost

Signetics $8 \times 305$ Prototyping System

- Single board module
- RS-232 interface
- Resident monitor
- 256 to 4096 words of Writable Control Storage
- Minimum cost


## SOFTWARE

MCCAP CrossAssembler

- Full function macroassembler
- Free format source code
- Symbolic address assignment
- Nested macro support
- Cross-reference table
- Supports extended microcode
- Multiple output formats
- Available in two versions
- FORTRAN source code
- Intellec/ISIS object code


## APPLICATIONS SUPPORT

Field applications engineers
Product applications engineers
Application notes

- Floppy disk controiler
- ECC
- Hard disk controller
- Local network interfacing

TRAINING AND DOCUMENTATION

- Videocassette training course
- Designer's seminar
- 8X305 User's Manual
- 8X300 Family Product Capabilities Manual
- MCCAP Programming Manual
- Full complement of Data Sheets



## 8X305 Prototyping System

This document provides the information required to understand, set up and operate the $8 \times 305$ Prototyping System. It is recommended that the user become thoroughly familiar with the $8 \times 305$ MicroController and the high speed peripherals that support the device. For this purpose, the following documents are recommended:

- 8X305 Users Manual - comprehensive functional detail, interface characteristics, hardware and software design data, and systems information for the 8X305 MicroController.
- 8X300 Family Product Capabilities Manual - overview of the $8 \times 300$ Family of parts, including application information on the 8X305 MicroController and its support devices.
- MCCAP Manual - complete description of the powerful MicroController CrossAssembler Program for the $8 \times 300$ and $8 \times 305$.
- Data Sheets - electrical and functional characteristics for each member of the $8 \times 300$ Family and related parts.
- 8X305 MicroController
- 8X310 Interrupt Control Coprocessor
- 8X320 Bus Interface Register Array
- 8X330 Floppy Disk Formatter/Controller
- 8X338 Local Area Network Controller
- 8X350 256 Byte Bipolar RAM
- 8X360 Memory Address Director
- 8X371 Latched 8-bit Bidirectional I/O Port
- 8X372/8X376 Addressable 8-bit Bidirectional I/O Port
- 8X374 Addressable 8-bit Bidirectional I/O Port with Parity
- 8X382 Addressable 4-IN/4-OUT I/O Port
- 8X60 FIFO RAM Controller


## INTRODUCTION



Figure 1-1. 8X305 Prototyping System

### 1.1 SYSTEM DESCRIPTION

The $8 \times 305$ Prototyping System is a powerful design support tool that aids the engineer in the evaluation, design, and prototyping of systems based on the Signetics 8X305 MicroController and its family of support devices. Its advanced features permit the development of both $8 \times 305$ firmware and application circuitry. The prototyping systems capabilities are adequate to serve as a complete development system for simple systems and provide a low-cost tool for evaluating portions of more complex designs.

### 1.2 ARCHITECTURAL OVERVIEW

As shown in Figure 1-1, the 8X305 Prototyping System consists of a single printed circuit board that includes an 8X305 MicroController and various $8 \times 305$ Family peripheral devices. The 8X305's microprogram resides in Writeable Control Storage (WCS). A Monitor Processor controls operation of the $8 \times 305$ by loading the WCS, activating the Run/ Step logic, and directly placing instructions onto the 8X305's Instruction bus. The Monitor Processor also controls the User Interface, which is through a standard RS-232 connector. The remainder of the board is occupied by power connections and a large wire-wrap area for prototyping of user-developed circuits. A complete discussion of the operation and interrelationship of these functions is contained in later chapters.

### 1.2.1 USER INTERFACE

The User Interface of the $8 \times 305$ Prototyping System is accomplished through a standard RS-232 connector. Data rates from 110 to 19,200 baud are switch selected by the user. The monitor program contained in the system controls all user communication, which is accomplished interactively through a straightforward and user-friendly syntax. While the operation of the system requires only a low-cost "dumb" terminal, it can be connected to a host computer to support more advanced developments. Commands are included to support up and down loading of programs in such applications.

### 1.2.2 MONITOR PROCESSOR AND RUN/STEP LOGIC

Operation of the system is controlled by the Monitor Processor, which is implemented using an 8035 Microprocessor. The Monitor Processor is responsible for the following functions:

- User interaction
- Loading Writeable Control Storage
- Loading and reading $8 \times 305$ registers and $1 / O$ devices
- Control of Run/Step logic

Programming for the Monitor Processor is supplied by Signetics and is contained in a PROM.

### 1.2.3 WRITEABLE CONTROL STORAGE

$8 \times 305$ MicroController programs are executed from a Writeable Control Storage (WCS) that is contained on the board. The prototyping system is supplied with 256 words of instruction memory. An expansion module is available to support address space requirements of up to 4096 words. The WCS is sufficiently fast to permit full speed operation of the $8 \times 305$.
Writeable Control Storage words are 25 bits wide to support advanced microprogramming requirements. Sixteen of these bits contain actual $8 \times 305$ instructions. Eight of the remaining bits are used to support "Extended Microcode" designs as described in the $8 \times 305$ Users Manual. The 25th bit, transparent to the user, is set by the Monitor Processor to control breakpoints.
Since the three-bus architecture of the $8 \times 305$ does not permit the MicroController to modify its own program memory, the WCS is loaded by the Monitor Processor.

### 1.2.4 8X305 MICROCONTROLLER AND PERIPHERALS

An 8X305 MicroController and various $8 \times 300$ Family peripheral devices are included in the prototyping system.
The Instruction and Program Address busses of the $8 \times 305$ are connected to Writeable Control Storage (WCS) as well as an $8 \times 310$ Interrupt Control Coprocessor (ICC). The interrupt and status pins of the $8 \times 310$ are available to the user for use in prototyping realtime or other interrupt driven systems.
The $8 \times 305$ 's IV bus is connected to the following $8 \times 300$ Family peripheral devices:
(1) $8 \times 320$ Bus Interface Register Array
(1) $8 \times 350256$ Byte Bipolar RAM
(1) $8 \times 360$ Memory Address Director
(3) $8 \times 372$ Addressable 8-bit Bidirectional I/O Ports
IV bus data and control signal connections are also available to the user to permit attachment of other devices or user developed logic. User interface connections to the $8 \times 320,8 \times 360$, and $8 \times 372$ 's are available adjacent to the wire-wrap area to permit prototyping of various 8X305 based designs.

## SYSTEM SETUP

### 2.1 POWER CONNECTIONS

| CAUTION |
| :--- |
| Power connections must be prop- |
| erly made; otherwise, component |
| damage will result. |

Power connections to the Prototyping System are made through four binding posts located on the left hand edge of the board. These are labeled GROUND, $+5,-12$, and +12 . Without options or user circuitry in the wire-wrap area, the current drawn from each power source is as follows:
+5 VDC - less than 2.5 amperes +12 VDC - less than 20 milliamperes - 12 VDC - less than 20 milliamperes

Additional current must be supplied for any options or user circuitry added to the board. At the user's option, a DC-to-DC converter (converts +5 VDC to $\pm 12 \mathrm{VDC}$ ) can be installed in the space allotted to the -12 VDC and +12 VDC binding posts. Refer to the parts list in Appendix $B$ for the manufacturer and part number of the recommended device.

### 2.2 RS-232 INTERFACE

An RS-232 connector is provided in the lower left-hand corner of the system for interconnection to the user's CRT terminal, and is connected as shown in Table 2-1.

Table 2-1 RS-232 CONNECTOR

| Pin <br> No. | Signal | Description |
| :---: | :---: | :---: |
| 1 | GND | Ground |
| 2 | TXD | Transmit Data(in) |
| 3 | RXD | Receive Data(out) |
| 4 | RTS | Request to Send(in) |
| 5 | CTS | Clear to ${ }^{\text {S }}$ Send(out) |
| 6 | DSR | Data Set Ready(out) |
| 7 | GND | Ground |
| 8 | CAD | Carrier Detect(out) |

RS-232 specifications call for data communications equipment (DCE), such as this system, to be connected to data terminal equipment (DTE), such as the user's CRT terminal. When connecting this system to another DCE, such as a
host computer, be sure to interchange TXD (pin 2) with RXD (pin 3), and RTS (pin 4) with CTS (pin 5). This can be done on the cable or it can be accomplished logically by using a Null Modem. Due to the variety of interpretations of RS-232, some terminals may not immediately work with the Prototyping System. If difficulties are encountered, first reduce the connections to three signals: TXD, RXD, and GND. Then if necessary, interchange TXD and RXD signals.

### 2.3 BAUD RATE SELECTION

Any of the eight baud rates listed in Table 2-2 may be selected by proper setting of switches B2, B1 and B0 located near the RS-232 connector.

Table 2-2 BAUD RATE

| $\frac{\text { B2 }}{0}$ | $\frac{B 1}{0}$ | $\frac{\text { B0 }}{0}$ | $\frac{\text { Baud }}{\text { Rate }}$ |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 9600 |
| 0 | 1 | 0 | 4800 |
| 0 | 1 | 1 | 2400 |
| 1 | 0 | 0 | 1200 |
| 1 | 0 | 1 | 600 |
| 1 | 1 | 0 | 300 |
| 1 | 1 | 1 | 110 |
| $=$ Switch off, $1=$ Switch on) |  |  |  |

For hard-copy printing terminals, an optional line-feed feature may be selected to avoid over-strike of characters after a backspace on error. This feature is selected by setting the LF switch located next to switch BO to the ON position.

### 2.4 EXTERNAL OSCILLATOR CONNECTIONS

[^17]The Prototyping System is supplied with a 10 MHz crystal; therefore it operates the $8 \times 305$ MicroController at its full rated speed of 200 nanoseconds per instruction. The crystal may be changed by the user to any frequency from 4 MHz to 10 MHz . Alternatively, an external oscillator may be connected to the X1 and X2 inputs of the $8 \times 305$, as described in the $8 \times 305$ Users Manual. The external oscillator may operate at any frequency between 0.2 MHz and 10 MHz . Note that the $8 \times 305$ is capable of running at frequencies lower than 0.2 MHz , but the Prototyping System's Monitor Processor expects the $8 \times 305$ to be finished executing an instruction within 10 microseconds, thereby imposing a lower limit of 0.2 MHz . Tie points for X 1 and X 2 are located next to crystal Y2 and the $8 \times 305$. Be sure to disconnect crystal Y2 before connecting the external oscillator inputs to X 1 and X 2 .

### 2.5 INHIBIT JUMPER FOR 8X310 ROM DISABLE

The 8X310 Interrupt Control Coprocessor connects to the Instruction and Address buses of the 8X305. It accomplishes interrupt and subroutine control by disabling the control storage that contains the $8 \times 305$ 's microprogram and placing specific JMP instructions onto the instruction bus. To permit the Prototyping System to operate either with or without an 8X310 in the circuit, a jumper is incorporated into the ROM Disable (RD) circuitry.
When the $8 \times 310$ Interrupt Control Coprocessor is physically present in location U16, the ROM Disable Inhibit Jumper located at R14 next to the $8 \times 310$ must not be present so that the $8 \times 310$ can disable WCS and avoid bus contention problems. When the $8 \times 310$ is not present, this jumper must be connected to the board at location R14 to permanently enable the Writeable Control Store RAMs.

## SYSTEM OPERATION

### 3.1 POWER UP AND DIAGNOSTICS

When power is applied to the Prototyping System, resident diagnostic programs are executed to test the MicroController and Writeable Control Store iWCSi. The following message is then printed:

```
8X305 PROTOTYPING SYSTEM
REV n
SYSTEM CHECK ON
```

where " $n$ " equals the current revision level.

If the Prototyping System is functioning improperly, either "MEMORY ERROR" or " $8 \times 305$ ERROR" messages will be printed. Then the "promit" character (*) will be printed and the user may examine WCS memory or $8 \times 305$ functions to diagnose the problem.

### 3.2 MONITOR PROGRAM

With the printing of the "prompt" character (*), system control passes to the monitor program. The user may then enter any of the ten monitor commands:

I INPUT $8 \times 305$ instructions into memory:
Accepts a starting WCS memory address and then permits the entering of an 8X305 instruction in mnemonic form and an extension instruction in octal notation.
$n$ Register examine/change, where " n " = register number:
Displays the register number and its contents and allows a new value to be substituted.
(R0 may be accessed by its alternate name $A \cup X$ by entering " $A$ " or, R10 may be accessed by its alternate name OVF by entering "0".)

G GO execute user's $8 \times 305$ program:
Accepts a starting memory address and executes at full speed until a breakpoint or keyboard entry is reached. Then the contents of the registers and the next executable instruction are displayed, and single stepping can proceed.

S STEP, single step user's program: Accepts a starting memory address and displays the contents of the registers and the instruction at that memory address. The instruction is executed by hitting the space bar; and successive instructions by successively hitting the space bar.

M
MEMORY and breakpoint examine/ change:
Accepts a starting WCS memory address and then displays the contents of that location in mnemonic form and indicates a possible breakpoint by an exclamation point. A breakpoint at this location may be set by typing an exclamation point or cleared by typing a backspace. A new $8 \times 305$ instruction and extension instruction is then entered by typing an I, as with the INPUT command.

## L LB, left-bank examine/change:

Accepts a bank address cor the currently enabled address, if a blank is entered) and displays the contents of that left-bank address (0-377 octal). A new value may be entered to substitute for the original content.

## RB, right-bank examine/change:

Operates the same as the LB command except action is upon the right-bank.

D DUMP memory contents to terminal:
Accepts a starting WCS memory address and an ending address, and then dumps the memory contents from the start address to the end address onto the RS-232 port in ASCII HEX QUOTE format as described in Section 3.6.

FILL memory contents from terminal:
Accepts a starting WCS memory address and fills memory in ASCII HEX QUOTE format as described in Section 3.6.

XCODE, temporarily set extended microcode latch:
Accepts a new extension code value to be temporarily set in the extended microcode latch for control of user circuitry. The content of the extended microcode section of WCS is not changed by this command.

Although the user need only enter a single letter command, the monitor will respond by typing the whole command name as indicated in capitals above.

Any of the commands may be aborted before completion by typing an ASCII "control-C" character. While entering any number (sequence of octal digits). corrections may be made by entering a backspace character and then entering the correct number.

### 3.3 COMMAND SYNTAX DIAGRAMS

System commands and monitor responses are defined in the syntax diagrams in Figure 3-1a, b and c.

### 3.4 SAMPLE USAGE

The sample program in Figure $3-3$ is shown to give the user an idea of a typical session and includes most commands used by the Prototyping System. A short program is input to WCS via the terminal Keyboard that continually increments R6 of the 8×305 and writes each new incremented value to location 133 of the $8 \times 350$ on the RightBank of the IV Bus and to I/O Port 001 on the Left-Bank. Since extended microcode is not needed in this example, none was entered as indicated by "/000"

### 3.5 BREAKPOINTS

Breakpoints are designed to halt the $8 \times 305$ just prior to the execution of an instruction on which a breakpoint has been specified. If the GO command is issued to start at an address that has a breakpoint set, the system will not stop on that address immediately. If the $8 \times 305$ should access that address again then a breakpoint stop will occur.


Figure 3-1a. Syntax Definitions


Figure 3-1b. Syntax Flow



Figure 3-1c. Syntax Flow

* DUMP 0000000014

DUMPING HIGH BYTES
(STX)
$00^{\prime} \mathrm{C} 0^{\prime} 24^{\prime} \mathrm{B9}^{\prime} \mathrm{C} 0^{\prime} \mathrm{AC} \mathrm{C}^{\prime} 68^{\prime} 74^{\prime} 01^{\prime} 10^{\prime} 70^{\prime} 11^{\prime} \mathrm{F} 1^{\prime}$
(ETX)
DUMPING LOW BYTES
(STX)
00'00'08'BF'10'FF'FF' $96^{\prime} 06^{\prime}$ FF' $7 D^{\prime} 40^{\prime}$ D7'
(ETX)
DUMPING EXT BYTES ....
(STX)
$00^{\prime} 00^{\prime} 00^{\prime} 00^{\prime} 00^{\prime} 50^{\prime} 00^{\prime} 00^{\prime} 00^{\prime} 00^{\prime} 00^{\prime} 00^{\prime} 00^{\prime}$
(ETX)
*
*

Figure 3-2. Example of ASCII HEX QUOTE Format

### 3.6 ASCII HEX QUOTE FORMAT

Memory contents to and from the terminal during the DUMP and FILL commands are in an object code format commonly supported by PROM programming hardware known as "ASCII HEX QUOTE" format. Each block of eight-bit wide data is preceeded by an STX (ASCII Start of Text) character. Then each 8 -bit byte is represented by 2 ASCII HEX characters (0, 1, 2, 3, 4, 5, $6,7,8,9, A, B, C, D, E, F)$ followed by a single quote ('). As many bytes as necessary may be transmitted until an ETX (ASCII End of Text) character terminates the block. Three such blocks are transmitted for any specified memory range: high byte of $8 \times 305$ instruction, low byte of $8 \times 305$ instruction, and extended microcode byte. Figure 3-2 shows an example of ASCII HEX QUOTE format.

### 3.7 XEC (EXECUTE) INSTRUCTIONS

When stepping through a user program and an $8 \times 305 \times E C$ instruction is encountered, the system will display an "XR" after the next instruction to indicate an XEC range of address.
Note that stepping must start on or before an XEC instruction for the program flow to be correct. If while running a program, a breakpoint or stop occurs on an instruction that is the target of an XEC instruction, an " $X R$ " will not be displayed and program flow will not be correct if single stepping is then begun.
It is valid to nest any number of XEC instructions. Single stepping will work properly provided that the user start on or before the first XEC instruction.

### 3.8 8X310 <br> INTERRUPT CONTROL COPROCESSOR CONSIDERATIONS

Certain 8X305 "NOP" instructions have specific meanings to the $8 \times 310$ as indicated in the data sheet. When using an $8 \times 310$ in the system, the user must start running or stepping from an instruction that is not an $8 \times 310$ instruction. It is valid, however, to start running and encounter a breakpoint or stop on an $8 \times 310$ instruction and then continue single stepping the program.


Figure 3-3. Sample Usage

## USER CONNECTIONS

### 4.1 WIRE-WRAP AREA

The wire-wrap area located at the top of the board provides 26 square inches for user prototyping. This space accommodates standard IC widths from 0.3 to 0.9 inches and also provides power and ground connections.

### 4.2 IV BUS CONNECTIONS

The IV bus is the major communications link between the $8 \times 305$ MicroController and its family of peripherals. The bus is logically partitioned into two banks, referred to as the Left-Bank and Right-Bank. In the Prototyping System the $8 \times 350$ Working Storage RAM is connected to the Left-Bank, and the 8X320 Register Array, 8X360 Memory Address Director, and 8X372 I/O Ports are connected to the Right-Bank. All IV bus signals are present at connector J2 as shown in Table 4-1.

Table 4-1 IV BUS CONNECTOR J2

| Pin No. | Signal | Description |
| :---: | :---: | :---: |
| 1 | $\overline{\text { IVO }}$ | BUS (MSB) |
| 3 | $\overline{\mathrm{V} 1}$ | BUS |
| 5 | $\overline{\mathrm{IV} 2}$ | BUS |
| 7 | $\overline{\mathrm{V} 3}$ | BUS |
| 9 | $\overline{\text { IV4 }}$ | BUS |
| 11 | $\overline{\text { IV5 }}$ | BUS |
| 13 | IV6 | BUS |
| 15 | IV7 | BUS(LSB) |
| 17 | $V_{C C}$ | +5V |
| 19 | $V_{\text {CC }}$ | +5V |
| 21 | HALT | Halt |
| 23 | $\overline{\text { RESET }}$ | Reset |
| 25 | MCLK | Clock |
| 27 | $\overline{\text { LB }}$ | Left-Bank |
| 29 | $\overline{\mathrm{RB}}$ | Right-Bank |
| 31 | SC | Select Control |
| 33 | WC | Write Control |
| (All even pins) | GND | Ground |

### 4.3 I/O PORTS

These $8 \times 372$ I/O ports have been provided on the Right-Bank of the IV bus for latching of input or output data. The ports are programmed for addresses 000,001 and 002 and all signals are available at connectors J4. J5 and J6 respectively. Signals on these connectors are described in Table 4-2. Note that I/O port compatibility allows the user to substitute an $8 \times 376$ or $8 \times 382$ for any one of the $8 \times 372$ I/O ports. (One $8 \times 371$ non-addressable I/O port may be substituted, but ONLY if all other components on that bank are removed.)

Table 4-2 I/O PORT CONNECTORS
J4, J5, AND J6

| $\begin{aligned} & \mathrm{Pin} \\ & \mathrm{No} . \end{aligned}$ | Signal | Description |
| :---: | :---: | :---: |
| 2 | UD7 | User Data (LSB) |
| 4 | UD6 | User Data |
| 6 | UD5 | User Data |
| 8 | UD4 | User Data |
| 10 | UD3 | User Data |
| 12 | UD2 | User Data |
| 14 | UD1 | User Data |
| 16 | UDO | User Data (MSB) |
| 18 | $\overline{U O C}$ | Output Control |
| 20 | UIC | Input Control |
| (All odd pins) | GND | Ground |

### 4.4 EXTENDED MICROCODE CAPABILITY

"Extended Microcode" is a technique commonly used in $8 \times 305$ MicroController based designs to optimize performance. It is implemented by designing program memory to be wider than the 16 -bit instruction word required for the $8 \times 305$. The additional bits are referred to as the extension and can be used for fast I/O selection or other system control and status monitoring purposes.
The Prototyping System uses a 24 -bit instruction word, thus providing facilities for 8 bits of extended microcode. These bits are accessible to the user at connector J3 as shown in Table 4-3.

## Table 4-3 EXTENDED MICROCODE BITS AT CONNECTOR J3

| $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Signal | Description |
| :---: | :---: | :---: |
| 1 |  | No Connection |
| 3 | EDO | Extended Microcode (MSB) |
| 5 | ED1 | Extended Microcode |
| 7 | ED2 | Extended Microcode |
| 9 | ED3 | Extended Microcode |
| 11 | ED4 | Extended Microcode |
| 13 | ED5 | Extended Microcode |
| 15 | ED6 | Extended Microcode |
| 17 | ED7 | Extended Microcode (LSB) |
| 19 |  | No Connection |
| (All even pins) | GND | Ground |

Table 4-4 8X320 SIGNAL CONNECTIONS

| $\frac{\text { Signal }}{\bar{W}}$ | $\underline{\text { Description }}$ |  |
| :--- | :--- | :--- |
| AO |  | Primary Port Address (LSB) |
| A1 |  | Primary Port Address |
| A2 |  | Primary Port Address |
| A3 |  | Primary Port Address (MSB) |
| $\overline{\text { PIOE }}$ |  | Programmed I/O Enable |
| R/W |  | Read/Write Control |
| WS |  | Write Strobe |
| $\overline{\text { DMAE }}$ |  | Direct Mem. Access Enable |
| D7A |  | Primary Data Port (LSB) |
| D6A |  | Primary Data Port |
| D5A |  | Primary Data Port |
| D4A |  | Primary Data Port |
| D3A |  | Primary Data Port |
| D2A |  | Primary Data Port |
| D1A |  | Primary Data Port |
| D0A |  | Primary Data Port |
| D7B |  | Primary Data Port |
| D6B |  | Primary Data Port |
| D5B | Primary Data Port |  |
| D4B | Primary Data Port |  |
| D3B | Primary Data Port |  |
| D2B | Primary Data Port |  |
| D1B | Primary Data Port |  |
| D0B | Primary Data Port (MSB) |  |

### 4.5 8X310 CONNECTIONS

The $8 \times 310$ is connected to the $8 \times 305$ MicroController and the Writeable Control Store RAM to provide interrupt and subroutine capability. Five additional signals are provided for user interface as described in the $8 \times 310$ data sheet. These signals are accessible at tie points just to the right of the $8 \times 310$ chip:

| STF | Stack Full Status |
| :--- | :--- |
| ID | Interrupt Disable Control |
| INT0 | Interrupt 0 Input |
| INT1 | Interrupt 1 Input |
| INT2 | Interrupt 2 Input |

### 4.6 8X320 CONNECTIONS

An 8X320 Bus Interface Register Array has ben provided on the IV Bus as a Right-Bank I/O device for interfacing to the user's system. The primary data, status and command signals are accessible at tie points located between the $8 \times 320$ and the wire-wrap area. A list of these signals is provided in Table 4-4.

### 4.7 8X360 CONNECTIONS

The 8X360 Memory Address Director has been incorporated into the Prototyping System design to facilitate implementation of a DMA channel. It is connected to the IV Bus as a RightBank I/O device. Interconnection to the signals listed in Table 4-5 can be made at the tie points located between the 8X360 and the wire-wrap area.

In applications using extended microcode to enable I/O devices care must be taken to avoid IV Bus contention with $8 \times 300$ Family peripheral devices enabled through the more commonly used address - select cycle. Refer to the $8 \times 305$ Users Manual for more information on extended microcode operations.

### 4.8 MEMORY EXPANSION

The Prototyping System is provided with 256 24-bit words of Writeable Control Storage; 16 bits for $8 \times 305$ instructions and 8 bits for extended microcode. The depth of Control Storage can be increased by the connection of an expansion module to connector J 1 , as shown in Table 4-6. A 4096 word Writeable Control Storage Expansion Module is available from Signetics (Part Number $8 \times 300 \mathrm{KT} 2 \mathrm{SK}$ ). A schematic for this expansion module is provided in Appendix D.

Table 4-5 8X360 SIGNAL CONNECTIONS

| Signal | Description |
| :---: | :---: |
| CLK | Clock Input |
| TC | Terminal Count Status |
| LABN | Loop Abort Control |
| TSCL | Tri-state Control |
| A0 | Address Output (LSB) |
| A1 | Address Output |
| A2 | Address Output |
| A3 | Address Output |
| A4 | Address Output |
| A5 | Address Output |
| A6 | Address Output |
| A7 | Address Output |
| A8 | Address Output |
| A9 | Address Output |
| A10 | Address Output |
| A11 | Address Output |
| A12 | Address Output |
| A13 | Address Output |
| A14 | Address Output |
| A15 | Address Output (MSB) |
| RSO | Register Select (LSB) |
| RS1 | Register Select |
| RS2 | Register Select |
| RS3 | Register Select (MSB) |

## Table 4-6 MEMORY EXPANSION CONNECTOR J1

| Pin No. | Signal | Description | Pin <br> No. | Signal | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | RAMEN | Disables on-board RAM | 2 | 115 | $8 \times 305$ Instruction (LSB) |
| 3 | GND | Ground | 4 | 114 | $8 \times 305$ Instruction |
| 5 | GND | Ground | 6 | 113 | $8 \times 305$ Instruction |
| 7 | OD | Output Disable | 8 | 112 | $8 \times 305$ Instruction |
| 9 | BKPT | Breakpoint | 10 | 111 | $8 \times 305$ Instruction |
| 11 | $\bar{W}$ | Write | 12 | 110 | $8 \times 305$ Instruction |
| 13 | - | No Connection | 14 | 19 | $8 \times 305$ Instruction |
| 15 | - | No Connection | 16 | 18 | $8 \times 305$ Instruction |
| 17 | - | No Connection | 18 | 17 | $8 \times 305$ Instruction |
| 19 | - | No Connection | 20 | 16 | $8 \times 305$ Instruction |
| 21 | CE1 | Chip Enable | 22 | 15 | $8 \times 305$ Instruction |
| 23 | A0 | 8X305 Address (MSB) | 24 | 14 | $8 \times 305$ instruction |
| 25 | A1 | 8X305 Address | 26 | 13 | $8 \times 305$ Instruction |
| 27 | A2 | $8 \times 305$ Address | 28 | 12 | $8 \times 305$ Instruction |
| 29 | A3 | 8X305 Address | 30 | 11 | $8 \times 305$ Instruction |
| 31 | A4 | 8X305 Address | 32 | 10 | 8X305 Instruction (MSB) |
| 33 | A5 | $8 \times 305$ Address | 34 | E7 | Extended Microcode (LSB) |
| 35 | A6 | $8 \times 305$ Address | 36 | E6 | Extended Microcode |
| 37 | A7 | $8 \times 305$ Address | 38 | E5 | Extended Microcode |
| 39 | A8 | $8 \times 305$ Address | 40 | E4 | Extended Microcode |
| 41 | A9 | $8 \times 305$ Address | 42 | E3 | Extended Microcode |
| 43 | A10 | $8 \times 305$ Address | 44 | E2 | Extended Microcode |
| 45 | A11 | $8 \times 305$ Address | 46 | E1 | Extended Microcode |
| 47 | A12 | $8 \times 305$ Address (LSB) | 48 | EO | Extended Microcode (MSB) |
| 49 | $V_{C C}$ | +5V | 50 | $V_{C C}$ | $+5 \mathrm{~V}$ |

## THEORY OF OPERATION

As can be noted with the aid of the block diagram in Figure 5-1, the $8 \times 305$ prototyping system board contains circuits which may be categorized as follows:

1. Monitor Processor
2. 8X305 MicroController and Family
3. Writeable Control Store
4. Run/Step Logic

### 5.1 FUNCTIONS OF THE MONITOR PROCESSOR

The Monitor Processor, an 8035 microprocessor and peripherals, controls all the commands and operations described in Chapter 3. The Monitor processor handles all communication with the terminal as well as reading and writing the $8 \times 305$ 's program storage, registers, and I/O port contents.

The $8 \times 305$ can execute instructions from Writeable Control Storage or an instruction that is latched into the 8243
by the Monitor Processor. Typically the instruction in the 8243 will store or read an $8 \times 305$ 's register contents, I/O Port contents, or set the address in the 8 X305 Program Counter.
The 8243 is also used to read and write the contents of Writeable Control Store. Since the 8X305 does not have an address bus that can be three-stated and because a buffer would increase the memory access time, to read a specific memory location a JMP is "forced" upon the 8 X305 by way of the 8243 to set the address lines.
The Monitor Processor reads the register contents of the $8 \times 305$ by forcing an XEC $R n, 000$, where $R n$ is the desired register. This causes the register contents to be placed on the lower eight address lines of the $8 \times 305$ where it may be read by the Monitor Processor and sent out on the RS-232 interface. To store a value into the $8 \times 305$, the Monitor Processor will force a XMT Rn, XXX, where XXX is the desired register contents. (For R12 and R13, this will be
accomplished by a XMT followed by a MOV.)

### 5.2 8X305 FAMILY

With the following two exceptions the 8X305 MicroController and its supporting peripherals connect to the prototyping system in a conventional manner:

1. Rather than a direct tie to the MCLK output of the $8 \times 305$, the MCLK input to the $8 \times 310$ Interrupt Control Coprocessor is gated. The gating circuits are required to implement correct single-step operation of the system.
2. The HALT and RESET inputs to the $8 \times 305$ are gated. Connected in this manner, the HALT and RESET signals will only affect the MicroController in the run mode. User circuits requiring either or both of these inputs should pick up the signals via the IV Bus connector J2.


Figure 5-1. Detailed Block Diagram

### 5.3 WRITEABLE CONTROL STORAGE

Instead of the usual PROM or ROM instruction storage found in a typical $8 \times 305$ based system, a Writeable Control Store (WCS) has been implemented with high speed RAM to facilitate programming via the RS-232 terminal. The RAM memory provides $256 \times 16$ bits for $8 \times 305$ instruction storage, $256 \times 8$ bits for extended microcode, and $256 \times 1$ bit for breakpoints. If extended microcode is not desired the RAM chip at U21 may be removed and references to the extension will be removed from the display. Any one or all memory address locations may contain a breakpoint.
Note that no page decoding is provided on the board, so the 256 words of instructions will be repeated every 256 addresses throughout the entire 8 K memory range of the $8 \times 305$.
The memory may be expanded up to the full 8 K directly addressable by the 8X305. A 4 K word Writeable Control Storage Expansion Module is available from Signetics (Part Number $8 \times 300 \mathrm{KT} 2 \mathrm{SK}$ ). When the additional memory is installed in J1, the RAM enable (RAMEN) signal is grounded to disable the on-board 256-word memory, and the Monitor Processor is signaled to provide the correct write cycle at J 1 for the added RAM. See Figure 5-2 for the differences:


Figure 5-2. Write Cycle Variations

### 5.4 RUN STEP LOGIC

The Run-Step logic consists of components U5, U6, U7, U9 and U10 on the schematic in Appendix A. These circuits provide the control logic required to allow the $8 \times 305$ to execute instructions at full speed or in a single step mode of operation. This is easily accomplished since all instructions are executed within one machine cycle, the time from the falling edge of MCLK to the next falling edge of MCLK. The HALT input is sampled by the $8 \times 305$ sometime after the falling edge of MCLK. If it is low, the address lines of the MicroController are held stable; the current instruction is executed after the HALT input goes high (inactive). During the time that the HALT input is low (active), the MCLK output is unaffected. Inputs to the Run-Step logic are labeled RUN/WAIT, STEP, BKPT and MCLK; the output is labeled HALT and connected directly to the HALT input of the $8 \times 305$ MicroController.
Two of the inputs, RUN/WAIT and STEP, are controlled by the Monitor Processor. The BKPT input connects to the extra bit in WCS that is used for breakpoints. The MCLK input comes directly from the MCLK output of the 8X305.
During single stepping the RUN/WAIT line is low and a puise on the STEP line causes the $8 \times 305$ to execute only the current instruction. This is because the HALT line will go high for just one machine cycle. Entering the run mode the RUN/WAIT line is high and a pulse on the STEP line causes the $8 \times 305$ to begin executing instructions from the current address at full speed. The HALT input will go high and remain so until the RUN/WAIT line is brought low or until a breakpoint is encountered.



Appendix B. 8X300KT1SK PCB Layout and Parts Placement

| Item No. | Manufacturer | Part Number | Description | Designator | Qty. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Signetics | MC1488N | Quad Line Driver | U1 | 1 |
| 2 | Signetics | SCN2661CC1N28 | EPCI | U2 | 1 |
| 3 | Signetics | N74LS04N | Hex Inverter | U3, U12 | 2 |
| 4 | Signetics | N74LS08N | Quad AND Gate | U4 | 1 |
| 5 | Signetics | N74S74N | Dual D-Flip-Flop | U5 | 1 |
| 6 | Signetics | N74S112N | Dual J-K Flip-Flop | U6 | 1 |
| 7 | Signetics | N74S10N | Triple NAND Gate | U7 | 1 |
| 8 | Signetics | N74S32N | Quad OR Gate | U8 | 1 |
| 9 | Signetics | N74S11N | Triple AND Gate | U9, U10 | 2 |
| 10 | Signetics | MC1489N | Quad Line Receiver | U11 | 1 |
| 11 | Signetics | N74LS373N | Octal Latch | U13 | 1 |
| 12 | Intel | P8255A | PPI | U14 | 1 |
| 13 | Signetics | 82S212N | $256 \times 9$ RAM | U15, U18, U21 | 3 |
| 14 | Signetics | N8X310N | Interrupt Control Coprocessor | U16 | 1 |
| 15 | Intel | 2732A-4 | $4096 \times 8$ EPROM | U17 | 1 |
| 16 | Signetics | SCN8035AC6N40 | 8-Bit Microcomputer | U19 | 1 |
| 17 | Intel | P8243 | Input/Output Expander | U20 | 1 |
| 18 | Signetics | N74F373N | Octal Latch | U22 | 1 |
| 19 | Signetics | $8 \times 3051 / \mathrm{N}$ | MicroController | U23 | 1 |
| 20 | Signetics | N8X360N | Memory Address Director | U24 | 1 |
| 21 | Signetics | N8X320N | Register Array | U25 | 1 |
| 22 | Signetics | N8×372-000N | I/O Port | U26 | 1 |
| 23 | Signetics | N8X372-001N | 1/O Port | U27 | 1 |
| 24 | Signetics | N8×372-002N | 1/O Port | U28 | 1 |
| 25 | Signetics | N8X350N | $256 \times 8$ RAM | U29 | 1 |
| 26 | ITT CANNON | DBP-25SAA | RS-232 Connector | P1 | 1 |
| 27 | TRW CINCH | 252-25-30-360 | Edge Connector, 50 Pin | $J 1$ |  |
| 28 | Spectra-Strip | 800-579 | Header, 34 Pin | J2 | 1 |
| 29 | Spectra-Strip | 800-586 | Header, 20 Pin | J3, J4, J5, J6 | 4 |

Appendix C. Parts List

| Item No. | Manufacturer | Part Number | Description | Designator | Qty. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 30 | Reliability | VA12-12 | DC-DC Converter |  |  |
| 31 | Saronix | NMP051L | Crystal, 5.688 MHz | Y1 | 1 |
| 32 | Saronix | NMP100L | Crystal. 10.000 MHz | Y2 | 1 |
| 33 |  | 2N5320 | Transistor | Q1 | 1 |
| 34 | ALCO | DSS-4 | Switch, Mini-dip | B2. B1. B0. LF | 1 |
| 35 | Smith | 230 | Binding Post |  | 4 |
| 36 |  | 1N914 | Diode | CR1 | 1 |
| 37 |  |  | CAP. $0.1 \mu \mathrm{~F}$ |  | 28 |
| 38 |  |  | CAP. $47 \mu$ F. 20 V | C2. C3. C4 | 3 |
| 39 |  |  | CAP. $47 \mu \mathrm{~F} .6 \mathrm{~V}$ | C1 | 1 |
| 40 |  |  | CAP. 47 pF | C5 | 1 |
| 41 |  |  | CAP, $0.1 \mu \mathrm{~F}$ | C6 | 1 |
| 42 |  |  | RES., 1K, 1/4 W | R19 | 1 |
| 43 |  |  | RES., 10K, 1/4 W | R1. R2. R3 | 3 |
| 44 |  |  | RES., 390, 1/4 W | R4. R5 | 2 |
| 45 |  |  | RES. 2.2K.1/4 W | R6-R13.R15 <br> R17. R18, R20. <br> R21 | 13 |
| 46 |  |  | RES.. 18, 1 W | R16 | 1 |
| 47 | H.H. Smith | 2501 | Bolt. Nylon 4-40*3/8" | P1 | 2 |
| 48 | H.H. Smith | 2554 | HEX Nut. Nylon 4 -- 40 | P1 | 2 |
| 49 | BURNDY | DILBQ50P-101 | Socket. 50 Pin | U23 | 1 |
| 50 | T.I. | C844002 | Socket. 40 Pin | U14. U16. U19 U24. U25 | 5 |
| 51 | T.I. | C842802 | Socket. 0.6" 28 Pin | U2 | 1 |
| 52 | T. 1. | C842402 | Socket. 0.6" 24 Pin | U17. U20 | 2 |
| 53 | EMC | 17424-01-445 | Socket. 0.4"24 Pin | U26. U27. U28 | 3 |
| 54 | T.I. | C842202 | Socket. 0.4"22 Pin | U15. U18. <br> U21. U29 | 4 |
| 55 | T. 1. | C842002 | Socket. 0.3" 20 Pin | U22 | 1 |
| 56 | Signetics | PCB-82001 | P.C. Board |  | 1 |
| 57 | H.H. Smith | 2450 | Rubber Bumper |  | 5 |

Appendix C. Parts List continued


Appendix D. Memory Expansion Assembly Schematic


## FEATURES

- Diagnostic Monitor for controlled program execution, 32 breakpoints, register, memory and I/O port examination/change, download/upload memory
- In-line assembler/disassembler for fast debugging of 8X305 code in symbolic assembly language
- System trace memory for 128 addresses, 12 bites each
- On-board emulation memory of $4096 \times 24$ bits
- Supports all other 8X305 family devices
- Supports microcoded designs using expanded instruction widths
- Power-on diagnostics
- Emulator and software runs with other CPiM* or ISIS* based systems


## COMPLETE HARDWARE/SOFTWARE DEVELOPMENT SYSTEM INCLUDING:

- 8X305 Emulator module
- CP/M 2.2 System - Z80A, 64K RAM, dual minifloppies with 1.6 Mbytes storage
- Screen oriented editor for easy program development
- Cross Assembler supporting Signetics standard format mnemonics
- IBM P.C. version available


## FASTER PRODUCT DEVELOPMENT

Demanding control applications based on the low cost, high performance Signetics 8X305 bipolar microcontroller can now be developed and implemented quickly and economically with the SIGEN 8 X305 ICEPACK.

ICEPACK is a powerful, high performance development and in-circuit emulation system for use with the $8 \times 305$ series microcontroller product family. Designed for CP/M compatibility, ICEPACK provides a cost-effective means of rapid product development without the costly dedicated resources previously required.

[^18]
## PERFORMANCE YOU NEED

ICEPACK provides both the hardware performance and software tools needed for efficient $8 \times 305$ product development throughout a broad range of applications. Designed specifically by SIGEN for the development of 8X305 based products, ICEPACK performance has been proven throughout a variety of products. Its capabilities are especially useful in real time control applications.

The ICEPACK Emulator module simply plugs into the prototype system $8 \times 305$ socket through a flat ribbon cable. The ICEPACK's superior noise immunity eliminates typical problems associated with circuit interfacing. The ICEPACK Emulator hardware features high speed electronics supporting clock operation up to 10 MHz . Rugged packaging assures long life and reliable operation.

ICEPACK software includes:

- Powerful screen oriented Editor for easy program devlopment.
- Full featured Cross Assembler supporting standard Signetics mnemonics.
- Powerful diagnostic Monitor enabling controlled program execution including single stepping, breakpoint setting, memory and register examination an modification.
- In-line assembler/disassembler for easy assembly language and debug and patching.


## FITS YOUR REQUIREMENTS

ICEPACK is available ready to use as a system, or ready to interface to your floppy based CP/M system. Either way, you get the same powerful ICEPACK System capabilities. The ICEPACK System includes a Z80A based, 64K RAM, dual flop-
py system, ICEPACK Emulator, interface adapter, CP/M 2.2 and all ICEPACK software and manuals. The ICEPACK Subsystem includes Emulator, parallel interface adapter, interface cables, ICEPACK software, and user manuals.

## TECHNICAL SPECIFICATIONS

Power Requirements: 115/230VAC, 100 W
Physical (CP/M System) . (Emulator)
Height $\quad 7.5$ inches 190 mm 1 inch 25 mm
Width
Depth
Weight
9.5 inches 241 mm 6 inches 152 mm
14.5 inches 368 mm 8 inches 204 mm
13.0 pounds 5.9 kg 1 pound .45 kg

Environmental
Operating Temperature: $0^{\circ} \mathrm{C}$ to $+40^{\circ} \mathrm{C}$
Storage: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Cables
(Target System)

- 100 wire flat cable, 18 inches long
- 20 wire flat cable, 18 inches long
(CP/M System)
- 37 wire flat cable, 5 feet long

Enclosure
(Emulator)

- Anodized brushed aluminum
(CP/M System)
- High impact plastic with internal shielding


## DEVELOPMENT DATA I/O PORT PROGRAMMER

## Hardware Features

- Real time in-circuit emulation to 10 MHz without wait states.
- 8 K words of 35 ns RAM, 16 or 32 -bit words.
- Memory mapping in 1 K word increments.
- Compatible with 8X310 Interrupt Control Chip.
- Trace capability includes 128 cycles of address, IV bus, RB, LB, WC, SC, and 3 selectable points in target system. Both input and output phases are traced in each cycle.
- Downloading and Uploading capability provided.
- I/O Port Programmer for $8 \times 372,8 \times 376,8 \times 382$.


## Software Features

- Relocating macroassembler compatible with Signetics MCCAP.
- Linking editor permits linking separately-assembled modules to form one load module.
- Debugger program controls single stepping, stopping on a specified address, printing trace information, disasembling, program patching, changing register contents and memory management. Symbolic debug capability is provided.
- Command file capability provided in the Asembler, Linking Editor, and Debugger program.
- PROM formatting program available. Slices 16 and 32-bit words into 4 or 8 -bit groups.


## BLOCK DIAGRAM

The block diagram shows how the $8 \times 300 / 305$ support devices are incorporated in an EZ-PRO system. Devices unique to the $8 \times 300 / 305$ includes the AA-572-8X35 In-Circuit Emulator, the AA-572-8X35-M Emulator Extension and the AA-574-8X37 I/O Port Programmer. The Emulator Extension provides an extra sixteen bits of word length over the basic sixteen bits required for the $8 \times 300 / 305$ processor and may or may not be required in a particular development. Note that the emulator consists of three printed circuit board assemblies and the extension, two.

The Address Control assembly incorporates trace memory and logic for memory mapping, stopping, and single stepping as well as circuitry required to communicate with the User Interface and Master Processor. Each Emulator Memory assembly is equipped with 8 K 16 -bit words of 35 ns memory as well as interface circuitry. This memory is loaded and unloaded under control of the Master Processor and is accessed by addresses generated by the $8 \times 300 / 305$.

The 8X300/305 User Interface has the processor mounted on it along with cable termination networks, cable drivers, some logic and test points. Test points are provided for the three points which may be traced in the target system, connection to the $8 \times 310$ Interrupt Control Chip and oscilloscope sync.

TARGET SYSTEM


The Extension User Interface is equipped with six DIP sockets and cables which permit connection into PROM sockets located in the target system. Four of the sockets are 18 pin (for 4-bit wide PROMs) and two are 24 pin (for 8 -bit wide PROMs). Either set of sockets and cables may be used. Pin outs are compatible with Signetics 82S137, 185, 181, and 191 PROM types.

PROM programming is supported in two ways. Both require that PMFORM, the PROM formatting program, be utilized. After PMFORM has created files consisting of either 4 -bit or 8 -bit wide slices of the object program words, these files may be directed to a DATA I/O (or equivalent) PROM programmer connected to the RS232 printer port. Alternatively, with 8-bit wide slices, the AA-574-27XX EPROM Programmer may be utilized to write the files into 2716 or 2732 EPROMs. With appropriate off-line equipment, information in the EPROMs may be transferred into bipolar PROMs.

The I/O Port Programmer consists of a printed board assembly, an adaptor that fits into the ZIF socket located on the front of the AA-570 Basic Development Unit and a program. After checking to see that the $8 \times 372 / 376,382$ is properly oriented in the ZIF socket and fuses are unblown, the program permits the desired address to be programmed into the I/O port. Complete checking is then accomplished including validation of the address and transfer of information in both directions through the port.

## EZ-PRO SYSTEM ELEMENTS

 FOR 8X300/305 SUPPORTModel Description

AA-570-200
AA-59X
AA-572-8X35
AA-572-8X35-M
AA-562
AA-563
AA-553
AA-574-8X37
AA-574-27XX
escription
Basic Development Unit
Dual Disk Unit
In-Circuit Emulator for 8X300/305
Emulator Extension
Printer, RS232 Interface
Video Terminal with Screen Editor
PMFORM, PROM Formatter Program
I/O Port Programmer
EPROM Programmer for 2716 \& 2732

Note that all required programs except PMFROM are supplied at no extra cost.

## 303A-8X PROGRAMMING TEST ADAPTER

The 303A-8X Programming Test Adapter is designed to program address fuses and activate protect fuses for Signetics' I/O Ports $8 \times 372,8 \times 374,8 \times 376$, and $8 \times 382$. Error messages are displayed if the programmed part is defective or if ambiguous addresses occur during the programming procedure. The test adapter operates in conjunction with the Data I/O Logic PAK 303A-V01 and various models of the Data I/O (System 19, 29A, and 100A). The Programming Test Adapter is quick and easy to use and most Signetics' Franchised Distributors provide on-site programming capabilities for customer parts.

## ECC APPLICATION NOTE

## INTRODUCTION

The widespread use of floppy/hard disk technologies in Commercial and Military environments has created the need for high-speed disk controllers that are capable of both errordetection and error-correction capabilities. At the present time, most disk controllers are limited to error-detection only, with one of the more widely used schemes being that of a Cyclic Redundancy generator Checker (CRC) and associated software/hardware support. Although the CRC technique is virtually foolproof from an error-detection point of view, it has no provision for error correction. With bit and track densities constantly on the increase, it is desirable to implement a reliable error-correction feature to improve the performance and reliability of the disk controller.
This application note describes a software approach to error correction for the Signetics 8×305/8×330 based floppy disk controller and 8X305 based hard disk controller. A typical floppy disk controller system is shown in Figure 1. This error correction algorithm can correct up to a 9 -bit single burst error and is fully compatible with controllers that use the CRC-CCITT $\left(X^{16}+X^{12}+X^{5}+1\right)$ polynomial. The Signetics $8 \times 330$ floppy disk controller chip provides some unique features, unmatched by other LSI chips, which allow the 8X305 MicroController firmware to implement the error correction procedure.

## GENERAL SCHEME FOR ERROR DETECTION AND CORRECTION

Error Detection by CRC Polynomial. The CRC scheme for error detection is implemented with a CRC generator. During transmission, a block of binary serial data passes through a preset CRC generator to generate the necessary and unique check bits for a particular block of data. The check bits are appended to the end of the data block. The complete data and check bits are then transmitted to the receiver. At the receiver, the complete data and check bits pass through the same preset CRC generator. If no errors occurred during data transmission, the CRC generator must have a remainder of all zeros.

Hardware implementation of the CRC generator is simply a feedback shift register with EX-OR gating. Figure 2 shows the equivalent circuit for the CRC-CCITT ( $X^{16}+X^{12}+X^{5}+1$ ) generator. The CRC-CCITT polynomial is the industry standard used in floppy disk controllers; however, if desired, other CRC polynomials can be easily implemented. In any case, there are as many register stages as the highest order of the polynomial and the number of EX-OR gates is one less than the number of $X$-terms. The detection span for a particular polynomial equals the number of the highest order X -term. For CRC-CCITT, the detection span is 16 bits.

Error Correction by Reverse CRC Polynomial. Several different error correction algorithms are currently used in high-performance disk systems. The error correction procedure described in this application note is based on the reciprocal polynomial algorithm.

The reciprocal or reverse polynomial for a particular forward polynomial can be derived by subtracting the order of every X-term of the forward polynomial from the highest order of the forward polynomial. For example, the CRC-CCITT polynomial is $X^{16}+X^{12}+X^{5}+1$, hence the CRC-CCITT reverse polynomial is $X^{16}+X^{11}+X^{4}+1$ (i.e., $X^{16-16}+X^{16-12}+$. $X^{16-5}+X^{16-0}$ ). Figure 3 shows the equivalent circuit and the hardware implementation for the CRC-CCITT forward/ reverse polynomial.

As described previously, error detection is achieved by examining the remainders of the CRC generation after the complete data and CRC check bits have passed through the CRC generator. A nonzero remainder indicates a read-data error. A nonzero remainder contains information to determine the error pattern and its location. Error correction is achieved by manipulating the nonzero remainder in a reverse CRC generator.

The error correction procedure begins with the loading of the nonzero remainder into the reverse CRC generator in reverse order. The Most Significant and Least Significant Bits


Figure 2. Equivalent Circuit for CRC-CCITT ( $x^{16}+x^{12}+x^{5}+1$ )


Note:

1. Shaded blocks may change to suit users system requirements.

Figure 1. 8×330 Based Floppy Disk Controller-Block Diagram
of the remainder are loaded into the Least Significant and Most Significant Bits of the reverse CRC generator, respectively. The DATA IN input of the reverse CRC generator is connected to ground to provide zero data input during the complete error correction process. Clocking is then provided for the CLOCK input. The contents of the generator are examined for an error condition after each clock cycle. If the generator has " $n$ " register stages and " $m$ " is the desired single burst correction span, then the error condition is characterized by ( $\mathrm{n}-\mathrm{m}$ ) consecutive zeros at specified bit locations. The number of clock cycles needed to find the error pattern provides the error location information.

## ERROR DETECTION AND CORRECTION SCHEME FOR 8X305/8X330 BASED CONTROLLER

Features of $8 \times 305 / 8 \times 330$ Based Floppy Disk Controller. The following error correction scheme for 8X305/8X330 based disk controllers requires two forward CRC generators (CRC1F and CRC2F) and two reverse CRC generators (CRC1R and CRC2R). The CRC1F generator has been implemented in the 8X330 hardware. The CRC2F, CRC1R, and CRC2R generators are implemented in the 8X305 firmware. One unique feature of the $8 \times 330$ is that the remainder in the internal CRC generator can be read by the controlling processor. This feature provides the required information for the

8X305 MicroController to do error correction in the firmware. The MOS LSI floppy disk controller implementation does not provide this flexibility and only generates a read error status flag for error detection.
The speed of the $8 \times 305$ MicroController and its bitmanipulation oriented instruction set, combined with the 8 -bit parallel CRC calculation algorithm described below allows the $8 \times 305$ to compute CRC for 8 bits of data input in 4 to 5 microseconds. Thus, even with a data transfer rate of 500 K bits/sec for a double density 8 -inch floppy disk drive, the $8 \times 305$ is fast enough to control the $8 \times 330$ and compute the CRC for CRC2F in software on-line, as each data byte is transferred between the 8X305 and 8X330 during the read and write cycles.

Two Forward CRC Polynomials. The first 16 -bit forward CRC polynomial (CRC1F) is the CRC-CCITT ( $\mathrm{X}^{16}+\mathrm{X}^{12}+$ $X^{5}+1$ ), which is the standard polynomial used in floppy disk controllers. The second 16 -bit forward CRC polynomial (CRC2F) is $X^{16}+X^{13}+X^{12}+X^{10}+X^{8}+X^{6}+X^{5}+X^{4}+1$. This polynomial is chosen by computer search to achieve a single burst correction span of 9 bits. A 16-bit CRC check word is generated for each of the two polynomials. These two 16-bit CRC check words are appended to the end of the transmit data. The CRC-CCITT is chosen for the first polynomial to achieve media compatibility with old (8X300)


Figure 3. Equivalent Circuit and Hardware Implementation for CRC-CCITT Forward/Reverse Polynomial ( $\left.\mathrm{x}^{16}+\mathrm{x}^{11}+\mathrm{x}^{4}+1\right)$
controllers without error correction capability and the $8 \times 305 / 8 \times 330$ based controller implemented with the proposed error correction scheme. A disk generated by earlier 8X300 MicroControllers can be read by the controller with the proposed error correction scheme and vice versa.
Software Implementation of the CRC2F Generator. The hardware implementation of the CRC2F generator is illustrated in Figure 4. The CRC2F generator shifts left one bit
each clock cycle. The most significant bit is located on the left side of the generator. Left shift is used to simplify the software implementation, because the MSB of the data byte transferred between the 8X305 and 8X330 is on the left side. The 8 -bit parallel CRC generation mechanism is shown in Figure 5. The initial contents of the generator are represented by symbols "abc. . . n op" with " $a$ " and " $p$ " being the MSB and LSB, respectively.


Figure 4. Hardware Implementation for $x^{16}+x^{13}+x^{12}+x^{10}+x^{8}+x^{6}+x^{5}+x^{4}+1$ (CRC2F)


Figure 5. 8-Bit Paraliel CRC Generation Mechanism for $x^{16}+x^{13}+x^{12}+x^{10}+x^{8}+x^{6}+x^{5}+x^{4}+x^{1}$

The eight bits of data input are symbolized by " $q$ r stuvw x", with " $q$ " being the MSB. The top part of Figure 5 is a symbolic representation of the eight left shift operations of the CRC generator shown in Figure 4, for the eight serial data input bits. As the first data bit " $q$ " comes in, it is EX-ORed with the MSB of the CRC generator. The result of this operation, " $q$ ' ", is then fed back and EX-ORed with the outputs of several register stages as shown in Figures 4 and 5. Then the generator is clocked and shifted left by one bit postion. This sequence of operations is repeated for the eight data inputs shown at the top of Figure 5. The bottom part of Figure 5 summarizes the number of EX-OR operations required to


Figure 6. Steps Required for the Software Implementation of CRC2F
derive the result. The operands of the EX-OR operations are mostly the field, rotated field, or subfield of the byte " $q^{\prime} r^{\prime} s^{\prime} t^{\prime} u^{\prime} v v^{\prime} w^{\prime} x^{\prime}$. This special characteristic, together with the $8 \times 305$ bit manipulation instruction set, permits an 8 -bit parallel CRC calculation for a 16 -bit polynomial to be accomplished in 4 to 5 microseconds. Figure 6 shows the software steps required to implement the 8 -bit parallel CRC calculation. The first step is to derive the byte " $q^{\prime} r^{\prime} s^{\prime} t t^{\prime} u^{\prime} v^{\prime} w^{\prime} x^{\prime \prime}$ " from the 8 -bit data input and the initial contents of the CRC generator by operations $\mathrm{A}, \mathrm{B}$, and C . The result is derived by a sequence of EX-OR operations as shown in Figure 6. The software implementation of CRC2F requires a total of 21 instructions, as shown in line numbers 448 to 471 of the program listing.

Two Reverse CRC Polynomials. Since the error correction scheme described in this application note uses the reciprocal polynomial algorithm, two reverse CRC generators, corresponding to CRC1F and CRC2F, are required during the correction cycle. The two reverse CRC generators are referred to as CRC1R and CRC2R.

$$
\begin{aligned}
& \text { CRC1R }=X^{16}+X^{11}+X^{4}+1 \\
& \text { CRC2R }=X^{16}+X^{12}+X^{11}+X^{8}+X^{6}+X^{4}+X^{3}+1
\end{aligned}
$$

Software Implementation of the CRC1R and CRC2R Generators. The implementation of the CRC1R and CRC2R generators in software is similar to that of the CRC2F. There are two exceptions:

- During the correction cycle, the DATA $\mathbb{N}$ inputs of the reverse CRC generators are connected to ground.
- The reverse CRC generators shift right, so that the MSB is on the right-hand side, thus simplifying the software. As errors are detected, the error correction procedure requires that the nonzero remainders of the forward CRC generators be loaded into the reverse CRC generators in reverse order; that is, the MSB from the forward CRC generator is loaded into the LSB of the corresponding reverse CRC generator. This process is achieved by loading the most significant byte of the forward generator into the least significant byte of the reverse generator, because the MSB of the forward generator is on the left side and the MSB of the reverse generator is on the right side.
Figures 7 and 8 show the mechanics and steps required to implement the CRC1R generator of Figure 3 in software. A similar procedure is used to implement the CRC2R generator. The software coding of the CRC1R and CRC2R are shown in the line numbers 487 through 541 of the program listing.


## CRC GENERATOR SHIFTS RIGHT




Figure 7. 8-Bit Parallel CRC Generation Mechanism for CRC1R


Figure 8. Steps Required for the Software Implementation of CRC1R


Figure 9. Write Cycle


Figure 10. Read Cycle

Error Detection Scheme. As shown in Figure 9, four CRC check bytes are appended to the last bit of data during the write cycle. The first two check bytes are derived by passing the data address mark and data bytes through the preset CRC1F generator. After accepting the data address mark and data bytes, the contents of the CRC1F generator are the two CRC1F check bytes. The two CRC2F check bytes are generated by applying the data address mark, the data, and sixteen bits of zero as inputs to the preset CRC2F generator.

During the read cycle, the preset CRC1F generator calculates from the first bit of data address mark to the last bit of CRC1F check bit as illustrated in Figure 10. During the read cycle the data address mark, the data, sixteen bits of zero, and two CRC2F check bytes are input to the preset CRC2F generator. No error is detected if the remainders of the CRC1F and CRC2F generators are zeros. The types of errors associated with nonzero remainders are as follows:

| CRC1F | CRC2F |  |
| ---: | ---: | :--- |
| Remainder |  |  |
| Remainder |  |  |
| Zero | Zero | No error <br> Zero |
| Nonzero | Correctable error in CRC2F check <br> bytes (or uncorrectable error) |  |
| Nonzero | Zero | Correctable error in CRC1F check <br> bytes (or uncorrectable error) |
| Nonzero | Nonzero | Correctable error in data bytes |

Error Correction Scheme. Once an error has been detected, the nonzero remainders of the two forward generators are used to determine the error pattern and location by loading them into the corresponding reverse generators in reverse order. The reverse generators are then generated with zero data input and checked for error conditions, as shown in Figure 11. The method of implementing the error correction scheme is illustrated in Figures 12 through 18. The process of locating an error starts with checking for errors in


Figure 11. Data Flow
the CRC2F least significant check byte and working backwards towards the first data byte of the sector. If errors are found in the CRC check bytes, the controller will raise a CRC error status flag for the host CPU to take the appropriate action.

During the first two 8 -bit parallel reverse generation cycles, only the CRC2R is generated with zero data input, the CRC1R generator remains idle. If errors occur in the CRC2F check bytes, the CRC1R should have 16 bits of zeros and the seven MSBs of CRC2R should be zeros during any of the first sixteen reverse generation clock cycles. Since the CRC2R software reverse generates one byte at a time, it is possible to miss the CRC2R error condition, because the error condition may occur in between the byte boundary. In order to solve this problem, a CHECK subroutine is written to monitor the error condition within the boundary limits. If the error condition is not found, the CHECK subroutine will swap the most significant and least significant bytes of the generator to maintain the contents of the generator before getting into the subroutine.

After the second 8 -bit parallel reverse generation cycle, both the CRC1R and CRC2R are reverse generated one byte at a time until the error is found or the error is determined to be uncorrectable. An error is uncorrectable if it cannot be found within 2608 -bit reverse generation cycles. In the third 8 -bit reverse generation cycle, the procedure checks for errors in the CRC1F least significant byte or errors that spanned the CRC1F byte and the CRC2F most significant byte. The error conditions are eight bits of zeros for the CRC1R most significant byte and the CRC2R least significant byte at the byte boundary. If these conditions occur, a 16 -bit word is formed by concatenating the most significant byte of CRC2R with the least significant byte of CRC1R, and the CHECK subroutine, as described previously, is used to check for seven leading zeros within eight one-bit rotations towards the LSB. This condition is required to assure that errors occur in CRC1F least significant check byte or between CRC1F and CRC2F check bytes. In the fourth 8 -bit reverse generation cycle, the procedure checks for errors in the CRC1F check bytes. The error conditions are 16 bits of zeros for CRC2R and seven
leading zeros in CRC1R found by the CHECK subroutine. Errors occurring in the last data byte or errors that span the CRC1F most significant check byte and the last data byte are checked in the fifth 8 -bit reverse generation cycle. The error conditions are zeros in the CRC2R most significant byte, a match of the CRC1R and CRC2R least significant byte, and seven leading zeros in CRC1R found by the CHECK subroutine. The sixth to the two hundred sixtieth 8 -bit reverse generation cycles check for errors in data byte 255 to the first data byte. The error conditions are a match in CRC1R and CRC2R, and seven leading zeros in CRC1R found by the CHECK subroutine.

The error conditions described in the previous sections determine when to stop the reverse generation cycle. The number of reverse generation cycles required to meet the error conditions are used to calculate the error location by the following equation:

> Error location in Record length in bytes + 4 CRC
> terms of byte number $=$ check bytes - number of reverse generation cycles +1

If the error location is one, then errors exist in the first data byte or between the first and second data byte of the sector. For example, if errors exist between the first and second data bytes of a 256-byte sector, then the error conditions are met in the two hundred sixtieth reverse generation cycle.

$$
\begin{aligned}
\text { Error location } & =256+4-260+1 \\
& =1
\end{aligned}
$$

The error pattern is found in the CRC1R generator. Error correction is done by XORing the data bytes in the error location and error location plus one with the CRC1R least significant and most significant byte respectively, as illustrated in Figure 11.

## CONCLUSION

This application note describes one unique error correction algorithm for the 8X305 based floppy or hard disk controller. The algorithm can correct up to a 9 -bit single burst error. The error correction procedure can be implemented with approximately $3008 \times 305$ instructions. The worst case error correction time for a 256 -byte sector is 3.0 msec .


Figure 12. Reverse Generation Cycle \#1 (CRCIR not reverse generated)



Note:
Note:

1. If errors are found in the CRC check bytes, the controller will raise a CRC error status flag for the host CPU to take the appropriate action. The controller will only attempt to correct errors in the data bytes.

Figure 13. Reverse Generation Cycle \#2 (CRCIR not reverse generated)


Figure 14. Reverse Generation Cycle \#3


Note:

1. If errors are found in the CRC check bytes, the controller will raise a CRC error status flag for the host CPU to take the appropriate action. The controller will only attempt to correct errors in the data bytes.

Figure 15. Reverse Generation Cycle \#4


Figure 16. Reverse Gerieration Cycle \#5

## ERROR CONDITION:



Figure 17. Reverse Generation Cycle \#6


Figure 18. Reverse Generation Cycle \#260


Notes

- Indicates the modification from the IBM System 34 data track format

1. These bytes missing clock transitions between data bits 3 and 4 . Data flux transition $=C 2$, clock flux transition - 14 .
2. These bytes missing clock transitions between data bits 4 and 5 . Data flux transitions $=A 1$, clock flux transition $-O A$
3. CRC calculation starts at first byte of ID address mark and ends on the sector length byte using the CRC-CCITT polynomial.
4. The first two bytes are derived from the CRC-CCITT polynomial. The second two bytes are derived from a second 16 -bit polynomial ( $X^{16}+X^{13}+X^{12}+X^{10}+X^{8}+X^{6}$ $x^{5}+x^{4}+1$ ). The CRC calculation of the 1st polynomial starts at first byte of data AM and ends on last byte of data. The CRC calculation of the 2nd polynomial includes data address mark, data bytes and two bytes of zeros
5. There are 26 sectors of 256 bytes.

Figure 19. Modified IBM System 34 Data Track Format

## Appendix A

## FLOWCHARTS

The CRC generators used to generate four CRC check bytes during the write cycle and to detect errors during the read cycle have been discussed previously and are documented by the WRITE SECTOR and READ SECTOR flowcharts that follow. One point in the READ SECTOR flowchart needs clarification. The error correction algorithm calls for the CRC1F to stop calculation after inputting the CRC1F least significant check byte during the read cycle. There is a slight modification to this procedure with the 8X330 implementation. The 8X330 internal CRC-CCITT generator (i.e., CRC1F) continues to generate up the CRC2F least significant check byte. That means two additional bytes, namely the CRC2F check bytes, are inputted to CRC1F. It is necessary to recover CRC1F remainders right after the input of the CRC1F least significant check byte as required by the error correction algorithm. This information can be recovered by loading the CRC1F remainders, which include the CRC2F check bytes in the generation, onto the CRC1R in reverse order, and then the CRC1R is generated with two bytes of zeros as shown in the READ SECTOR flowchart. At this point, the remainder of the CRC1R has the same information as if the CRC1F stopped generation after the input of the CRC1F least significant check byte.

## FLOWCHARTS

ERROR CORRECTION ROUTINE:


FLOWCHARTS (Continued)


FLOWCHARTS (Continued)

CHECK SUBROUTINE


## Appendix B

PROGRAM LISTING

The error correction scheme described in this application note has been implemented in software as shown in the following program listing. This error correction program works with the existing hardware and software of the demonstration floppy disk controller as described in the Signetics $8 \times 330$ Floppy Disk Controller Manual. The first part of the error correction program is a software patch to read and write the two CRC2F check bytes for the demonstration controller program. The main error correction routine is located in the second half of the program. The error correction program is designed to work with the IBM system 34 data track format ( 256 data bytes per sector)-see illustration that follows the program listing. The only modification to the IBM system 34 data tract format is to add two more CRC check bytes to the end of the data field. With slight modifications, this program can also be used for other data track formats. For testing purposes additional coding has been added to the program to print out the contents of both CRC1R and CRC2R after each 8-bit reverse generation cycle. This section of codes can be deleted for the final program.


FILE: ECC330 OUTPUT A



FILE: ECC330 OUTPUT A
1

| 160 | $87823$ | ${ }_{6} 027885$ |
| :---: | :---: | :---: |
| 162 | P07024 | 6 330 11000 |
|  | 07025 | 2 |
| 163 | 07026 | 701774 |
| 164 | 07027 | 617137 |
| 165 | 07030 | 605000 |
| 166 | 07031 | $\begin{array}{llll}6 \\ 7 & 11001 \\ 7 & 06342\end{array}$ |
|  | 07032 |  |
| 168 | 07034 | 17137 |
| 169 | 07035 | 605000 |
| 170 | C7036 | 11002 |
|  | 07037 | $0 \in 342$ |
| 171 | 07040 | 617132 |
| 172 | 07041 | 36100 |
| 174 | 07043 | 17137 37005 |
| 175 | 07044 | 55004 |
| 176 | 07045 | 11003 |
|  | 07046 | 06342 |
| 177 | 07047 | 17132 |
| 178 | 07050 | 631100 |
| 179 | 07051 | 617132 |
| 180 | 07052 |  |
| 181 | 07053 | 17137 |
| 182 | 07054 | 37005 |
| 183 | 07055 | 05003 |
| 184 | 07056 | 11004 |
|  | 07057 | 06342 |
| 185 | 07060 | 02004 |
| 186 | 07061 | 617121 |
| 187 | C7062 | 00037 |
| 188 | 07063 | 02013 |
| 189 | 07064 | 617120 |
| 190 | 07065 | 00037 |
| 191 | 07066 | 11005 |
|  | 07067 | 706370 |
| 192 | 07070 | 611006 |
|  | 07071 | 06370 |
|  | 07072 | 03000 |
| 194 | 07073 | 37037 |
| 195 | 07074 | 617121 |
| 196 | 07075 | 004000 |
| 197 | 07076 | 37037 |
| 198 | 07077 | 01001 |
| 200 | 07100 | 4 |
| 2 Cl | 07101 | 17120 |
| 202 | 07102 | 37 CO |
| 203 | 07103 | 01000 |
| 204 | 07104 | 600002 |
| 205 | c7105 | 17124 |

PAGE 004
AA4 SMP 1774 H AA5 SMP 2OOOH


SE
XM
CAL

*CALCULATE CRC2F WITH 8 BITS OF 0 INPUTS * DURING THE FIRST CRC CHECK BYTE TIME

* CALCULATE CRC2F with 8 bits of 0 INPuts * JURING THE SECOND CRC CHECK BYTE TIME *CRC2F INPUT = 3RD CRC CHECK BYTE
*STRE 3RO CRC BYTE IN R4
*CALCULATE CRC2F
* oi sable crcif calculation
*WAIT FOR 4 TH CRC CHECK BYTE
*CRC2F INPUT = 4 TH CRC CHECK BYTE *CALCULATE CRC2F
*LOAD M.S. BYTE OF CRCIF INTO L.S. BYTE OF *LOAD LES BYTE OF CRCIF INTO M.S. BYTE OF
*CALCULATE CRCIR WITH B BITS OF O INPUT *BECAUSE 3RD ANJ $4 T H$ CRC BYTES GO THRU CRC *
* 

*R $L=1$ IF CRCIF REMAINDERS NOT EQ. ZERO *M.S. BYIE OF MCRCIF REMAINDER $=0$ ? YES, **4


FILE: ECC330 CUTPUT

SIGNFTICS CORPGKATICN


FILE: ECC330 CUTPUT A
SIGNFTICS CORPORATICN
PAGE 206

| 257 258 259 260 261 | $\begin{array}{r} 07162 \\ 07163 \\ \text { c7164 } \\ 07165 \\ 07166 \\ \text { PROG } \end{array}$ | $\begin{array}{cc} 6 & 17132 \\ 5 & 36122 \\ 6 & 17115 \\ 0 & 37000 \\ 6 & 17137 \\ C 330 \end{array}$ |
| :---: | :---: | :---: |
| 262 | 07167 | 000037 |
| 263 | 07170 | 601375 |
| 264 | 07171 | 605377 |
| 265 | 07172 | 617132 |
| 266 | 07173 | 536132 |
| 267 | 07174 | 617137 |
| 268 | 07175 | C 05037 |
| 269 | 07176 | 600001 |
| 270 | 07177 | 101001 |
| 271 | 07200 | 501172 |
| 272 | 07201 | 617132 |
| 273 | 07202 | 702300 |
| $\begin{aligned} & 274 \\ & 275 \end{aligned}$ |  |  |
| 276 |  |  |
| 277 |  |  |
| 278 |  |  |
| 279 |  |  |
| 280 281 | 07203 | 6017136 |
| 282 | 07204 | 037000 |
| 283 284 | 07205 | 400206 |
| 284 285 |  |  |
| 286 |  |  |
| 287 |  |  |
| 288 |  |  |
| 289 |  |  |
| 290 |  |  |
| 291 |  |  |
| 291 |  |  |
| 291 | 06000 | 617136 |
| 291 |  | 000000 |
| 291 | 06301 | 637000 |
| 291 | 06002 | 706234 |
| 291 |  |  |
| 291 | 07206 | 706003 |
| 291 292 | 06003 |  |
|  | 06004 | 706407 |
| 293 |  |  |
| 293 | $060 C 5$ | 617136 |
| 293 |  | 000001 |
| 293 | 06006 | 637001 |
| 293 | 06007 | 706234 |
| 293 293 | 07207 | 706010 |






FILE: ECC330

SIGNETICS CCRPGPATION
PAGE 008


FILE: ECC330 DUTPUT A
SIGNETICS CORPQRATICN
PAGE 010




FILE: ECC 330 CUTPUT A SIUNETICS CCRPORATION
PAGE 014





FILE: ECC330 OUTPUT A SIGNETICS CORPORATION OLI
P50C 006142
$\begin{array}{ll}\text { * } 8 & \\ \text { PRT2 } & 006245\end{array}$

* 9

PRT3 006264
$\begin{array}{ll}\text { * } 10 \\ \text { PRT4 } & \\ \text { PC6 } & \end{array}$
$\begin{array}{ll}\text { * } 11 & \\ \text { PRI5 } & 006325\end{array}$

* 12 (ART 006342

START 006342
$* 13$
START 006370

* 14
* 15

ECHECK 006465 LCCPI 006435 SHIFT 006434

- 16
- 17
$\begin{array}{llllllll}T 1 & 006502 & T 100 & 006546 & T 11 & 006516 & T 12 & 066526 \\ 12 & 0 \mathrm{C} 550 & T 3 & 006507 & 14 & 006540 & 15 & 006534\end{array}$
$\begin{array}{llllllll}\text { •18 } & & & & & \\ \mathrm{C} 36 & 006632 & \mathrm{C} 37 & 006606 & \mathrm{C} 39 & 006577 & 121 & 006560 \\ \mathrm{~T} 24 & 006567 & \mathrm{~T} 25 & 006563 & & & & \end{array}$
Software support
8X300AS1SS ..... 765
8X300AS2SS ..... 766


## MCCAP 8X300/8X305 CROSS ASSEMBLER PROGRAM

Originally published by Signetics January 1984

The MicroController Cross Assembler Program (MCCAP) has been developed to support the Signetics 8X300/8X305 MicroController. MCCAP provides many powerful features including macros, automatic subroutine handling, conditional assembly and extended instructions. These features significantly reduce the time required to compose and assemble MicroController programs. When combined with standard assembler features such as mnemonic op-codes and address labels, these extended features make MCCAP a powerful programming tool.

As input, MCCAP accepts source code written according to the rules presented in this manual. After assembling the source input, MCCAP produces an assembly listing and machinereadable object module.

MCCAP is written in ANSI standard FORTRAN IV and is available on the more popular timesharing services. MCCAP is also available as a fully supported product from Signetics for use on a user's in-house system.

## MCCAP 8X300/8X305 CROSS ASSEMBLER

## PROGRAM

MCCAP, the crossassembler program for the $8 \times 300$ and $8 \times 305$ Micro-Controllers, is supplied as a 9 -track magnetic tape containing FORTRAN IV source code for the crossassembler program. For compatibility with various computer systems, the tape is available in various combinations of density and data encoding. To order, use the following part numbers:

| NUMBER | DENSITY | ENCODING |
| :---: | :---: | :---: |
| $8 \times 300$ AS1-3SS | 1600 BPI | ASCII |
| $8 \times 300 \mathrm{AS1-4SS}$ | 1600 BPI | EBCDIC |

## 8X300/8X305 CROSS ASSEMBLER

## INTRODUCTION

The 8X300AS2 runs on an Intel Intellec ${ }^{\text {TM }}$ Microcomputer Development System with 64K memory under the contorl of ISIS II operating system.

The 8X300AS2 is composed of a two-pass crossassembler program and a PROM formatter overlay. Both programs are written entirely in Intel 8080 Assembly language, and are assembled on the Intel 8080/8085 Macro Assembler version 4.0, linked and located to execute in overlay.

It assembles both 8X300 and 8X305 programs. Also needed is at least one single or double density disk drive with the PROM formatter overlay always residing in drive zero.

The 8X300AS2 software is contained on three diskettes. Disks 1 and 2 contain the Single Density version and disk 3 contains the Double Density version. Both versions will be shipped when ordered under this part number.

## Special purpose circuits

8X01A/9401 ..... 769
8X02A ..... 775
8X41 ..... 783
8X60. ..... 789
2960 ..... 797
2964B ..... 831
9403 ..... 843

## Signetics

# 8X01A/9401 CRC Generator/Checker 

Product Specification

## Logic Products

## FEATURES

- TTL inputs/outputs
- $\mathbf{1 2 M H z}$ (Max) data rate
- Separate preset/reset controls
- SDLC specified pattern match (8X01A only)
- Automatic right justification
- Pin-for-pin compatibility and functionally identical with $8 \times 01$ (8X01A only)
- $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$
- 14-Pin DIP


## APPLICATIONS

- Floppy and other disk systems
- Digital cassette and cartridge systems
- Data communication systems


## DESCRIPTION

The CRC Generator/Checker (8X01A or 9401) provides error-correction capabilities for digital systems that handle serial data. The two parts differ in that the 8X01A provides Synchronous Data Link Control (SDLC).
The serial data stream is divided by a selected polynomial; the remainder resulting from this algebraic process is transmitted at the end of the data stream as a Cyclic Redundancy Check Character (CRCC). At the receiving end, the same calculation is performed on the data. If the received message is errorfree, the calculated remainder should satisfy a predetermined pattern. In most cases, the remainder is zero; however, where SDLC protocols (8X01A only)

## 8X01A \& 9401 PACKAGE/PIN DESIGNATOR



## BLOCK DIAGRAM OF 8X01A \& 9401


are used, the correct remainder is $1111000010111000\left(X^{0}-X^{15}\right)$.
Eight polynomials are provided and any of these can be selected via a 3-bit control bus. Popular polynomials, such as CRC-16 and CCITT are implemented and the one selected can be programmed to start with all zeroes or all ones. Right justification for polynomials of degree less than 16 is automatic.

## FUNCTIONAL OPERATION <br> 8X01A and 9401

The CRC Generator/Checker circuit provides a means of detecting errors in a serial data communications environment. A binary message can be interpreted as a binary polynomial $\mathrm{H}(\mathrm{x})$. This polynomial can be divided by a generator polynomial $P(x)$ such that $H(x)=P(x)$ $Q(x)+R(x)$ whereby $Q(x)$ is the quotient and $R(x)$ is the remainder. During transmission, the remainder is appended to the end of the message as check bits. For a given message, a unique remainder is generated. Hardware implementation of division is simply a feedback shift register with Exclusive-OR gating. Subtraction and addition in modulo 2 is implemented by the Exclusive-OR function. The number of shift register stages is equal to the degree of the divisor polynomial.
The accompanying truth table defines the polynomials implemented in the CRC circuit. Each polynomial can be selected via control inputs $S_{0}, S_{1}$ and $S_{2}$. To generate the check bits, the data stream is entered via the Data (D) input, using the high to low transition of the Clock $(\overline{\mathrm{CP}})$ input. This data is gated with the most significant output (Q) of the shift register which, in turn, controls the exclusive OR gates. The Check Word Enable (CWE) must be held high while the data is being entered. After the last data bit is entered, the CWE is brought low and the check bits are shifted out of the register and appended to the data bits using external gating - see Check Word Generation diagram.

## CRC Generator/Checker

To check an incoming message for errors, both the data and check bits are entered through the ' $D$ ' input with the CWE input held high. The $8 \times 01 \mathrm{~A}$ while not in the data path, monitors the message. After the last check bit is entered, in the $8 \times 01 \mathrm{~A}$, the ERror output is made valid by a high-to-low transition of $\overline{C P}$. If no error is detected during the data transmission, all bits of the internal register are low and the ERror output is also low; if an error is detected, it is reflected by the bit pattern and the ERror output is high. The ERror output status remains valid until the next high-to-low transition of $\overline{\mathrm{CP}}$ or until initialized by the preset ( $\overline{\mathrm{P}}$ ) or reset (MR) functions. The $\overline{\mathrm{PME}}$ line must be high if the

ERror output is used to indicate an all-zero result.
A high level applied to the Master Reset (MR) input asynchronously clears the shift register. A low level applied to the Preset ( $P$ ) input asynchronously sets all bits to the appropriate state if the control-code inputs $\left(\mathrm{S}_{0}, \mathrm{~S}_{1}\right.$, and $\mathrm{S}_{2}$ ) specify a 16 -bit polynomial. In the case of check polynomials that are 8-or-12 bits in length, only the most significant 8 -or12 bits of the shift register are set; all remaining bits are cleared.

## 8X01A ONLY

For data communications using the Synchronous Data Link Control (SDLC) protocol, the

## TRUTH TABLE

| SELECT CODE |  |  | POLYNOMIAL | REMARKS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{2}$ | $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ |  |  |
| L | L | L | $x^{16}+x^{15}+x_{2}+1$ | CRC-16 |
| L | L | H | $x^{16}+x^{14}+x^{+1}$ | CRC-16 REVERSE |
| L | H | L | $x^{16}+x^{15}+x^{13}+x^{7}+x^{4}+x^{2}+x^{1}+1$ |  |
| L | H | H | $x^{12}+x^{11}+x^{3}+x^{2}+x+1$ | CRC-12 |
| H | L | L | $x^{8}+x^{7}+x^{5}+x^{4}+x+1$ |  |
| H | L | H | $x^{8}+1$ | LRC-8 |
| H | H | L | $x^{16}+x^{12}+x^{5}+1$ | CRC-CCITT |
| H | H | H | $x^{16}+x^{11}+x^{4}+1$ | CRC-CCITT REVERSE |

## RECOMMENDED OPERATING CONDITIONS

| PARAMETER |  | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ | Max |  |  |
| $V_{C C}$ | Supply voltage | 4.75 | 5.0 | 5.25 | V |
| $\overline{\mathrm{CP}}$ | Clock input | 0 |  | 12 | MHz |

$8 \times 01 \mathrm{~A}$ is preset to an all-ones configuration before any accumulation is done; this applies to both transmitting and receiving modes of operation. Using SDLC, the check sum shifted out of the 8X01A must be inverted.

During the receiving mode, a special pattern of $1111000010111000\left(X^{0}-X^{15}\right)$ is used in place of all-zeroes to check for a valid message. The Pattern Match Enable pin allows the user to select this option. If $\overline{\text { PME }}$ is low during the last bit time of the message, the ERror output is low providing the result matches the special pattern; if an error occurs, ER is high.

DC ELECTRICAL CHARACTERISTICS FOR 8X01A

| PARAMETER | DESCRIPTION | TEST CONDITIONS ${ }^{1}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input high voltage |  | 2.0 |  |  | V |
| $V_{\text {IL }}$ | Input low voltage |  |  |  | 0.8 | V |
| $V_{\text {IC }}$ | Input clamp diode voltage | $V_{C C}=$ Min, ${ }^{\text {IN }}=-18 \mathrm{~mA}$ |  | -0.9 | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output high voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.7 | 3.4 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output low voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  | 0.35 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=8.0 \mathrm{~mA}$ |  | 0.45 | 0.5 | $\checkmark$ |
| 11. | Input low current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  | -0.22 | -0.36 | mA |
| $\mathrm{IIH}^{\text {H}}$ | Input high current Max input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{H}}$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| los | Output short circuit current | $\mathrm{V}_{\text {CC }}=$ Max, $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}^{2}$ | -10 |  | -42 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply current | $V_{C C}=$ Max, inputs open |  | 60 | 110 | mA |

## DC ELECTRICAL CHARACTERISTICS FOR 9401

| PARAMETER | DESCRIPTION | TEST CONDITIONS ${ }^{1}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input high voltage | Guar. input high voltage | 2.0 |  |  | V |
| $V_{\text {IL }}$ | Input low voltage | Guar. input low voltage |  |  | 0.8 | V |
| $V_{\text {IC }}$ | Input clamp diode voltage | $V_{C C}=$ Min, $\mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  | -0.9 | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output high voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 | 3.4 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output low voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  | 0.35 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=8.0 \mathrm{~mA}$ |  | 0.45 | 0.5 | V |
| 1 IL | Input low current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  | -0.22 | -0.36 | mA |
| $\mathrm{I}_{\mathrm{H}}$ | Input high current | $V_{C C}=M a x, V_{I N}=2.7 \mathrm{~V}$ |  | 1.0 | 40 | $\mu \mathrm{A}$ |
|  |  | $V_{C C}=M a x, V_{I N}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| Ios | Output short circuit current ${ }^{2}$ | $V_{\text {CC }}=$ Max, $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | -15 |  | -100 | mA |
| ICC | Supply current | $V_{C C}=$ Max, inputs open |  | 70 | 110 | mA |

## NOTES:

1. Commercial $-\mathrm{V}_{C C}(\mathrm{MIN})=4.75 \mathrm{~V} ; \mathrm{V}_{C C}(\mathrm{MAX})=5.25 \mathrm{~V}$.
2. No more than one output should be shorted at a time.

AC ELECTRICAL CHARACTERISTICS FOR 8X01A $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| PARAMETER | DESCRIPTION | FROM | TO | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ | Max |  |
| $\mathrm{f}_{\text {max }}$ | Max clock freq |  |  |  | 12 |  |  | MHz |
| Pulse widths: $\begin{aligned} & t_{w}-\overline{C P}(L) \\ & t_{w}-\bar{P}(L) \\ & t_{w}-M R(H) \end{aligned}$ | Clock low <br> Preset low <br> Master reset high |  |  | See Figure 2 <br> See Figure 3 <br> See Figure 4 | $\begin{aligned} & 35 \\ & 35 \\ & 35 \end{aligned}$ |  |  |  |
| Set-up/hold times: $\begin{aligned} & t_{s}-D \\ & t_{s}-\overline{C W E}(L) \\ & t_{\mathrm{h}}-D \& C W E \end{aligned}$ | Set-up time Set-up time Hold time | Data CWE <br> Data \& CWE | Clock Clock Clock | See Figure 5 | $\begin{gathered} 55 \\ 55 \\ 0 \end{gathered}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ ns |
| Propagation delay: <br> $t_{\text {PLH, PHL }}$ <br> $t_{\text {PLH,PHL }}$ <br> $t_{\text {PLH, PHL }}$ <br> $t_{\text {PLH, PHL }}$ <br> tplu, PHL <br> $t_{\text {PLH, PHL }}$ | Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low | $\overline{\text { PRESET }}$ <br> Master reset <br> $\overline{\text { PRESET }}$ <br> Master reset <br> $\overline{\mathrm{CP}}$ <br> $\overline{C P}$ | Data <br> output <br> Data <br> output <br> Error <br> output <br> Error <br> output <br> Data <br> output <br> Error <br> output | See Figures <br> $1,2, \& 3$ <br> See Figure 4 <br> See Figure 3 <br> See Figure 4 <br> See Figure 2 <br> See Figure 2 |  |  | 55 <br> 55 <br> 55 <br> 55 <br> 55 <br> 55 | ns ns ns ns ns ns |
| $t_{\text {REC }}$ | Recovery time | Preset, MR | Clock | See Fig. 3 \& 4 | 35 |  |  | ns |

AC ELECTRICAL CHARACTERISTICS FOR $9401 \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

| PARAMETER | DESCRIPTION | FROM | TO | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ | Max |  |
| $f_{\text {max }}$ | Max clock freq |  |  |  | 12 | 20 |  | MHz |
| Pulse widths: $\begin{aligned} & t_{w}-\overline{C P}(L) \\ & t_{w}-\bar{P}(L) \\ & t_{w}-M R(H) \end{aligned}$ | Clock low <br> Preset low <br> Master reset high |  |  | See Figure 2 <br> See Figure 3 <br> See Figure 4 | $\begin{aligned} & 35 \\ & 40 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 25 \end{aligned}$ |  |  |
| Set-up/hold times: $\begin{aligned} & t_{s}-D \\ & t_{s}-C W E \\ & t_{h}-D \& C W E \end{aligned}$ | Set-up time Set-up time Hold time | Data <br> CWE <br> Data \& CWE | Clock Clock Clock | See Figure 5 | $\begin{gathered} 55 \\ 55 \\ 0 \end{gathered}$ | $\begin{array}{r} 35 \\ 35 \\ -8 \end{array}$ |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Propagation delay: <br> tplin, PHL <br> tplh. PHL <br> tplh, PHL <br> tplin, PHL <br> $t_{\text {PLH,PHL }}$ <br> $t_{\text {PLH,PHL }}$ | Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low Low-to-High and High-to-Low | PRESET <br> Master reset <br> PRESET <br> Master reset <br> $\overline{C P}$ <br> $\overline{\mathrm{CP}}$ | Data output <br> Data output Error output Error output Data output Error output | See Figures <br> $1,2, \& 3$ <br> See Figure 4 <br> See Figure 3 <br> See Figure 4 <br> See Figure 2 <br> See Figure 2 |  | 40 30 40 40 30 40 | $\begin{aligned} & 60 \\ & 55 \\ & 60 \\ & 60 \\ & 55 \\ & 60 \end{aligned}$ | ns ns ns ns n ns ns |
| $t_{\text {REC }}$ | Recovery time | Preset, MR | Clock | See Fig. 3 \& 4 | 35 | 25 |  | ns |

## TEST CIRCUIT



INPUT/OUTPUT STRUCTURES
ALL INPUTS, EXCEPT $\overline{C P}$ CP INPUT


## NOTES:

1. Check Word Enable is HIGH while data is being clocked: it is LOW during transmission of check bits.
2. The 8X01A (or 9401) must be RESET or PRESET before computation.
3. CRC check bits are generated and appended to data bits.

Figure 1. Check Word Generation

## TEST CIRCUITS AND WAVEFORMS


$V_{M}=1.3 \mathrm{~V}$ for $74 \mathrm{~S} ; \mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V}$ for all other TTL familes.
Figure 2. Propagation Delay - $\overline{\mathbf{C P}}$ to $\mathbf{Q}$ and $\overline{\mathbf{C P}} \mathbf{E R}$

$V_{M}=1.3 V$ for $74 \mathrm{~S} ; \mathrm{V}_{M}=1.5 \mathrm{~V}$ for all other TTL familes.

Figure 4. Propagation Delay -MR to $Q$ and ER; Recovery Time - MR to CP

$\mathrm{V}_{\mathrm{M}}=1.3 \mathrm{~V}$ for $74 \mathrm{~S} ; \mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V}$ for all other TTL familes.
Figure 3. Propagation Delay $\overline{\bar{P}} \bar{P}$ to $Q$ and ER; Recovery Time - $\overline{\mathbf{P}}$ to $\overline{\mathbf{C P}}$

$\mathrm{V}_{\mathrm{M}}=1.3 \mathrm{~V}$ for $74 \mathrm{~S} ; \mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V}$ for all other TTL familes. The shaded areas indicate when the input is permitted to change for predictable output performance.

Figure 5. Set-up and Hold Times $-\bar{D}$ to $\overline{\mathrm{CP}}$, CWE to CP, and PME to $\overline{C P}$

## Signetics

## Logic Products

## FEATURES

- 10-Bit Address Generator (1024 Microinstruction Addressability)
- Operating Frequency Exceeding 12 MHz
- Direct Branching Over Full Address Range
- Conditional Branching
- Subroutine Branching Capability
- 4-Level Stack Register File

8X02A

## Control Store Sequencer

## Product Specification

## - Loop Control Facility Using Stack <br> - Three-State Address Outputs

## PRODUCT DESCRIPTION

The Signetics 8X02A Control Store Sequencer generates addresses to access instructions from a microprogram memory (control store). This high-speed device provides an efficient means of controlling the flow through a microprogram
with a powerful set of sequencing functions. The $8 \times 02 \mathrm{~A}$ can directly address up to 1024 microinstructions; however, the total address space can be expanded by adding conventional paging techniques. Combined with memory, the 8X02A forms a powerful control section for CPU's, controllers, test equipment, and other microprogram-controlled systems.

## 8X02A PACKAGE AND PIN DESIGNATIONS

## N PACKAGE

|  |  |
| :---: | :---: |
| ${ }^{4}$, | 40 ncP |
| $A_{10}$ | 390 |
| $A_{2}$ 3 | (30) CNT |
| $A_{11} 4$ | 37 CAsEN |
| $A_{3}$ 析 | 30 otack |
| $A_{12} 6$ | 35 $\overline{\text { ass }}$ |
| $\wedge_{4} 7$ | (34) ma |
| $A_{13} 8$ | 33 ma, |
| $A_{5}$ - | (32) MA |
| $A_{14} 10$ | 313 cno |
| vcc | 30 ma |
| $A_{6} 12$ | 20. MA, |
| A 15 | 20] MAs |
| A) 114 | $27 .{ }^{2} A_{6}$ |
| A, 16 | $22^{26} \mathrm{ma}$ |
| $A_{5} 16$ | (25) MA |
| $A_{17} 17$ | $2{ }^{29} \mathrm{CP}$ |
| $A_{5} 16$ | 23 SEL2 |
| $A_{12} 110$ | 22] $\overline{\text { EEO2 }}$ |
| SETI 20 | [2] $\overline{\text { REa }}$ |

PIN NO. IDENTIFIER FUNCTION
1, 28, $27 \mathrm{AC}_{2}-A C_{0}$ Inputs used to select any one of eight Address Control Functions - see Table 1.
$2 \quad \overline{E N}$ Enable three-state address outputs ( $A_{0}-A_{9}$ ); active-low input.
3-6, $\quad A_{0}-A_{9} \quad$ Three-state address outputs used to specify microprogram address;

$$
8-13 \quad\left(A_{0}=L S B, A_{9}=M S B\right)
$$

7 GND Ground
14-21, $\quad B_{0}-B_{9} \quad$ Branch address inputs: $\left(B_{0}=L S B, B_{9}=M S B\right)$.
23, 24
$22 \quad V_{C C} \quad$ Supply voltage.
25 CLK Clock input (positive edge used for all triggering).
26 TEST Active-high condition input used to determine conditional skips, branches, subroutine calls, and loop termination.

## ORDER NUMBER

N8X02AN


Figure 1. 8X02A Control Store Sequencer - Functional Block Diagram

## FUNCTIONAL OPERATION

As shown in Figure 1, the data appearing on the address output pins ( $A_{0}-A_{9}$ ) is the contents of the 10 -bit Address Register. On the rising edge of the clock input pulse (CLK), a new address is latched into the Address Register. This new address is supplied via the Address Multiplexer which selects one of five sources:

- Branch Address Input ( $\mathrm{B}_{0}-\mathrm{B}_{9}$ )
- Current Address + 1
- Current Address + 2 (for the SKIP function)
- Stack Register File (most recent entry)
- All Zeroes (RESET)

The selection of the next address is determined by the "Address Control Function" specified by inputs $A C_{0}-A C_{2}$ and the TEST input. Table 1 defines the eight Address Control Functions.

The 'Reset' (RST) Address Control Function unconditionally forces all Address Register bits to zero on the rising edge of CLK. Sequential microprogram flow is provided by the "Increment" (INC) function which unconditionally increments the Address Register by one for each clock cycle. The Address Register automatically wraps around from the highest address (all "1s') to the lowest address (all ' 0 ' ').

As shown in Table 1, the TEST input is used to conditionally execute four of the eight Address Control Functions. If the TEST input is low (false), the Address Register is simply
incremented by one - (for the BLT function, the Stack Pointer is also decremented). If the TEST input is high (true), the sequencer executes one of the following:

- Skip (TSK) - the Address Register is incremented by two.
- Branch (BRT) - the Address Register is loaded from the
Branch Address Inputs.
- Branch-to-Subroutine (BSR).
- Branch-to-Loop (BLT).

The Stack Register File holds up to four 10-bit addresses and operates in the Last-In/FirstOut (LIFO) mode. A Stack Pointer keeps track of the next register of the Stack File to be written into; the pointer is incremented after each "push" and decremented after each "pop" - see Table 1. When branching to a subroutine (BSR), the return address (current address +1 ) is "pushed" onto the stack and the branch address input is loaded into the Address Register. To return from a subroutine, the "POP" function pops the return address off the stack and loads it into the Address Register.
The "Push-for-Looping" (PLP) function may be specified in the first instruction of a loop to "push' the current address onto the stack: the Address Register is incremented. A "Branch-to-Loop" (BLT) function placed at the end of the loop "pops" the stack and conditionally branches to the top-of-loop address, depending on the TEST input. If the test for repeating the loop is satisfied (TEST input high), the sequencer causes a branch
back to the first instruction of the loop in which the top-of-loop address is "pushed" back onto the stack. If the test fails (TEST input low), the top-of-loop address is discarded, the stack pointer is decremented and the Address Register is incremented. A combination of subroutines and loops may be nested up to four levels deep.

In abnormal circumstances, the Stack Pointer will wraparound from the fourth to the first register of the Stack File and vice-versa. If the stack is full (four addresses currently stored), an additional 'push' causes the first (oldest) entry to be overwritten - (the four most recent entries are always maintained). If the stack is empty, a "pop" will access the fourth register of the Stack File; however, the contents of this register may be unpredictable.
The three-state address outputs ( $\mathrm{A}_{0}-\mathrm{A}_{g}$ ) are controlled by a common enable input (EN). When the enable input is high, the output drivers are placed in the high-impedance state allowing alternative access to the microprogram memory. Other circuit functions are unaffected by $\overline{\mathrm{EN}}$.

## NOTE

To implement a RESET externally it is necessary to force all Address Control Inputs $\left(A C_{0}-A C_{2}\right)$ to the high state until at least one rising edge of CLK has occurred. If the AC inputs are supplied directly from the microprogram memory, a RESET may be accomplished by disabling the memory outputs. Pullup resistors should be provided to achieve the required high voltage level.

## Control Store Sequencer

8X02A

Table 1. Address Control Functions

| MNEMONIC AND DESCRIPTION | CONTROL LINES |  |  |  | NEXT ADDRESS | STACK OPERATION | STACK POINTER |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{AC}_{2}$ | $\mathrm{AC}_{1}$ | $A_{0}$ | Test |  |  |  |
| TSK - Test and skip | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Current address +1 Current address + 2 | No change No change | No change No change |
| INC - Increment | 0 | 0 | 1 | X | Current address + 1 | No change | No change |
| BLT - Branch to loop if test condition is true | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Current address +1 From stack register file | POP (ignore data) POP (read) | Decrement by 1 Decrement by 1 |
| POP - Pop stack (return from subroutine) | 0 | 1 | 1 | X | From stack register file | POP (read) | Decrement by 1 |
| BSR - Branch to subroutine if test condition is true | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Current address + 1 Branch address inputs $B_{0}-B_{9}$ | No change PUSH (write current address + 1) | No change increment by 1 |
| PLP - Push for looping | 1 | 0 | 1 | $x$ | Current address + 1 | PUSH (write current address) | Increment by 1 |
| BRT - Branch if test condition is true | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Current address + 1 Branch address inputs $B_{0}-B_{9}$ | No change No change | No change No change |
| RST - Reset address to zero | 1 | 1 | 1 | X | All zeroes | No change | No change |

X = Don't Care

## ABSOLUTE MAXIMUM RATINGS

| PARAMETER | RATING | UNIT |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ Power supply voltage | +7 | Vdc |
| $V_{\text {IN }}$ input voltage | + 5.5 | Vdc |
| $\mathrm{V}_{\mathrm{O}}$ Off-state output voltage | +5.5 | Vdc |
| $T_{\text {STG }}$ Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS Conditions: Commercial $-\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}( \pm 5 \%), 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$

| PARAMETER | DESCRIPTION | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| $\begin{aligned} & V_{i H} \\ & V_{I L} \\ & V_{I C} \end{aligned}$ | High level input voltage Low level input voltage Input clamp voltage | $\mathrm{V}_{\text {CC }}=\mathrm{Min}$ | 2 |  |  | V |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Min}$ |  |  | 0.8 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |
| $\mathrm{V}_{\mathrm{OH}}$$\mathrm{V}_{\mathrm{OL}}$ | High level output voltage Low level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ; \mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.42 | 0.5 |  |
| $!$ | input current at maximum input voltage | $V_{C C}=M a x ; V_{i}=5.5 \mathrm{~V}$ |  | 1 | 100 | $\mu \mathrm{A}$ |
| $I_{\text {IH }}$ | High level input current: $\mathrm{AC}_{2}-\mathrm{AC}_{0}$, TEST, CLK | $V_{C C}=$ Max; $V_{1 H}=2.7 \mathrm{~V}$ |  | < 0.1 | 40 | $\mu \mathrm{A}$ |
|  | $\mathrm{B}_{9}-\mathrm{B}_{0}, \overline{\mathrm{EN}}$ |  |  | < 0.1 | 20 |  |
| ILL | Low level input current: $\mathrm{AC}_{2}-\mathrm{AC}_{0}$, TEST, CLK | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |  | -24 | -800 | $\mu \mathrm{A}$ |
|  | $\mathrm{B}_{9}-\mathrm{B}_{0}$, EN |  |  | -12 | -400 |  |
| los | Short circuit output current ${ }^{2}$ | $V_{C C}=$ Max | -15 | -60 | -100 | mA |
| IOZH | High-Z state output current high level | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \mathrm{V}_{\mathrm{OH}}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| Iozl | High-Z state output current low level | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |  |  | -20 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply current | $V_{C C}=$ Max |  | 170 | 250 | mA |

## MOTES:

1. Typical limits are: $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. For purposes of testing, not more than one output should be shorted at a time.

AC ELECTRICAL CHARACTERISTICS Conditions: Commercial $-\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}( \pm 5 \%), 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$ Loading-See Test Loading Circuit

| PARAMETERS ${ }^{1}$ | REFERENCES |  | LIMITS ${ }^{4}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | From | To | Min | Typ ${ }^{2}$ | Max |  |
| Pulse width: <br> tow Clock cycle time | $\uparrow$ CLK | $\uparrow$ CLK | 80 |  |  | ns |
| tpWH Clock high | $\uparrow$ CLK | $\downarrow$ CLK | 35 | 24 |  | ns |
| tpWL Clock low | $\downarrow$ CLK | $\uparrow$ CLK | 15 | 9 |  | ns |
| Propagation delay: tpLz Low to high-Z | $\uparrow$ EN | $A_{0}-A_{9}$ |  | 14 | 20 | ns |
| tpHz High to high-Z | $\uparrow$ EN | $A_{0}-A_{9}$ |  | 35 | 42 | ns |
| tpzL High-Z to low | $\downarrow$ EN | $A_{0}-A_{9}$ |  | 10 | 20 | ns |
| tpzH High-Z to high | $\downarrow$ EN | $A_{0}-A_{9}$ |  | 20 | 30 | ns |
| tpHL High to low | $\uparrow$ CLK | $\downarrow \mathrm{A}_{0}-\mathrm{A}_{9}$ |  | 25 | 45 | ns |
| tplH Low to high | $\uparrow$ CLK | $\uparrow A_{0}-A_{9}$ |  | 25 | 45 | ns |
| $\mathrm{t}_{\text {HA }}$ Address output hold time ${ }^{3}$ | $\uparrow$ CLK | $A_{0}-A_{9}$ | 13 |  |  | ns |
| Set-up/hold times: tsF Function set-up time | $\mathrm{AC}_{0}-\mathrm{AC}_{2}$ | $\uparrow$ CLK | 20 | 18 |  | ns |
| tsk $^{\text {S }}$ Branch set-up time | $\mathrm{B}_{0}-\mathrm{B}_{9}$ | $\uparrow$ CLK | 15 | 7 |  | ns |
| $\mathrm{t}_{\mathbf{S}}$ Test set-up time | TEST | $\uparrow$ CLK | 20 | 15 |  | ns |
| $t_{\text {HF }}$ Function hold time | $\uparrow$ CLK | $\mathrm{AC}_{0}-\mathrm{AC}_{2}$ | 20 | 2 |  | ns |
| $\mathrm{t}_{\text {HK }}$ Branch hold time | $\uparrow$ CLK | $\mathrm{B}_{0}-\mathrm{B}_{9}$ | 15 | 9 |  | ns |
| $\mathrm{t}_{\mathrm{H} 1}$ Test hold time | $\uparrow$ CLK | TEST | 12 | -2 |  | ns |

## NOTES:

1. Parameter definitions are illustrated in the Timing Diagrams - See Figure 2.
2. Typical limits are: $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
3. $t_{H A}$ is the minimum time the current address outputs remain stable before changing. This delay may be used to provide some of the hold times required for the $A C, B$, and TEST inputs, if these inputs are determined by the microprogram memory addressed by the $8 \times 02 \mathrm{~A}$.
4. This data supercedes the November, 1980 edition of this data sheet.

TIMING DIAGRAM


Figure 2. Timing Diagrams

AC VOLTAGE WAVEFORMS AND TEST LOADING


## APPLICATION

## FUNCTIONAL DESCRIPTION

Figure 3 shows a typical configuration of an 8 $\times 02$ A-based control section in a CPU appiication. Microinstructions read from the memory are used to produce control signals for
the CPU and to determine the next microinstruction via the 8X02A Address Control inputs ( $A C_{0}-A C_{2}$ ). In the case of a conditional branch or skip, the status condition applied to the $8 \times 02 \mathrm{~A}$ TEST input is selected according to the microinstruction. In a branch-type microinstruction, a branch field typically supplies the $8 \times 02 \mathrm{~A}$ Branch Address inputs ( $\mathrm{B}_{0}-\mathrm{B}_{9}$ ). (In non-branching instructions, this field may
contairi other CPU control information.) When a macroinstruction is presented to the CPU, the starting address of the microprogram routine which executes the macroinstruction is presented to the Branch Address inputs. Similar configurations may be used for other applications in which the Branch Address inputs are typically supplied directly from the microprogram memory.


Figure 3. Control Section of a Microprogrammed CPU

## Signetics

## Logic Products

## DESIGN FEATURE

- Intelligent bidirectional bus repeater with self-generating or external control
- Eight independent channels
- Open-collector outputs (meets DEC UNIBUS* specifications)
- TTL compatible
- High speed (30-nanoseconds max)
- Expandable to any number of bits
- High input impedance for every operating value of $\mathbf{V}_{\mathbf{c c}}$
- Low input current (less than 100microamperes); high output current (up to 70 -milliamperes)
- 0.6 in. 24-pin DIP
- +5 V supply


## USE AND APPLICATION

- Minicomputers
- Microcomputers MOS/Bipolar
- Communications
- Signal buffer
- Bus fan-out extensions
- Distributed processing
- Bidirectional bus connector/ isolator


## PRODUCT DESCRIPTION

The Signetics 8X41 Autodirectional Bus Transceiver is a general purpose asynchronous device ideal for system bus expansion applications. The 8X41 consists of eight data channels, each with one pair of terminals ( $A_{i}$ and $B_{i}$ ); each data channel can be operated independently.

The device requires no external controls since all intelligence is internally generated; thus, operation of the device is completely autonomous. The first logic

Product Specification

low signal that occurs on one channel terminal ( $A_{i}$ and $B_{i}$ ) will be repeated on the corresponding terminal $\left(B_{i}\right.$ or $\left.A_{i}\right)$ of the same channel.
The $8 \times 41$ is designed for use in opencollector bus systems where high speed and low-current inputs/high-current outputs are required. In system configurations, the discrete capabilities of the bus transceiver can be expanded by parallel connection to service any number of bits. To provide reliable operation and integrity of data transfers, all channels are disabled by an on-chip power monitor whenever $\mathrm{V}_{\mathrm{CC}}$ falls below approximately 4 V .

## FUNCTIONAL OPERATION

The $8 \times 41$ (Figure 1) consists of eight functionally independent yet logically identical channels. Each channel consists of two bus terminals ( $\mathrm{A}_{\mathrm{i}}$ and $\mathrm{B}_{\mathrm{i}}$ ); each terminal is internally connected to an open-collector driver and a highimpedance receiver. The monitoring state of each channel is defined when both terminals ( $A_{i}$ and $B_{i}$ ) are 'high'; in this state, the internal logic of the $8 \times 41$ continually examines the $A$ and $B$ bus signals to determine signal direction $A_{i}$ to $B_{i}$ or $B_{i}$ to $A_{i}$. A low signal occurring at either of the two terminals causes the open-collector driver on the opposite terminal to follow suit; hence, the signal is repeated by the $8 \times 41$. For each channel, latches L1 and L2 determine signal direction. As shown in the truth table for these latches, there is no transmission of data when both signals are low; however, this condition should never occur during normal system operation.
The internal automatic direction control can be overridden by either or both of the common disable inputs - $\overline{\mathrm{DBA}}$ and $\overline{D A B}$. When $\overline{D B A}$ is driven low ( $\overline{\mathrm{DAB}}=$ high), the $B_{i}$ to $A_{i}$ path is inter-
rupted and the device becomes a unidirectional repeater in the $A_{i}$ to $B_{i}$ direction only. With these conditions reversed ( $\overline{\mathrm{DAB}}=$ low and $\overline{\mathrm{DBA}}=$ high ), the $\mathrm{A}_{i}$ to $\mathrm{B}_{\mathrm{i}}$ path is interrupted and the chip functions as a unidirectional repeater in the $B_{i}$ to $A_{i}$ direction. When both control signals are low, data passage is inhibited in both directions. Refer to the I/O truth table for all possible input/output conditions.

## 8X41 PACKAGE/PIN

 DESIGNATIONS


Figure 1. Logic Diagram of $8 \times 41$

## INPUT/OUTPUT TRUTH TABLE

| EXTERNAL CONTROLS |  | INPUT SIGNALS |  | OUTPUT DRIVER SIGNALS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { DAB }}$ | $\overline{\text { DBA }}$ | $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{B}_{\mathrm{i}}$ | $A D_{i}$ | $B D_{i}$ |
| H | H | L | L | H | H |
| H | H | L | H | H | L |
| H | H | H | L | L | H |
| H | H | H | H | H | H |
| H | L | L | L | H | L |
| H | L | L | H | H | L |
| H | L | H | L | H | H |
| H | L | H | H | H | H |
| L | H | L | L | L | H |
| L | H | L | H | H | H |
| L | H | H | L | L | H |
| L | H | H | H | H | H |
| L | L | X | X | H | H |

## NOTES:

$A_{i}=$ External signal
$A D_{i}=$ Output $A$ driver
$B_{i}=$ External signal
$B D_{i}=$ Output $B$ driver
$\mathrm{X}=$ Don't care

| $\overline{\mathrm{DBA}}$ | $\overline{\mathrm{DAB}}$ | FUNCTION |
| :---: | :---: | :--- |
| 0 | 0 | Data transmission <br> inhibited |
| 0 | 1 | $A_{i} \rightarrow \mathrm{~B}_{\mathrm{i}}$ |
| 1 | 0 | $A_{i} \leftarrow \mathrm{~B}_{\mathrm{i}}$ |
| 1 | 1 | $A_{i} \rightarrow B_{i}$ <br> $A_{i} \leftarrow B_{i}$ |

$i=$ Channel $0,1,2,3,4,5,6$, or 7
$A_{i} \rightarrow B_{i}=$ Data transmission from $A_{i}$ to $B_{i}$ $A_{i} \leftarrow B_{i}=$ Data transmission from $B_{i}$ to $A_{i}$

## TRUTH TABLE

| LATCHES |  | DIRECTION OF DATA |
| :---: | :---: | :--- |
| $L_{1}$ | $L_{2}$ |  |
| 1 | 1 | Monitoring state |
| 1 | 0 | $A_{i}$ to $B_{i}$ |
| 0 | 1 | $B_{i}$ to $A_{i}$ |
| 0 | 0 | No transmission |

## LOAD CIRCUIT FOR OUTPUTS



Autodirectional Bus Transceiver

DC CHARACTERISTICS $V_{C C}=5 \mathrm{~V}( \pm 5 \%) ; T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | LImits |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\text {OL }}$ | Bus output low voltage (driver ON) |  | $\begin{aligned} & \mathrm{IOL}^{2}=70 \mathrm{~mA} ; \\ & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} \end{aligned}$ |  |  | 0.5 | V |
| ${ }^{*} \mathrm{~V}_{\text {B }}$ | Bus input threshold voltage (driver OFF) |  | 1.3 |  | 1.7 | V |
| $\frac{V_{\mathrm{IH}}}{\left.\frac{\mathrm{DAB}}{\mathrm{DAR}} \text { only }\right)}$ | High level input voltage |  | 2.0 |  |  | V |
| $\begin{aligned} & \frac{V_{\mathrm{IL}}}{\mathrm{DAB} \text { only }} \overline{(\overline{\mathrm{DBA}},} \end{aligned}$ | Low level input voltage |  |  |  | 0.8 | V |
| VIC | Input clamp voltage | $\begin{aligned} & V_{C C}=M I N ; \\ & I_{L L}=-18 \mathrm{~mA} \end{aligned}$ |  |  | -1.5 | V |
| $V_{P D}$ | Power ON/OFF detector threshold voltage |  | 3.7 |  | 4.35 | V |
| $\begin{aligned} & \frac{l_{1 H}(\overline{\mathrm{DBA}},}{} \\ & \frac{\mathrm{DAB} \text { only })}{} \end{aligned}$ | High level input current | $\begin{aligned} & V_{C C}=M a x ; \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ |  |  | 20 | $\mu \mathrm{A}$ |
| IL ( $\overline{\mathrm{DBA}}$, $\overline{\mathrm{DAB}}$ only) | Low level input current | $\begin{aligned} & V_{C C}=M a x ; \\ & V_{\text {IN }}=0.4 \mathrm{~V} \end{aligned}$ |  |  | -0.4 | mA |
| 1 | Bus input current (driver OFF) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ; \\ & \mathrm{V}_{\mathrm{B}}=2.5 \mathrm{~V}^{*} \end{aligned}$ |  |  | 100 | $\mu \mathrm{A}$ |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Max} \\ & \mathrm{~V}_{\mathrm{B}}=0 \mathrm{~V}^{*} \end{aligned}$ |  |  | -20 |  |
| Ioff | Bus leakage current (power OFF) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V} ; \\ & \mathrm{V}_{\mathrm{B}}=2.5 \mathrm{~V}^{*} \end{aligned}$ |  |  | 100 | $\mu \mathrm{A}$ |
| ${ }^{\text {cc }}$ | Supply current | $\mathrm{V}_{\mathrm{CC}}=$ Max; <br> $\mathrm{A}_{0}-\mathrm{A}_{7}=$ Low or $\mathrm{B}_{0}-\mathrm{B}_{7}=$ Low and $\overline{\mathrm{DBA}}=\overline{\mathrm{DAB}}=\mathrm{High}$ |  | 145 | 180 | mA |

NOTE:
${ }^{*} V_{B}=V_{B U S}$
AC CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}( \pm 5 \%) ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| PARAMETER | DESCRIPTION | FROM | TO | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ | Max |  |
| $t_{\text {PLL }}$ | Propagation delay | Low $\mathrm{A}_{\mathrm{i}}$ Low $\mathrm{B}_{\mathrm{i}}$ | Low $\mathrm{BD}_{\mathrm{i}}$ Low $A D_{i}$ | $\overline{\mathrm{DBA}}=\overline{\mathrm{DAB}}=\mathrm{High}$ |  |  | 30 | ns |
| $t_{\text {PHH }}$ | Propagation delay | High $A_{i}$ High $B_{i}$ | High $B D_{i}$ <br> High $A D_{i}$ | $\overline{\mathrm{DBA}}=\overline{\mathrm{DAB}}=\mathrm{High}$ |  |  | 30 | ns |
| $t_{\text {DHH }}$ | Propagation delay | High $\mathrm{A}_{\mathrm{i}}$ | High $\mathrm{BD}_{\mathrm{i}}$ | $\overline{\mathrm{DBA}}=$ Low $; \overline{\mathrm{DAB}}=$ High |  |  | 25 | ns |
|  |  | High $\mathrm{B}_{\mathrm{i}}$ | High $\mathrm{AD}_{\mathrm{i}}$ | $\overline{\mathrm{DAB}}=$ Low $; \overline{\mathrm{DBA}}=$ High |  |  | 25 | ns |
| ${ }^{\text {D DLL }}$ | Propagation delay | Low $A_{i}$ | Low $\mathrm{BD}_{\mathrm{i}}$ | $\overline{\mathrm{DBA}}=$ Low $; \overline{\mathrm{DAB}}=$ High |  |  | 25 | ns |
|  |  | Low $\mathrm{B}_{\mathrm{i}}$ | Low $\mathrm{AD}_{\mathrm{i}}$ | $\overline{\mathrm{DAB}}=$ Low; $\overline{\mathrm{DBA}}=$ High |  |  | 25 | ns |
| ${ }^{\text {DEEH }}$ | Propagation delay | Low $\overline{\mathrm{DAB}}$ | High AD $_{i}$ | $\overline{\mathrm{DAB}}=$ Low; $A_{i}=$ Low |  |  | 30 | ns |
| $t_{\text {DEL }}$ | Propagation delay | $\frac{\text { High }}{\overline{D B A}}$ | Low AD ${ }_{\text {i }}$ | $\overline{\mathrm{DAB}}=$ Low; $\mathrm{B}_{\mathrm{i}}=$ Low |  |  | 30 | ns |
| $t_{\text {DEH }}$ | Propagation delay | Low $\overline{\mathrm{DBA}}$ | High $\mathrm{BD}_{\mathrm{i}}$ | $\overline{\text { DBA }}=$ Low; $\mathrm{B}_{\mathrm{i}}=$ Low |  |  | 30 | ns |
| $t_{\text {DEL }}$ | Propagation delay | $\frac{\text { High }}{\overline{D A B}}$ | Low $\mathrm{BD}_{\mathrm{i}}$ | $\overline{\mathrm{DBA}}=$ Low; $\mathrm{A}_{\mathrm{i}}=$ Low |  |  | 30 | ns |
| $\mathrm{t}_{\mathrm{r}}$ | Recovery time (see timing diagram) | - | - | $\overline{\mathrm{DBA}}=\overline{\mathrm{DAB}}=$ High |  | 20 |  | ns |

## NOTES:

$A_{i}=$ External signal
$A D_{i}=$ Output A driver
$B_{i}=$ External signal
$B D_{i}=$ Output $B$ driver
$8 \times 41$ TIMING DIAGRAM


USING THE 8X41 IN A BUS-SHARED CONFIGURATION


INTERFACING 8X41 TO IEEE 488 BUS


## Signetics

## Logic Products

## FEATURES

- 12-Bit FIFO Address Generator
- Data Rate Exceeding $\mathbf{8 M H z}$
- Asynchronous Read/Write Operations
- Three-State Address Outputs
- User-Defined Word Width
- Specifically Designed for Use with High-Speed Bipolar RAMs (Adaptable for Use with MOS RAMs)
- TTL Input and Output
- 16 mA Address-Drive Capability

USE AND APPLICATION

- Interface Between IndependentlyClocked Systems
- Buffer Memories for Disk and/or Tape
- Data Communication Concentrators
- CPU/Terminal Buffering
- DMA Applications
- CRT Terminals


## PRODUCT DESCRIPTION

The Signetics $8 \times 60$ FIFO RAM Controller (FRC) is an address and status generator designed to implement a high-speed/high-capacity First-In/First-Out (FIFO) stack utilizing standard off-theshelf RAMs - see Applications on the last page of this data sheet. The FRC can control up to 4096 words of buffer memory; intermediate buffer sizes can be selected - refer to the memory length table on the next page. Built-in arbitration logic handles read/write operations on a first-come/first-served basis.

## $8 \times 60$ FIFO RAM Controller (FRC)

## Product Specification

As shown in Figure 1, the FRC consists of:

- A 12-Bit Write Address Generation Counter (Counter \#1) and a 12-Bit Read Address Generation Counter (Counter \#2).
- A 12-Bit Up/Down Status Counter (Counter \#3).
- Twelve Three-State Address Drivers.
- Control Logic.

The two address counters, \#1 and \# 2, respectively, are used to generate write and read addresses; the outputs of these counters are multiplexed to the three-state address drivers. Counter \#3 generates full, empty, and half full status.

## FUNCTIONAL OPERATION

The FRC operates in either of two basic modes - write into the FIFO buffer memory or read from the FIFO buffer memory. These two operations are described in subsequent paragraphs and the complete sequence is summarized in Table 1. Typical Write/Read timing relationships, arbitration logic, and chipenable control are shown in the Timing Diagrams.

PACKAGE AND PIN DESIGNATOR


ORDER NUMBERS
N8×60N, RB8×60F

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 1 | $V_{B B}$ | Supply voltage for internal circuits. |
| $\begin{gathered} 2,14, \\ 21 \end{gathered}$ | GND | Circuit ground. |
| 3 | $\overline{\text { SI }}$ | Shift-In request for write cycle; active-low input. |
| 4 | $\overline{\mathrm{SO}}$ | Shift-Out request for read cycle; active-low input. |
| 5 | PESET | Active-low master reset input. |
| 6 | $\overline{C E}$ | Active-low chip enable input. |
| 7 | WRITE | Write cycle address valid; active-low output. |
| 8 | READ | Read cycle address valid; active-low output. |
| 9 | FULL | Memory full status output; also, override input capability. Active when high. |
| 10 | $\begin{aligned} & \text { HALF } \\ & \text { FULL } \end{aligned}$ | Memory half-full status output; active-high. |
| 11 | EMPTY | Memory empty status output; also, override input capability. Active when high. |
| 12 | LS1 | Least significant bit (LSB) of the memory length select input. |
| 13 | L.S2 | Most significant bit (MSB) of the memory length select input. |
| $\begin{aligned} & 15-20 \\ & 22-27 \end{aligned}$ | $A_{11}-A_{0}$ | Three-state address outputs: $A_{0}=$ LSB. |
| 28 | $V_{C C}$ | Supply voltage. |



Figure 1. Functional Block Diagram of FIFO RAM Controller

## FIFO BUFFER MEMORY - <br> WRITE CYCLE

To perform a write operation, $\overline{\mathrm{SO}}$ must be high and Si must be low. When these conditions exist and other control parameters (Table 1) are satisfied, the write address in Counter \#1 (Figure 1) is output to the address bus via the multiplexer and WRITE output goes low. (Note. Normally, the WRITE output goes low after the address output becomes state refer to WRITE Cycle Timing Diagram. The WRITE output may then act as a write or chip enable for the RAMs that are used to implement the memory.
When the write cycle is ended ( $\overline{\mathrm{SI}}$ is forced high), the WRITE output goes high, the address output buffers return to a high-impedance state Counter \#1 (Write Address Generation) and Counter \#3 (Status) are both incremented, and Counter \# 2 (Read Address Generation) remains unchanged.

## FIFO BUFFER MEMORY - READ CYCLE

To perform a read operation, SI must be high and $\overline{\mathrm{SO}}$ must be low. When these conditions exist and other control parameters (Table 1) are satisfied, the read address contained in Counter \#2. (Figure 1) is output to the address bus and the $\overline{R E A D}$ output goes low.
When the read cycle is ended ( $\overline{\mathrm{SO}}$ is forced high) the $\overline{R E A D}$ output goes high, the output buffers return to a high-impedance state. Counter \#2 (Pead Address Generation) is incremented. Counter \#3 (Status) is decremented, and Counter \# 1 (Write Address Generation) remains unchanged.

MEMORY LENGTH

| LS1 | LS2 | HALF LENGTH | FULL LENGTH |
| :---: | :---: | :---: | :---: |
| L | L | 2048 | 4096 |
| H | L | 32 | 64 |
| L | $H$ | 512 | 1024 |
| H | $H$ | 128 | 256 |

## CONTROL LOGIC

To prevent the possibility of operational conflicts, $\overline{\mathrm{SI}}$ and $\overline{\mathrm{SO}}$ are treated on a first-come/ first-served basis; these two input signals are controlled by internal arbitration logic - refer to the applicable Timing Diagrams and AC Characteristics for functional and timing relationships. If one cycle is requested while the other cycle is in progress, the requested cycle will commence as soon as the current-cycle is complete (provided other control parameters are satisfied).
As shown in the accompanying diagram, the buffer length of the FIFO memory can be hardware-selected via the Length Select (LS1, LS2) inputs. When less than the maximum length is selected, the unused highorder bits of the address outputs are held in the high-impedance state.
Generation of the status output signals (HALF FULL, FULL and EMPTY) is a function of the Length Select (LS1, LS2) inputs and the current state of Status Counter \#3. In general, the status outputs reflect the conditions that follow:

- HALF FULL - this status output signals goes high on the positive-going edge of SI if the MSB of the selected length of Counter \#3 becomes a " 1 ". The HALF FULL signal will go from high-to-low on the positive-going edge of SO when,
after the read cycle, the selected length of Counter \#3 changes from "100 .. 00 " to " 111 ... 11". For example, if the selected memory length is 256 words ( $F U L L=256$ ), then HALF FULL $=128$ words; hence, on the positive-going edge of $\overline{S O}$ when Counter \#3 reaches a count of 127, the HALF FULL output will go from high-to-low.
- FULL - this signal serves both as a status output and as an override input. The FULL signal goes high on the negative-going edge of $\overline{S I}$ if all bits of Counter \#3 for selected length are equal to " 1 ". The FULL output goes from high-to-low on the negative-going edge of $\overline{\mathrm{SO}}$.
- EMPTY - this signal also serves as a status output and as an override input. On the negative-going edge of $\overline{\mathrm{SO}}$, the EMPTY output is driven high if Status Counter \#3 contains a value of " 1 "; on the positive-going edge of $\overline{\mathrm{SO}}$, the counter is decremented to " 0 '". The EMPTY output goes from high-to-low on the negative-going edge of $\overline{\mathrm{S}}$.

Once the FULL signal is high, further Write Cycie Requests (SI = low) are ignored; similarly, once the EMPTY signal is high, further Read Cycle requests ( $\overline{\mathrm{SO}}=$ low) are ignored. However, to accommodate diversified applications, the FULL and EMPTY outputs are
open-collector with on-chip 4.7K passive pullup resistors. If either the FULL or EMPTY pins are forced low via external control, the corresponding write or read cycle may resume (provided the external FULL or EMPTY input is held low until the corresponding WRITE or $\overline{R E A D}$ output goes low) and the address/ status counters will continue normal operation* - refer to Table 1.

The user must force the $\overline{\operatorname{RESET}}$ input low to initialize the chip. (Note. If the RESET signal is driven low during a write or read cycle, the
address output may have a short period of uncertainty before assuming a high-impedance state.) The following actions occur when RESET is active:

- All internal counters are set to " 0 ' .
- All address output lines are forced to the high-impedance state.
- HALF FULL and FULL outputs are forced low.
- WRITE, $\overline{\text { READ }}$, and EMPTY outputs are forced high.

When $\overline{C E}$ is high, the address output lines are forced to the high-impedance state, further write or read cycle requests are ignored, and all counters remain unchanged. If $\overline{\mathrm{CE}}$ switches from low-to-high during a write or read cycle, the cycle in progress is always completed before the disabled state is entered. For details of these operations, refer to the timing information shown later in this data sheet.
*Refer to Note on inside back cover

Table 1. Summary of Operation

| INPUTS |  |  |  | INITIAL CONDITIONS | RESULTING OUTPUTS |  |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RESET | $\overline{\mathbf{C E}}$ | SI | SO |  | WRITE | $\overline{\text { READ }}$ | Address Bus |  |
| L | X | X | X |  | H | H | $\mathrm{Hi}-\mathrm{Z}$ | Reset all counters to 0. |
| H | X | H | H |  | H | H | $\mathrm{Hi}-\mathrm{Z}$ | No action |
| H | L | L | H | $F U L L=L$ | L | H | Write address from Ctr \#1 | Shift into FIFO stack (Write Cycle) |
| H | L | L | H | $F U L L=H$ | H | H | $\mathrm{Hi}-\mathrm{Z}$ | Stack full (write inhibited) |
| H | L | H | L | EMPTY = L | H | L | Read address from Ctr \#2 | Shift out of FIFO stack (Read Cycle) |
| H | L | H | L | EMPTY $=\mathrm{H}$ | H | H | $\mathrm{Hi}-\mathrm{Z}$ | Stack empty (read inhibited) |
| H | L | L | $\downarrow$ | Write cycle in progress | L | H | Write address from Ctr \#1 | Continue write cycle (until $\overline{\text { SI }}$ goes high) |
| H | L | $\downarrow$ | L | Read cycle in progress | H | L | Read Address from Ctr \#2 | Continue read cycle (until $\overline{\mathrm{SO}}$ goes high) |
| H | L | L | L | EMPTY $=\mathrm{H}$ | L | H | Write address from Ctr \#1 | Shift in (read inhibited) |
| H | L | L | L | FULL $=\mathrm{H}$ | H | L | Read address from Ctr \#2 | Shift out (write inhibited) |
| H | L | $\uparrow$ | H | Write cycle in progress | $\uparrow$ | H | Goes to $\mathrm{Hi}-\mathrm{Z}$ | Increment write address counter \#1 and status counter \#3 |
| H | L | H | $\uparrow$ | Read cycle in progress | H | $\uparrow$ | Goes to Hi-Z | Increment read address counter \#2; decrement status counter \#3 |
| H | L | $\uparrow$ | L | Write cycle in progress (note 1) | $\uparrow$ | $\downarrow$ | Changes to read address from Ctr \#2 | Increment write address counter \#1 and status counter \#3 |
| H | L | L | $\uparrow$ | Read cycle in progress (note 2) | $\downarrow$ | $\uparrow$ | Changes to write address from Ctr \#1 | Increment read address counter \#2; decrement status counter \#3 |
| H | H | $\downarrow$ | H |  | H | H | $\mathrm{Hi}-\mathrm{Z}$ | Chip disabled |
| H | H | H | $\downarrow$ |  | H | H | $\mathrm{Hi}-\mathrm{Z}$ | Chip disabled |
| H | $\uparrow$ | L | X | FULL = L; write cycle begun (note 1) | L | H | Write address from Ctr \#1 | Continue write cycle (until $\overline{\mathrm{SI}}$ goes high) |
| H | $\uparrow$ | X | L | EMPTY = L: read cycle begun (note 2) | H | L | Read address from Ctr \#2 | Continue read cycle (until $\overline{\mathrm{SO}}$ goes high) |
| H | $\downarrow$ | L | L | $\begin{aligned} & \text { FULL = L; } \\ & \text { EMPTY }=\mathrm{L} \end{aligned}$ | - | - | - | This set of conditions should be avoided |

## NOTES:

1. Write cycle will occur if either $\overline{\mathrm{SI}}$ goes low before $\overline{\mathrm{SO}}$ goes low or EMPTY $=\mathrm{H}$ when $\overline{\mathrm{SO}}$ goes low.
2. Read cycle will occur if either $\overline{\mathrm{SO}}$ goes low before $\overline{\mathrm{SI}}$ goes low or FULL $=\mathrm{H}$ when $\overline{\mathrm{S} I}$ goes low.

## ABSOLUTE MAXIMUM RATINGS

|  | PARAMETER | RATING | UNIT |
| :--- | :--- | :---: | :---: |
| $V_{C C}$ | Power supply voltage | +7 | Vdc |
| $\mathrm{V}_{\mathrm{BB}}$ | Supply voltage for internal circuits | +4 | Vdc |
| $\mathrm{V}_{\text {IN }}$ | Input voltage | +5.5 | Vdc |
| $\mathrm{V}_{\mathrm{O}}$ | Off-state output voltage | +5.5 | Vdc |
| $\mathrm{T}_{\text {STG }}$ | Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS Conditions: Commercial $-\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}( \pm 5 \%), \mathrm{V}_{\mathrm{BB}}=1.5 \mathrm{~V}( \pm 5 \%)^{1}$, $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{2}$ | Max |  |
| $\mathrm{V}_{\text {IH }}$ | High level input voltage |  | Note 3 | 2.0 |  |  | V |
| VIL | Low level input voltage |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High level output voltage: <br> All outputs except FULL and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ; \mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.7 | 3.5 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low level output voltage: <br> Address Bus, WRITE, READ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ; \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.38 | 0.5 | V |
| , | HALF FULL, FULL, and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ; \mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 | V |
| $V_{C D}$ | Diode clamp voltage: <br> All inputs except FULL and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ; \mathrm{I}_{C D}=-18 \mathrm{~mA}$ | -1.5 | -0.8 |  | V |
| IH | High level input current: <br> All inputs except FULL and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{1 \mathrm{H}}=2.7 \mathrm{~V}$ |  | 0.1 | 20 | $\mu \mathrm{A}$ |
|  | FULL and EMPTY | $V_{C C}=M A X ; V_{I H}=2.7 V$ <br> stack FULL or stack EMPTY <br> (Note 3) |  | -470 | -750 | $\mu \mathrm{A}$ |
| IIL | Low level input current: All inputs except FULL and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |  | -0.17 | -0.4 | mA |
|  | FULL and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ <br> Stack FULL or Stack EMPTY |  | -1.12 | -1.8 | mA |
| IOH | High level output current: FULL, EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ; \mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{CC}}(\mathrm{min})$ |  | 15 | 100 | $\mu \mathrm{A}$ |
| 1 OzH | High-Z output current <br> (HIGH); address bus (Three-state) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}$ |  | 0.9 | 20 | $\mu \mathrm{A}$ |
| lozl | High-Z output current (LOW); address bus (Three-state) | $\mathrm{V}_{\text {CC }}=\mathrm{MAX} ; \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  | -0.6 | -20 | $\mu \mathrm{A}$ |
| 1 | Input leakage current: All inputs except FULL and EMPTY | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{\mathbb{I N}}=5.5 \mathrm{~V}$ |  | 0.03 | 0.1 | mA |
| los | Short-circuit output current: address bus and HALF FULL | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{\mathrm{OH}}=0 \mathrm{~V}$ | -15 | -68 | -100 | mA |
|  | $\overline{\text { WRITE, }} \overline{\text { READ }}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ; \mathrm{V}_{\mathrm{OH}}=0 \mathrm{~V}$ | -40 | -73 | -100 | mA |
| ICC | Supply current from $\mathrm{V}_{\mathrm{CC}}$ | $\begin{array}{lr} \mathrm{V}_{\mathrm{CC}}=\text { MAX; Address } & 0^{\circ} \mathrm{C} \rightarrow \\ \text { Bus }=\text { High }-\mathrm{Z} & 70^{\circ} \mathrm{C} \rightarrow \end{array}$ |  | 81 81 | 140 | mA |
| $I_{B B}$ | Supply current from $\mathrm{V}_{\mathrm{BB}}$ | $V_{B B}=\operatorname{Max}$ |  | 63 | 95 85 | mA |

## NOTES:

1. $V_{B B}$ can be obtained from a regulated 1.5 V supply; alternately, proper supply current ( $l_{\mathrm{BB}}$ ) can be obtained by connecting a 56 -ohm ( $\pm 5 \%, 0.5 \mathrm{~W}$ ) resistor in series with $\mathrm{V}_{\mathrm{CC}}$ as shown later in the APPLICATIONS diagram.
2. Typical limits are: $V_{C C}=5.0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
3. Because of the internal pull-up resistor on the FULL and EMPTY pins, a negative current is required to force the required voltage.

AC ELECTRICAL CHARACTERISTICS Conditions: Commercial $-V_{C C}=5.0 \vee( \pm 5 \%) V_{B B}=1.5 \vee( \pm 5 \%) 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 70^{\circ} \mathrm{C}$

| PARAMETERS | REFERENCES |  | TEST CONDITIONS | LIMITS |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | From | To |  | Min | Typ | Max |  |
| Pulse widths: <br> $\mathrm{T}_{\text {LH }} \quad \overline{\mathrm{SI}}$ high | $\uparrow \overline{\mathrm{SI}}$ | $\downarrow$ SI | Stack approaching FULL (note 1) | 25 | 13 |  | ns |
| $\mathrm{T}_{\mathrm{DH}} \overline{\mathrm{SO}}$ high | $\uparrow \overline{\mathrm{SO}}$ | $\downarrow \overline{\mathrm{SO}}$ | Stack approaching EMPTY (note 1) | 30 | 16 |  | ns |
| Write cycle timing: <br> TLA Address stable delay | $\downarrow$ SI | An | FULL $=$ Low; $\overline{\mathrm{SO}}=$ High |  | 40 | 55 | ns |
| $\mathrm{T}_{\text {AW }}$ Address lead time | An | $\downarrow$ WRITE |  | 3 |  |  | ns |
| TLAW $\overline{\text { WRITE }}$ output active delay | $\downarrow$ SI | $\downarrow$ WRITE | FULL $=$ Low; $\overline{\text { SO }}=$ High | 35 | 51 | 65 | ns |
| TLW WRITE output inactive delay | $\uparrow \overline{\text { SI }}$ | $\uparrow \overline{\text { WRITE }}$ |  |  | 3 | 10 | ns |
| TWA Address lag time | $\uparrow \overline{\text { WRITE }}$ | An |  | 20 | 34 |  | ns |
| $\mathrm{T}_{\text {LT }}$ Address output disable | $\uparrow \overline{\mathrm{SI}}$ | An (Hi-Z) |  |  | 37 | 60 | ns |
| $T_{\text {LF }}$ FULL status active delay | $\downarrow \overline{\mathrm{SI}}$ | $\uparrow$ FULL | Stack approaching FULL; $\overline{\mathrm{SO}}=$ High |  | 39 | 65 | ns |
| TLE EMPTY status inactive delay | $\downarrow \overline{\text { SI }}$ | $\downarrow$ EMPTY | Stack = EMPTY |  | 40 | 65 | ns |
| THFH HALF-FULL status active delay | $\uparrow \overline{\text { S }}$ | $\uparrow$ HALF FULL | Stack approaching HALF-FULL |  | 30 | 45 | ns |
| TDW WRITE output active after read | $\uparrow \overline{\mathrm{SO}}$ | $\downarrow$ WRITE | Both $\overline{\mathrm{SI}}$ \& $\overline{\mathrm{READ}}=$ Low |  | 74 | 95 | ns |
| Read cycle timing: <br> TDA Address stable delay | $\downarrow \overline{\mathrm{SO}}$ | An | EMPTY = Low; $\overline{\mathrm{SI}}=$ High |  | 40 | 55 | ns |
| $\mathrm{T}_{\text {AR }}$ Address lead time | An | $\downarrow$ READ |  | -1 |  |  | ns |
| T DAR $\overline{R E A D}$ output active delay | $\downarrow$ SO | $\downarrow$ READ | EMPTY = Low; $\overline{\text { SI }}=$ High | 30 | 48 | 65 | ns |
| $\mathrm{T}_{\mathrm{DR}}$ 兂EAD output inactive delay | $\uparrow \overline{\mathrm{SO}}$ | $\uparrow \overline{\text { READ }}$ |  |  | 5 | 10 | ns |
| $\mathrm{T}_{\text {RA }}$ Address lag time | $\uparrow$ READ | An |  | 20 | 32 |  | ns |
| $\mathrm{T}_{\text {DT }}$ Address output disable | $\uparrow \overline{\mathrm{SO}}$ | An (Hi-Z) |  |  | 37 | 60 | ns |
| $T_{\text {DE }}$ EMPTY status active delay | $\downarrow \overline{\mathrm{SO}}$ | $\uparrow$ EMPTY | Stack approaching EMPTY; $\overline{\text { SI }}=$ High |  | 38 | 50 | ns |
| T ${ }_{\text {DF }}$ FULL status inactive delay | $\downarrow \overline{\mathrm{SO}}$ | $\downarrow$ FULL | Stack = FULL |  | 38 | 50 | ns |
| THFL HALF-FULL status inactive delay | $\uparrow \overline{\mathrm{SO}}$ | $\downarrow$ HALF FULL | Stack exactly HALF-FULL |  | 54 | 75 | ns |
| TLR $\overline{\text { READ }}$ output active after write | $\uparrow \overline{\mathrm{SI}}$ | $\downarrow \overline{\text { READ }}$ | Both $\overline{\text { SO }}$ \& $\overline{\text { WRITE }}=$ Low |  | 70 | 90 | ns |
| Chip enable timing (write): <br> $T_{\text {HEW }}$ Chip enable hold time ${ }^{2}$ | $\downarrow$ S | $\uparrow \overline{\mathrm{CE}}$ | FULL = Low; $\overline{\text { SO }}=$ High | 10 | 1 |  | ns |
| $T_{\text {SEW }}$ Chip disable set-up time ${ }^{3}$ | $\uparrow \overline{\mathrm{CE}}$ | $\downarrow \overline{\text { SI }}$ | FULL = Low; $\overline{\text { SO }}=$ High | 10 | 1 |  | ns |
| TPEW Chip enable delay time | $\downarrow \overline{\mathrm{CE}}$ | $\downarrow$ WRITE | FULL = Low; $\overline{\mathrm{Sl}}=$ Low; $\overline{\mathrm{SO}}=$ High |  | 69 | 95 | ns |
| Chip enable timing (read): THER Chip enable hold time ${ }^{2}$ | $\downarrow \overline{\mathrm{SO}}$ | $\uparrow \overline{\mathrm{CE}}$ | EMPTY = Low; $\overline{\mathrm{SI}}=$ High | 10 | 1 |  | ns |
| $\mathrm{T}_{\text {SER }}$ Chip disable set-up time ${ }^{3}$ | $\uparrow \overline{\mathrm{CE}}$ | $\downarrow \overline{\mathrm{SO}}$ | EMPTY = Low; $\overline{\mathrm{Sl}}=$ High | 10 | 1 |  | ns |
| $T_{\text {PER }}$ Chip enable delay time | $\downarrow \overline{\mathrm{CE}}$ | $\downarrow$ READ | EMPTY = Low; $\overline{\mathrm{SO}}=$ Low; $\overline{\mathrm{SI}}=$ High |  | 64 | 95 | ns |
| Reset timing: <br> TRR RESET recovery | $\uparrow \overline{\text { RESET }}$ | $\downarrow$ WRITE | $\overline{\mathrm{SI}}=$ Low |  | 57 | 75 | ns |
| $\mathrm{T}_{\mathrm{RL}}$ RESET pulse width (low) | $\downarrow$ RESET | $\uparrow \overline{\text { RESET }}$ |  | 25 | 8 |  | ns |
| Full/empty override timing: <br> $\mathrm{T}_{\text {FW }}$ Override Recovery for FULL | $\downarrow$ FULL | $\downarrow$ WRITE | Stack $=$ Full; $\overline{\mathrm{Sl}}=$ Low; $\overline{\mathrm{SO}}=$ High |  | 70 | 95 | ns |
| TER Override Recovery for EMPTY | $\downarrow$ EMPTY | $\downarrow$ रहAD | Stack = EMPTY; $\overline{\mathrm{SO}}=$ Low; $\overline{\mathrm{Sl}}=$ High |  | 65 | 90 | ns |

## NOTES:

1. Such that write/read request is inhibited after stack becomes full/empty.
2. The earliest rising edge of $\overline{\mathrm{CE}}$ such that the $\overline{\text { WRITE }}$ or $\overline{\text { READ }}$ output always occurs.
3. The latest rising edge of $\overline{C E}$ such that the WRITE or $\overline{\text { READ }}$ output never occurs.

## TEST LOADING CIRCUITS

APPLICABLE PINS: WRITE (7), READ (8), HALF FULL (10)


APPLICABLE PINS: FULL (8) AND EMPTY (11)


TC03370S

APPLICABLE PINS: $A_{n}(15-20$, 22-27)


Tcos 3 eos

| OUTPUT <br> STATE |  | SWITCH <br> POSITION |  |
| :---: | :---: | :---: | :---: |
| FROM | TO | S1 | s2 |
| Low | High | Closed | Closed |
| High | Low | Closed | Closed |
| High | HI-Z | Closed | Closed |
| Low | HI-Z | Closed | Closed |
| HI-Z | High | Open | Closed |
| HI-Z | Low | Closed | Open |

NOTES:

1. In all cases $C_{L}$ includes probe and jig capacitance
2. All diodes are 1 N916, 1 N3064, or equivalent.
3. For $\overline{\text { READ }}$ and WRITE outputs, $R_{L}=280$ ohms; for HALF FULL output, $\mathrm{R}_{\mathrm{L}}=2 \mathrm{~K}$ ohms.

## AC TEST WAVEFORMS



Propagation Delay
(Typical Example)
NOTE:
Pulse widths and Set-up/Hold times are measured using the same reference points as above waveform.


WF10830S

For all waveforms, $V_{M}=1.5 \mathrm{~V}$ for 74 and 74 S ; $\mathrm{V}_{\mathrm{M}}=1.3 \mathrm{~V}$ for 74LS.

3-State Enable Time To LOW Level And Disable Time From LOW Level

3-State Enable Time To HIGH Level And Disable Time From HIGH Level

## FIFO RAM Controiler (FRC) $8 \times 60$

TIMING DIAGRAMS

*The rising edge of $\overline{C E}$ should not occur within 10 -nanoseconds before or after a falling edge of $\overline{\mathrm{S}}$ or $\overline{\mathrm{SO}}$.

## FIFO RAM Controller (FRC)

TIMING DIAGRAMS (Continued)
Empty Override Timing

## APPLICATIONS



## Signetics

## Logic Products

## FEATURES

- Boosts Memory Reliability Corrects all single-bit errors. Detects all double and some triple-bit errors. Reliability of dynamic RAM systems is increased more than $\mathbf{6 0}$-fold.
- Very High Speed - Perfect for MOS microprocessor, minicomputer and mainframe systems.
- Data in to error detect: 32ns worst case.
- Data in to corrected data out: 65ns worst case.
- High performance systems can use the Signetics EDC in the check-only mode to avoid memory system slowdown.
- Replaces 25 to 50 MSI chips All necessary features are built-in to the Signetics 2960, including


## 2960

## Error Detection and Correction (EDC) Unit

Product Specification

diagnostics, data in, data out and check bit latches.

- Handles Data Words From 8 to 64 Bits - The Signetics 2960 is cascadable: 1 EDC for 8 or 16 bits, 2 for 32 bits, 4 for 64 bits.
- Easy Byte Operations - Separate byte enables on the data out latch simplify the steps and cuts the time required by byte writes.
- Built-In Diagnostics - The processor may completely exercise the EDC under software control to check for proper operation.


## DESCRIPTION

The Signetics 2960 Error Detection and Correction Unit (EDC) (Figure 1) contains the logic necessary to generate check bits on a 16-bit data field accord-
ing to a modified Hamming Code, and to correct the data word when check bits are supplied. Operating on data read from memory, the EDC will correct any single bit error and will detect all double and some triple bit errors. For 16 -bit words, 6 check bits are used. The 2960 can be expanded to operate on 32-bit words ( 7 check bits) and 64-bit words (8 check bits). In all configurations, the device makes the error syndrome available on separate outputs for data logging.
The Signetics 2960 also features two diagnostic modes, in which diagnostic data can be forced into portions of the chip to simplify device testing and to execute system diagnostic functions.

The product is supplied in a 48 lead hermetic DIP package and a 48-pin plastic package.


Figure 1. Block Diagram Of 2960

## Error Detection and Correction (EDC) Unit

## 2960 PACKAGE AND PIN DESIGNATIONS



## PIN DESCRIPTION

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 1 | Correct | Correct input: When HIGH this signal allows the correction network to correct any single-bit error in the Data input Latch (by complementing the bit-in-error) before putting it onto the Data Output Latch. When LOW the EDC will drive data directly from the Data input latch to the Data Output Latch without correction. |
| 2-5 | DATA $_{15-12}$ | 16 Bidirectional Data Lines: They provide input to the Data Input Latch and Diagnostic Latch, and |
| 9-12 | $\mathrm{DATA}_{11-8}$ | receive output from the Data Output Latch. DATA $_{0}$ is the least significant bit; DATA 15 is the most |
| 14-17 | $\mathrm{DATA}_{7-4}$ | significant. |
| 20-23 | DATA $_{3-0}$ |  |
| 6 | LE IN | Latch Enable: Data Input Latch. Controls latching of the input data. When HIGH the Data input Latch and Check Bit Input Latch follow the input data and input check bits. When LOW, the Data Input Latch and Check Bit Input Latch are latched to their previous state. |
| 7 | LE DIAG | Latch Enable: Diagnostic Latch. When HIGH the Diagnostic Latch follows the 16 -bit data on the input lines. When LOW the outputs of the Diagnostic Latch are latched to their previous states. The Diagnostic Latch holds diagnostic check bits, and internal control signals for CODE $\mathrm{ID}_{0-2}$, DIAG $M_{0 D E}{ }_{0-1}$, CORRECT and PASS THRU. |

Error Detection and Correction (EDC) Unit

## PIN DESCRIPTION (Continued)

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :---: |
| 18, 8 | OE BYTE 0, OE BYTE 1 | Output Enable: Bytes 0 and 1, Data Output Latch. These lines control the 3 -state outputs for each of the two bytes of the Data Output Latch. When LOW these lines enable the Data Output Latch and when HIGH these lines force the Data Output Latch into the high impedance state. The two enable lines can be separately activated to enable only one byte of the Data Output Latch at a time. |
| 13 | GND | Ground. |
| 19 | LE OUT | Latch Enable: Data Output Latch. Controls the latching of the Data Output Latch. When LOW the Data Output Latch is latched to its previous state. When HIGH the Data Output Latch follows the output of the Data Input Latch as modified by the correction logic network. In Correct Mode, single-bit errors are corrected by the network before loading into the Data Output Latch. In Detect Mode, the contents of the Data Input Latch are passed through the correction network unchanged into the Data Output Latch. The inputs to the Data Output Latch are unspecified if the EDC is in Generate Mode. |
| 24, 25-30 | $S C S_{1} S_{6}-S_{0}$ | Syndrome/Check Bit Outputs: These seven lines hold the check/partial-check bits when the EDC is in Generate Mode, and will hold the syndrome/partial syndrome bits when the device is in Detect or Correct Modes. These are 3 -state outputs. |
| 31 | OE SC | Output Enable: Syndrome/Check Bits. When LOW, the 3 -state output lines $\mathrm{SC}_{0-6}$ are enabled. When HIGH, the SC outputs are in the high impedance state. |
| 32 | ERROR | Error Detected Output: When the EDC is in Detect or Correct Mode, this output will go LOW if one or more syndrome bits are asserted, meaning there are one or more bit errors in the data or check bits. If no syndrome bits are asserted, there are no errors detected and the output will be HIGH. In Generate Mode, ERROR is forced HIGH. (In a 64-bit configuration, ERROR must be externally implemented.) |
| 33 | MULT ERROR | Multiple Errors Detected Output: When the EDC is in Detect or Correct Mode, this output if LOW indicates that there are two or more bit errors that have been detected. If HIGH this indicates that either one or no errors have been detected. In Generate mode, MULT ERROR is forced HIGH (in a 64-bit configuration, MULT ERROR must be externally implemented.) |
| $\begin{aligned} & 40,34-35 \\ & 37-39,41 \end{aligned}$ | $\mathrm{CB}_{0-6}$ | Seven Check Bit Input Lines: The check bit lines are used to input check bits for error detection. Also used to input syndrome bits for error correction in 32 and 64-bit configurations. |
| 36 | $V_{C C}$ | +5V Power Supply. |
| 42 | GENERATE | Generate Check Bits Input: When this input is LOW the EDC is in the Check Bit Generate Mode. When HIGH the EDC is in the Detect Mode or Correct Mode. <br> In the Generate Mode the circuit generates the check bits or partial check bits specific to the data in the Data Input Latch. The generated check bits are placed on the SC outputs. <br> In the Detect or Correct Modes the EDC detects single and multiple errors, and generates syndrome bits based upon the contents of the Data Input Latch and Check Bit input Latch. In Correct Mode, single-bit errors are also automatically corrected - corrected data is placed at the inputs of the Data Output Latch. The syndrome result is placed on the SC outputs and indicates in a coded form the number of errors and the bit-in-error. |
| 43-45 | Code $1 D_{0-2}$ | Code Identification Inputs: These three bits identify the size of the total data word to be processed and which 16 -bit slice of larger data words a particular EDC is processing. <br> The three allowable data word sizes are 16,32 and 64 bits and their respective modified Hamming codes are designated $16 / 22,32 / 39$ and $64 / 72$. Special CODE ID input $001\left(\mathrm{ID}_{2}, I D_{1}, I D_{0}\right)$ is also used to instruct the EDC that the signals, CODE $I_{0-2}$, DIAG MODE $0_{0-1}$, CORRECT and PASS THRU are to be taken from the Diagnostic Latch, rather than from the input control lines. |
| 46, 47 | DIAG <br> MODE $_{0-1}$ | Diagnostic Mode Select: These two lines control the initialization and diagnostic operation of the EDC. |
| 48 | PASS <br> THRU | Pass Thru Input: This line when HIGH forces the contents of the Check Bit Latch onto the Syndrome/Check Bit outputs $\left(\mathrm{SC}_{0-6}\right)$ and the unmodified contents of the Data Input Latch onto the inputs of the Data Output Latch. |

## ARCHITECTURAL SUMMARY

The EDC Unit is a powerful 16-bit cascadable slice used for check bit generation, error detection, error correction and diagnostics.

As shown in Figure 1, the device consists of
the following

- Data Input Latch
- Check Bit Input Latch
- Check Bit Generation Logic
- Syndrome Generation Logic
- Error Detection Logic

Table 1. Hamming Code and Slice Identification

| CODE <br> $\mathbf{I D}_{\mathbf{2}}$ | CODE <br> $\mathbf{I D}_{\mathbf{1}}$ | CODE <br> $\mathbf{I D}_{\mathbf{0}}$ | HAMMING CODE AND <br> SLICE SELECTED |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Code 16/22 |
| 0 | 0 | 1 | Internal Control Mode |
| 0 | 1 | 0 | Code 32/39, Bytes 0 and 1 |
| 0 | 1 | 1 | Code 32/39, Bytes 2 and 3 |
| 1 | 0 | 0 | Code 64/72, Bytes 0 and 1 |
| 1 | 0 | 1 | Code 64/72, Bytes 2 and 3 |
| 1 | 1 | 0 | Code 64/72, Bytes 4 and 5 |
| 1 | 1 | 1 | Code 64/72, Bytes 6 and 7 |

Table 2. EDC Operating Modes

| OPERATING <br> MODE DIAGNOSTIC <br> MODE**  GENERATE  <br>  DM $_{\mathbf{1}}$    DM $_{\mathbf{0}}$ | $\mathbf{0}$ | $\mathbf{1}$ |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  | 0 | 0 | Generate | Correct* $^{*}$ |
| Diagnostic <br> Generate | 0 | 1 | Diagnostic <br> Generate | Correct* $^{*}$ |
| Diagnostic <br> Correct | 1 | 0 | Generate | Diagnostic <br> Correct* |
| Initialize | 1 | 1 | Initialize | Initialize |
| Pass Thru | When PASS THRU is asserted the Operating Mode is <br> defaulted to the Pass Thru Mode. |  |  |  |

*Correct if the CORRECT Input is HIGH. Detect if the CORRECT Input is LOW.
**In Code $\mathrm{ID}_{2-0} 001\left(\mathrm{ID}_{2}, \mathrm{ID}_{1}, \mathrm{ID}_{0}\right) \mathrm{DM}_{1}$ and $\mathrm{DM}_{0}$ are taken from the Diagnostic Latch.

- Error Correction Logic
- Data Output Latch
- Diagnostic Latch
- Control Logic


## Data Input Latch

16 bits of data are loaded from the bidirectional DATA lines under control of the Latch Enable input, LE IN. Depending on the control mode the input data is either used for check bit generation or error detection/correction.

## Check Bit Input Latch

Seven check bits are loaded under control of LE IN. Check bits are used in the Error Detection and Error Correction modes.

## Check Bit Generation Logic

This block generates the appropriate check bit for the 16 bits of data in the Data Input Latch. The check bits are generated according to a modified Hamming code.

## Syndrome Generation Logic

In both Error Detection and Error Correction modes, this logic block compares the check bits read from memory against a newly generated set of check bits produced for the data read in from memory. If both sets of check bits match, then there are no errors. If there is a mismatch, then one or more of the data or check bits is in error.

The syndrome bits are produced by an exclu-sive-OR of the two sets of check bits. If the two sets of check bits are identical (meaning
there are no errors) the syndrome bits will be all zeroes. If there are errors, the syndrome bits can be decoded to determine the number of errors and the bit-in-error.

## Error Detection Logic

This section decodes the syndrome bits generated by the Syndrome Generation Logic. If there are no errors in either the input datas or check bits, the ERROR and MULT ERROR outputs remain HIGH. If one or more errors are detected, ERROR goes LOW. If two or more errors are detected, both ERROR and MULT ERROR go LOW.

## Error Correction Logic

For single errors, the Error Correction Logic complements (corrects) the single data bit in error. This corrected data is loadable into the Data Output Latch, which can then be read onto the bidirectional data lines. If the single error is one of the check bits, the correction logic does not place corrected check bits on the syndrome/check bit outputs. If the corrected check bits are needed the EDC must be switched to Generate Mode.

## Data Output Latch

The Data Output Latch is used for storing the result of an error correction operation. The latch is loaded from the correction logic under control of the Data Output Latch Enable, LE OUT. The Data Output Latch may also be loaded directly from the Data Input Latch under control of the PASS THRU control input.

The Data Output Latch is split into two 8-bit (byte) latches which may be enabled independently for reading onto the bidirectional data lines.

## Diagnostic Latch

This is a 16-bit latch loadable from the bidirectional data lines under control of the Diagnostic Latch Enable, LE DIAG. The Diagnostic Latch contains check bit information in one byte and control information in the other byte. The Diagnostic Latch is used for driving the device when in Internal Control Mode, or for supplying check bits when in one of the Diagnostic Modes.

## Control Logic

The control logic determines the specific operating mode of the device. Normally the control logic is driven by external control inputs. However, in Internal Control Mode, the control signals are read from the Diagnostic Latch.

## FUNCTIONAL OPERATION

The EDC contains the logic necessary to generate check bits on a 16-bit data field according to a modified Hamming code (Table 1). Operating on data read from memory, the EDC will correct any single-bit error and will detect all double and some triple-bit errors. The EDC can be configured to operate on 16-bit data words (with 6 check bits), 32 bit data words (with 7 check bits) and 64-bit data words (with 8 check bits). In fact, the EDC can be configured to work on data words from 8 to 64 bits. In all configurations, the device makes the error syndrome bits available on separate outputs for error data logging.

## Code and Byte Specification

The EDC may be configured in several different ways and operates differently in each configuration. It is necessary to indicate to the device what size data word is involved and which bytes of the data word it is processing. This is done with input lines CODE $I D_{0-2}$, as shown in Table 1; the three modified Hamming codes are defined below:

| $-16 / 22$ | 16 data bits |
| :---: | :---: |
|  | 6 check bits |
|  | 22 bits in total. |
|  | 32 data bits |
|  | 7 check bits |
| 39 | bits in total. |
|  | 64 data bits |
|  | 8 check bits |
|  | 72 bits in total. |

CODE ID input $001\left(\mathrm{ID}_{2}, I \mathrm{I}_{1}, I \mathrm{I}_{0}\right)$ is a special code, described later, used to operate the device in Internal Control Mode.

Table 3. Diagnostic Mode Control

| DIAG <br> MODE $_{\mathbf{1}}$ | DIAG <br> MODE $_{\mathbf{0}}$ | DIAGNOSTIC MODE SELECTED |
| :---: | :---: | :--- |
| 0 | 0 | Non-diagnostic mode: The EDC functions normally in all modes. |
| 0 | 1 | Diagnostic Generate: The contents of the Diagnostic Latch are substituted for the normally <br> generated check bits when in the Generate Mode. The EDC functions normally in the Detect <br> or Correct modes. |
| 1 | 0 | Diagnostic Detect/Correct: In the Detect or Correct Mode, the contents of the Diagnostic <br> Latch are substituted for the check bits normally read from the Check Bit Input Latch. The <br> EDC functions normally in the Generate Mode. |
| 1 | 1 | Initialize: The outputs of the Data Input Latch are forced to zeroes (and latched upon <br> removal of the Initialize Mode) and the check bits generated correspond to the all-zero data. |

Table 4. 16-Bit Modified Hamming Code

| GENERATED | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BITS |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| CX | Even (XOR) |  | X | x | x |  | x |  |  | X | x |  | $x$ |  |  | X |  |
| C0 | Even (XOR) | $x$ | X | X |  | $x$ |  | X |  | X |  | X |  | X |  |  |  |
| C1 | Odd (XNOR) | X |  |  | X | X |  |  | X |  | X | X |  |  | X |  | X |
| C2 | Odd (XNOR) | X | x |  |  |  | X | X | x |  |  |  | x | x | X |  |  |
| C4 | Even (XOR) |  |  | X | X | x | X | X | X |  |  |  |  |  |  | X | X |
| C8 | Even (XOR) |  |  |  |  |  |  |  |  | x | X | X | x | X | X | X | X |

## NOTE:

The check bit is generated as either an XOR or XNOR of the eight data bits noted by an " X " in the table.

## Control Mode Selection

The device control lines are GENERATE, CORRECT, PASS THRU, DIAG MODE $0_{-1}$ and CODE $\mathrm{ID}_{0-2}$. Table 2 indicates the operating modes selected by various combinations of the control line inputs.

## Diagnostics

Table 3 shows specifically how DIAG $M_{O D E}^{0-1}$ select between normal operation, initialization and one of two diagnostic modes. The Diagnostic Modes allow the user to operate the EDC under software control in order to verify proper functioning of the device.

## Check and Syndrome Bit <br> Labelling

The check bits generated in the EDC are designed as follows:

- 16-bit configuration - CX, C0, C1, C2, C4, C8;
- 32-bit configuration - CX, C0, C1, C2, C4, C8, C16;
- 64-bit configuration - CX, C0, C1, C2, C4, C8, C16, C32.

Syndrome bits are similarly labeled SX through S32. There are only 6 syndrome bits in the 16 -bit configuration, 7 for 32 bits and 8 syndrome bits in the 64-bit configuration.

The error correction code can be selected independent of the processor with the exception of diagnostic software.
Diagnostic software run by a processor to checkout the EDC system must know specifically which code is being used. This is only a problem when the EDC replaces an existing MSI implementation on an existing computer. In this case, the computer's software must first determine which of two codes (the old one used by the MSI implementation or the new one used by the EDC) is used by the computer's memory system.
This is easily determined by writing a test data word into memory and then examining whether the generated check bits are typical of the
old or the new code. From then on the software runs only the diagnostic appropriate for the code used on that particular computer's memory system.

## Initialize Mode

The inputs of the Data Output Latch are forced to zeroes. The check bit outputs (SC) are generated to correspond to the all-zero data. ERROR and MULT ERROR are forced HIGH in the Initialize Mode.

Initialize Mode is useful after power up when RAM contents are random. The EDC may be placed in initialize mode and its outputs written in to all memory locations by the processor.

## Code Selections

The Signetics 2960 EDC uses a modified Hamming Code which provides the following functions:

- Cascading of EDC Units
- Detection of all double-bit errors
- Detection of gross error conditions (all " 0 s " or all " 1 s ").


Figure 2. 16-Bit Data Format And I/O

16-Bit Data Word Configuration
The 16-bit format consists of 16 data bits, six check bits and, as previously indicated, is designated as the 16/22 code. The data format and I/O configuration for a 16-bit word is shown in Figure 2.

## Generate Mode

In this mode check bits will be generated that correspond to the contents of the Data Input Latch. The check bits generated are placed on the outputs $\mathrm{SC}_{0-5}\left(\mathrm{SC}_{6}\right.$ is a logical one, or high).
Check bits are generated according to a modified Hamming code. Details of the code for check bit generation are contained in Table 4.

Each check bit is generated as either an XOR or XNOR of eight of the 16 data bits as indicated in the table. The XOR function results in an even parity check bit; the XNOR is an odd parity check bit. Data flow for the Generate Mode is shown in Figure 3.


Figure 3. Check Bit Generation


Figure 4. Error Detection And Correction

Table 5. Syndrome Decode to Bit-In-Error

| SYNDROME BITS |  |  | $\begin{aligned} & \text { S8 } \\ & \text { S4 } \\ & \text { S2 } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | 010 | 0 | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | 0 | 011 | 111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |
| SX | S0 | S1 |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 |  | * | C8 | C4 | T | C 2 | T | T | M |
| 0 | 0 | 1 |  | C1 | T | T | 15 | T | 13 | 7 | T |
| 0 | 1 | 0 |  | C0 | T | T | M | T | 12 | 6 | T |
| 0 | 1 | 1 |  | T | 10 | 4 | T | 0 | T | T | M |
| 1 | 0 | 0 |  | CX | T | T | 14 | T | 11 | 5 | T |
| 1 | 0 | 1 |  | T | 9 | 3 | T | M | T | T | M |
| 1 | 1 | 0 |  | T | 8 | 2 | T | 1 | T | T | M |
| 1 | 1 | 1 |  | M | T | T | M | T | M | M | T |

*     - no errors detected

Number - the location of the single bit-in-error
$T$ - two errors detected
M - three or more errors detected

## Detect Mode

In this mode the device examines the contents of the Data input Latch against the Check Bit input Latch, and will detect all single-bit errors, all double-bit errors and some triple-bit errors. If one or more errors are detected, ERROR goes LOW. If two or more errors are detected, MULT ERROR goes LOW. Both error indicators are HIGH if there are no errors.

Also available on device outputs $\mathrm{SC}_{0-5}$ are the syndrome bits generated by the error detection step. The syndrome bits may be decoded to determine if a bit error was detected and, for single-bit errors, which of the data or check bits is in error. Table 5 provides decoding data for the syndrome bits generated by the 16 -bit configuration (as an example, if the syndrome bits SX/S0/S1/S2/ S4/S8 were 101001 this would be decoded to indicate that there is a single-bit error at data bit 9). If no error is detected the syndrome bits will all be zeroes.

In Detect Mode, the contents of the Data Input Latch are driven directly to the inputs of the Data Output Latch without correction.

Table 6. Diagnostic Latch Loading

| DATA BIT | INTERNAL FUNCTION |
| :---: | :--- |
| 0 | Diagnostic Check Bit X |
| 1 | Diagnostic Check Bit 0 |
| 2 | Diagnostic Check Bit 1 |
| 3 | Diagnostic Check Bit 2 |
| 4 | Diagnostic Check Bit 4 |
| 5 | Diagnostic Check Bit 8 |
| 6,7 | Don't Care |
| 8 | CODE ID 0 |
| 9 | CODE ID 1 |
| 10 | CODE ID 2 |
| 11 | DIAG MODE 0 |
| 12 | DIAG MODE 1 |
| 13 | CORRECT |
| 14 | PASS THRU |
| 15 | Don't Care |

## Correct Mode

In this mode, the EDC functions the same as in Detect Mode except that the correction network is allowed to correct (complement) any single-bit error of the Data Input Latch before putting it onto the inputs of the Data Output Latch - see Figure 4. If multiple errors are detected, the output of the correction network is unspecified. If the single-bit error is a check bit there is no automatic correction. If check bit correction is desired, this can be done by placing the device in Generate Mode to produce a correct check bit sequence for the data in the Data Input Latch.

## Pass Thru Mode

In this mode, the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch and the contents of the Check Bit Input Latch are placed on outputs $\mathrm{SC}_{0-5}$. ERROR and MULT ERROR are forced HIGH in this mode.

## Diagnostic Latch

The diagnostic Latch serves both for diagnostic uses and internal control uses. It is loaded from the DATA lines under the control of LE DIAG. Table 6 shows the loading definitions for the DATA lines.

## Diagnostic Generate/Detect/ Correct

These are special diagnostic modes selected by DIAG MODE $0-1$ where either normal
check bit inputs or outputs are substituted for by check bits loaded into the Diagnostic Latch - See Table 2 for details. Figures 5 and 6 illustrate the flow of data during the two diagnostic modes.

## Internal Control Mode

This mode is selected by CODE $I D_{0-2}$ input $001\left(\mathrm{ID}_{2}, \mathrm{ID}_{1}, I \mathrm{D}_{0}\right)$.
When in Internal Control Mode, the EDC takes the CODE $\mathrm{ID}_{0-2}$, DIAG MODE ${ }_{0-1}$, CORRECT, and PASS THRU control signals from the internal Diagnostic Latch rather than from the external input lines.

Table 6 gives the format for loading the Diagnostic Latch.

## 32-Bit Data Word Configuration

The 32-bit format consists of 32 data bits, seven check bits and, as previously indicated, is designated as the $32 / 39$ code. The data format and I/O configuration for a 32-bit word is shown in Figure 7.
The upper EDC (Slice 0/1) handles the least significant bytes 0 and 1 - the external DATA lines 0 to 15 are connected to the same numbered inputs of the upper device. The lower EDC (Slice $2 / 3$ ) handles the most significant bytes 2 and 3 - the external DATA lines for bits 16 to 31 are connected to inputs DATA $_{0}$ through DATA $_{15}$ respectively.

The valid syndrome and check bit outputs are those of Slice $2 / 3$ as shown in the diagram. In Correct Mode these must be read into Slice $0 / 1$ via the CB inputs and are selected by the MUX as inputs to the bit-in-error decoded (see block diagram), thus requiring external buffering and output enabling of the check bit lines as shown. The OE SC signal can be used to control enabling of check bit inputs when syndrome outputs are enabled, the external check bit inputs will be disabled.

The valid ERROR and MULT ERROR outputs are those of the Slice $2 / 3$. The ERROR and MULT ERROR outputs of Slice $0 / 1$ are unspecified. All of the latch enables and control signals must be input to both of the devices.

## Generate Mode

In this mode check bits will be generated that correspond to the contents of the Data Input Latch. The check bits generated are placed on the outputs $\mathrm{SC}_{0-6}$ of Slice $2 / 3$.

Check bits are generated according to a modified Hamming code. Details of the code for check bit generation are contained in Table 7. Check bits are generated as either
an XOR or XNOR or 16 of the 32 data bits as indicated in the table. The XOR function results in an even parity check bit, the XNOR in an odd parity check bit.

## Detect Code

In this mode the device examines the contents of the Data Input Latch against the Check Bit input Latch, and will detect all single-bit errors, all double-bit errors and some triple-bit errors. If one or more errors are detected, ERROR goes LOW. If two or more errors are detected MULT ERROR goes LOW. Both error indicators are HIGH if there are no errors. The valid ERROR and MULT ERROR signals are those of Slice 2/3those of Slice $0 / 1$ are undefined.

Also available on Slice $2 / 3$ outputs $\mathrm{SC}_{0 / 6}$ are the syndrome bits generated by the error detection step. The syndrome bits may be decoded to determine if a bit error was detected and, for single-bit errors, which of the data or check bits is in error. Table 8 gives the chart for decoding the syndrome bits generated for the 32 -bit configuration (as an example, if the syndrome bits SX/S0/S1/ S2/S4/S8/S16 were 0010011 this would be decoded to indicate that there is a single-bit error at data bit 25). If no error is detected the syndrome bits will be all zeroes.

In Detect Mode, the contents of the Data Input Latch are driven directly to the inputs of the Data Output Latch without corrections.

## Correct Mode

In this mode, the EDC functions the same as in Detect Mode except that the correction network is allowed to correct (complement) any single-bit error of the Data Input Latch before putting it onto the inputs of the Data Output Latch. If multiple errors are detected, the output of the correction network is unspecified. If the single-bit error is a check bit there is no automatic correction - if desired this would be done by placing the device in Generate Mode to produce a correct check bit sequence for the data in the Data Input Latch.

For data correction, both Slices 0/1 and 2/3 require access to the syndrome bits on Slice $2 / 3$ 's outputs $\mathrm{SC}_{0-6}$. Slice $2 / 3$ has access to these syndrome bits through internal data paths, but for Slice $0 / 1$ they must be read through the inputs $\mathrm{CB}_{0-6}$. The device connections for this are shown in Figure 7. When in Correct Mode the SC outputs must be enabled so that they are available for reading in through the $C B$ inputs.

## Error Detection and Correction (EDC) Unit



AF02630S
Figure 5. Diagnostic Check Bit Generation


Figure 6. Diagnostic Detect And Correct

Table 7. 32-Bit Modified Hamming Code

| GENERATED CHECK BITS | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| CS | Even (XOR) | X |  |  |  | X |  | X | X | X | X |  | X |  |  | X |  |
| C0 | Even (XOR) | X | X | X |  | X |  | X |  | X |  | X |  | X |  |  |  |
| C1 | Odd (XNOR) | X |  |  | X | X |  |  | $x$ |  | X | X |  |  | $x$ |  | X |
| C2 | Odd (XNOR) | X | X |  |  |  | X | X | X |  |  |  | X | X | X |  |  |
| C4 | Even (XOR) |  |  | X | X | X | X | X | X |  |  |  |  |  |  | X | X |
| C8 | Even (XOR) |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |
| C16 | Even (XOR) | X | X | X | X | X | X | X | X |  |  |  |  |  |  |  |  |


| GENERATED | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BITS |  | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| CS | Even (XOR) |  | X | X | X |  | X |  |  |  |  | X |  | X | X |  | X |
| C0 | Even (XOR) | X | X | X |  | X |  | X |  | X |  | X |  | X |  |  |  |
| C1 | Odd (XNOR) | X |  |  | X | x |  |  | X |  | X | X |  |  | x |  | X |
| C2 | Odd (XNOR) | x | X |  |  |  | x | X | X |  |  |  | X | X | X |  |  |
| C4 | Even (XOR) |  |  | X | X | X | X | X | X |  |  |  |  |  |  | X | X |
| C8 | Even (XOR) |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |
| C16 | Even (XOR) |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |

NOTE:
The check bit is generated as either an XOR or XNOR of the sixteen data bits noted by an " X " in the table.
Table 8. Syndrome Decode to Bit-In-Error

| SYNDROME BITS |  |  |  | S16 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | S2 | S8 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| sx | So | S1 |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 |  | * | C16 | C8 | T | C4 | T | T | 30 |
| 0 | 0 | 0 | 1 |  | C2 | T | T | 27 | T | 5 | M | T |
| 0 | 0 | 1 | 0 |  | C1 | T | T | 25 | T | 3 | 15 | T |
| 0 | 0 | 1 | 1 |  | T | M | 13 | T | 23 | T | T | M |
| 0 | 1 | 0 | 0 |  | C0 | T | T | 24 | T | 2 | M | T |
| 0 | 1 | 0 | 1 |  | T | 1 | 12 | T | 22 | T | T | M |
| 0 | 1 | 1 | 0 |  | T | M | 10 | T | 20 | T | T | M |
| 0 | 1 | 1 | 1 |  | 16 | T | T | M | T | M | M | T |
| 1 | 0 | 0 | 0 |  | CX | T | T | M | T | M | 14 | T |
| 1 | 0 | 0 | 1 |  | T | M | 11 | T | 21 | T | T | M |
| 1 | 0 | 1 | 0 |  | T | M | 9 | T | 19 | T | T | 31 |
| 1 | 0 | 1 | 1 |  | M | T | T | 29 | T | 7 | M | T |
| 1 | 1 | 0 | 0 |  | T | M | 8 | T | 18 | T | T | M |
| 1 | 1 | 0 | 1 |  | 17 | T | T | 28 | T | 6 | M | T |
| 1 | 1 | 1 | 0 |  | M | T | T | 26 | T | 4 | M | T |
| 1 | 1 | 1 | 1 |  | T | 0 | M | T | M | T | T | M |

- no errors detected

Number - the location of the single bit-in-error
T - two errors detected
M - three or more errors detected

## Error Detection and Correction (EDC) Unit


*Check Bit Latch is forced transparent in this CODE ID combination for this slice.
Figure 7. 32-Bit Data Format And I/O

## Error Detection and Correction (EDC) Unit



Figure 8. 64-Bit Data Format and I/O Configuration

Table 9. Diagnostic Latch Loading

| DATA BIT | INTERNAL FUNCTION |
| :---: | :---: |
| 0 | Diagnostic Check. Bit X |
| 1 | Diagnostic Check Bit 0 |
| 2 | Diagnostic Check Bit 1 |
| 3 | Diagnostic Check Bit 2 |
| 4 | Diagnostic Check Bit 4 |
| 5 | Diagnostic Check Bit 8 |
| 6 | Diagnostic Check Bit 16 |
| 7 | Don't Care |
| 8 | Slice 0/1 - CODE ID 0 |
| 9 | Slice 0/1 - CODE ID 1 |
| 10 | Slice 0/1 - CODE ID 2 |
| 11 | Slice 0/1 - DIAG MODE 0 |
| 12 | Slice 0/1 - DIAG MODE 1 |
| 13 | Slice 0/1 - CORRECT |
| 14 | Slice 0/1 - PASS THRU |
| 15 | Don't Care |
| 16-23 | Don't Care |
| 24 | Slice $2 / 3$ - CODE ID 0 |
| 25 | Slice $2 / 3$ - CODE ID 1 |
| 26 | Slice $2 / 3$ - CODE ID 2 |
| 27 | Slice $2 / 3$ - DIAG MODE 0 |
| 28 | Slice 2/3 - DIAG MODE 1 |
| 29 | Slice $2 / 3$ - CORRECT |
| 30 | Slice 2/3 - PASS THRU |
| 31 | Don't Care |

## Pass Thru Mode

In this mode, the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch and the contents of the Check Bit Input Latch are placed on outputs $\mathrm{SC}_{0-6}$ of Slice 2/3. ERROR and MULT ERROR are forced HIGH in this mode.

## Diagnostic Latches/AC

## Calculations

Table 9 shows how the latches (Slice 1 and Slice 2) are loaded for code $32 / 39$ (32-bit format). Table 10 shows key AC parameters for the 32-bit configuration.

## 64-Bit Data Word Configuration

The 64-bit format consists of 64 data bits, eight check bits and, as previously indicated, is designated as the 64/72 code. The data format and I/O configuration for a 64 -bit word is shown in Figure 8.

The configuration to process the 64-bit format is similar to that shown in Figure 2. in this configuration a portion of the syndrome generation and error detection is implemented externally of the EDCs in MSI. For error correction the syndrome bits generated must be read back into all four EDCs through the CB inputs. This necessitates the check bit buffering shown in Figure 8. The OE SC signal can control the check bit enabling when syndrome bit outputs are enabled the external check bit lines will be disabled so that the syndrome bits may be read onto the CB inputs.
The error detection signals for the 64-bit configuration differ from the 16 and 32 -bit configurations. The ERROR signal functions the same: it is LOW if one or more errors are detected, and HIGH if no errors are detected.

The DOUBLE ERROR signal is HIGH if and only if a double-bit error is detected - it is LOW otherwise. All of the MULT ERROR outputs of the four devices are valid. MULT ERROR is LOW for all three ERROR cases and some DOUBLE ERROR combinations See Table 15. It is HIGH if either zero or one errors are detected.

This is a different meaning for MULT ERROR than in other configurations.

## Generate Mode

In this mode check bits will be generated that correspond to the contents of the Data Input Latch. The check bits generated appear at the outputs of the XOR gates as indicated in Figure 8.

Check bits are generated according to a modified Hamming code. Details of the code for check bit generation are contained in Table 11. Check bits are generated as either an XOR or XNOR of 32 of the 64 bits as indicated in the table. The XOR function results in an even parity check bit, the XNOR in an odd parity check bit.

Table 10. Key AC Calculations for the 32-Bit Configuration

| $\begin{gathered} \text { 32-BIT } \\ \text { PROPAGATION DELAY } \end{gathered}$ |  | COMPONENT DELAY FROM 2960 |
| :---: | :---: | :---: |
| From | To |  |
| DATA | Check Bits Out | (DATA to SC) $+(\mathrm{CB}$ to SC, CODE ID 011) |
| DATA In | Corrected DATA Out | (DATA to SC) + (CB to SC, CODE ID 011) + (CB to DATA, CODE ID 010) |
| DATA | Syndromes Out | (DATA to SC) + (CB to SC, CODE ID 011) |
| DATA | ERROR for 32 Bits | (DATA to SC) + (CB to ERROR, CODE ID 011) |
| DATA | $\overline{\text { MULT ERROR }}$ for 32 Bits | (DATA to SC) + (CB to MULT ERROR, CODE ID 011) |

## Error Detection and Correction (EDC) Unit

Table 11. 64-Bit Modified Hamming Code Check Bit Encoding

| GENERATED CHECK BITS | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| $\begin{aligned} & C X \\ & C O \end{aligned}$ | Even (XOR) <br> Even (XOR) | X | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X | X | X | X |  | $\begin{aligned} & x \\ & x \end{aligned}$ | X | X | X | X |  | X |  |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2 \end{aligned}$ | Odd (XNOR) Odd (XNOR) | $\begin{aligned} & x \\ & x \end{aligned}$ | X |  | X | X | X | X | $\begin{aligned} & x \\ & x \end{aligned}$ |  | X | X | X | X | $\begin{aligned} & x \\ & x \end{aligned}$ |  | X |
| $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 8 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  | X | X | X | X | X | X | X | X | X | X | X | X | X | X <br> X |
| $\begin{aligned} & \text { C16 } \\ & \text { C32 } \end{aligned}$ | Even (XOR) <br> Even (XOR) | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{X} \end{aligned}$ |  |  |  |  |  |  |  |  |


| GENERATED | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BITS |  | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| $\begin{aligned} & \text { CX } \\ & \text { CO } \end{aligned}$ | Even (XOR) <br> Even (XOR) | X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | X | X |  | X |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ | x | x | X |  | X |  |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2 \end{aligned}$ | Odd (XNOR) <br> Odd (XNOR) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X |  | x | x | X | X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | x | X | X | X | X $\times$ |  | X |
| $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 8 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  | X | X | X | X | X | X | X | X | X | X | X | $x$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |
| $\begin{aligned} & \text { C16 } \\ & \text { C32 } \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  |  |  |  |  |  |  | X <br> X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X <br> X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X <br> X <br> X | X <br> $\times$ | X <br> X | X <br> X |


| GENERATED CHECK BITS | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
| CX | Even (XOR) | X |  |  |  | X |  | $\times$ | X |  |  | X |  | X | X |  | X |
| CO | Even (XOR) | X | X | X |  | X |  | X |  | X |  | X |  | X |  |  |  |
| C1 | Odd (XNOR) | X |  |  | X | X |  |  | x |  | X | X |  |  | x |  | x |
| C2 | Odd (XNOR) | X | X |  |  |  | X | X | X |  |  |  | X | X | X |  |  |
| C4 | Even (XOR) |  |  | X | X | X | X | X | X |  |  |  |  |  |  | X | X |
| C8 | Even (XOR) |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |
| C16 | Even (XOR) | x | X | x | X | X | X | X | X |  |  |  |  |  |  |  |  |
| C32 | Even (XOR) |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |


| GENERATED CHECK BITS | PARITY | PARTICIPATING DATA BITS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 |
| CX | Even (XOR) | X |  |  |  | X |  | X | X |  |  | X |  | X | X |  | x |
| C0 | Even (XOR) | X | X | X |  | X |  | X |  | X |  | X |  | X |  |  |  |
| C1 | Odd (XNOR) | X |  |  | x | x |  |  | x |  | x | x |  |  | x |  | $x$ |
| C2 | Odd (XNOR) | X | X |  |  |  | x | X | X |  |  |  | x | x | X |  |  |
| C4 | Even (XOR) |  |  | x | x | x | X | X | X |  |  |  |  |  |  | X | x |
| C8 | Even (XOR) |  |  |  |  |  |  |  |  | X | x | X | x | x | $x$ | x | x |
| C16 | Even (XOR) |  |  |  |  |  |  |  |  | X | X | X | x | X | X | X | x |
| C32 | Even (XOR) | X | X | X | X | X | X | X | X |  |  |  |  |  |  |  |  |

NOTE:
The check bit is generated as either an XOR or XNOR of the 32 data bits noted by an ' X ' in the table.

Table 12. Syndrome Decode to Bit-In-Error


*     - no errors detected

Number - the location of the single bit-in-error
T - two errors detected
M - three or more errors detected

## Detect Mode

In this mode the device compares the contents of the Data Input Latch against the contents of the Check Bit Input Latch and will detect all single-bit errors, all double-bit errors and some triple-bit errors. If one or more errors are detected, ERROR goes LOW. If exactly two errors are detected, DOUBLE ERROR goes HIGH. If three or more errors are detected, MULT ERROR goes LOW - the MULT ERROR output of any of the four EDCs may be used.

Available as XOR gate outputs are the generated syndrome bits - see Figure 8. The syndrome bits may be decoded to determine if a bit error was detected and for single-bit errors, which of the data or check bits is in error. Table 12 gives the chart for encoding the syndrome bits generated for the 64-bit configuration (as an example, if the syndrome bits SX/S1/S2/S4/S8/S16/S32 were 00100101 this would be decoded to indicate that there is a single-bit error at data bit 41). If no error is detected the syndrome bits will all be zeroes. In Detect Mode the contents of
the Data Input Latch are driven directly to the Inputs of the Data Output Latch without corrections.

## Correct Mode

In this mode, the EDC functions the same as in Detect Mode except that the correction network is allowed to correct (complement) any single-bit error of the Data Input Latch before putting it onto the inputs of the Data Output Latch. If multiple errors are detected, the output of the correction network is unspecified, if the single bit error is a check bit there is no automatic correction. Check bit correction can be done by placing the device in generate mode to produce a correct check bit sequence for the data in the Data Input Latch.

To perform the correction step, all four slices require access to the syndrome bits which are generated externally of the devices. This access is provided by reading the syndrome bits in through the CB inputs where they are selected as inputs to the bit-in-error decoded by the multiplexer (see block diagram). The device connections for this operation are
shown in Figure 8. When in Correct Mode the SC outputs must be enabled so that the syndrome bits are available at the CB inputs.

## Pass Thru Mode

In this mode, the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch, and the contents of the Check Bit Input Latch are passed through the external XOR network and appear inverted at the XOR gate outputs labeled CX to C32-see Figure 8.

## Diagnostic Latch

The Diagnostic Latch is used for both diagnostic and internal control of the EDC. Table 13 provides bit definitions and shows the 64bit loading format.

## Diagnostic Generate/Detect/ Correct

These are special diagnostic modes selected by DIAG MODE $0-1$ where either normal check bit inputs or outputs are substituted for by check bits from the Diagnostic Latch see Table 2 for details.

Table 13. Diagnostic Latch Loading

| DATA BIT | INTERNAL FUNCTION |
| :---: | :---: |
| 0 | Diagnostic Check Bit X |
| 1 | Diagnostic Check Bit 0 |
| 2 | Diagnostic Check Bit 1 |
| 3 | Diagnostic Check Bit 2 |
| 4 | Diagnostic Check Bit 4 |
| 5 | Diagnostic Check Bit 8 |
| 6, 7 | Don't Care |
| 8 | Slice 0/1 - CODE ID 0 |
| 9 | Slice 0/1 - CODE ID 1 |
| 10 | Slice 0/1 - CODE ID 2 |
| 11 | Slice 0/1 - DIAG MODE 0 |
| 12 | Slice 0/1 - DIAG MODE 1 |
| 13 | Slice 0/1 - CORRECT |
| 14 | Slice 0/1 - PASS THRU |
| 15 | Don't Care |
| 16-23 | Don't Care |
| 24 | Slice 2/3 - CODE ID 0 |
| 25 | Slice 2/3-CODE ID 1 |
| 26 | Slice 2/3-CODE ID 2 |
| 27 | Slice 2/3 - DIAG MODE 0 |
| 28 | Slice 2/3 - DIAG MODE 1 |
| 29 | Slice 2/3 - CORRECT |


| DATA BIT | INTERNAL FUNCTION |
| :---: | :---: |
| 30 | Slice 2/3 - PASS THRU |
| 31 | Don't Care |
| 32-37 | Don't Care |
| 38 | Diagnostic Check Bit 16 |
| 39 | Don't Care |
| 40 | Slice 4/5 - CODE ID 0 |
| 41 | Slice 4/5 - CODE ID 1 |
| 42 | Slice 4/5-CODE ID 2 |
| 43 | Slice 4/5 - DIAG MODE 0 |
| 44 | Slice 4/5 - DIAG MODE 1 |
| 45 | Slice 4/5 - CORRECT |
| 46 | Slice 4/5 - PASS THRU |
| 47 | Don't Care |
| 48-54 | Don't Care |
| 55 | Diagnostic Check Bit 32 |
| 56 | Slice 6/7 - CODE ID 0 |
| 57 | Slice 6/7 - CODE ID 1 |
| 58 | Slice 6/7- CODE ID 2 |
| 59 | Slice 6/7 - DIAG MODE 0 |
| 60 | Slice 6/7 - DIAG MODE 1 |
| 61 | Slice 6/7 - CORRECT |
| 62 | Slice 6/7 - PASS THRU |
| 63 | Don't Care |

## Internal Control Mode

This mode is selected by CODE $I D_{0-2}$, input $001\left(\mathrm{ID}_{2}, \mathrm{ID}_{2}, I \mathrm{ID}_{0}\right)$.

When in Internal Control Mode the EDC takes the CODE $I_{0-2}$, DIAG MODE $0_{0-1}$, CORRECT and PASS THRU signals from the internal Diagnostic Latch rather than from the external control lines - see Table 13 for latch loading.

## AC Calculations

Table 14 shows key AC parameters for the 64-bit configuration.

## Functional Equations

The following equations and tables describe in detail how the output values of the Signetics 2960 are determined as a function of input values and internal states of the chip. Before examining the tables, the following symbol definitions should be carefully studied.

Table 14. Key AC Calculations for the 64-Bit Configuration

| 64-BITPROPAGATION DELAY |  | COMPONENT DELAYS FROM 2960 AC SPECIFICATIONS, TABLE C (PLUS MSI) |
| :---: | :---: | :---: |
| From | To |  |
| DATA | Check Bits Out | (DATA to SC) + (XOR Delay) |
| DATA in | Corrected DATA Out | $($ DATA to SC) $+($ (XOR Delay $)+($ Buffer Delay $)+(\mathrm{CB}$ to DATA, CODE ID 1xx $)$ |
| DATA | Syndromes | (DATA to SC) $+($ (XOR Delay $)$ |
| DATA | $\overline{\text { ERROR }}$ for 64 Bits | (DATA to SC) + (XOR Delay) + (NOR Delay $)$ |
| DATA | MULT ERROR for 64 Bits | $($ DATA to SC) $+($ XOR Delay $)+($ Buffer Delay $)+(\mathrm{CB}$ to MULT ERROR, CODE ID 1xx) |
| DATA | DOUBLE ERROR for 64 Bits | (DATA to SC) $+($ XOR Delay $)+($ XOR/NOR Delay $)$ |

## Table 15. TOME (Three or More Errors)*

| S1 | S2 | $\begin{array}{r} \text { S0 } \\ \\ \\ \\ \\ \\ \\ \text { **S6 } \\ \mathbf{S 3} \\ \mathrm{S} 5 \\ \mathrm{~S} 4 \end{array}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | 0 0 0 1 | 1 0 0 1 | 0 1 0 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | 1 0 1 1 | 0 1 1 1 | 1 1 1 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

'S6, S5, ... S0 are internal syndromes except in Modes 010, 100, 101, 110, 111, (CODE ID $\left.2, I D_{1}, I D_{0}\right)$. In these modes the syndromes are input over the Check-Bit lines $\mathrm{S} 6-\mathrm{C} 6, \mathrm{~S} 5-\mathrm{C} 5, \mathrm{~S} 1-\mathrm{C} 1$, So-C0.
**The S6 internal syndrome is always forced to 0 in CODE ID 000.

## SC Outputs

Tables 16 through 20 show how outputs $\mathrm{SC}_{0-6}$ are generated in each control mode for various CODE IDs (internal control mode not applicable).

## DEFINITIONS

```
\(D_{i} \quad \leftarrow\left(\right.\) DATA \(_{i}\) if LE \(N \mathbb{N}\) is HIGH or the output of bit \(i\) of the Data input Latch if LE IN is LOW)
\(\mathrm{C}_{\mathrm{i}} \quad \sim\left(\mathrm{CB}_{\mathrm{i}}\right.\) if LE IN is HIGH or the output of bit i of the Check Bit Latch if LE IN is LOW)
\(D L_{i} \leftarrow\) Output of the bit \(i\) of the Diagnostic Latch
\(\mathrm{S}_{\mathrm{i}} \leftarrow\) Internally generated syndromes (same as outputs of \(\mathrm{SC}_{\mathrm{i}}\) if outputs enabled)
\(\mathrm{PA} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 1 \oplus \mathrm{D} 2 \oplus \mathrm{D} 4 \oplus \mathrm{D} 6 \oplus \mathrm{D} 4 \oplus \mathrm{D} 10 \quad \oplus \mathrm{D} 12\)
\(\mathrm{PB} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 1 \oplus \mathrm{D} 2 \oplus \mathrm{D} 3 \oplus \mathrm{D} 4 \oplus \mathrm{D} 5 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7\)
\(\mathrm{PC} \leftarrow \mathrm{D} 8 \oplus \mathrm{D} 9 \oplus \mathrm{D} 10 \oplus \mathrm{D} 11 \quad \oplus \mathrm{D} 12 \oplus \mathrm{D} 13 \oplus \mathrm{D} 14 \quad \oplus \quad \mathrm{D} 15\)
\(\mathrm{PD}-\mathrm{D} 0 \oplus \mathrm{D} 3 \oplus \mathrm{D} 4 \oplus \mathrm{D} 7 \oplus \mathrm{D} 9 \oplus \mathrm{D} 10 \oplus \mathrm{D} 13 \oplus \mathrm{D} 15\)
\(\mathrm{PE} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 1 \oplus \mathrm{D} 5 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7 \oplus \mathrm{D} 11 \oplus \mathrm{D} 12 \oplus \mathrm{D} 13\)
\(\mathrm{PF} \leftarrow \mathrm{D} 2 \oplus \mathrm{D} 3 \oplus \mathrm{D} 4 \oplus \mathrm{D} 5 \oplus \mathrm{D} 6 \oplus \mathrm{D} 4 \oplus \mathrm{D} 14 \oplus \mathrm{D} 15\)
\(\mathrm{PG}_{1} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 4 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7\)
\(\mathrm{PG}_{2} \leftarrow \mathrm{D} 1 \oplus \mathrm{D} 2 \oplus \mathrm{D} 3 \oplus \mathrm{D} 5\)
\(\mathrm{PG}_{3} \leftarrow \mathrm{D} 8 \oplus \mathrm{D} 9 \oplus \mathrm{D} 11 \oplus \mathrm{D} 14\)
\(\mathrm{PG}_{4} \leftarrow \mathrm{D} 10 \oplus \mathrm{D} 12 \oplus \mathrm{D} 13 \oplus \mathrm{D} 15\)
```


## ERROR SIGNALS

ERROR $\leftarrow\left(\overline{\mathrm{S} 6 \cdot\left(I \mathrm{D}_{1}+\mathrm{ID}_{2}\right)}\right) \cdot \overline{\mathrm{S} 5} \cdot \overline{\mathrm{~S} 4} \cdot \overline{\mathrm{~S} 3} \cdot \overline{\mathrm{~S} 2} \cdot \overline{\mathrm{~S} 1} \cdot \overline{\mathrm{~S} 0}+$ GENERATE + INITIALIZE + PASSTHRU

$\overline{\text { MULT ERROR }}$ (64-Bit Modes) $\leftarrow$ TOME + GENERATE + PASSTHRU + INITIALIZE

## Error Detection and Correction (EDC) Unit

Table 16. Syndrome/Check Bit Generation in GENERATE Mode

| GENERATE MODE <br> (CHECK BITS) | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{0 0 0}$ | $\mathbf{0 1 0}$ | $\mathbf{0 1 1}$ | $\mathbf{1 0 0}$ | $\mathbf{1 0 1}$ | $\mathbf{1 1 0}$ | $\mathbf{1 1 1}$ |  |
|  | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{4}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ |  |
| $\mathrm{SC}_{1^{*}}$ | PA | PA | PA | PA | PA | PA | PA |  |
| $\mathrm{SC}_{2^{*}}$ | $\overline{\mathrm{PD}}$ | $\overline{\mathrm{PD}}$ | PD | $\overline{\mathrm{PD}}$ | PD | PD | PD |  |
| $\mathrm{SC}_{3^{*}}$ | $\overline{\mathrm{PE}}$ | $\overline{\mathrm{PE}}$ | PE | $\overline{\mathrm{PE}}$ | PE | PE | PE |  |
| $\mathrm{SC}_{4^{*}}$ | PF | PF | PF | PF | PF | PF | PF |  |
| $\mathrm{SC}_{5^{*}}$ | PC | PC | PC | PC | PC | PC | PC |  |
| $\mathrm{SC}_{6^{*}}$ | 1 | PB | PC | PB | PB | PB | PB |  |

Table 17. Syndrome/Check Bit Generation in Detect/Correct Modes

|  | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODES (SYNDROMES) | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}{ }^{*}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{C} 0 \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{1} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{C} 0 \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{4} \\ \oplus \mathrm{CB}_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{C} 0 \end{gathered}$ | $P \mathrm{G}_{2} \oplus \mathrm{PG}_{3}$ | $P \mathrm{~F}_{1} \oplus \mathrm{PG}_{4}$ | $P G_{1} \oplus \mathrm{PG}_{4}$ |
| $\mathrm{SC}_{1}{ }^{*}$ | $\mathrm{PA} \oplus \mathrm{C} 1$ | $\mathrm{PA} \oplus \mathrm{C} 1$ | $\mathrm{PA} \oplus \mathrm{CB}_{1}$ | $\mathrm{PA} \oplus \mathrm{C} 1$ | PA | PA | PA |
| $\mathrm{SC}_{2}{ }^{*}$ | $\overline{\mathrm{PD}} \oplus \mathrm{C} 2$ | $\overline{P D} \oplus \mathrm{C} 2$ | $\mathrm{PD} \oplus \mathrm{CB}_{2}$ | $\overline{P D} \oplus \mathrm{C} 2$ | PD | PD | PD |
| $\mathrm{SC}_{3}{ }^{*}$ | $\overline{\mathrm{PE}} \oplus \mathrm{C} 3$ | $\overline{\mathrm{PE}} \oplus \mathrm{C} 3$ | $\mathrm{PE} \oplus \mathrm{CB}_{3}$ | $\overline{\mathrm{PE}} \oplus \mathrm{C} 3$ | PE | PE | PE |
| $\mathrm{SC}_{4}{ }^{*}$ | $\mathrm{PF} \oplus \mathrm{C} 4$ | $\mathrm{PF} \oplus \mathrm{C} 4$ | $\mathrm{PF} \oplus \mathrm{CB}_{4}$ | $\mathrm{PF} \oplus \mathrm{C} 4$ | PF | PF | PF |
| $\mathrm{SC}_{5}{ }^{*}$ | $\mathrm{PC} \oplus \mathrm{C} 5$ | $\mathrm{PC} \oplus \mathrm{C} 5$ | $\mathrm{PC} \oplus \mathrm{CB}_{5}$ | $\mathrm{PC} \oplus \mathrm{C} 5$ | PC | PC | PC |
| $\mathrm{SC}_{6}{ }^{*}$ | 1 | $\mathrm{PB} \oplus \mathrm{C} 6$ | $\mathrm{PC} \oplus \mathrm{CB}_{6}$ | PB | PB | $\mathrm{PB} \oplus \mathrm{C} 6$ | $\mathrm{PB} \oplus \mathrm{C} 6$ |

*In CODE $1 D_{2-0} 011$ the Check-Bit Latch is forced transparent, the Data Latch operates normaliy.
Table 18. Syndrome/Check Bit Generation in Diagnostic Read Mode

| DIAGNOSTIC READ MODE | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}{ }^{*}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{DL}_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{1} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{DL}_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{4} \\ \oplus \mathrm{CB}_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{3} \\ \oplus \not \mathrm{DL}_{0} \end{gathered}$ | $P G_{2} \oplus \mathrm{PG}_{3}$ | $P \mathrm{G}_{1} \oplus \mathrm{PG}_{4}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ |
| $\mathrm{SC}_{1}{ }^{*}$ | $\mathrm{PA} \oplus \mathrm{DL}_{1}$ | $\mathrm{PA} \oplus \mathrm{DL}_{1}$ | $\mathrm{PA} \oplus \mathrm{CB}_{1}$ | $P A \oplus D L_{1}$ | PA | PA | PA |
| $\mathrm{SC}_{2}{ }^{*}$ | $\overline{P D} \oplus \mathrm{DL}_{2}$ | $\overline{\mathrm{PD}} \oplus \mathrm{DL}_{2}$ | $\mathrm{PD} \oplus \mathrm{CB}_{2}$ | $\overline{\mathrm{PD}} \oplus \mathrm{DL}_{2}$ | PD | PD | PD |
| $\mathrm{SC}_{3}$ * | $\overline{\mathrm{PE}} \oplus \mathrm{DL}_{3}$ | $\overline{\mathrm{PE}} \oplus \mathrm{DL}_{3}$ | $\mathrm{PE} \oplus \mathrm{CB}_{3}$ | $\overline{\mathrm{PE}} \oplus \mathrm{DL}_{3}$ | PE | PE | PE |
| $\mathrm{SC}_{4}{ }^{*}$ | $\mathrm{PF} \oplus \mathrm{DL}_{4}$ | $\mathrm{PF} \oplus \mathrm{DL}_{4}$ | $\mathrm{PF} \oplus \mathrm{CB}_{4}$ | $\mathrm{PF} \cdot \oplus \mathrm{DL}_{4}$ | PF | PF | PF |
| $\mathrm{SC}_{5}{ }^{*}$ | $\mathrm{PC} \oplus \mathrm{DL}_{5}$ | $\mathrm{PC} \oplus \mathrm{DL}_{5}$ | $\mathrm{PC} \oplus \mathrm{CB}_{5}$ | $\mathrm{PC} \oplus \mathrm{DL}_{5}$ | PC | PC | PC |
| $\mathrm{SC}_{6}{ }^{*}$ | 1 | $\mathrm{PB} \oplus \mathrm{DL}_{6}$ | $\mathrm{PC} \oplus \mathrm{CB}_{6}$ | PB | PB | $\mathrm{PB} \oplus \mathrm{DL}_{6}$ | $\mathrm{PB} \oplus \mathrm{DL}_{6}$ |

[^19]
## Error Detection and Correction (EDC) Unit

Table 19. Syndrome/Check Bit Generation in Diagnostic Write Mode

|  | CODE $\mathrm{ID}_{\mathbf{2 - 0}}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DIAGNOSTIC WRITE MODE | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}-$ | DL ${ }_{0}$ | DL | $\mathrm{CB}_{0}$ | DLo | 1 | 1 | 1 |
| $\mathrm{SC}_{1}$ - | $\mathrm{DL}_{1}$ | DL | $\mathrm{CB}_{1}$ | DL ${ }_{1}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{2}$ - | DL2 | $\mathrm{DL}_{2}$ | $\mathrm{CB}_{2}$ | $\mathrm{DL}_{2}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{3}$ - | DL3 | $\mathrm{DL}_{3}$ | $\mathrm{CB}_{3}$ | $\mathrm{DL}_{3}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{4}$.- | DL4 | DL4 | $\mathrm{CB}_{4}$ | $\mathrm{DL}_{4}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{5}$ - | DL ${ }_{5}$ | DL5 | $\mathrm{CB}_{5}$ | DL ${ }_{5}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{6}-$ | 1 | DL6 | $\mathrm{CB}_{6}$ | 1 | 1 | DL6 | DL7 |

*In CODE $\mathrm{ID}_{2 \ldots 0} 011$ the Check-Bit Latch is forced transparent; the Data Latch operates normally.
Table 20. Syndrome/Check Bit Generation in PASS THRU Mode

|  | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PASS THRU MODE | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0} \leftarrow$ | C0 | C0 | $\mathrm{CB}_{0}$ | C0 | 1 | 1 | 1 |
| $\mathrm{SC}_{1}$ - | C1 | C1 | $\mathrm{CB}_{1}$ | C1 | 1 | 1 | 1 |
| $\mathrm{SC}_{2}$ - | C2 | C2 | $\mathrm{CB}_{2}$ | C2 | 1 | 1 | 1 |
| $\mathrm{SC}_{3}$ - | C3 | C3 | $\mathrm{CB}_{3}$ | C3 | 1 | 1 | 1 |
| $\mathrm{SC}_{4} \leftarrow$ | C4 | C4 | $\mathrm{CB}_{4}$ | C4 | 1 | 1 | 1 |
| $\mathrm{SC}_{5}$ - | C5 | C5 | $\mathrm{CB}_{5}$ | C5 | 1 | 1 | 1 |
| $\mathrm{SC}_{6} \leftarrow$ | 1 | C6 | $\mathrm{CB}_{6}$ | 1 | 1 | C6 | C6 |

*In CODE $I_{2-0} 011$ the Check-Bit Latch is forced transparent; the Data Latch operates normally.

Table 21. CODE $1 D_{2-0}=000^{*}$

|  |  | $\begin{aligned} & \text { S5 } \\ & \text { S4 } \\ & \text { S3 } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
| S2 | S1 |  |  |  |  |  |  |  |  |  |
| 0 | 0 |  | - | - | - | 5 | - | 11 | 14 | - |
| 0 | 1 |  | - | 1 | 2 | 6 | 8 | 12 | - | - |
| 1 | 0 |  | - | - | 3 | 7 | 9 | 13 | 15 | - |
| 1 | 1 |  | - | 0 | 4 | - | 10 | - | - | - |

*Unlisted S combinations are no correction.
Table 22. CODE $1 D_{2-0}=010^{*}$

|  |  | $\mathrm{CB}_{6}$ <br> $\mathrm{CB}_{5}$ <br> $\mathrm{CB}_{4}$ <br> $\mathrm{CB}_{3}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | 1011 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{CB}_{2}$ | $\mathrm{CB}_{1}$ |  |  |  |  |  |  |  |  |  |
| 0 | 0 |  | - | 11 | 14 | - | - | - | - | 5 |
| 0 | 1 |  | 8 | 12 | - | - | - | 1 | 2 | 6 |
| 1 | 0 |  | 9 | 13 | 15 | - | - | - | 3 | 7 |
| 1 | 1 |  | 10 | - | - | - | - | 0 | 4 | - |

*Unlisted CB combinations are no correction.
Table 23. CODE $\mathrm{ID}_{2-0}=011^{*}$

|  |  | $\begin{aligned} & \text { S6 } \\ & \text { S5 } \\ & \text { S4 } \\ & \text { S3 } \end{aligned}$ |  |  |  |  |  |  |  | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |
|  |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |
|  |  | 0 | 0 | 1 | 1 | 0 | 0 | 1 |  |
|  |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 |  |
| S2 | S1 |  |  |  |  |  |  |  |  |  |
| 0 | 0 |  |  | - | - | - | 5 | - | 11 | 14 | - |
| 0 | 1 |  |  | - | 1 | 2 | 6 | 8 | 12 | - | - |
| 1 | 0 |  |  | - | - | 3 | 7 | 9 | 13 | 15 | - |
| 1 | 1 |  |  | - | 0 | 4 | - | 10 | - | - |  |

*Unlisted S combinations are no correction.
Table 24. CODE $I D_{2-0}=100^{*}$

|  |  | $\mathbf{C B}_{\mathbf{0}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{C B}_{6}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |
| $\mathbf{C B}_{5}$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |  |
| $\mathbf{C B}_{\mathbf{4}}$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |  |
| $\mathbf{C B}_{\mathbf{3}}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |  |
| $\mathbf{C B}_{\mathbf{2}}$ | $\mathbf{C B}_{\mathbf{1}}$ |  |  |  |  |  |  |  |  |
| 0 | 0 |  | - | 11 | 14 | - | - | - | - |
| 0 | 1 | 8 | 12 | - | - | - | 1 | 2 | 6 |
| 1 | 0 | 9 | 13 | 15 | - | - | - | 3 | 7 |
| 1 | 1 | 10 | - | - | - | - | 0 | 4 | - |

*Unlisted CB combinations are no correction.

## Data Correction

Tables 21 through 27 show which data output bits are corrected (inverted) depending upon the syndromes and the CODE ID position. Note that the syndromes that determine data correction are in some cases syndromes input externally via the CB inputs and in some cases syndromes generated internally by that EDC ( $\mathrm{S}_{\mathrm{i}}$ are the internal syndromes and are the same as the value of the $\mathrm{SC}_{\mathrm{i}}$ output of that EDC if enabled).
The tables show the number of data bit inverted (corrected) if any for the CODE ID and syndrome combination.

Table 25. CODE $\mathrm{ID}_{2-0}=101^{*}$

|  |  | $\mathrm{CB}_{0}$ $\mathrm{CB}_{6}$ $\mathrm{CB}_{5}$ $\mathrm{CB}_{4}$ $\mathrm{CB}_{3}$ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  |  | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
|  |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\mathrm{CB}_{2}$ | $\mathrm{CB}_{1}$ |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 |  |  | - | - | - | 5 | - | 11 | 14 | - |
| 0 | 1 |  |  | - | 1 | 2 | 6 | 8 | 12 | - | - |
| 1 | 0 |  |  | - | - | 3 | 7 | 9 | 13 | 15 | - |
| 1 | 1 |  |  | - | 0 | 4 | - | 10 | - | - | - |

*Unlisted CB combinations are no correction.
Table 26. CODE $I D_{2-0}=110^{*}$

|  |  | $\mathbf{C B}_{\mathbf{0}}$ |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{C B}_{\mathbf{6}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |
|  |  | $\mathbf{C B}_{\mathbf{5}}$ | 0 | 1 | 1 | 1 | 0 | 0 | 0 |
| $\mathbf{C B}_{4}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |
| $\mathbf{C B}_{3}$ | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |  |
| $\mathbf{C B}_{\mathbf{2}}$ | $\mathbf{C B}_{\mathbf{1}}$ |  |  |  |  |  |  | 1 | 0 |
| 0 | 0 | - | - | - | 5 | - | 11 | 14 | - |
| 0 | 1 | - | 1 | 2 | 6 | 8 | 12 | - | - |
| 1 | 0 | - | - | 3 | 7 | 9 | 13 | 15 | - |
| 1 | 1 | - | 0 | 4 | - | 10 | - | - | - |

*Unlisted CB combinations are no correction.
Table 27. CODE $\mathrm{ID}_{2-0}=111^{*}$

|  | $\mathbf{C B}_{\mathbf{0}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathbf{C B}_{6}$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 |
| $\mathbf{C B}_{5}$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |  |
| $\mathbf{C B}_{4}$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |  |
| $\mathbf{C B}_{\mathbf{3}}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |  |
| $\mathbf{C B}_{\mathbf{2}} \mathbf{C B}_{\mathbf{1}}$ |  |  |  |  |  |  |  |  |  |
| 0 | 0 | - | 11 | 14 | - | - | - | - | 5 |
| 0 | 1 | 8 | 12 | - | - | - | 1 | 2 | 6 |
| 1 | 0 | 9 | 13 | 15 | - | - | - | 3 | 7 |
| $\mathbf{1}$ | 1 | 10 | - | - | - | - | 0 | 4 | - |

*Unlisted CB combinations are no correction.

## Error Detection and Correction (EDC) Unit



Figure 9. Check-Only Configuration

## SYSTEM DESIGN CONSIDERATIONS

## High Performance Parallel Operation

For maximum memory system performance the EDC should be used in the Check-Only configuration shown in Figure 9. With this configuration the memory system operates as fast with EDC as it would without.

On reads from memory, data is read out from the RAMs directly to the data bus (same as in a non-EDC system). At the same time, the data is read into the EDC to check for errors.

If an error exists the EDC's error flags are used to interrupt the CPU and/or to stretch the memory cycle. If no error is detected, no slowdown is required

If an error is detected, the EDC generates corrected data for the processor. At the designer's option the correct data may be written back into memory; error logging and diagnostic routines may also be run under processor control.

The Check-Only configuration allows data reads to proceed as fast with EDC as without. Only if an error is detected is there any slowdown. But even if the memory system had an error every hour this would mean only one error every 3-4 billion memory cycles. So even with a very high error rate, EDC in a Check-Only configuration has essentially zero impact on memory system speed.

On writes to memory, check bits must be generated before the full memory word can be written into memory. The data word is frequently buffered while the check bits are generated. This makes the check bit generate time transparent to the processor.

## EDC in the Data Path

The simplest configuration for EDC is to have the EDC directly in the data path as shown in Figure 10. Correct-Always Configuration). In the configuration data read from memory is always corrected prior to putting the data on the data bus. The advantages are simpler operation and no need for mid-cycle interrupts. The disadvantages is that memory system speed is slowed by the amount of time it takes for error correction on every cycle.

Usually the Correct-Always Configuration will be used with MOS microprocessors which have ample memory timing budgets. Most high performance processors will use the high performance parallel configuration shown in Figure 9.
Scrubbing Avoids Double Errors
Single-bit errors are by far the most common in a memory system and are always correctable by the EDC.

Double bit memory errors are far less frequent than single bit errors ( 50 to 1 , or 100 to 1) and are always detected by the EDC but not corrected.

In a memory system, soft errors occur only one at a time. A double bit error in a data
word occurs when a single soft error is left uncorrected and is followed by another error in the data word hours, days, or weeks after the first.
'Scrubbing" memory periodically avoids almost all double-bit errors. In the scrubbing operation, every data word in a memory is periodically checked by the EDC for single-bit errors. If one is found, it is corrected and the data word written back into memory. Errors are not allowed to pile up and so most double-bit errors are avoided.

The scrubbing operation is generally done as a background routine when the memory is not being used by the processor.
If memory is scrubbed frequently, errors are detected and corrected during processor accesses need not be immediately written back into memory. Instead the error will be corrected in memory during scrubbing. This reduces the time delay involved in a processor access of an incorrect memory word.

## Correction of Double-Bit Errors

In some cases, double-bit memory errors can be corrected. This is possible when one of the two bit errors is a hard error.

When a double bit error is detected the data word should be checked to determine if one of the errors is a hard error. If so the hard error bit may be corrected by inverting it leaving only a single, correctable error. The time for this operation is negligible since it will occur infrequently.

## Error Detection and Correction (EDC) Unit 2960



The procedure after detection of a double error is as follows:

- Invert the data bits read from memory.
- Write the inverted data back into the same memory word.
- Re-read the memory location and XOR the newly read out value with the old. If there is no hard error then the XOR
result will be 1's. If there is a hard error, it will have the same bit value regardless of what was written in. So it will show as a 0 after the XOR operation.
- Invert the hard error bit (this will "correct" it) leaving only one error in the data.
- The EDC can then correct the single bit error.
- Rewrite the correct data word into memory. This does not change the hard error but does eliminate the soft error. So the next memory access will find only a single-bit, correctable error.
An example helps to illustrate the procedure:


## Example of Double Bit Error Correction When One is a Hard Error

|  | 16 DATA BITS | 6 CHECK BITS |
| :---: | :---: | :---: |
| 1) Data read from memory ( $\left.D_{2} 2\right)$ | 1111111100000011 | 011010 |
| 2) EDC detects a multiple error Syndromes: |  | 011000 |
| 3) Syndrome decode indicates a double bit error. |  |  |
| 4) Invert the bits read from memory ( $\mathrm{D}_{1} 1$ ) | 0000000011111100 | 100101 |
| 5) Write $D_{1}$ back to the same memory location. |  |  |
| 6) Read back the memory location ( $\mathrm{D}_{2}$ ) | 0000000011111101 | 100101 |
| 7) $X$ OOR $D_{1}$ and $D_{2}$ | 11111111100000010 | 111111 |
| 8) So the last data bit is the hard error. Use this to modify $D_{1}$ | 1111111100000010 | 011010 |
| 9) Pass the modified $D_{i}$ through the EDC. The EDC detects a single bit correctable error and outputs corrected data. | 1111111100000000 | 011010 |
| 10) Write the corrected data back to memory to fix the soft error |  |  |

# Error Detection and Correction (EDC) Unit 

## Error Logging and Preventative

 MaintenanceThe effectiveness of preventative maintenance can be increased by logging information on errors detected by the EDC. This is called error logging.
The EDC provides syndromes when errors are detected. The syndromes indicate which bit is in error. In most memory systems, each individual RAM supplies only one bit of the memory word. So the syndrome and data word address specify which RAM was in error.

Typically a permanent/hard RAM failure is preceded by a period of time where the RAM displays an increasing frequency of intermittent, soft errors. Error logging statistics can be used to detect an increasing intermittent error frequency so that the RAM can be replaced before a permanent failure occurs.

Error logging also records the location of aiready hard failed RAMs. With EDC a hard failure will not halt system operation. EDC always can correct single bit errors even if it is a hard error. EDC can also correct double bit errors where one is hard and one soft. The ability to continue operation despite hard errors can greatly reduce the need for emergency field maintenance. The hard-failed AANs can be instead replaced at low cost during a regularly scheduled preventative maintenance session.

## Feducing Check Bit Overhead

Memory word widths need not be same as the data word width of the processor. There is a substantial reduction in check bit overhead if wider memory words are used. (See Table 28.)

This reduction in check-bit overhead lowers cost and increases the amount of data that can be packed on to each board.
The tradeoff is that when writing data pieces into memory that are narrower than the mem-

Table 28. Reducing Check Bit Overhead

| MEMORY WORD |  | CHECK <br> BIT OVERHEAD |
| :---: | :---: | :---: |
| \#Data Bits | \#Check Bits |  |
| 8 | 5 | $27 \%$ |
| 16 | 6 | $14 \%$ |
| 32 | 7 | $11 \%$ |
| 64 | 8 |  |

ory word width, more steps are required. These steps are exactly the same as those described in Byte Write in the Applications section. No penalty exists for reads from memory.

## EDC per Board vs EDC Per System

The choice of an EDC per system or per board depends on the economics and the architecture of the system.
Certainly the cheaper approach is to have only one EDC per system and this is a viable solution if only one memory location is accessed at a time.
This solution does require that the system have both data and check bit lines - see Figure 11. This makes retrofitting a system difficult and creates complications if static or ROM memory, which do not require check bits, are mixed in with dynamic RAM.
If the system has an advanced architecture it is quite likely that it is necessary to simultaneously access memory locations on different memory boards - see Figure 12. Architectural features that require this are interleaved memory, cache memory, and DMA that is done simultaneously with processor memory accesses. EDC per board is a simpler system from a design standpoint.
The EDC is designed to work efficiently in either the per system or per board configurations.

## Test Information

Incoming test procedures on this device should be carefully planned, taking into account the complexity and power levels of the part. The following notes may be useful.

1. Insure the part is adequately decoupled at the test head. Large changes in $\mathrm{V}_{\mathrm{CC}}$ current as the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable may allow the ground pin at the device to rise by 100's of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{I H}$ until the noise has settled. Signetics recommends using $\mathrm{V}_{\mathrm{IL}} \quad 0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}-2.4 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform $D C$, Function, and $A C$ tests as three distinct groups of tests.
6. To assist in testing, Signetics offers documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.


Figure 11. EDC Per System


Figure 12. EDC Per Board

ABSOLUTE MAXIMUM RATINGS (Above which the useful life
may be impaired)

| PARAMETER | RATING | UNIT |
| :--- | :---: | :---: |
| Storage Temperature | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Temperature (Case) Under Bias | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential | -0.5 to +7.0 | V |
| DC Voltage Applied to Outputs for High | -0.5 to $\mathrm{V}_{\mathrm{CC}}$ max. | V |
| Output State | -0.5 to +5.5 | V |
| DC Input Voltage | 30 | mA |
| DC Output Current, Into Outputs | -30 to +5.0 | mA |
| DC Input Current |  |  |

## OPERATING RANGE

| PART NO. | TEMPERATURE | V $_{\text {CC }}$ |
| :---: | :---: | :---: |
| N2960N <br> N2960I | $T_{\text {A }}=0$ to $+70^{\circ} \mathrm{C}$ | $5 \mathrm{~V}( \pm 5 \%)$ |

DC CHARACTERISTICS $V_{C C} M I N=4.75 \mathrm{~V}, \mathrm{~V}_{C C} M A X=5.25 \mathrm{~V}$

| PARAMETER |  | TEST CONDITIONS ${ }^{1}$ |  |  | 2960 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{2}$ | Max |  |
| VOH | Output HIGH voltage |  |  |  | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOH}=-0.8 \mathrm{~mA}$ |  | 2.7 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| $V_{1 H}$ | input HIGH voltage | Guaranteed input logical HIGH voltage for all inputs ${ }^{6}$ |  |  | 2.0 |  |  | V |
| $V_{\text {IL }}$ | input LOW voltage | Guaranteed input logical LOW voltage for all inputs ${ }^{6}$ |  |  |  |  | 0.8 | V |
| $v_{1}$ | input clamp voltage | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | V |
| If | input LOW current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=0.5 \mathrm{~V} \end{aligned}$ | DATA $_{0-15}$ |  |  |  | -410 | $\mu \mathrm{A}$ |
|  |  |  | All other inputs |  |  |  | -360 |  |
| ! ${ }_{\text {H }}$ | Input HiGH current | $\begin{aligned} & V_{C C}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{IN}}=2.7 \mathrm{~V} \end{aligned}$ | DATA $_{0-15}$ |  |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  | All other inputs |  |  |  | 50 |  |
| 4 | input HIGH current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| $\begin{gathered} \mathrm{OZZH}^{4} \\ \mathrm{O}_{4}^{4} \end{gathered}$ | Off state (high impedance) output current | $V_{C C}=$ MAX | $\mathrm{DATA}_{0-15}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -410 |  |
|  |  |  | $\mathrm{SC}_{0-6}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 |  |
| 103 | Output short circuit current ${ }^{3}$ | $\mathrm{V}_{C C}=\mathrm{V}_{C C} \mathrm{MAX}+0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -25 |  | -85 | mA |
| locs | Power supply current ${ }^{5}$ | $V_{C C}=\mathrm{MAX}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  | 300 | 360 | mA |
|  |  |  | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |  |  |  |  |  |
|  |  |  | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |  |  |  |  |  |

## NOTES:

1. For conditions shown as MIN or MAX, use the appropriate value specified under Electrical Characteristics for the applicable device type.
2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. These are three-state outputs internally connected to TTL inputs. Input Characteristics are measured with output enables HIGH.
5. Worst case $\mathrm{l}_{\mathrm{Cc}}$ is at minimum temperature.
6. These input levels provide zero noise immunity and should only be tested in a static, noise-free environment.

## Error Detection and Correction (EDC) Unit

## GUARANTEED PERFORMANCE <br> OVER COMMERCIAL <br> TEMPERATURE RANGE OF 0

TO $+70^{\circ} \mathrm{C}$
The tables that follow specify the guaranteed performance of the 2960 over the commercial
operating range of 0 to $+70^{\circ} \mathrm{C}$, with $\mathrm{V}_{\mathrm{CC}}$ from 4.75 V to 5.25 V . All data are in ns with inputs switching between 0 V and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.

This data applies to the following part numbers: N2960N and N2960I.

COMBINATIONAL PROPAGATION DELAYS $-\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$

| TO OUTPUT <br> FROM INPUT | $\mathrm{SC}_{0-6}$ | DATA 0 - 15 | ERROR | MULT ERROR |
| :---: | :---: | :---: | :---: | :---: |
| DATA $_{0-15}$ | 32 | 65* | 32 | 50 |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \left(\mathrm{CODE} \quad \mathrm{ID}_{2-0} 000,011\right) \end{aligned}$ | 28 | 56 | 29 | 47 |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \left(\mathrm{CODE} \mathrm{ID} 2_{-0}\right. \\ & 010,100,101,110,111) \end{aligned}$ | 28 | 45 | 29 | 34 |
| GENERATE | 35 | 63 | 36 | 55 |
| CORRECT <br> (Not internal control mode) | - | 45 | - | - |
| DIAG MODE <br> (Not internal control mode) | 50 | 78 | 59 | 75 |
| PASS THRU <br> (Not internal control mode) | 36** | 44 | 29 | 46 |
| CODE $\mathrm{ID}_{2-0}$ | 61 | 90 | 60 | 80 |
| LE IN <br> (From latched to transparent) | 39 | 72* | 39 | 59 |
| LE OUT <br> (From latched to transparent) | - | 31 | - | - |
| LE DIAG <br> (From latched to transparent; not internal control mode) | 45 | 78 | 45 | 65 |
| Internal control mode: <br> LE DIAG <br> (from latched to transparent) | 67 | 96 | 66 | 86 |
| Internal control mode: DATA $_{0-15}$ (via diagnostic latch) | 67 | 96 | 66 | 86 |

*Data In (or LE In) to Correct Data Out measurement requires timing as shown below.


[^20]SET-UP AND HOLD TIMES RELATIVE TO LATCH ENABLES

| FROM INPUT | TO <br> (LATCHING <br> UP DATA) | SET-UP <br> TIME | HOLD <br> TIME |
| :--- | :---: | :---: | :---: |
| ${\text { DATA } A_{0-15}}^{\text {CB }_{0-6}}$ | LE IN | 6 | 7 |
| DATA $_{0-15}$ | LE IN | 5 | 6 |
| $C_{0}-6$ <br> (CODE ID 000, 011) | LE OUT | 44 | 5 |
| CB <br> $0-6$ <br> (CODE ID 010, 100, 101, 110, 111) | LE OUT | 35 | 0 |
| GENERATE | LE OUT | 27 | 0 |
| CORRECT | LE OUT | 42 | 0 |
| DIAG MODE | LE OUT | 26 | 1 |
| PASS THRU | LE OUT | 69 | 0 |
| CODE ID $2-0$ | LE OUT | 26 | 0 |
| LE IN | LE OUT | 81 | 0 |
| DATA $A_{0-15}$ | LE OUT | 51 | 5 |

OUTPUT ENABLE/DISABLE TIMES Output disable tests performed with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ and measured to 0.5 V change of output voltage level.

| INPUT | OUTPUT | ENABLE | DISABLE |
| :--- | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ BYTE 0, $\overline{\mathrm{OE}}$ BYTE 1 | DATA $_{0-15}$ | 30 | 30 |
| $\overline{\mathrm{OE} ~ S C ~}$ | $\mathrm{SC}_{0-6}$ | 30 | 30 |

## TEST LOADING

Three-State Outputs:


## NOTES:

1. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without devices in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function test and all $A C$ tests, except output enable tests
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpZH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZ1 test.
4. $R_{2}=1 K$ for three-state output.
$\mathrm{R}_{2}$ is determined by the $\mathrm{I}_{\mathrm{OH}}$ at $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ for non-three-state output.
5. $R_{1}$ is determined by $\mathrm{l}_{\mathrm{OL}}$ (MIL) with $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ minus the current to ground through $\mathrm{R}_{2}$
6. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

MINIMUM PULSE WIDTHS

| LE IN, LE OUT, LE DIAG | 15 |
| :--- | :--- |


| Three-State Outputs: Normal Outputs: | TEST O | UTPUT LOA |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{v}_{\mathrm{cc}}$ | PIN $\#$ | PIN LABEL | TEST CIRCUIT | $\mathrm{R}_{1}$ | $\mathbf{R}_{2}$ |
| \%/ vcc | - | $\mathrm{D}_{0}-\mathrm{D}_{15}$ | Fig. 11 | $430 \Omega$ | $1 \mathrm{k} \Omega$ |
| $s_{2}$ | 24-30 | $\mathrm{SC}_{0}-\mathrm{SC}_{6}$ | Fig. 11 | $430 \Omega$ | $1 \mathrm{k} \Omega$ |
| $\left.\left.R_{1}\right\} \quad R_{1}\right\}$ | 32 | ERROR | Fig. 12 | $470 \Omega$ | $3 \mathrm{k} \Omega$ |
|  | 33 | $\overline{\text { MULTERROR }}$ | Fig. 12 | $470 \Omega$ | $3 \mathrm{k} \Omega$ |
|  | PACKA <br> TYPE: <br> Configurat Width: <br> Length: <br> Pin Center | E DATA <br> Plastic and <br> n: DIP $C=0.6^{\prime \prime}$ <br> 2.4" <br> 2.54 BSC | eramic $P=0.55^{\prime \prime}$ |  |  |
|  | ORDER | NG INFORM | TION |  |  |
| TCo3s40s | Commercia |  |  |  |  |
| NOTES: <br> 1. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without devices in test fixture. | $\begin{aligned} & \text { N2960N } \\ & \text { N2960I } \end{aligned}$ | (Plastic) <br> Ceramic) |  |  |  |
| 2. $S_{1}, S_{2}, S_{3}$ are closed during function test and all $A C$ tests, except output enable tests. |  |  |  |  |  |
| 3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpzH test. <br> $S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpzL test. <br> 4. $R_{2}=1 \mathrm{~K}$ for three-state output. <br> $\mathrm{R}_{2}$ is determined by the $\mathrm{I}_{\mathrm{OH}}$ at $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ for non-three-state output. <br> 5. $R_{1}$ is determined by loL (MIL) with $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ minus the current to ground through $\mathrm{R}_{2}$. <br> 6. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests. |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |

## APPLICATIONS

## Byte Write

Byte operations are increasingly common for 16 and 32-bit processors. These complicate memory operations because check bits are generated for a complete 16 or 32 or 64 -bit memory word, not for a single byte.

To write a byte into memory with EDC requires the following steps - See Figures 13 and 14.

- Latch the byte into the bus buffers
- Read the complete word from memory
- Correct the complete data word if necessary
- Insert the byte to be written into the data word
- Generate new check bits for the entire data word
- Store the data word back into memory.
(In fact these steps must be taken for any piece of data being written into memory that is not as wide as a full memory word).

The EDC is designed with the intent of keeping byte operations simple in error detection/correction systems. The EDC has separate output enables for each byte in the Data Output Latch. As shown in Figures 13 and 14, this allows the data word to be read from memory, the new byte to be inserted among the old, and new check bits to be generated using less time and less hardware than if separate byte enables were not available.

## Diagnostics

EDC is used to boost the reliability of the overall system. It is necessary to also be able to check the operation of the EDC itself. For this reason the EDC has an internal control mode, a diagnostic latch, and two diagnostic modes.

To check that the EDC is functioning properly, the processor can put the EDC under software control by setting CODE $I D_{2-0}$ to 001 . This puts the EDC into Internal Control Mode. In Internal Control Mode the EDC is controlled by the contents of the Diagnostic

| DATA BITS | CHECK BITS REQUIRED |  |
| :---: | :---: | :---: |
|  | Single Error <br> Corrections Only | Single Error Correct <br> \& Double Error Detect |
|  | 4 | 5 |
| 16 | 5 | 6 |
| 32 | 6 | 7 |
| 64 | 7 | 8 |

Latch, which is loaded from the DATA inputs under processor control.

The EDC is set into CORRECT Mode. The processor loads in a known set of check bits into the Diagnostic Latch, a known set of data bits into the Data in Latch, and forces data errors. The output of the EDC (syndromes, error flags, corrected data) is then compared against the expected responses. By exercising the EDC with a string of data/check combinations and comparing the output against the expected responses, the EDC can be fully checked out.

## Eight Bit Data Word

Eight bit MOS microprocessors can use EDC too. Only five check bits are required. The EDC configuration for eight bits is shown in Figure 15. It operates as does the normal 16bit configuration with the upper byte fixed at 0.

## Other Word Widths

EDC on data words other than $8,16,32$, of 64 bits can be accomplished with the 2960. In most cases the extra data bits can be forced to a constant and EDC will proceed as normal. For example a 24 -bit data word is shown in Figure 16.

## Single Error Correction Only

The EDC normally corrects all single bit errors and detects all double bit and some triple bit errors. To save one check bit per word the ability to detect double bit errors can be sacrificed - single errors are still detected and corrected.

Figure 17 shows single error correction only configurations for $8,16,32$, and 64 -bit data words respectively.

## Check Bit Correction

The EDC detects single bit errors whether the error is a data bit or a check bit. Data bit errors are automatically corrected by the EDC. To generate corrected check bits once a single check bit error is detected, the EDC need only be switched to GENERATE mode (data in the DATA INPUT LATCH is valid).
The syndromes generated by the EDC may be decoded to determine whether the single bit error is a check bit.

In many memory systems, a check bit error will be ignored on the memory read and corrected during a periodic 'scrubbing' of memory - see System Design Considerations).

## Multiple Errors

The bit-in-error decode logic uses syndrome bits SO through S32 to correct errors, SX is only used in developing the multiple error signal. This means that some multiple errors will cause a data bit to be inverted.

For example, in the 16 -bit mode if data bits 8 and 13 are in error the syndrome 111100 (SX, $\mathrm{S} 0, \mathrm{~S} 1, \mathrm{~S} 2, \mathrm{~S} 4 \mathrm{~S} 8$ ) is produced. This is flagged a double error by the error detection logic, but the decoded bit-in-error only receives syndrome 11100 (S0, S1, S2, S4, S8) which it decodes as a single error in data bit 0 and inverts that bit. If it is desired to inhibit this inversion, the multiple error output may be connected to the correct input as in Figure 18. This will inhibit correction when a multiple error occurs. Extra time delay may be introduced in the data to correct data path when this is done.


Figure 13. Byte Write, Phase 1: Read Out The Old Word And Correct


Figure 14. Byte Write, Phase 2: Insert The New Byte Generate Checks And Write Into Memory


Figure 16. 24-Bit Configuration

## Error Detection and Correction (EDC) Unit 2960



LD03720S

b. 16-Bit Data Word


D03740S
c. 32-Bit Data Word

NOTE:
"The code ID combination for this slice forces the check bit latch transparent.
Figure 17. Single Error "Correction Only" Configurations

## Error Detection and Correction (EDC) Unit


d. 64-Bit Data Word

## NOTES:

1. In Pass Thru Mode the contents of the check latch appear on the XOR outputs inverted.
2. In Diagnostic GENERATE Mode the contents of the diagnostic latch appear on the XOR outputs inverted.

Figure 17. (Continued)


L003760S
Figure 18. Inhibition Of Data Modification

## Signetics

## Logic Products

## FEATURES

- Operating Options - controls 16K or 64K DRAMs
- 8-Bit Refresh Counter - refresh address generation, clear input, and selectable terminal count (128 or 256) output
- Row Address Decoder - four Active Row Address Select (RAS) outputs during refresh
- On-Chip Latches - dual 8-bit address latches and RAS decoder latches
- User-Selectable Refresh Modes burst, distributed or transparent
- 3-port, 8-bit address multiplexer with Schottky speed
- Non-inverting address for RAS and CAS signal paths

2964B

## Dynamic Memory Controller

## Product Specification

## PRODUCT DESCRIPTION

The Signetics 2964B Dynamic Memory Controller (DMC) provides address multiplexing, refresh address generation, and RAS/CAS control for dynamic RAMs of any data width. The eight-bit address path is designed for 64 K DRAMs but can be used equally well with 16K DRAMs. Sixteen address input latches and two row address select latches (for higher order addresses) allow the DMC to control up to 256K words of memory (with 64K DRAMs) by using the internal RAS decoder to select from one-of-four banks of DRAMs.

## FUNCTIONAL OPERATION

The Signetics 2964B Dynamic Memory Controller (Figure 1) replaces a dozen MSI devices by grouping several unique
functions. Two 8-bit latches capture and hold the memory address. These latches and a clearable, 8 -bit refresh counter feed into an 8 -bit, 3 -input, Schottky speed MUX, for output to the DRAM address lines.

The 2964B also includes a special RAS decoder and CAS buffer. Placing these functions on the same chip minimizes the time skew between output functions which would otherwise be separate MSI chips, and therefore, allows a faster memory cycle time by the amount of skew eliminated.

The RAS Decoder allows upper addresses to select one-of-four banks of DRAM by determining which bank receives an RAS input. During refresh (RFSH = LOW), the decoder mode is changed to four-of-four and all banks of


8002240S
Figure 1. Block Diagram of 2964B Dynamic Memory Controller (DMC)

2964B PACKAGE/PIN DESIGNATIONS


2964B PACKAGE/PIN DESIGNATIONS (Continued)

## PIN

NO. IDENTIFIER FUNCTION
$25 \overline{\mathrm{RFSH}}$

The Refresh control input. When active LOW, the $\overline{\text { RFSH }}$ input switches the address output multiplexer to output the inverted contents of the 8 -bit refresh counter. $\overline{\text { RFSH }}$ LOW also inhibits the $\overline{\text { CAS }}$ buffer and changes the mode of the $\overline{\text { RAS }}$ decoder from one-of-four to four-of-four so that all four $\overline{\mathrm{RAS}}$ decoder outputs, $\overline{\mathrm{RAS}}_{0}, \overline{\mathrm{RAS}}_{1}, \overline{\mathrm{RAS}}_{2}$ and $\overline{\operatorname{RAS}}_{3}$, go LOW in response to a LOW input at $\overline{\text { RASI. This action refreshes one row }}$ address in each of the four $\overline{R A S}$ decoded memory banks. The refresh counter is advanced at the end of each cycle by the LOW-to-HIGH transition of RFSH or RASI (whichever occurs first). In burst mode refresh. $\overline{\text { RFSH }}$ may be held LOW and refresh accompanied by toggling $\overline{\text { RASI. }}$

## PIN

NO. IDENTIFIER FUNCTION
GND
LE
Ground.

The address latch enable input. An active HIGH input at LE causes the two 8-bit address latches and the 2-bit $\overline{\text { RAS }}$ Select input latch to go transparent, accepting new input data. A LOW input on LE latches the input data which meets set-up and hold time requirements.
memory receive an RAS input for refresh in response to an RASI active LOW input. CAS is inhibited during refresh.

## TRUTH TABLES:

RAS OUTPUT FUNCTIONS

| $\overline{\text { RFSH }}$ | RASI | RSEL ${ }_{1}$ | RESEL ${ }_{0}$ | $\overline{\mathbf{R A S}}_{\mathbf{0}}$ | $\overline{\mathrm{RAS}}_{1}$ | $\overline{\mathrm{RAS}}_{2}$ | $\overline{\mathbf{R A S}}_{3}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | H | X | X | H | H | H | H |
| L | L | X | X | L | L | L | L |
| H | H | X | X | H | H | H | H |
| H | L | L | L | L | H | H | H |
| H | L | L | H | H | L | H | H |
| H | L | H | L | H | H | L | H |
| H | L | H | H | H | H | H | L |

Burst mode refresh is accomplished by holding RFSH low and toggling RASI.
$\mathrm{A}_{15}$ is a dual function input which controls the refresh counter's range. For 64 K DRAMs, it is
an address input. For 16 K DRAMs, it can be pulled to +12 V through 1 K to terminate the refresh count at 128 instead of 256.

CASO FUNCTION

| $\overline{\text { RFSH }}$ | $\overline{\text { CASI }}$ | $\overline{\text { CASO }}$ |
| :---: | :---: | :---: |
| $H$ | $L$ | $L$ |
| $H$ | $H$ | $H$ |
| $L$ | $X$ | $H$ |

ADDRESS OUTPUT FUNCTIONS

| MSEL | $\overline{\text { RFSH }}$ | $\mathbf{0}_{\mathbf{0}}-\mathbf{0}_{\mathbf{7}}$ |
| :---: | :---: | :---: |
| $H$ | $H$ | $A_{0}-A_{7}$ |
| $L$ | $H$ | $A_{\mathbf{8}}-A_{15}$ |
| $X$ | $L$ | Refresh Address |

## REFRESH ADDRESS COUNTER FUNCTION

| A $_{\mathbf{1 5}}$ | CLR | $\overline{\text { RFSH }}$ | $\overline{\text { RASI }}$ | $\overline{\text { TC }}$ | REFRESH COUNT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| X | L | X | X | X | $\mathrm{FF}_{\mathrm{H}}$ | Clear counter |
| X | H |  | X | X | NC | Output refresh address <br> no change for counter |
| X | H |  | L | X | Count -1 | Return to memory cycle <br> mode and decrement counter |
| X | H | L |  | X | NC | Output all RASI to RAM <br> no change for counter |
| X | H | L |  | X | Count -1 | Return RAS $\mathrm{S}_{\mathrm{i}}$ to HIGH and <br> decrement counter |
| L or H | H | X | X | L | $00_{\mathrm{H}}$ | Terminal count for <br> 256 line refresh |
| $+12 \mathrm{~V}^{*}$ | H | X | X | L | $00_{\mathrm{H}}$ and $80_{\mathrm{H}}$ | Terminal count for <br> 128 line refresh |

*Through $1 \mathrm{~K} \Omega$ resistor.
ABSOLUTE MAXIMUM RATINGS (Above which useful life may be impaired)

| Storage temperature | -65 to $+150^{\circ} \mathrm{C}$ |
| :--- | :--- |
| Temperature (ambient) under bias | -55 to $+125^{\circ} \mathrm{C}$ |
| Supply voltage to ground potential | -0.5 to +7.0 V |
| DC voltage applied to outputs <br> for high output state | +0.5 V to $+\mathrm{V}_{\mathrm{CC}} \mathrm{MAX}$ |
| DC input voltage | -0.5 to 5.5 V |
| DC output current, into outputs | 30 mA |
| DC input current | -30 to +5.0 mA |

DC ELECTRICAL CHARACTERISTICS Commercial: $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}( \pm 5 \%)$, $(\mathrm{Min}=4.75 \mathrm{~V}),(\mathrm{Max}=5.25 \mathrm{~V})$

| DESCRIPTION |  | TEST CONDITIONS ${ }^{1}$ |  | 2964B |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{2}$ | Max |  |
| Vor | Output HIGH voltage |  |  | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & I_{O H}=-1 \mathrm{~mA} \end{aligned}$ | $\overline{T C}$ | 2.5 |  |  | v |
|  |  | Others | 3.0 |  |  |  | V |
| VOH | Output HIGH voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & I_{O H}=-15 \mathrm{~mA} \end{aligned}$ | All outputs except TC | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } I_{I L} \end{aligned}$ | All outputs except $\overline{\mathrm{TC}}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 | V |
|  |  |  | $\overline{\mathrm{TC}}, \mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | v |
| $V_{1 H}$ | Input HIGH level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | V |
| $V_{\text {IL }}$ | Input LOW level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | V |
| V | Input clamp voltage | $V_{C C}=$ MIN, $\mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  | -1.5 | $\checkmark$ |
| 11. | Input LOW current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=0.4 V \end{aligned}$ | RASI |  |  | -3.2 | mA |
|  |  |  | $\overline{\text { CASI, MSEL, }} \overline{\mathrm{RFSH}}$ |  |  | -1.6 | mA |
|  |  |  | $\begin{aligned} & \mathrm{A}_{0}-\mathrm{A}_{15}, \overline{\mathrm{CLF}} \\ & \text { RSEL }_{0.1}, \mathrm{LE} \end{aligned}$ |  |  | -0.4 | mA |
| $\mathrm{I}_{\mathrm{H}}$ | Input HIGH current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ | $\overline{\text { RASI }}$ |  |  | 100 | $\mu \mathrm{A}$ |
|  |  |  | $\overline{\text { CASI, MSEL, }} \overline{\mathrm{RFSH}}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  | $\begin{aligned} & \mathrm{A}_{0}-A_{15}, \overline{\mathrm{CLF}} \\ & \mathrm{RSEL}_{0.1}, \mathrm{LE} \end{aligned}$ |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=-5.5 \mathrm{~V} \\ & V_{C C}=M A X \\ & V_{\mathbb{I N}}=5.5 \mathrm{~V} \end{aligned}$ | $\overline{\text { RASI }}$ |  |  | 2.0 | mA |
|  |  |  | CASI, MSEL, $\overline{\mathrm{RFSH}}$ |  |  | 1.0 | mA |
|  |  |  | $\begin{aligned} & \mathrm{A}_{0}-\mathrm{A}_{15}, \overline{\mathrm{CLR}} \\ & \text { RSEL }_{0.1}, \mathrm{LE} \\ & \hline \end{aligned}$ |  |  | 0.1 | mA |
| Isc | Output short circuit current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ (note 3) |  | -40 |  | -100 | mA |
| $I_{\text {cc }}$ | Power supply current (note 4) | $25^{\circ} \mathrm{C}, 5 \mathrm{~V}$ | Com'l |  | 122 |  | mA |
|  |  | 0 to $70^{\circ} \mathrm{C}$ |  |  |  | 173 | mA |
|  |  | $70^{\circ} \mathrm{C}$ |  |  |  | 165 | mA |
| $I_{T}$ | $\mathrm{A}_{15}$ Enable current | $\mathrm{A}_{15}$ connected to +12 V through $1 \mathrm{~K} \Omega \pm 10 \%$ |  |  |  | 5 | mA |

## NOTES:

1. For conditions shown as MIN or MAX, use the appropriate value specified under DC Electrical Characteristics for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. ICC is worst case when the Address inputs are latched HIGH, the refresh counter is at terminal count (255), $\overline{\text { RASI }}$ and $\overline{\text { CASI }}$ are HIGH and all other inputs are LOW.

## AC ELECTRICAL

## CHARACTERISTICS

Tables 1 and 2 specify performance characteristics of the Signetics 2964B over the
operating range for capacitive loads of 50 and 150 picofarads, respectively. Note that the minimum specified limits for $t_{P W}$, $t_{s}$, and $t_{H}$ are for minimum system operating require-
ments and that limits for tSKEW and tPD are guaranteed test limits for the device. All AC parameters are specified at 1.5 volts.

Table 1. Performance Characteristics for Capacitive Loading of 50 Picofarads

| $\begin{aligned} & \text { PARAMETER } \\ & \text {-See } \\ & \text { Figure } 2 . \end{aligned}$ | DESCRIPTION | $\begin{gathered} T_{A}=+25^{\circ} \mathrm{C} \\ \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ \hline \text { Typ } \end{gathered}$ | CON | IAL | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{gathered} \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% \end{gathered}$ |  |  |
|  |  |  | Min | Max |  |
| 1 tPD | $A_{i}$ to $O_{i}$ Delay | 14 |  | 19 | ns |
| 2 tpHL | $\overline{\text { RASI }}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{H})$ | 14 |  | 20 | ns |
| $3 \mathrm{t}_{\text {PHL }}$ | $\overline{\text { RASI }}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 14 |  | 20 | ns |
| 4 tpD | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 17 | 9 |  | ns |
| 5 tpD | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 17 |  | 21 | ns |
| 6 tpHL | $\overline{\text { CASI }}$ to $\overline{\text { CASO }}(\overline{\text { RFSH }}=\mathrm{H})$ | 12 |  | 17 | ns |
| 7 tpHL | $\mathrm{RSEL}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(L E=H, \overline{\mathrm{RASI}}=\mathrm{L})$ | 15 |  | 20 | ns |
| 8 tpLH | $\overline{\text { RFSH }}$ to $\overline{\text { TC }}(\overline{\text { RASI }}=\mathrm{L})$ | 30 |  | 40 | ns |
| 9 tPLH | $\overline{\text { RASI }}$ to $\overline{\mathrm{TC}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 25 |  | 35 | ns |
| 10 tpw | $\overline{\mathrm{RASI}}=\mathrm{L}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 10 | 50 |  | ns |
| 11 tpw | $\overline{\text { AASI }}=\mathrm{H}(\overline{\text { RFSH }}=\mathrm{L})$ | 10 | 50 |  | ns |
| 12 tPD | $\overline{\mathrm{RFSH}}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\mathrm{RASI}}=\mathrm{X})$ | 17 |  | 21 | ns |
| 13 tphL | $\overline{\mathrm{RFSH}}$ to $\overline{\mathrm{RAS}}$ ( $(\overline{\mathrm{RASI}}=\mathrm{L})$ | 19 |  | 26 | ns |
| 14 tpw | $\overline{\mathrm{CLR}}=\mathrm{L}$ | 10 | 30 |  | ns |
| 15 tpLH | $\begin{aligned} & \overline{\overline{\text { FFSH}} \text { to } \overline{\text { CASO }}} \\ & (\overline{\mathrm{RASI}}=\mathrm{L} \overline{\mathrm{CASI}}=\mathrm{L}, \text { Note } 1) \end{aligned}$ | 16 |  | 21 | ns |
| 16 tPD | $L E$ to $\mathrm{O}_{\mathrm{i}}$ | 25 |  | 35 | ns |
| 17 tphL | LE to $\overline{\mathrm{RAS}}_{\mathrm{i}}$ | 30 |  | 40 | ns |
| 18 tpLH | $\overline{\text { CLR }}$ to $\overline{\mathrm{TC}}$ | 35 |  | 45 | ns |
| 19 tpLH | $\overline{\text { CLR }}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 31 |  | 44 | ns |
| $20 \mathrm{t}_{5}$ | $A_{i}$ to LE Set-up time | 0 | 5 |  | ns |
| $21 \mathrm{t}_{\mathrm{H}}$ | $A_{i}$ to LE Hold time | 5 | 12 |  | ns |
| 22 ts | RSEL i to LE Set-up time | 0 | 5 |  | ns |
| $23 \mathrm{t}_{\mathrm{H}}$ | RSEL ${ }_{\text {i }}$ to LE Hold time | 10 | 17 |  | ns |
| 24 ts | $\overline{\text { CLR }}$ Recovery time | 10 | 16 |  | ns |
| 25 tskew | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{H}$, Note 2) | 2 |  | 5 | ns |
| $26 \mathrm{t}_{\text {SKEW }}$ | $\mathrm{O}_{\mathrm{i}}$ to CASO (Note 2) | 6 |  | 8 | ns |
| $27 \mathrm{t}_{\text {SKEW }}$ | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L}$, Note 3) | 6 |  | 8 | ns |
| $28 \mathrm{t}_{\text {SKEW }}$ | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\mathrm{MSEL}=\mathrm{Z}$, Note 4) | 1 |  | 5 | ns |

## AC ELECTRICAL CHARACTERISTICS (Continued)

Table 2. Performance Characteristics for Capacitive Loading of 150 Picofarads

| PARAMETER <br> - See <br> Figure 2. | DESCRIPTION | $\begin{aligned} & \mathrm{T}_{A}=+25^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ <br> Typ | CO | IAL | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{gathered} \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% \end{gathered}$ |  |  |
|  |  |  | Min | Max |  |
| $1 \mathrm{t}_{\text {PD }}$ | $A_{i}$ to $O_{i}$ Delay | 20 |  | 25 | ns |
| 2 tPHL | $\overline{\text { RASI }}$ to $\overline{\text { RAS }}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{H})$ | 18 |  | 24 | ns |
| 3 tphL | $\overline{\text { RASI }}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 18 |  | 24 | ns |
| $4 \mathrm{t}_{\text {PD }}$ | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 23 | 12 |  | ns |
| $5 \mathrm{t}_{\text {PD }}$ | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 23 |  | 27 | ns |
| $6 \mathrm{t}_{\mathrm{PHL}}$ | $\overline{\text { CASI }}$ to $\overline{\mathrm{CASO}}(\overline{\mathrm{RFSH}}=\mathrm{H})$ | 17 |  | 24 | ns |
| $7 \mathrm{t}_{\mathrm{PHL}}$ | RSEL ${ }_{i}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\mathrm{LE}=\mathrm{H}, \overline{\mathrm{RASI}}=\mathrm{L})$ | 19 |  | 27 | ns |
| 8 tPLH | $\overline{\mathrm{RFSH}}$ to $\overline{\mathrm{TC}}(\overline{\mathrm{RASI}}=\mathrm{L})$ | 34 |  | 45 | ns |
| $9 \mathrm{t}_{\mathrm{PLH}}$ | $\overline{\text { RASI }}$ to $\overline{\mathrm{TC}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 32 |  | 45 | ns |
| 10 tpW | $\overline{\text { RASI }}=\mathrm{L}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 10 | 50 |  | ns |
| 11 tpW | $\overline{\text { RASI }}=\mathrm{H}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 10 | 50 |  | ns |
| 12 tPD | $\overline{\text { RFSH }}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\text { RASI }}=\mathrm{X})$ | 21 |  | 27 | ns |
| 13 tPHL | $\overline{\mathrm{RFSH}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RASI}}=\mathrm{L})$ | 25 |  | 33 | ns |
| 14 tPW | $\overline{C L R}=\mathrm{L}$ | 10 | 30 |  | ns |
| $15 \mathrm{t}_{\text {PLH }}$ | $\begin{aligned} & \overline{\mathrm{RFSH}} \text { to } \overline{\mathrm{CASO}} \\ & (\overline{\mathrm{RASI}}=\mathrm{L} \overline{\mathrm{CASI}}=\mathrm{L}, \text { Note } 1) \end{aligned}$ | 21 |  | 27 | ns |
| 16 tPD | $L E$ to $\mathrm{O}_{\mathrm{i}}$ | 30 |  | 40 | ns |
| $17 \mathrm{t}_{\mathrm{PHL}}$ | LE to $\overline{\mathrm{RAS}}_{\mathrm{i}}$ | 34 |  | 45 | ns |
| $18 \mathrm{t}_{\text {PLH }}$ | $\overline{\mathrm{CLR}}$ to $\overline{\mathrm{TC}}$ | 39 |  | 55 | ns |
| $19 \mathrm{t}_{\text {PLH }}$ | $\overline{\mathrm{CLR}}$ to $\mathrm{O}_{i}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 38 |  | 50 | ns |
| 20 ts | $A_{i}$ to LE Set-up time | 0 | 5 |  | ns |
| $21 t_{H}$ | $A_{i}$ to LE Hold time | 5 | 12 |  | ns |
| $22 \mathrm{ts}^{\text {s }}$ | RSEL ${ }_{\text {i }}$ to LE Set-up time | 0 | 5 |  | ns |
| $23 \mathrm{t}_{\mathrm{H}}$ | RSEL i $^{\text {to LE Hold time }}$ | 10 | 17 |  | ns |
| $24 \mathrm{ts}^{\text {s }}$ | $\overline{\text { CLR }}$ Recovery time | 10 | 16 |  | ns |
| 25 tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{H}$, Note 2) | 3 |  | 6 | ns |
| 26 tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{CASO}}$ (note 2) | 6 |  | 8 | ns |
| 27 tSKEW | $\mathrm{O}_{i}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L}$, Note 3) | 6 |  | 9 | ns |
| 28 tskew | $\mathrm{O}_{i}$ to $\overline{\mathrm{RAS}}_{i}(\overline{\mathrm{MSEL}} \mathrm{L}$, Note 4) | 1 |  | 5 | ns |

## NOTES:

1. $\overline{\mathrm{RFSH}}$ inhibits $\overline{\mathrm{CASO}}$ during refresh. Specification is for $\overline{\mathrm{CASO}}$ inhibit time.
2. $O_{i}$ to $\overline{\operatorname{RAS}}_{i}$, ( $\left.\overline{\mathrm{RFSH}}=\mathrm{HIGH}\right)$ skew is guaranteed maximum difference between fastest $\overline{\mathrm{RASII}}$ to $\overline{\mathrm{RAS}}$, delay and slowest $A_{i}$ to $O_{i}$ delay within a single device. $O_{i}$ to $\overline{\text { CASO }}$ skew is maximum difference between fastest $\overline{\text { CASII }}$ to $\overline{\text { CASO }}$ delay and slowest MSEL to $O_{i}$ delay within a single device. See application section entitled Memory Cycle Timing for correlation to System Tirning requirements.
3. $\mathrm{O}_{i}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}$, $\overline{\mathrm{RFSH}}=\mathrm{LOW}$ ) skew is guaranteed maximum difference between fastest $\overline{\mathrm{RASI}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}$ delay and slowest $\overline{\mathrm{RFSH}}$ to $\mathrm{O}_{\mathrm{i}}$ delay within a single device. See application section on Refresh Timing for correlation to system refresh timing requirements.


TIMING DIAGRAM


## Dynamic Memory Controller

MEMORY CYCLE TIMING
The relationship between DMC specifications and system timing requirements are shown in Figure 3. $T_{1}, T_{2}$, and $T_{3}$ represent the minimum timing requirements at the DMC inputs
to guarantee that DRAM timing requirements are met and that maximum system performance is achieved.
The minimum requirements for $T_{1}, T_{2}$, and $T_{3}$ are as follows:
$\mathrm{T}_{1} \mathrm{MIN}=\mathrm{t}_{\mathrm{RAH}}+\mathrm{t}_{28}$
$\mathrm{T}_{2} \mathrm{MIN}=\mathrm{t}_{1}+\mathrm{t}_{26}+\mathrm{t}_{\text {ASC }}$
$\mathrm{T}_{3} \mathrm{MIN}=\mathrm{t}_{\text {ASR }}+\mathrm{t}_{25}$ where,
$t_{\text {RAH }}=$ Row Address Hold Time
$t_{\text {ASC }}=$ Column Address Set-up Time
$t_{\text {ASR }}=$ Row Address Set-up Time


WFFO960S
Legend
(25) $=$ Guaranteed maximum difference between fastest $\overline{\mathrm{RASI}} \overline{1}_{1}$ to $\overline{\mathrm{RAS}}$ delay and the slowest $A_{1}$ to $O_{1}$ delay on any single device. (28) $=$ Guaranteed maximum difference between fastest CASI to CASO delay and the slowest MSEL to $O_{1}$ delay on any single device. (28) $=$ Guaranteed maximum difference between fastest MSEL to $O_{i}$ delay and the slowest RASI to RAS ${ }_{i}$ delay on any single device.
a. Specifications Applicable to Memory Cycle Timing


WF10970S

## b. Desired System Timing

Figure 3. Memory Cycle Timing

## REFRESH CYCLE TIMING

The timing relationships for refresh are shown
in Figure 4.
$T_{4}$ minimum is calculated as follows:

$$
\mathrm{T}_{4}=\mathrm{t}_{\mathrm{ASR}}+\mathrm{t}_{27}
$$

Burst refresh timing is shown in Figure 5.

## AC WAVEFORMS



NOTE:
The timing shown assumes that burst mode applications may power-down the 2964 B with the RAM. Therefore, the counter is cleared prior to executing the refresh sequence

ORDERING INFORMATION<br>Commercial:<br>N2964BN (Plastic)<br>N2964BI (Ceramic)

## PACKAGE DATA

Type: Plastic or Ceramic
Configuration: DIP
Width: 0.6 in .
Length: 2.0 in .
Pin Centers: 0.1 in .

## APPLICATIONS

## Speed with Minimum Skew

The DMC provides Schottky speed in all of the critical paths. In addition, time skew between the Address, RAS and CAS paths is minimized (and specified) by placing these functions on the same chip. The inclusion of the CAS buffer allows matching of its propagation delay, and also provides the CAS inhibit function during RAS - only refresh.

## Input Latches

The eighteen input latches are transparent when LE is HIGH and latch the input data, meeting the set-up and hold time requirements when LE goes LOW. In systems with separate address and data buses, LE may be permanently enabled HIGH.

## Refresh Counter

The 8-bit refresh counter provides both 128 and 256 line refresh capability. Refresh con-
trol is external to allow maximum user flexibility. Transparent (hidden), burst, synchronous or asynchronous refresh modes are all possible.

The refresh counter is advanced at the LOW-to-HIGH transition of RFSH (or RASI). This assures a stable counter output for the next refresh cycle. The counter will continue to cycle through 256 addresses unless reset to zero by CLR. This actually causes all output to go HIGH since the output MUX is inverting. (Address inputs to outputs are non-inverting since both the input latches and output MUX are inverting.)

## Refresh Terminal Count

The refresh counter also provides a Terminal Count output for burst mode refresh applications. TC normally occurs at count $255\left(00_{7}\right.$ to $0_{7}$ all LOW when RFSH is LOW). TC can be made to occur at count 127 for 128 line burst mode refresh by pulling $A_{15}$ up to +12 V through a $1 \mathrm{~K} \Omega \pm 10 \%$ resistor. The counter actually cycles through 256 with TC determined by $A_{15}$. Otherwise $A_{15}$ functions as an address input when driven at normal TTL levels.

## Three-Input 8-Bit Address

## Multiplexer

The address MUX is 8 -bits wide (for 64 K DRAMs) and has three data sources, the lower address input latch ( $A_{0}$ to $A_{7}$ ), the upper address input latch ( $A_{8}$ to $A_{15}$ ), and the internal refresh counter. The lower address latch is selected when MSEL is HIGH. This is
normally the Row address. The upper address latch is selected when MSEL is LOW. This is normally the Column address. The third source - the refresh counter is selected when RFSH is LOW and overrides MSEL.

When RFSH goes LOW, the MUX selects the refresh counter address and CASO is inhibited. Also, the RAS Decoder function is changed from one-of-four to four-of-four so all RAS outputs $R^{2} S_{0}-$ RAS $_{3}$ go low to refresh all banks of memory when RASI goes LOW. When RFSH is HIGH, only one RAS output goes low, determined by the RAS Select inputs, RSEL $_{0}$ and RSEL $_{1}$. In either case the RAS Decoder output timing is controlled by RASI to make sure the refresh count appears at $00_{0}-0_{7}$ before $R^{2} S_{0}-$ RAS $_{3}$ goes LOW. This assures meeting Row address Set-up time requirement of the DRAM ( $t_{\text {ASR }}$ ).

## Maximum Performance System

The typical organization of a maximum performance 16 -bit system including Error Detection and Correction is shown in Figure 6. Delay lines provide the most accurate timing and are recommended for RAS, MSEL, and CAS timing in this type of system.

## Controlling 16K RAMS or

## Smaller Systems

16K DRAMs require seven address inputs and 128 line refresh. Also $A_{0}$ is often used to designate upper or lower byte transactions in 16 -bit systems. These modifications are shown in Figure 7.

## Dynamic Memory Controller



BDO2150S
Figure 6. Dynamic Memory Control with Error Detection and Correction

${ }^{*} A_{0}$ controls byte select logic.
Figure 7. Word Organized Memory Using 16K RAMs

## Signetics

## Logic Products

## FEATURES

- 10MHz Serial or Parallel Data Rate
- Serial or Parallel Input and Output
- Expandable Without External Logic
- Three-State Outputs
- Fully TTL-Compatible
- Slim (0.4 In.) 24-Pin DIP


## PRODUCT DESCRIPTION

The 9403 is an expandable fall-through type First-In First-Out (FIFO) Buffer Memory that is optimized for high-speed disc/tape controllers and communica-tion-buffer applications. In multiples of four, the device can be expanded to any number of bits and subsequently, to any number of words. Serial or parallel data can be asynchronously entered or retrieved which makes the 9403 the costeffective solution for implementing buffer memories.

9403

## 64-Bit FIFO Buffer Memory

## Product Specification

## FUNCTIONAL DESCRIPTION

As shown in Figure 1, the 9403 consists of three parts which operate asynchronously and are virtually independent. These parts are:

- Input Register - with serial and parallel data inputs and control signals that permit easy expansion and a handshake interface.
- FIFO Stack - 4-bit wide, 14 -word deep fall-through type with selfcontained control logic.
- Output Register - with serial and parallel data outputs and control signals that permit easy expansion and a handshake interface.


PIN DESIGNATIONS \&
DESCRIPTIONS



Figure 2. Functional Equivalent of Input Register


Figure 3. Final Bit Positions Resulting from a Serial Train of 64 -Bits

## INPUT REGISTER

Data can be entered serially or, using the parallel mode of operation, data is entered in 4-bit increments. In either case, the data is subsequently transferred to the fall-through stack; the functional equivalent of this register is shown in Figure 2. The Input Register Full ( $\overline{\mathrm{RF}}$ ) status signal is internally generated by the Register Status (RS) flip-flop; when initialized, the $\bar{Q}$ (IRF) output of this flip-flop is high.

## Serial Entry (Input Register)

Serial data is entered via the $\mathrm{D}_{\mathrm{S}}$ input and is handled by a 5 -bit shift register consisting of flip-flops F3, F2, F1, F0, and RS. With IES and PL both low, each high-to-low transition of the serial input clock ( $\overline{\mathrm{CPSI}})$ shifts the input data in domino order from F3 to F2 to F1 to F0. After the fourth clock transition, the four bits of serial data are aligned in F3 through F0 and RS is set, forcing $\overline{\mathrm{RF}}$ low and inhibiting
$\overline{\text { CPSI }}$ until contents of the input register are transferred to the stack. Figure 3 shows how a serial train of 64-bits would appear in the 9403 - four bits (B60-B63) in the input register, 56 bits ( $B 4-B 59$ ) in the stack, and four bits ( $\mathrm{BO}-\mathrm{B} 3$ ) in the output register.

## Parallel Entry (Input Register)

When PL is high and CPSI is low (Figure 2), flip-flops F0-F3 are loaded with data and $\overline{\mathrm{RFF}}$ is forced low. This condition remains until current data is transferred to the stack. Once the data is transferred, $\overline{\mathrm{IRF}}$ is driven high and new data can again be clocked into the input flip-flops. If parallel expansion is not being implemented, IES must be low to establish row mastership - refer to discussion of parallel expansion.

## STACK OPERATION

As shown in Figure 2, the outputs of F0 - F3 are applied to the stack under control of a signal derived from TTS. When TTS is low, an attempt to inititate a fall-through action is made. If the top location of stack is empty, data is loaded and the input register is reinitialized provided PL is low. Note that initialization is postponed until PL is again low. Thus, automatic FIFO action is achieved by connecting the TTS input to the IRF output.

The RS flip-flop (Figure 2) records the fact that data has been transferred to the stack; this flip-flop is not cleared until PL goes low. Therefore, if a particular data word is transferred to the stack and falls to the second location before PL goes low, the same word will not be re-transferred even though IRF and TTS are still low. Once data enters the stack, 'fall-through'' is automatic; a delay is
necessary only when waiting for the next stack location to empty. In the 9403, as in most modern FIFO designs, the $\overline{M R}$ input initializes the stack control section and does not clear the data.

## OUTPUT REGISTER

This register receives and stores 4-bits of data from the bottom stack location and, on demand, outputs data onto a three-state 4-bit parallel data bus or a three-state serial data bus. The Output Register Full ( $\overline{\mathrm{ORE}}$ ) status signal is internally-generated by the FX flipflop; when data is transferred from the stack to the output register, ORE goes high. The functional equivalent of the output register is shown in Figure 4.

## Retrieval of Serial Data

When the FIFO stack is empty and MR is driven low, the $\overline{\text { ORE }}$ output goes low to indicate that the output register is ready to accept new data from the stack. After new data is entered and falls through to the bottom stack location, it is transferred to the output register provided TOS is low and TOP is high. As a result of the data transfer, $\overline{O R E}$ goes high indicating valid data in the output register. Subsequently, the $\bar{Q}_{S}$ output is automatically enabled and the first data bit is transmitted to the three-state serial data bus Henceforth, a serial shift of data occurs on each high-to-low transition of CSPO. On the fourth transition, the register is emptied, $\overline{\text { ORE }}$ is forced low, and serial output $\bar{Q}_{S}$ is diabled. To request a new word from the stack, the $\overline{T O S}$ input can be connected to the ORE output.


Figure 4. Functional Equivalent of Output Register


Figure 5. Word Expansion

## Retrieval of Parallel Data

With the stack empty and $\overline{M R}$ in the activelow state, the ORE output goes low, signifying that the output register is also empty. When
new data is entered and has fallen through to bottom location of the stack, it is automatically transferred to the output register, provided the Transfer Out Parallel (TOP) input is high. When the data is transferred from stack-toregister, $\overline{\mathrm{ORE}}$ goes high and valid data appears at $Q_{0}-Q_{3}$ (Figure 4), provided the three-state buffers are enabled, that is, $\overline{\mathrm{EO}}$ is active-low. When TOP goes low, $\overline{\text { ORE }}$ is driven low which indicates that the data output cycle is complete; however, the original data remains latched in the flip-flops until the next word (if available) is transferred from the stack to the output register.
For parallel operation, $\overline{\text { CPSO }}$ must be low, whereas, $\overline{\text { TOS }}$ should be grounded for singleslice operation or connected to the appropriate $\overline{O R E}$ for expanded operation. The TOP input is not edge-triggered; therefore, if it goes high before data is available from stack but data becomes available before it goes low, the data will be transferred to the output register. However, internal control circuits prevent the same data from being transferred twice. If TOP goes high and returns to low before data is available from the stack, $\overline{\text { ORE }}$ will remain low, indicating the absence of valid output data.

## VERTICAL EXPANSION

In a vertical structure, the 9403 can be expanded to achieve greater word capacity
without any external parts; a 46-word by 4-bit FIFO is shown in Figure 5. Using the same technique and similar connections, any FIFO of $15 n+1$ words (where $n$ is the number of devices) can be constructed. Observe that word expansion does not sacrifice flexibility of the 9403 FIFO as regards serial/parallel input and output.

## HORIZONTAL EXPANSION

The 9403 can be horizontally expanded to store long words in multiples of 4-bits, again without external logic. Connections required to form a 16 -word by 12 -bit FIFO are shown in Figure 6, using similar techniques, any 16word by $4 n$-bit FIFO (where $n$ is the number of devices) can be constructed.
For horizontal or bit expansion, it is good practice to connect, respectively, the IRF and $\overline{\text { ORE }}$ ouputs of the right-most device (most significant device) to the TTS and TOS inputs of all devices to the left (least significant devices) to guarantee that no operation is initiated before each and every device is ready. Word expansion does not affect the ability of the 9403 to handle serial/parallel inputs and outputs; however, the ripple form of expansion shown in Figure 6 does extract a penalty in speed of operation. Whereas a single 9403 is guaranteed to operate at 10 MHz , an array of four FIFOs connected as shown is guaranteed to operate at 4.3 MHz .

## 64-Bit FIFO Buffer Memory



Figure 6. Bit Expansion


Figure 7. Horizontal and Vertical Expansion - $31 \times 16$ FIFO


Figure 8. Entry of Serial Data for Array of Figure 7


Figure 9. Retrieval of Serial Data for Array of Figure 7


## 64-Bit FIFO Buffer Memory

## ABSOLUTE MAXIMUM RATINGS

|  | PARAMETER | RATING | UNIT |
| :--- | :--- | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Power supply voltage | +7 | Vdc |
| $\mathrm{V}_{\text {IN }}$ | Input voltage | +5.5 | Vdc |
| $\mathrm{V}_{\mathrm{O}}$ | Off-state output voltage | +5.5 | $\mathrm{Vdc}^{\circ}$ |
| $\mathrm{T}_{\mathrm{A}}$ | Operating temperature range | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {stg }}$ | Storage temperature range | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS Over operating temperature range unless otherwise noted

| PARAMETER |  | TEST CONDITIONS ${ }^{1,2}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input high voltage |  | Guaranteed input high voltage | 2.0 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Input low voltage | Guaranteed input low voltage |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{CD}}$ | Input clamp diode voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  | -0.9 | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output high voltage, $\overline{\mathrm{ORE}}$, $\overline{\mathrm{IRF}}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 | 3.4 |  | V |
| VOH | Output high voltage, $Q_{0}-Q_{3}, Q_{S}$ | $\mathrm{l}_{\mathrm{OH}}=-5.7 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{MIN}$ | 2.4 | 3.1 |  | V |
| $\mathrm{V}_{\text {OL }}$ | Output low voltage, $\mathrm{Q}_{0}-\mathrm{Q}_{3}, \mathrm{Q}_{\mathrm{S}}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.5 | V |
| VoL | Output low voltage, $\overline{\text { ORE, }} \overline{\mathrm{RF}}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OL}}=8.0 \mathrm{~mA}$ |  | 0.35 | 0.5 | V |
| lozh | Output off current high, $Q_{0}-Q_{3}, Q_{S}$ | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{E}}=2 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| lozL | Output off current low, $Q_{0}-Q_{3}, Q_{S}$ | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{E}}=2 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{H}}$ | Input high current | $\begin{aligned} & V_{C C}=M A X, V_{I N}=2.7 V \\ & V_{C C}=M A X, V_{I N}=5.5 V \end{aligned}$ |  | 1.0 | $\begin{aligned} & 40 \\ & 1.0 \end{aligned}$ | ${ }_{\mathrm{mA}}^{\mu \mathrm{A}}$ |
| IL | Input low current, all except $\overline{O E S}$ \& $\overline{I E S}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  | $\begin{aligned} & -0.36 \\ & -0.96 \end{aligned}$ | mA |
| los | Output short circuit current, $Q_{0}-Q_{3}, Q_{S}, \overline{O R E}, \overline{O E S}$ | $V_{C C}=M A X, V_{\text {OUT }}=0,($ Note 3) | -30 |  | -130 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | Supply Current | $\mathrm{V}_{C C}$ MAX, Inputs open |  | 115 | 170 | mA |

NOTES:

1. Operating temperature ranges are guaranteed after terminal equilibrium has been reached.
2. All voltages measured with respect to ground terminal.
3. No more than one output should be shorted at a time.

AC ELECTRICAL CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$


AC ELECTRICAL CHARACTERISTICS $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ (Cont.)

| PARAMETER | FROM INPUT | TO OUTPUT | TEST CONDITIONS ${ }^{1,2,3}$ | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Set-up and hold time: <br> $t_{s} \quad$ Set-up time <br> $t_{h}$ Hold time | $\begin{aligned} & \mathrm{D}_{\mathrm{S}} \\ & \mathrm{D}_{\mathrm{S}} \\ & \hline \end{aligned}$ | $\frac{\text { Negative CPSI }}{\text { CPSI }}$ | PL low (a \& b, Fig. 11) | $\begin{gathered} 28 \\ 0 \end{gathered}$ | $\begin{array}{r} 17 \\ -6 \end{array}$ |  | ns |
| $\mathrm{t}_{\text {s }}$ Set-up time | Parallel inputs | PL | Length of time parallel inputs must be applied prior to rising edge of PL | 0 | -22 |  | ns |
| $t_{n}$ Hold time | Parallel inputs | PL | Length of time parallel inputs must remain applied after falling edge of PL | 2 |  |  | ns |
| $\mathrm{t}_{\mathrm{s}} \quad$Set-up time (serial <br> or parallel mode) | TTS | $\overline{\mathrm{IRF}}$ | (a, b, g, \& h, Fig. 11) | 0 | -20 |  | ns |
| $\mathrm{t}_{\text {s }} \quad$ Set-up time | Negative going $\overline{\text { ORE }}$ | Negative going TOS | TOP high (c \& d, Fig. 11) | 0 | -24 |  | ns |
| $t_{s}$ Set-up time <br> $t_{s}$ Set-up time | Negative going $\overline{\mathrm{IES}}$ Negative TTS | $\overline{\overline{\mathrm{CPSI}}} \overline{\mathrm{CPSI}}$ | (b, Fig. 11) | $\begin{aligned} & 45 \\ & 84 \end{aligned}$ | $\begin{aligned} & 23 \\ & 58 \end{aligned}$ |  | ns |
| Recovery time: $t_{\text {rec }}$ | $\overline{\mathrm{MR}}$ | Any input | (f, Fig. 11) | 15 | 5 |  | ns |

## NOTES:

1. Initialization requires a master reset to occur after power has been applied.
2. TTS normally connected to $\overline{\mathrm{RF}}$.
3. If stack is full, $\overline{\mathrm{RF}}$ will stay low.

## TEST CIRCUITS AND WAVEFORMS



## 64-Bit FIFO Buffer Memory

## TEST CIRCUITS AND WAVEFORMS (Continued)



## LOGIC DIAGRAM



## DIGITAL SIGNAL PROCESSOR (DSP)

PCB5010 ..... 855
PCB5011 ..... 855

## SINGLE-CHIP DIGITAL SIGNAL PROCESSOR

## HOW TO USE THIS DATA SHEET

- Section 1 contains ordering information and the main features of the PCB5010 and PCB5011.
- Section 2 describes the signals of the PCB5010 and PCB5011, with block diagrams and full descriptions of what functions can be performed by each block.
- Section 3 describes how the blocks are controlled by the instructions given by the programmer. This section is used during programming, it assumes however, a full knowledge of section 2.0. Programming can be simplified by using the software tools available.
- Section 4 describes all the electrical characteristics. This section is used during the design of system hardware.
- Section 5 gives details of the PCB5010 and PCB5011 packages.


## CONTENTS

### 1.0 INTRODUCTION

### 2.0 FUNCTIONAL DESCRIPTION

2.1 General description
2.2 Program control unit
2.2.1 Program memory
2.2.2 Load Program RAM circuitry (LPR)
2.2.3 Program counter ( PC ) and mode circuitry ( P and NP-mode)
2.2.4 Instruction register (IR)
2.2.5 Stack
2.2.6 Instruction repeat circuitry (RPR)
2.2.7 Branch circuitry
2.2.8 The PST and IOF register (PST, IOF, IFA - IFD pins)
2.2.9 Interrupt circuitry (ㅍNT and $\overline{\mathrm{IACK}}$ pins, RX and RY)
2.2.10 Reset circuitry ( $\overline{\mathrm{RST}}$ pin)
2.2.11 Synchronization circuitry (SYNC pin)
2.3 Data memories and ACUs
2.3.1 Data memories
2.3.2 ACUs and PG register
2.4 Multiplier, accumulator, barrel-shifter and format-adjuster unit
2.4.1 Multiplier
2.4.2 Accumulator
2.4.3 Barrel-shifter
2.4.4 Format adjuster
2.4.5 Barrel-shifter register BSR
2.5 ALU and register filter
2.5.1 ALU
2.5.2 Register file
2.6 Parallel I/O
2.7 Serial I/O
2.7.1 Serial input procedure
2.7.2 Serial output procedure
2.8 Data buses $X$ and $Y$
3.0 INSTRUCTION SET
3.1 Basic operations
3.2 Instruction format
3.3 Instruction fields

### 4.0 ELECTRICAL SPECIFICATION

4.1 Absolute maximum ratings
4.2 DC characteristics
4.3 AC characteristics

### 5.0 PACKAGE OUTLINES

5.1 PCB5010 package outline
5.2 PCB5011 package outline

### 1.0 INTRODUCTION

The PCB5010 and PCB5011 are part of our SP 50 family of digital signal processors that contains devices for various applications. These CMOS devices have a common processor structure and are accompanied by a common set of development tools.

The processor structure is characterized by a double data bus, a two operand hardware multiply/accumulate unit and a two operand ALU to improve through. put. Powerful parallel and serial interfaces enable communication with external devices. Large on-chip data memories, each with its own programmable address computation unit (ACU), offer the possibility to make systems with only a few components.

The PCB5010 and PCB5011 are the optimal solutions for implementing DSP functions in telecommunications, and can also be used to advantage in speech processing, high-speed control, image processing and many other fields.

- PCB 5010: Version with on-chip ROM (mask programmable)
- PCB 5011: ROMI ess bond-out version, for use with external program/data memory


## ORDERING INFORMATION

| order number | speed <br> $(\mathrm{MHz})$ | operating ambient <br> temperature $\mathbf{~}^{\circ} \mathrm{C}$ ) | package |
| :--- | :--- | :---: | :--- |
| PCB5010WP-8 | 8 | 0 to +70 <br> -40 to +85 | 68 -pin PLCC <br> 68 -pin PLCC |
| PCF5010WP-8* | 8 | 0 to +70 <br> -40 to +85 | 144 PGA |
| PCB5011YC-8 | 8 | 144 PGA |  |
| PCF5011YC-8* | 8 |  |  |

* The PCF versions will be identical to the PCB versions except that they have an extended operating ambient temperature range. However, minor variations may occur in the AC characteristics.


Fig. 1.0-1 Simplified block diagram of the PCB5010.


Fig. 1.0-2 Simplified block diagram of the PCB5011.

## FEATURES

- Harvard architecture with two data buses of 16 bit width
- 4 instruction types:
- multiply/accumulate operation +2 data moves +3 address calculations/ memory read accesses
- alu operation +2 data moves +3 address calculations/ memory read accesses
+ 3 address calculations/ memory read accesses
+ 3 address calculations/ memory read accesses
Note: a high degree of parallel processing allows up to 6 basic operations to be performed simultaneously.
- Hardware two's complement $16 \times 16$ multiplier with 40 -bit accumulator, full range barrel-shifter and format adjuster:
- 45 different multiply/accumulate operations
- multi-precision multiplication support
- result bit-reversal possibility
-4 status flags
- 16-bit 2-operand ALU with:
- 31 different operations
- multi-precision operation support
- $15 \times 16$-bit 3 -port register-file
- 5 status flags
- Program memory:

PCB5010: $987 \times 40$-bit on-chip ROM (mask programmable)
$32 \times 40$-bit on-chip RAM (loaded via the X-bus) $5 \times 40$-bit on-chip ROM (fixed load RAM program)
PCB5011: $1024 \times 40$-bit external memory (or $64 \mathrm{~K} \times 40$-bit when some external logic is added)

- Data memory:

PCB5010: $512 \times 16$ bit on-chip ROM (mask programmable) $2 \times(128 \times 16)$ on-chip static RAM
PCB5011: $512 \times 16$ bit external memory (read and write possible) $2 \times(128 \times 16)$ on-chip static RAM

- 3 powerful programmable address computation units (ACU's) for the data ROM and both data RAMs and also for 16 pages of $4096 \times 16$ bit external data memory
- each ACU has 8 different operations
- 1 status flag for each ACU
- 5 level deep hardware stack (software extendable)
- 16-bit parallel I/O to access external data memory
- 8 million words/s
- WAIT facility so that "slow" peripherals can be connected
- 2 independent serial inputs and outputs (one pair for each data bus), with a maximum speed of 4 million bit/s under the control of external clocks
- 4 user input flags
- Maskable interrupt
- Repeat possibility of single instruction
- Maximum clock rate 8 MHz
- Pipelined (P) and Non-pipelined (NP) modes under programmer control: P-mode: a new instruction can start every 125 ns NP-mode: a new instruction can start every 250 ns
- Single 5 V power supply ( $\pm 5 \%$ )
- All I/O are TTL compatible
- Operating ambient temperature range:

PCB5010/11: 0 to $+70^{\circ} \mathrm{C}$
PCF5010/11: -40 to $+85^{\circ} \mathrm{C}$

### 2.0 FUNCTIONAL DESCRIPTION

### 2.1 GENERAL DESCRIPTION

The detailed block diagram of the PCB5010 and PCB5011 are shown in Fig. 2.1-1 and Fig. 2.1-2. The signals of the processors are described briefly in the table below.

SIGNAL DESCRIPTION

| SIGNAL | DESCRIPTION |
| :---: | :---: |
| $V_{\text {DD }}$ | Supply voltage: $5 \mathrm{~V} \pm 5 \%$ |
| $V_{\text {SS }}$ | Ground |
| CLK | Clock (input) |
| SCAN | This signal must be grounded |
| RST | Reset (input) |
| D15... D0 | 16-bit wide parallel I/O port (input/output) |
| A15... A0 | 16 -bit wide address for 64 K -words in external data memory (output) |
| R/W | Read/write signal for control of external memory (output) |
| DS | Data strobe (output) |
| WAIT | Wait signal for synchronization of parallel I/O (input) |
| DIX | Serial data input (input) for the X -bus |
| SIXEN | Serial data enable (input) for the X -bus |
| SIXRO | Serial input request (output) for the X -bus |
| CIX | Serial input clock (input) for the X -bus |
| DIY | Serial data input (input) for the Y -bus |
| SIYEN | Serial input enable (input) for the Y-bus |
| SIYRO | Serial input request (output) for the Y -bus |
| CIY | Serial input clock (input) for the Y-bus |
| DOX | Serial data output (output) for the X-bus |
| SOXEN | Serial output enable (input) for the X-bus |
| SOXRQ | Serial output request (output) for the X -bus |
| COX | Serial output clock (input) for the X-bus |
| DOY | Serial data output (output) for the Y -bus |
| SOYEN | Serial output enable (input) for the Y-bus |
| SOYRQ | Serial output request (output) for the Y-bus |
| COY | Serial output clock (input) for the Y-bus |
| INT | Maskable interrupt (input) |
| $\overline{\text { IACK }}$ | Interrupt acknowledge (output) |
| SYNC | Synchronization signal; indicates where execution of a new instruction starts (output) |
| IFA | User flag (input) |
| IFB | User flag (input) |
| IFC | User flag (input) |
| IFD | User flag (input) |

## SIGNAL DESCRIPTION (Cont'd)

| SIGNAL | DESCRIPTION |
| :--- | :--- |
| PCB5011 only: |  |
|  |  |
| PA9 . . PA0 | External program memory address (output) |
| PD39... PD0 | External program word (input) |
| ARR8 . . ARRO | 9-bit address for 512 words in external data memory (output) |
| RD15 . . RD0 | Second 16 -bit parallel I/O port (input/output) |
| $\frac{R R / \bar{W}}{}$ | Read/write signal for second 16 -bit parallel I/O port (output) <br> RDS |

The main blocks of PCB5010/11 are:

- Program control unit with:
- Program ROM (only for PCB5010)
- IR (instruction register)
- Sync pin
- PC (program counter)
- RPR (instruction repeat register)
- Stack
- PST (processor status register)
- IOF (input/output status and user flag register)
- User flag pins
- INT pin and $\overline{\mathrm{IACK}}$ pin
- Bus-save registers $R X$ and $R Y$
- $\overline{\text { RST }}$ pin
- External program memory port (only PCB5011)
- External program memory address port (only PCB5011)
- Data memory and address computation units with:
- RAMA, ACUA (address computation unit A), DRA (data register A)
- PG (page register)
- RAMB, ACUB (address computation unit B ), DRB (data register B)
- ROM (only PCB5010), ACUR (address computation unit R), DRR (data register R)
- External data word pins (only PCB5011)
- External data memory address pins (only PCB5011)
- Multiplier/accumulator and barrelshift unit with:
- Input selectors ILX and ILY
- Latches MXL and MYL
- MPY (multiplier)
- Accumulator with ACC (adder), ACR (multiplication/accumulation register) and S/SD (sign/scaledown block)
- BS (barrelshifter)
- FA (format adjuster)
- BSR (barrelshift and format adjust control register)
- ALU and register file with:
- Input selectors ILA and ILB
- Latches AAL and ABL
- ALU (arithmetic logic unit)
- R1-R15 (register file)
- Trash can
- Parallel I/O with:
- PI (parallel data input latch)
- PO (parallel data output buffer)
- Parallel I/O data and control pins
- Serial I/O with:
- SIX (serial input latch connected to X bus)
- SOX (serial output latch connected to $X$ bus)
- SIY (serial input latch connected to Y bus)
- SOY (serial output latch connected to $Y$ bus)
- SIOST (serial I/O control register)
- Serial I/O data and control pins
- Data buses with:
- 16 bits $X$-bus
-16 bits $Y$-bus
The working of the main blocks is described in the following sections. The instruction set is described in the section 3.0.
DEVELOPMENT DATA

$X, Y$

Note 1: $\uparrow$ means connected to the $X$-bus/Y-bus.
Note 2: all data paths are 16 bits wide unless indicated otherwise.
Fig. 2.1-1 Detailed block diagram of the PCB5010.


Note 1: $\uparrow$ means connected to the X -bus/ Y -bus.
Note 2: all data paths are 16 bits wide unless indicated otherwise.
Fig. 2.1-2 Detailed block diagram of the PCB5011.

### 2.2 PROGRAM CONTROL UNIT

### 2.2.1 Program memory

The PCB5011 has no on-chip program memory but you can connect external program memory. To access the external program memory, there are 40 program data pins (PD39-PDO) and 10 program address pins (PA9-PAO). The on-chip 10-bit program counter contents are available via these address pins.

The PCB5010 has $1 \mathrm{~K} \times 40$-bit on-chip program memory:

- $987 \times 40$-bit mask programmable ROM (address 0-986)
- $32 \times 40$-bit static RAM (address 992-1023)
$5 \times 40$-bit "load RAM" program in ROM (address 987-991)
The memory is addressed by the 10 -bit on-chip program counter. The static
RAM of the program memory can be loaded via the X-bus by MOVE or LOAD IMMEDIATE operations, following the procedure described in the section 2.2.2 "Load program RAM circuitry".

The "load RAM" program stored in the ROM can be used to load the RAM instructions from an external data memory. This program's code, and its equivalent expressed in the PCB5010/11 assembly language is given in Fig. 2.2.1-1.

### 2.2.2 Load program RAM circuitry (LPR)

LPR enables the programmer to load the $32 \times 40$-bit program RAM. To load each 40 -bit instruction, three 16 -bit words must be transferred to LPR via the X-bus, using MOVE or LOAD IMMEDIATE operations. LPR contains a 5 -bit address register (AREG) in which the load address (range 0-31) is loaded and it contains a 24 -bit data register (DREG) in which the instruction word is assembled. The loading procedure is shown in Fig. 2.2.2-1.

### 2.2.3 Program counter (PC) and mode circuitry ( P and NP-mode)

The 10 -bit program counter in the PCB5010 and PCB5011 is automatically incremented every instruction cycle during sequential program flow.


Fig. 2.2.1-1 "Load RAM" program.


AREG = address register
DREG = data register
$\operatorname{PRAM}(i)=$ position $i$ in the program RAM
$[m-n]=$ bit $m$ to bit $n$

Fig. 2.2.2-1 Data RAM loading procedure.

There are however, certain situations when the program counter is not incremented but updated differently:

- reset (see section 2.2.10)
- interrupt (see section 2.2.9)
- instruction repetition (see section 2.2.6)
- branch operations (see section 2.2.7)
- loading PC via the X-bus by means of a MOVE or LOAD IMMEDIATE operation (the 10 least significant bits of the X -bus data are loaded)

The processors work in two different modes:

1. Pipelined mode (P):
instruction cycle $=$ one clock cycle
2. Non-pipelined mode (NP):
instruction cycle $=$ two clock cycles
When the processor works in the P-mode, the result of a basic operation (see section 3.1 on instruction set) is not always available after the first instruction cycle but sometimes one clock cycle later. Since the processor uses pipelining, a new operation can start before the result of the previous operation is available. When the processor operates in NP-mode, the result of a basic operation is always available at the end of an instruction cycle. On reset, the processor is placed in the P-mode. Mode switching is possible under program control by setting and resetting the FQR bit in the PST register using a MOVE or LOAD IMMEDIATE operation. The instruction after the one that caused the change in the FOR bit is executed in the new mode.

### 2.2.4 Instruction register (IR)

In every instruction cycle (i.e. every clock cycle when working in the P-mode and every two clock cycles when working in the NP-mode) an instruction word is fetched from the program memory. The program memory access and storing of the result in the instruction register (IR) takes one clock cycle. During the next clock cycle, the new contents of the IR is decoded and the processor controlled accordingly.

### 2.2.5 Stack

When an interrupt or subroutine call occurs, the value of PC (in the P-mode) or the value of PC+1 (in the NP-mode)
is placed on the stack. The stack is a $5 \times 10$-bit LIFO register file that allows automatic nesting up to five levels of subroutines and/or interrupts. The top of the stack containing the most recent PC value can be accessed via the data buses. This enables the programmer to extend the stack in the data memory.

### 2.2.6 Instruction repeat circuitry (RPR)

RPR is an 8 -bit register that can be loaded via the X-bus by a MOVE or LOAD IMMEDIATE operation. Only the 8 LSBs on the bus (representing a number N between 0 and 255) are loaded. The instruction after the one in which these 8 bits are loaded is then executed $N$ times as long as $2 \leqslant N \leqslant 255$. The execution count is undefined when $0 \leqslant N<2$. The execution count is also undefined when the instruction to be repeated is to load RPR or to load the PC.

### 2.2.7 Branch circuitry

The PCB5010 and PCB5011 make it possible to depart from the sequential program flow under software control. There are 4 branch types, and each branch can depend on any one of 50 different conditions.

The 4 branch types are:

- go to
- subroutine call
- return from subroutine
- return from interrupt.

The 50 branch conditions are the true and false status of the following flags or combination of flags:

- ALU flags: Z, N, C, $\overline{\text { C.OR.Z. }}, ~ V, V L$, \{N.XOR.V\}.OR.Z, N.XOR.V
- Accumulator flags: SGNM, OVFL
- Barrel-shifter flags: OOR, OORL
- ALU and barrel-shifter flags:

OORL.OR.VL

- ACU flags: ACA, ACB, ACR
- User flags: IFA, IFB, IFC, IFD, IFA.AND.IFB.AND.IFC.AND.IFD
- Serial I/O flags: SIXACK, SIYACK, SOXACK, SOYACK


### 2.2.8 The PST and IOF registers (PST, IOF, IFA - IFD pins)

PST and IOF are 16 -bit registers that contain all the flags. Furthermore, PST also contains a bit (EI) that indicates whether the interrupt is enable or not (enabled $=1$; disabled $=0$ ), a bit (FQR) indicating which mode ( $\mathrm{P}=0$ or $\mathrm{NP}=1$ ) the processor is working in, and two bits (PIO1 and PIO2) determining the input criteria for the parallel input. The meaning of each bit of PST and IOF is given below:

| bit | PST register | IOF register |  |  |
| :--- | :--- | :--- | :--- | :--- |
| 00 | OVFL | (accumulator flag) | SIXACK | (serial I/O flag) |
| 01 | OORL | (barrel-shifter flag) | SOXACK | (serial I/O flag) |
| 02 | VL | (ALU flag) | SIYACK | (serial I/O flag) |
| 03 | V | (ALU flag) | SOYACK | (serial I/O flag) |
| 04 | C | (ALU flag) | IFA | (user flag) |
| 05 | Z | (ALU flag) | IFB | (user flag) |
| 06 | N | (ALU flag) | IFC | (user flag) |
| 07 | OOR | (barrel-shifter flag) | IFD | (user flag) |
| 08 | SGNM | (accumulator flag) | reserved |  |
| 09 | ACA | (ACU flag) | reserved |  |
| 10 | ACB | (ACU flag) | reserved |  |
| 11 | ACR | (ACU flag) | reserved |  |
| 12 | PIO2 | (parallel I/O flag) | reserved |  |
| 13 | PIO1 | (parallel I/O flag) | reserved |  |
| 14 | EI | (interrupt enable/disable) | reserved |  |
| 15 | FQR | (operation mode) | reserved |  |

The flags in PST and IOF reflect the status of the functional units to which they belong and they are updated during each relevant instruction. The flags IFA, IFB, IFC and IFD reflect the signal level on their respective input pins. "Lock" type flags (OVFL, OORL and VL) can only be changed from 0 to 1 by the functional units to which they belong. The programmer can overrule the functional units updating the flags in the PST register: the PST register can be overwritten using a MOVE or LOAD IMMEDIATE operation. These operations are also used for loading the EI, FQR, PIO1 and PIO2 bits. Furthermore, the programmer can load the FQR bit using a MOVE or LOAD IMMEDIATE operation without changing the other bits in the PST register.

The PST and IOF register can be read using a MOVE operation. The flags can also be used as conditions in BRANCH operations (see section 2.2.7 on BRANCH circuitry). "Lock" type flags will automatically be reset to 0 when they are tested in a BRANCH operation.

### 2.2.9 Interrupt circuitry (INT and IACK pins, RX and RY)

The processor has an interrupt facility that the user can access via the INT and $\overline{\text { IACK }}$ pins. When an interrupt is accepted by the processor the program counter is loaded with address 1. The interrupt procedure is described below and the logic timing diagrams are given in Figures 2.2.9-1 and 2.2.9-2.

An interrupt is initiated by a LOW on the $\overline{\mathrm{INT}}$ pin. The first positive going edge of CLK after a HIGH to LOW transition on INT, the interrupt is clocked in by the processor. Two or three clock pulses later (see timing diagrams), the processor decides to accept the interrupt or postpone it. An interrupt is postponed:

- while the PC is being loaded (as part of a BRANCH, MOVE or LOAD IMMEDIATE operation)
- while the RPR register is loaded
- during instruction repetition
- when the stack is the source or destination to the X -bus
- when the interrupt is disabled by software (EI bit in PST register is 0 ).


Fig. 2.2.9-1 Interrupt logic timing in P-mode.


Note: The interrupt is postponed when one of the following conditions is true during instruction $\mathrm{N}+1$ :

- loading of PC (as part of BRANCH or MOVE operation)
- loading of RPR
- stack source or destination to X-bus
- repetition mechanism on
- interrupt disabled by $\mathrm{EI}=0$

Fig. 2.2.9-2 Interrupt logic timing in NP-mode.

As soon as the above situations are completed, the postponed interrupt is accepted and thereafter handled in the same way as an interrupt that was accepted directly.

Accepting the interrupt means pushing
the value of the PC (in P-mode) or PC+1 (NP-mode) on to the stack and loading the PC with address 1 . When the PC contains address 1 , the $\overline{\mathrm{IACK}}$ pin goes LOW for one clock cycle to indicate to the outside world that the interrupt has been acknowledged.

In the P-mode, the instruction in the pipeline that should have been executed is not executed while the PC contains address 1 even though the expected $X$ and $Y$-bus sources put their data on the buses. This data is stored in the bus-save register, RX and RY, that are automatically assigned as the destinations for the buses.

An interrupt routine is completed under program control using an RETI conditional BRANCH operation (see instruction set section 3.0). When the condition is true, PC is loaded with the address that was pushed onto the stack, and then the instruction at that address is executed. In the P -mode, however, RX and RY are used instead of the indicated X and Y -bus sources. Nested interrupts are permitted, but in the P-mode they are latched so long as the programmer has not stored the data in RX and RY elsewhere (i.e. so long as RX and RY have not been used as sources for the X and Y -buses). After returning from a nested interrupt in the P -mode, the old contents of RX and RY must be restored by the programmer.

Note: A new interrupt can onle be generated after the $\overline{\mathrm{NNT}}$ signal has been HIGH for at least one positive going edge on CLK.

### 2.2.10 Reset circuitry ( $\overline{\operatorname{RST}} \mathbf{~ p i n )}$

The processor is reset to an initial state when RST is LOW over at least 7 rising edges of CLK. A shorter reset may lead to an undefined situation.
The initial state is characterized by:

- PC : all zeros
- PST : all zeros
- IOF: SIXACK = SIYACK = 0 and SOXACK $=$ SOYACK $=1$
- RX, RY : all zeros
- STACK : all zeros $(5 \times 10)$
- RPR : instruction repeat mechanism off
- LPR : undefined STATE; STATE $=0$ in an instruction in which there is no MOVE or LOAD IMMEDIATE operation with PRAM as the destination
- MXL, MYL : all zeros

|  | - PR | : all zeros |
| :---: | :---: | :---: |
|  | - ACR | : all zeros |
|  | - BSR | : all zeros |
|  | $\begin{aligned} & -\mathrm{AAL}, \\ & \\ & \hline A B L \end{aligned}$ | : all zeros |
|  | ARA, <br> AA, SA | : all zeros |
|  | - ARB, |  |
|  | AB, SB ARR, | : all zeros |
|  | AR, SR | : all zeros |
|  | MA, |  |
|  | MB, MR | : undefined |
|  | PG | : all zeros |
|  | SIOST | : all zeros |
|  | SOX, |  |
|  | SOY | : all zeros |
|  | SIXRQ | $=$ SIYRQ $=0$ |
|  | SO | SOYR |

The logic timing of the reset is shown in Fig. 2.2.10-1.


1 - reset detection
2 - reset of all registers and latches mentioned above (excluding ACR), and "top of stack", serial I/O request signals, and PR
3 - reset of ACR and 2nd stack position
4 - reset of 3rd stack position
5 - reset of 4th stack position
6 - reset of 5th stack position
7 - reset of 6th stack position (note: this stack position must not be used, otherwise it may lead to an undefined state).

Fig. 2.2.10-1
The complete reset action.

### 2.2.11 Synchronization circuitry (SYNC pin)

The processor indicates where execution of a new instruction starts with a HIGH at the SYNC pin for half a clock cycle. This occurs once every two clock cycles in the NP-mode, and once every clock cycle in the P -mode. However, in the $P$-mode it will not occur when the program counter is loaded with a new address during the execution of a BRANCH operation, a MOVE operation, an interrupt, or a reset.

### 2.3 DATA MEMORIES AND ACU'S

### 2.3.1 Data memories

The processor contains 3 on-chip data memories:

- RAMA: $128 \times 16$ bits, static
- RAMB: $128 \times 16$ bits, static
- ROM : $512 \times 16$ bits (only on PCB5010, external for PCB5011)
It is also possible to connect up to 64 K of external data memory via the parallel I/O.

Memory outputs are connected to the data registers (DRA, DRB and DRR) and the parallel data input register PI. DRA, DRB and DRR are updated every instruction cycle, but in the P-mode, DRA and DRB are not updated when in that instruction cycle, data is moved (from one of the buses) into RAMA or RAMB. Updating PI is described in the section 2.6 on the parallel I/O. Data written into the data registers and PI can be transferred via the X or Y -bus during a subsequent instruction.

RAMA can be written-to via the X-bus, RAMB can be written-to via the Y -bus and, external RAM can be written-to via either bus.

With the PCB5011, it is not only possible to read from an external ROM, but in place of the read, it is also possible to write-to an external $512 \times 16$-bit memory because the port is bidirectional, and therefore can be used as a second parallel I/O port.

### 2.3.2 ACUs and PG register

The 3 address computation units, ACUA, ACUB and ACUR, function identically but, their address widths differ: 12, 8 and 9 bits respectively. ACUs calculate the addresses for the on-chip RAMs (only the 7 least significant address bits are used for this addressing) and data ROM. ACUA not only generates the address for RAMA but also the part of the address for
external data memory that defines the position within a page of $4096 \times 16$ words. It is possible to have 16 pages of external data memory. Pages are selected using the address pins A12 to A15 that reflect the contents of the page register PG that is loaded using a MOVE or LOAD IMMEDIATE operation.

Fig. 2.3.2-1 illustrates the memory addressing.


Fig. 2.3.2-1 Memory addressing.

## An ACU contains:

- an address register AR (which addresses the ROM respectively RAM's)
- a base address register $A$
- an offset register S
- an address masking register M
- a dedicated arithmetic unit

Only the AR registers (ARR, ARB and ARA) are shown in Figs 2.1-1 and 2.1-2. The $A, S$ and $M$ registers of RAMA, RAMB and the ROM (AA/BA/RA, $A S / B S / R S$ and $A M / B M / R M$ ) are not shown.
The $A, S, M$ and $A R$ registers can be loaded directly (for initialization) via one of the data buses ( X -bus for ACUB registers and Y -bus for ACUA and ACUR registers) using a MOVE or LOAD IMMEDIATE operation or they can be modified during address computation operations. Direct loading and address computation cannot take place simultaneously (see the section 3.0 on the instruction set).

Direct loading offers the following options:

- Load AR with value on the bus
- Load $A R$ and $A$ with value on the bus
- Load $A R$ and $S$ with value on the bus
- Load A with value on the bus
- Load $S$ with value on the bus
- Load $M$ with value on the bus
- Load AR, A and S with value on the bus
- Load AR with (value on the bus) !M

The notation !M means that, depending on the contents of the $M$ register, all bits are not necessarily updated as the expression indicates:

- the bits whose corresponding bits in the $M$ register are 1 are updated as specified in the expression
- the bits whose corresponding bits in the $M$ register are 0 will retain their value (for AR) or will receive the previous value of their AR bit (for A and S).
The notation br(. . .) means that the bits are reversed in order.

Three flags in the PST register indicate the status of the 3 ACU's:

- ACA - ACUA flag
is 1 when AR contains 00000000 0000;
is 0 when $A R$ does not contain 000000000000
- ACB - ACUB flag is 1 when $A R$ contains 0000 0000; is 0 when AR does not contain 00000000
- ACR - ACUR flag is 1 when $A R$ contains 00000 0000;
is 0 when AR does not contain 000000000


### 2.4 MULTIPLIER, ACCUMULATOR, BARREL-SHIFTER AND FORMAT-ADJUSTER UNIT

### 2.4.1 Multiplier

The multiplier performs a multiplication of two signed 16 bits operands $P$ and Q presented in 2 's complement notation. The result is presented by 32 bits in 2 's complement notation and stored in the product result latch PR.

One of the following values can be chosen as P -operand:

- The value present on the X -bus
- The previous value which was automatically latched in the MXL latch
- The number - 1

One of the following values can be chosen as Q -operand:

- The value present on the $Y$-bus
- The previous value which was automatically latched in the MYL latch
- The negated $Y$-bus value

Note: when the Y -bus contains the highest negative value, $-2^{15}$ (1000 000000000000 in binary) then the operand will be the highest positive value plus one, $+2^{15}$ (1 0000000000000000 in binary). This number is stored in MYL which has a width of 17 bits for this particular situation.

The contents of $M X L, M Y L$ and $P R$ are not changed when no MULTIPLY operation or a multiply HOLD operation is executed.

### 2.4.2 Accumulator

The accumulator unit consists of a 40 bit adder ACC, a 40 bit multiplication/ accumulation register ACR and a sign and scale down block S/SD. The adder adds the in PR stored result of the multiplication to a second operand (provided by the S/SD block) which can be chosen from the following set:

-     + or - the contents of ACR
-     + or - the contents of ACR divided by $2^{15}$ (which allows multiprecision multiplication and addition)
- the number 0

The result of the addition is stored in ACR and is fed simultaneously to the barrel-shifter. The contents of the ACR register are not changed when no MULTIPLY operation is performed or a multiply HOLD operation is executed.

The 40 -bit width of the accumulator allows the programmer to accumulate a number of multiplier results (at least 256) without the risk of overflow. Two flags in the PST register indicate the status of the accumulator:

- OVFL-overflow lock flag; this flag is set when overflow occurs in the adder (result outside the range $-2^{39}$ to $+2^{39}-1$ ).
For reset conditions see description of PST register (section 2.2.8).
- SGNM - sign flag; indicates the sign of the result of the addition (is identical to bit ACR(39)).


### 2.4.3 Barrel-shifter

From the 40 -bit ACR contents, the barrel-shifter extracts 32 contiguous bits. The programmer determines which group of 32 bits is extracted by a value placed in the BSR register (bits BSR3 to BSRO).
Sixteen different sets are possible:

| BSR contents BSR3-BSRO | 32-bit word, E31-E0, extracted by the barrel-shifter |
| :---: | :---: |
| 0000 | ACR30, . . . . , ACRO,0 |
| 0001 | ACR31, .... , ACRO |
| 0010 | ACR32, . . . , ACR1 |
| 0011 | ACR33, . . . . ACR2 |
| 0100 | ACR34, .... , ACR3 |
| 0101 | ACR35, . . . . ACR4 |
| 0110 | ACR36, . . . . ACR5 |
| 0111 | ACR37, . . . , ACR6 |
| 1000 | ACR38, . . . . ACR7 |
| 1001 | ACR39, ... . ACR8 |
| 1010 | ACR39,ACR39, . . . . ACR9 |
| 1011 | ACR39,ACR39,ACR39, . . . . ACR10 |
| 1100 | ACR39,ACR39,ACR39,ACR39, . . . , ACR11 |
| 1111 | ACR39,ACR39,ACR39,ACR39,ACR39, . . . , ACR 12 |
| 1111 | ACR39,ACR39,ACR39,ACR39,ACR39,ACR39, . . . , ACR13 |
| 1111 | ACR39,ACR39,ACR39,ACR39,ACR39,ACR39,ACR39, ...,ACR14 |

Two flags in the PST register indicate the status of the barrel-shifter:

- OOR - Out of range flag. It is set when the sign bit of the extracted word E31-EO has no significance. This occurs when one or more bits of ACR to the left of the extracted word differs from E31.
- OORL - Out of range lock flag. The conditions for setting are identical to those of OOR. The conditions for resetting are given in the section describing the PST register.


### 2.4.4 Format adjuster

The output E31-E0 of the barrel-shifter is split into a 16 -bit most significant part MSP and a 16 -bit least significant part LSP'. MSP can be connected directly to the $X$ and/or $Y$ bus. LSP' passes through a format adjuster (FA) before it reaches the X or Y bus. The output of FA is called LSP. Under software control, three FA options can be selected by placing a value in the BSR register (bits BSR5 to BSR4). The options are:

| BSR contents <br> BSR5-BSR4 | output LSP of format adjuster |
| :--- | :--- |
| 00 | E15-E0 (no change) <br> E0-E15 (bits reversed in order, used to speed-up certain serial <br> outputs) <br> $0, E 15-E 1$ (bits shifted right over 1 position, left adjusted with zero; <br> used for multi-precision multiplications) <br> reversed/undefined |
| 10 |  |

### 2.4.5 Barrel-shifter register (BSR)

BSR is a 6 -bit register. Its contents control the barrel-shifter (bit 0-3) and the format adjuster (bit 4-5) as explained in the previous sections. BSR can be loaded by means of a MOVE or LOAD IMMEDIATE operation. Loading has to be done at least one instruction before LSP or MSP is read to the X or Y-bus.

### 2.5 ALU AND REGISTER FILE

### 2.5.1 ALU

The PCB5010/11 has an ALU totally independent from the multiplier/ accumulator unit. It is a 16 -bit, 2 -operand unit capable of executing 31 distinct operations. There are arithmetic, logic and some special purpose operations. The arithmetic operations defined as "extended" (mnemonic starts with X ) are included to facilitate multi-precision operations. Extended operands are represented by 16 -bit multiples.

An ALU operation produces a result $R$ that may be stored in the register file or may be ignored (dumped in the trash can)

Several flags in the PST register give the status of the ALU. The flags are:
Z - Zero flag
N - Negative flag
C - Carry flag
V - Overflow flag
VL - Overflow lock flag (same as V but locked; see PST register description, section 2.2.8).

One of the following values can be chosen as A-operand

- the value on the $X$-bus
- the value on the $Y$-bus
- the previous value which was automatically latched in the AAL-latch (this is not the case with the "byte swap" instruction).

One of the following values can be chosen as B-operand:

- the value on the $Y$-bus
- the previous value which was automatically latched in the ABL-latch

Dyadic operations require an $A$ and B-operand, while monadic operations require only an A-operand. Some operations do not require an operand at all.

The ALU operations and their result $R$ and flag settings are summed up in the following three tables:
A: Arithmetic operations
B: Logic operations
C: Other operations

The following notation is used:

- ZERO(R) $\quad-0$ (when not all 16 bits of $R$ are 0 )
- 1 (when all 16 bits of $R$ are 0 )
- $\operatorname{CARRY}(F) \quad-0$ (when a function $F$ does not lead to a carry)
- 1 (when a function $F$ leads to a carry)

Note: For this calculation, the operands are unsigned 16 -bit numbers from 0 to 65535 . The carry is 1 when the result of the addition is greater than 0. In all other cases the carry is 0 .

- BORROW(F) - 0 (when a function $F$ does not lead to a borrow)
- 1 (when a function $F$ leads to a borrow)

Note: For this calculation, the operands are unsigned 16 -bit numbers from 0 to 65535 . The borrow is 1 when the result of the subtraction is below 0 . In all other cases the borrow is 0 .

- OVERFLOW(F) - 0 (when a function $F$ foes not lead to an overflow)
- 1 (when a function $F$ leads to an overflow)

Note: For this calculation, the operands are signed 16 -bit numbers between $-2^{15}$ and $2^{15}-1$. The overflow is 1 when the result of the calculation is outside this range. In all other cases the overflow is 0 .
$R(i)$

- Bit i of the 16 -bit word R.


## A: Arithmetic operations (see table on next page)

For the calculation of result $R$, the operands $A$ and $B$ are considered to be binary numbers in 2 's complement notation (between $-2^{15}$ and $+2^{15}-1$ ). $R$ is also a binary number in 2's complement notation. However, with the DIV operation, the operands and the result are unsigned numbers (between 0 and 65535).

## A: Arithmetic operations

| function | mnemonic | result (R) | flags |  |  |  | condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Z | N | C | V |  |
| addition | ADD | $\begin{aligned} & A+B \\ & A+B-2^{16} \\ & A+B+2^{16} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \\ & \text { ZERO(R) } \\ & \hline \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \\ & R(15) \\ & \hline \end{aligned}$ | CARRY $(A+B)$ CARRY $(A+B)$ CARRY $(A+B)$ | OVERFLOW(A+B) OVERFLOW $(A+B)$ OVERFLOW $(A+B)$ | no overflow positive overflow negative overflow |
| extended addition | XADD | $\begin{aligned} & A+B+C \\ & A+B+C-2(16) \\ & A+B+C+2(16) \end{aligned}$ | ZERO(R).AND.Z ZERO(R).AND.Z ZERO(R).AND.Z | $\begin{aligned} & R(15) \\ & R(15) \\ & R(15) \end{aligned}$ | $\begin{aligned} & \text { CARRY }(A+B+C) \\ & \text { CARRY }(A+B+C) \\ & \text { CARRY }(A+B+C) \end{aligned}$ | OVERFLOW ( $A+B+C$ ) OVERFLOW $(\mathrm{A}+\mathrm{B}+\mathrm{C})$ OVERFLOW $(A+B+C)$ | no overflow positive overflow negative overflow |
| subtraction | SUB | $\begin{aligned} & A-B \\ & A-B-2^{16} \\ & A-B+2^{16} \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \\ & R(15) \end{aligned}$ | BORROW $(A-B)$ <br> BORROW(A-B) <br> BORROW (A-B) | OVERFLOW (A-B) OVERFLOW $(A-B)$ OVERFLOW $(A-B)$ | no overflow positive overflow negative overflow |
| extended subtraction | XSUB | $\begin{aligned} & A-B-C \\ & A-B-C-2^{16} \\ & A-B-C+2^{16} \end{aligned}$ | ZERO(R).AND.Z ZERO(R).AND.Z ZERO(R).AND.Z | $\begin{aligned} & R(15) \\ & R(15) \\ & R(15) \\ & \hline \end{aligned}$ | BORROW(A-B-C) BORROW(A-B-C) <br> BORROW(A-B-C) | OVERFLOW (A-B-C) OVERFLOW(A-B-C) OVERFLOW $(A-B-C)$ | no overflow positive overflow negative overflow |
| conditional subtraction | CSUB | A | ZERO(R) | R(15) | 0 | 0 | If $\mathrm{N}=1$, same as SUB |
| negate | NEG | $\begin{aligned} & 0-A \\ & A \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | BORROW(0-A) <br> BORROW (0-A) | OVERFLOW (0-A) OVERFLOW (O-A) | $\begin{aligned} & A \neq-2^{15} \\ & A=-2^{15} \end{aligned}$ |
| extended negate | XNEG | $\begin{aligned} & 0-A-C \\ & A \end{aligned}$ | ZERO(R).AND.Z ZERO(R).AND.Z | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | BORROW(0-A-C) BORROW (0-A-C) | OVERFLOW (0-A-C) OVERFLOW(0-A-C) | $\begin{aligned} & A \neq-2^{15} \cdot \text { OR.C }=1 \\ & A=-2^{15} \cdot A N D \cdot C=0 \end{aligned}$ |
| conditional negate | CNEG | A | ZERO(R) | R(15) | 0 | 0 |  |
| decrement | DEC | $\begin{aligned} & A-1 \\ & 2^{15}-1 \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | BORROW (A-1) <br> BORROW $(A-1)$ | OVERFLOW (A-1) OVERFLOW (A-1) | $\begin{aligned} & A \neq-2^{15} \\ & A=-2^{15} \end{aligned}$ |
| extended decrement | XDEC | $\begin{aligned} & A-C \\ & 2^{15}-1 \end{aligned}$ | ZERO(R).AND.Z ZERO(R).AND.Z | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | BORROW(A-C) <br> BORROW(A-C) | OVERFLOW(A-C) <br> OVERFLOW(A-C) | $\begin{aligned} & A \neq-2^{15} \cdot O R \cdot C=0 \\ & A=-2^{15} \cdot A N D \cdot C=1 \end{aligned}$ |
| increment | INC | $\begin{aligned} & \mathrm{A}+1 \\ & -2^{15} \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | $\begin{aligned} & \operatorname{CARRY}(A+1) \\ & \operatorname{CARRY}(A+1) \end{aligned}$ | OVERFLOW $(A+1)$ OVERFLOW $(\mathrm{A}+1)$ | $\begin{aligned} & A \neq 2^{15}-1 \\ & A=2^{15}-1 \end{aligned}$ |
| extended increment | XINC | $\begin{aligned} & A+C \\ & -2^{15} \end{aligned}$ | ZERO(R).AND.Z ZERO(R).AND.Z | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | $\begin{aligned} & \text { CARRY }(A+C) \\ & \text { CARRY }(A+C) \end{aligned}$ | OVERFLOW(A+C) <br> OVERFLOW $(A+C)$ | $\begin{aligned} & A \neq 2^{15}-1 . O R . C=0 \\ & A=2^{15}-1 . A N D \cdot C=1 \end{aligned}$ |
| arithmetic shift left | ASL | $\begin{aligned} & 2^{*} \mathrm{~A} \\ & 2^{*} \mathrm{~A}-2^{16} \\ & 2^{*} \mathrm{~A}+2^{16} \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \\ & R(15) \end{aligned}$ | $\begin{aligned} & \text { CARRY }(A+A) \\ & \text { CARRY }(A+A) \\ & \text { CARRY }(A+A) \end{aligned}$ | $\begin{aligned} & \text { OVERFLOW }(A+A) \\ & \text { OVERFLOW }(A+A) \\ & \text { OVERFLOW }(A+A) \end{aligned}$ | $\begin{aligned} & -2^{14}<A<2^{14} \\ & A \geqslant 2^{14} A \\ & A<-2^{14} \end{aligned}$ |
| extended arithmetic shift left | XASL | $\begin{aligned} & 2^{*} A+C \\ & 2^{*} A+C-2^{16} \\ & 2^{*} A+C+2^{16} \end{aligned}$ | $\begin{aligned} & \text { ZERO(R).AND.Z } \\ & \text { ZERO(R).AND.Z } \\ & \text { ZERO(R).AND.Z } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \\ & R(15) \end{aligned}$ | $\begin{aligned} & \text { CARRY }(A+A) \\ & \text { CARRY }(A+A) \\ & \operatorname{CARRY}(A+A) \end{aligned}$ | $\begin{aligned} & \text { OVERFLOW }(A+A) \\ & \text { OVERFLOW } A+A) \\ & \text { OVERFLOW }(A+A) \end{aligned}$ | $\begin{aligned} & -2^{14}<A<2^{14} \\ & A \geqslant 2^{14} \\ & A<-2^{14} \end{aligned}$ |
| arithmetic shift right | ASR | A/2-fraction | ZERO(R) | R(15) | 1(0) | 0 |  |
| extended arithmetic shift right | XASR | A/2-fraction <br> A/2-fraction-2 $2^{15}$ <br> A/2-fraction $+2^{15}$ | ZERO(R).AND.Z ZERO(R).AND. $Z$ ZERO(R).AND.Z | $\begin{aligned} & N \\ & N \\ & N \end{aligned}$ | $\begin{aligned} & \mathrm{A}(0) \\ & \mathrm{A}(0) \\ & \mathrm{A}(0) \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { MSB of } A=C \\ & \text { MSB of } A=0 \cdot A N D \cdot C=1 \\ & \text { MSB of } A=1 \cdot A N D \cdot C=0 \end{aligned}$ |

## A: Arithmetic operations (Cont'd)

| function | mnemonic | result (R) | flags |  |  |  | condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | z | $N$ | C | V |  |
| add MSB of $B$ to $A$ | ADDM | $\begin{aligned} & A+B(15) \\ & A+B(15)-2^{16} \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { ZERO(R) } \\ \text { ZERO(R) } \end{array}$ | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | $\operatorname{CARRY}(A+B(15))$ <br> $\operatorname{CARRY}(A+B(15))$ | OVERFLOW(A+B(15)) OVERFLOW( $A+B(15))$ | $\begin{aligned} & A+B(15)<2^{15} \\ & A+B(15)=2^{15} \end{aligned}$ |
| unsigned division | DIV | $\begin{aligned} & 2^{*}(A-B) \\ & 2^{*} A \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \end{aligned}$ | $\frac{\overline{B O R R O W}(\mathrm{~A}-\mathrm{B})}{\mathrm{BORROW}(\mathrm{~A}-\mathrm{B})}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \leqslant A-B<2^{15} \\ & A-B<0 \text { or } A-B>2^{15} \end{aligned}$ |
| sign extension | XSGN | NN . . . N | Z.AND.NOT.N | N | N | V |  |

## B: Logic operations

For the calculation of result $R$, the operands $A$ and $B$ are considered to be 16 -bit binary words. $R$ is also a 16 -bit binary word.

| function | mnemonic | result (R) | flags |  |  |  | condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | z | N | c | v |  |
| compare | COM | .NOT.A(i) |  | R(15) | 0 | 0 | for $\mathrm{i}=0 \ldots 15$ |
| logic AND | AND | A(i).AND.B(i) | ZERO(R) | R(15) | 0 | 0 | for $\mathrm{i}=0 \ldots 15$ |
| logic OR | OR | A(i).OR.B(i) | ZERO(R) | R(15) | 0 | 0 | for $\mathrm{i}=0 \ldots 15$ |
| exclusive OR | EXOR | A(i).EXOR.B(i) | ZERO(R) | R(15) | 0 | 0 | for $\mathrm{i}=0 . .15$ |
| byte swap | SWAP | $\begin{aligned} & \mathrm{A}(\mathrm{i}+8) \\ & \mathrm{A}(\mathrm{i}-8) \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & R(15) \\ & R(15) \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{array}{\|l\|l\|} 0 \\ 0 \end{array}$ | $\begin{aligned} & \text { for } i=0 \ldots 7 \\ & \text { for } i=8 \ldots 15 \end{aligned}$ |
| logic shift left | LSL | $\begin{aligned} & A(i-1) \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & A(14) \\ & A(14) \end{aligned}$ | $\begin{array}{\|l} A(15) \\ A(15) \end{array}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { for } i=1 \ldots 15 \\ & \text { for } i=0 \end{aligned}$ |
| logic rotate left | LROL | $\begin{aligned} & A(i-1) \\ & C \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & \mathrm{A}(14) \\ & \mathrm{A}(14) \end{aligned}$ | $\begin{aligned} & A(15) \\ & A(15) \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { for } i=1 \ldots 15 \\ & \text { for } i=0 \end{aligned}$ |
| logic shift right | LSR | $\begin{aligned} & A(i+1) \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & A(0) \\ & A(0) \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { for } i=0 \ldots 14 \\ & \text { for } i=5 \end{aligned}$ |
| logic rotate right | LROR | $\begin{aligned} & A(i+1) \\ & C \end{aligned}$ | $\begin{aligned} & \text { ZERO(R) } \\ & \text { ZERO(R) } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & A(0) \\ & A(0) \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { for } i=0 \ldots 14 \\ & \text { for } i=5 \end{aligned}$ |

## C: Other operations

| function | mnemonic | result (R) | flags |  |  |  | condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  | Z | N | C | V |  |
| pass and flag update | PASS | A | ZERO(A) | A(15) | 0 | 0 |  |
| generate 0 | NULL | 0 | 1 | 0 | 0 | 0 |  |
| no operation | - | - | Z | N | C | V |  |

### 2.5.2 Register file

The output of the ALU is connected to the register file. This register file contains fifteen 16 -bit registers. The programmer can choose to which register the ALU result is written and also has the option of discarding the result by writing it to the trash can.

The contents of any register may be read to either or both of the buses. Moreover, the register file is implemented as a 3 -port memory, so that in the same instruction cycle three registers can be accessed: two accesses to read the present contents of register(s) and one to write in a new value.

The register file can be filled directly from the buses by a MOVE or LOAD IMMEDIATE operation. This does not affect the ALU flags. ALU operations cannot be specified simultaneously with the aforementioned MOVE operation.

### 2.6 PARALLEL I/O

Via the D15 - D0 pins, the PCB5010/11 permits parallel communication between the X or Y -bus and the outside world. An input ot output can take place during each instruction cycle. Output occurs when data is transferred via the X or Y -bus with destination PO. The output is direct, there is no latching. Inputs are loaded into the parallel input latch PI , whose contents can be transferred via the X or Y -bus during a subsequent instruction. The programmer can select one of three input criteria by writing specified values into PST bits, PIO1 and PIO2;

The following control signals are associated with the parallel I/O (see timing in section 4):
$-\mathrm{R} / \overline{\mathrm{W}}$ : indicates a read or write action (output)

- $\overline{\mathrm{DS}}$ : data strobe (output)
- WAIT: signals for synchronization of the parallet I/O (input). This signal delays the internal clock, so that "slow" peripheral devices may be connected. Note: that $\overline{\text { WAIT }}$ signal can also be used with the second parallel I/O port in the PCB5011 (see section 2.3.1).

A block diagram of the parallel $1 / 0$ circuitry is shown in Fig. 2.6-1.


Fig. 2.6-1 Parallel I/O circuitry.

| PIO1 | PIO2 |  |
| :--- | :--- | :--- |
| 0 | 0 | A read action is performed each instruction cycle <br> A read action is performed only when: <br> - ACUA is not executing a "no operation", or when <br> - PI latch is source to $X$ or Y-bus |
| 1 | 0 | A read action is performed only when: <br> - PI latch is source to $X$ or Y-bus <br> Reserved |
| 1 | 1 |  |

Note: a read is only performed when there is no write (MOVE or LOAD IMMEDIATE operation to PO).

### 2.7 SERIAL I/O

The PCB5010/11 has 2 independent serial inputs DIX and DIY and 2 independent serial outputs DOX and DOY (destinations and sources for X and Y -bus respectively). Actual transfer occurs, with a maximum speed of 4 million bits/s, under the control of clocks CIX, COX, CIY, and COY from external devices.

The following handshake signals, described in more detail in the following sections, are associated with the serial I/O: - input/output enable SIXEN, $\overline{\text { SOXEN}, ~ S I Y E N ~ a n d ~ S O Y E N ~}$ (input signals)

- input/output request $\overline{\text { SIXRQ }}, \overline{\text { SOXRQ }}, \overline{\text { SIYRO }}$ and $\overline{\text { SOYRO (output signals) }}$

The following flags, whose functions are also described in the following sections, are associated with the serial I/O:

- serial I/O acknowledge flags SIXACK, SOXACK, SIYACK and SOYACK.

The programmer may control the length of the words to be transferred (between 1 and 16 bits) by writing the applicable values in the SIOST register fields:


SILX = length of serial input word with destination X-bus SOLX = length of serial output word with source X-bus SILY = length of serial input word with destination Y -bus SOLY = length of serial output word with source $Y$-bus

The binary number in each field specifies the length; the code 0000 indicates a length of 16 bits.

### 2.7.1 Serial input procedure

The serial input procedure, as illustrated in the flow diagram in Fig. 2.7.1-1, is described below. A detailed block diagram of the serial input circuitry (Fig. 2.7.1-2) is needed to understand the procedure.

Note: Only the serial input via the DIX pin is described since the serial input via the DIY pin operates in the same way.

1. At reset, the SIXACK flag is reset to ' 0 ' indicating that no word has been received in the SIX latch awaiting transfer via the X -bus.
2. The $\overline{\text { SIXRO }}$ signal is reset to ' 0 ', indicating to external devices that they are allowed to send new data.
3. Nothing happens until the external device enables the serial input by setting the input signal $\overline{\mathrm{SIXEN}}$ to ' 0 '. This is checked only on the rising edge of the incoming clock signal CIX.
$\overline{\text { SIXEN }}$ equal to ' 0 ', results in the shifting in of the first bit (LSB) available via the DIX pin. Then an internal counter COUNT is set to one less than the word-length. The word-length information is taken from the SILX field of the SIOST register.
4. At the next rising edge of the incoming clock signal CIX , the contents of COUNT is tested. When the contents of the counter is zero, data input is finished (continue at step 5). If it does not contain zero the data input continues as long as the SIXEN signal is ' 0 ': COUNT is decremented and a bit is shifted in via the DIX pin. Step 4 is then repeated. When the SIXEN signal is one, the data input is finished (aborted) and the procedure continues with step 5.
5. After finishing data input, the content of the shift register SIXS is copied to latch SIX. When less than 16 bits have been received the word is placed in the most significant part of SIX and the remaining bits are set to ' 0 '. Also, the SIXACK flag is set to 1 indicating that a word has been received and is awaiting transfer via the X-bus.

This copying and flag setting however does not occur when the SIXACK flag is not ' 0 ' (indicating that the previous input has not been transferred via the X-bus; note that the first time after reset or power up SIXACK is always 0 ). The $\overline{\text { SIXRO }}$ signal is set to one, indicating to external devices that they are not allowed to send new data.

After SIXACK has become ' 0 ' (this is tested only at rising edges of the CIX clock signal) the copying and flag setting finally takes place. The procedure continues with step 2.

Note: After changing the contents of the SILX and SILY fields of the SIOST register (which means: changing the word-length) the contents of SIX and SIY are undefined.


* SIXACK goes to 0 when SIX is the source on the X -bus.
** When less than 16 -bits have been received, the word is placed in the most significant part of SIX and the remaining bits are set to 0 .
- This point is only passed when a rising edge on CIX occurs.

Fig. 2.7.1-1 Serial input procedure.


Fig. 2.7.1-2 Serial input circuitry.

### 2.7.2 Serial output procedures

The serial output procedure, as illustrated in the flow diagram in Fig. 2.7.2-1 is described below. A detailed block diagram of the serial output circuitry (Fig. 2.7.2-2) is needed to understand the procedure.
Note: Only the serial output via the DOX pin is described; the serial output via the DOY pin operates in the same way.

1. At reset, the SOXACK flag is set to ' 1 ', indicating that a word may be transferred via the X-bus to the SOX latch.
2. The $\overline{\text { SOXRO }}$ output signal is set to ' 1 ' indicating to the external devices that there is no data available to be clocked out. The procedure is suspended until the first falling edge of incoming clock signal COX.
3. When the SOXACK flag is not ' 0 ' (then no data has been transferred via the X-bus to the SOX latch), step 2 is repeated. When SOXACK is ' 0 ' (data has been transferred via the X-bus to the SOX latch), the data in the SOX latch is copied to the SOXS output shift register. The first bit (LSB) of the word that must be shifted out is placed in front of the output 3 -state driver.
Then the SOXRO output signal is set to ' 0 ' indicating to the external devices that data is available to be clocked out.

Also, the SOXACK flag is set to one to indicate that a new data word may be transferred via the X-bus to the SOX latch. Finally, an internal counter is loaded with a value one less than the word-length. The word-length information is taken from the SOXL field of the SIOST register.
The procedure is now suspended until the next falling edge of the incoming clock signal COX.
4. When the word-length is 1 (then the count is 0 ), the output procedure is finished. One bit words can be read by external devices that set the SOXEN signal to ' 0 ' which enables the 3 -state output buffer. In this case, the procedure continues with step 3 . It is important to note that SOXS can be overwritten before the bit has been read by the external devices.
When the word-length is greater than 1 (then count is not equal to zero) the output procedure is not finished.
The procedure is suspended until one of the external devices enables the serial output by setting the input signal SOXEN to ' 0 '. The first bit is available on the DOX pin immediately after the serial output is enabled.
5. Nothing happens until a falling edge on the clock input COX is generated. At that moment another bit in the SOXS shift-register is shifted out via DOX. In addition, the contents of the counter is decremented. The output is finished when the counter contents has been decremented to zero (continue at step 3).
If after decrementing, the counter value is not zero, the output continues by repeating step 5 unless $\overline{\text { SOXEN }}$ is now ' 1 '. When SOXEN $=1$, the output is finished (aborted) and the procedure continues at step 3.


Fig. 2.7.2-2 Serial output circuitry.

## Single-chip digital signal processor

### 2.8 DATA BUSES X AND Y

The data buses have a width of 16 -bits and are used for transferring data between the functional units connected to them. Bus transfers are always part of MOVE and LOAD

IMMEDIATE operations and can be part op MPY and ALU operations. The possible sources and destinations of the bus are given in the table below.

| source on $X$ | destination on $X$ | source on Y | destination on $Y$ |
| :---: | :---: | :---: | :---: |
| STACK | STACK |  |  |
| RX | RX | RY | RY |
|  | PC |  |  |
|  | RPR |  |  |
| IOF |  |  |  |
| IR(DATA field) |  | IR(DATA field) |  |
| PST | PST | PST |  |
|  | FQR |  |  |
| $\begin{aligned} & \text { DRA } \\ & \text { DRB } \\ & \text { DRR } \end{aligned}$ |  | $\begin{aligned} & \text { DRA } \\ & \text { DRB } \\ & \text { DRR } \\ & \hline \end{aligned}$ |  |
|  | RAMA |  | RAMB |
| ARB |  | ARA <br> ARR |  |
|  | ACUB |  | $\begin{aligned} & \text { ACUA } \\ & \text { ACUR } \end{aligned}$ |
|  |  | PG | PG |
|  | ILX |  | ILY |
| $\begin{aligned} & \text { LSP } \\ & \text { MSP } \end{aligned}$ |  | $\begin{aligned} & \text { LSP } \\ & \text { MSP } \end{aligned}$ |  |
|  |  | BSR | BSR |
| RFILE | RFILE | RFILE | RFILE |
|  | ILA |  | $\begin{aligned} & \text { ILA } \\ & \text { ILB } \end{aligned}$ |
| PI | PO | PI | PO |
| SIOST | SIOST |  |  |
| $\begin{aligned} & \text { six } \\ & \text { sox } \end{aligned}$ | SOX | $\begin{aligned} & \text { SIY } \\ & \text { SOY } \end{aligned}$ | SOY |

Note 1: FQR is loaded by putting the required value ( 0 or 1 ) in bit 13 of the 16 -bit word that is sent. The other bits are 'don't cares'.
Note 2: When the source or destination has a width of less
than 16 bits, only the least significant bits on the bus (same width) contain information.
Note 3: ILX and ILY select the operands for the multiplier; ILA and ILB select the operands for the ALU.

### 3.0 INSTRUCTION SET

The behaviour of the processor is controlled by the instructions stored in on-chip ROM (PCB5010) or external program memory (PCB5011). Each instruction leads to the execution of one or more (up to 6) basic operations. The basic operations, the instruction format and the instruction fields are described in the following sections.

### 3.1 BASIC OPERATIONS

The execution of a basic operation can take either 1 or 2 clock cycles. This means that:

- for 2 cycle basic operations pipelining is used in the $P$-mode
- a 1 cycle operation is extended by a second "no action" cycle when the processor is operating in the NP-mode.

Basic operation sequencing is shown in Fig. 3.1-1 for the P-mode, and Fig. 3.1-2 for the NP-mode. There are 6 different basic operations which are described below.

- ALU operation (1 clock cycle)

One of 31 different ALU operations is executed. The operations need 2, 1 or 0 operands. The operation's result is stored in the register file or thrown away (into the trash can). In addition, a number of flags are updated.

- MOVE operation (1 clock cycle)

Data from an X -bus ( Y -bus) source is transferred via the X -bus ( Y -bus) to an X -bus ( Y -bus) destination. In the case that both buses have the same destination no transfer takes place.

- ACU (address computation and memory access) operation (2 clock cycles)


## Clock cycle 1:

An address is calculated by the ACU and written into an address register (ARA, ARB, or ARR).

Clock cycle 2:
RAMA, RAMB, ROM or external memory is accessed at the location given by the address register (ARA, ARB, or ARR). This access is normally a read which updates one of the data registers (DRA, DRB, DRR, or PI). If in the P-mode, however, the relevant RAM (RAMA, RAMB or external RAM) is assigned as a destination during a MOVE executed in parallel, the access will be a write. The result in this case is that the RAM is updated.

- MPY (multiply/accumulate) operation (2 clock cycles)

Clock cycle 1:
Two operands are multiplied together and the result stored in the PR latch.

Clock cycle 2:
The content of PR is added to the output of S/SD and stored in the ACR.

Note 1: The content of the ACR is accessed via the barrel-shifter and format-adjuster so that it can be transferred on the X or Y -bus during the clock cycle following ACR loading. The buses are selected by specifying LSP and/or MSP as the source for the X or Y -bus.

Note 2: The explanation of the MPY operation is a simplified presentation of what really happens. In fact, clock cycle 1 is not just used for multiplication, but part of the accumulation as well: i.e. accumulation of the lower part of the multiplier result and the contents of the accumulator. Therefore, in the P -mode, an MPY with +ACRS or -ACRS in the MPY field (see section 3.3 on description of MPY field) that directly follows another MPY operation leads to an undefined situation where the higher part of the first multiplication/accumulation result is already required at the end on clock cycle 1, but is only ready after clock cycle 2. If it is necessary to have an MPY operation with +ACRS or -ACRS directly after a previous MPY operation (for multiprecision multiplication), then there has to be a no operation cycle (or at least no MPY operation) between them.

- BRANCH operation (1 or 2 clock cycles)

Clock cycle 1:
The branch condition is checked, the result of which can be true or false. When the result is false, the BRANCH operation is terminated. When the result is true, the action specified under "Clock cycle 2 " is executed.

Clock cycle 2:
The program counter is loaded with the branch address.
Note: no new operation is started during loading.

- LOAD IMMEDIATE operation (1 clock cycle)

The 16 -bit data word specified in the instruction is put on the X -bus and the Y -bus and transferred to one or two specified destinations. In the case that two identical destinations are specified no transfer takes place.


Fig. 3.1-1 Basic operation sequencing in P-mode.

## Notes to Fig. 3.1-1

NOTE 1: Each instruction may contain several simultaneous basic operations (see section 3.2 on instruction formats).
NOTE 2: "Loading new address" (BRANCH) takes place only when the condition is true.
NOTE 3: During "loading new address" (BRANCH) no new operation is started.
NOTE 4: Memory access is normally a data register (DRA, DRB, DRR, or PI) read. This read doesn't take place when there is a simultaneous MOVE to a RAM (during a RAM access).

NOTE 5: An MPY operation with +ACRS or -ACRS in the MPY field directly following another MPY operation leads to an undefined situation (see description of MPY operation).
NOTE 6: After instruction $N$ which specifies a MOVE or LOAD IMMEDIATE operation to PC (with DATA m) first instruction $\mathrm{N}+1$ is exceeded before instruction $m$ is executed.


Fig. 3.1-2 Basic operation sequencing in NP-mode.

## Notes to Fig. 3.1-2

NOTE 1: Each instruction may contain several simultaneous basic operations (see section 3.2 on instruction format).
NOTE 2: "Loading new address" (BRANCH) takes place
only when the condition is true. If the condition is false, there is no action during the second clock cycle.
NOTE 3: Memory access is a data register read.

### 3.2 INSTRUCTION FORMAT

All instruction words are 40-bits wide.
4 types of instructions are defined, each with their own set of basic operations:
Type 0: ALU operation + 2 MOVE operations + 3 ACU operations
Type 1: MULTIPLY operation + 2 MOVE operations + 3 ACU operations

Type 2: BRANCH operation +3 ACU operations
Type 3: LOAD IMMEDIATE operation + 3 ACU operations. Each basic operation is specified by the contents of one or more instruction fields (see Fig. 3.2-1).

The field at the far left of each instruction indicates the instruction type. The other fields are defined in the following table.

| ALU | $=$ Type of ALU operation | dedicated for ALU operations |
| :--- | :--- | :--- |
| AOPS | $=$ ALU operands | dedicated for ALU operations |
| SX | $=$ Source on X-bus | These fields are for ALU and/or MOVE operations, |
| SY | = Source on Y-bus | or for MPY and/or MOVE operations |
| DX | = Destination on X-bus | for MOVE or LI operations |
| DY | $=$ Destination on Y-bus | for MOVE or LI operations |
| RFILE | $=$ Destination in Register file | for ALU, MOVE or LI operations |
| ACUA | $=$ Type of ACUA operation | dedicated for ACU operations |
| ACUB | $=$ Type of ACUB operation | dedicated for ACU operations |
| ACUR | $=$ Type of ACUR operation | dedicated for ACU operations |
| MPY | $=$ Type of accumulator operation | dedicated for MPY operations |
| MOPS | $=$ Multiply operands | dedicated for MPY operations |
| NAP | $=$ Address of next instruction when condition is true | dedicated for BRANCH operations |
| BR | $=$ Type of branch operation | dedicated for BRANCH operations |
| COND | $=$ Branch condition | dedicated for BRANCH operations |
| DATA | $=16$ bits data word that is transmitted on X and Y-bus | dedicated for LI operations |

### 3.3 INSTRUCTION FIELDS

For each instruction field, the valid codes and their function are specified. For most fields, not only the function is
specified but also a mnemonic. The PCB5010/11 assembly language, using the mnemonics in this data sheet, is described in a separate document.

## DEVELOPMENT DATA

## Instruction type 0:

| 39 | 38 | $\begin{array}{lllll}37 & 36 & 35 & 34 & 33\end{array}$ | 3231 | $\begin{array}{lllll}30 & 29 & 28 & 27 & 26\end{array}$ | $\begin{array}{llll}25 & 24 & 23 & 22\end{array}$ | $\begin{array}{llll}20 & 19 & 18 & 17\end{array}$ | $\begin{array}{llll}16 & 15 & 14 & 13\end{array}$ | $12 \quad 11 \quad 10 \quad 9$ | 876 | 543 | 210 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | ALU | AOPS | SX | SY | DX | DY | RFILE | ACUA | ACUR | ACUB |

Instruction type 1:

| 39 | 38 | $37 \quad 36 \quad 35$ | $\begin{array}{llll}34 & 33 & 32 & 31\end{array}$ | $\begin{array}{lllll}30 & 29 & 28 & 27 & 26\end{array}$ | $\begin{array}{lllll}25 & 24 & 23 & 22 & 21\end{array}$ | $\begin{array}{llll}20 & 19 & 18 & 17\end{array}$ | $\begin{array}{llll}16 & 15 & 14 & 13\end{array}$ | $\begin{array}{llll}12 & 11 & 10 & 9\end{array}$ | 876 | 54 | 210 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | MPY | MOPS | SX | SY | DX | DY | RFILE | ACUA | ACUR | ACUB |

## Instruction type 2



Instruction type 3:


Fig. 3.2-1 The four instruction types and their fields.

ALU

| mnemonic | code | type | function |
| :---: | :---: | :---: | :---: |
| Arithmetic operations: |  |  |  |
| ADD | 10100 | dyadic | addition |
| XADD | 10101 | dyadic | extended addition |
| SUB | 10110 | dyadic | subtraction |
| XSUB | 10111 | dyadic | extended subtraction |
| CSUB | 11000 | dyadic | conditional subtraction |
| NEG | 01100 | monadic | negate |
| XNEG | 01101 | monadic | extended negate |
| CNEG | 01110 | monadic | conditional negate |
| DEC | 01010 | monadic | decrement |
| XDEC | 01011 | monadic | extended decrement |
| INC | 01000 | monadic | increment |
| XINC | 01001 | monadic | extended increment |
| ASL | 00111 | monadic | arithmetic shift left |
| XASL | 00110 | monadic | extended arithmetic shift left |
| ASR | 00011 | monadic | arithmetic shift right |
| XASR | 00000 | monadic | extended arithmetic shift right |
| ADDM | 11010 | dyadic | add MSB of B to A |
| DIV | 11001 | dyadic | unsigned division step |
| XSGN | 11110 | no operand | extended N flag |
| Logic operations: |  |  |  |
| COM | 10000 | monadic | logic complement |
| AND | 10001 | dyadic | logic AND |
| OR | 10010 | dyadic | logic OR |
| EXOR | 10011 | dyadic | logic exclusive OR |
| SWAP | 11100 | monadic | byte swap |
| LSL | 00101 | monadic | logic shift left |
| LROL | 00100 | monadic | logic rotate left |
| LSR | 00001 | monadic | logic shift right |
| LROR | 00010 | monadic | logic rotate right |
| Other operations: PASS | 01111 | monadic | pass with flag update |
| NULL | 11101 | no operand | generate 0 |
|  | 11111 | - . | no operation |
| - | 11011 | - | reserved |

AOPS

| mnemonic | code | AINS-type | A-operand | B-operand |
| :---: | :---: | :---: | :---: | :---: |
| * * | 00 | dyadic | source on X-bus | source on Y -bus |
| AAL, * | 01 | dyadic | AAL | source on Y-bus |
| ${ }^{*}, \mathrm{ABL}$ | 10 | dyadic | source on X-bus | ABL |
| AAL, ABL | 11 | dyadic | AAL | ABL |
| AAL | 00 | monadic | AAL | - |
| (the operation is undefined when this operand is selected with a SWAP operation) |  |  |  |  |
|  | 01 | monadic | source on X-bus | - |
| * | 10 | monadic | source on Y-bus | - |
| - | 11 | - | reserved | - |

Note: the AOPS field has no meaning when a no operand operations is specified in the ALU field and as there is no operation, $A A L$ and $A B L$ retain their values.

* The mnemonic of the particular source is used (see SX and SY fields).

| < | mnemonic | code | full name of source |
| :---: | :---: | :---: | :---: |
| $\square$ | - | 00000 | no source |
| - | ROM | 00001 | data register DRR |
| E | - | 00010 | reserved |
| ${ }^{\text {m }}$ | TOS | 00011 | top of stack (Note 1) |
| $\sum_{0}$ | RX | 00100 | bussave register X |
| 0 | PI | 00101 | parallel data input register |
| 山 | IOF | 00110 | input/output status and user flag register |
| > | SOX | 00111 | serial output register connected to X-bus |
| - | SIX | 01000 | serial input register connected to X -bus |
|  | SIOST | 01001 | serial I/O control register |
|  | - | 01010 | reserved |
|  | RAMB | 01011 | data register DRB |
|  | PST | 01100 | processor status register |
|  | RAMA | 01101 | data register DRA |
|  | ACU(RAMB) | 01110 | address register ARB |
|  | LSP | 01111 | least significant 16 bits of multiply/shift/adjust result |
|  | MSP | 10000 | most significant 16 bits of multiply/shift/adjust resuit |
|  | R1 | 10001 | register 1 |
|  | R2 | 10010 | register 2 |
|  | R3 | 10011 | register 3 |
|  | R4 | 10100 | register 4 |
|  | R5 | 10101 | register 5 |
|  | R6 | 10110 | register 6 |
|  | R7 | 10111 | register 7 |
|  | R8 | 11000 | register 8 |
|  | R9 | 11001 | register 9 |
|  | R10 | 11010 | register 10 |
|  | R11 | 11011 | register 11 |
|  | R12 | 11100 | register 12 |
|  | R13 | 11101 | register 13 |
|  | R14 | 11110 | register 14 |
|  | R15 | 11111 | register 15 |

Note 1: When TOS is used as a source, the stack is popped one level.

SY

| mnemonic | code | full name of source |
| :--- | :--- | :--- |
| - | 00000 | no source |
| RAMB | 00001 | data register DRB |
| - | 00010 | reserved |
| RAMA | 00011 | data register DRA |
| RY | 00100 | bussave register Y |
| ROM | 00101 | data register DRR |
| SIY | 00110 | serial input register connected to Y-bus |
| - | 00111 | reserved |
| PG | 01000 | page register |
| BSR | 01001 | barrel-shifter/format adjuster control register |
| ACU(ROM) | 01010 | address register ARR |
| ACU(RAMA) | 01011 | address register ARA |
| PST | 01100 | processor status register |
| PI | 01101 | parallel data input register |
| SOY | 01110 | serial output register connected to Y-bus |
| LSP | 01111 | least significant 16 bits of multiply/shift/adjust result |
| MSP | 10000 | most significant 16 bits of multiply/shift/adjsut result |
| R1 | 10001 | register 1 |
| R2 | 10010 | register 2 |
| R3 | 10011 | register 3 |
| R4 | 10100 | register 4 |
| R5 | 10101 | register 5 |
| R6 | 10110 | register 6 |
| R7 | 10111 | register 7 |
| R8 | 11000 | register 8 |
| R9 | 11001 | register 9 |
| R10 | 11010 | register 10 |
| R11 | 11011 | register 11 |
| R12 | 11110 | register 12 |
| R13 | 11101 | register 13 |
| R14 | 11110 | register 14 |
| R15 | 11111 | register 15 |

DX

| mnemonic | code | full name of destination |
| :--- | :--- | :--- |
| - | 0000 | no destination |
| FQR | 0001 | FQR bit in PST; the required value for FQR must be present |
| in bit 15 on the bus; the other bits are don't cares |  |  |
| SIOST | 0010 | serial I/O control register |
| RPO | 0011 | second parallel data output buffer (PCB5011 only) |
| RX | 0100 | bussave register X |
| PC | 0101 | program counter |
| SOX | 0110 | serial output register connected to X-bus |
| PRAM | 0111 | program RAM |
| RPR | 1000 | reserved |
| PO | 1001 | instruction repeat register |
| RAMA | 1010 | parallel data output buffer |
| PST | 1100 | RAMA |
| TOS | 1101 | processor status register |
| ACU(RAMB,*) | 1110 | top of stack (Note 1) |
| $* *$ | 1111 | ACUB |
|  |  | register file |

* fill in a mnemonic of the ACU-initialization field.
** fill in a mnemonic of the RFILE field.
Note 1: When TOS is used as a destination, the stack is pushed one level.

DY

| mnemonic | code | full name of destination |
| :--- | :--- | :--- |
| - | 0000 | no destination |
| BSR | 0001 | barrel-shifter/format adjuster control register |
| - | 0010 | reserved |
| RAMB | 0011 | RAMB |
| - | 0100 | reserved |
| RY | 0101 | bussave register Y |
| - | 0110 | reserved |
| - | 0111 | reserved |
| - | 1000 | reserved |
| PG | 1001 | page register |
| ACU(RAMA,*) | 1010 | ACUA |
| PO | 1011 | parallel data output buffer |
| RPO | 1100 | second parallel data output buffer (PCB5011 only) |
| SOY | 1101 | serial output register connected to Y-bus |
| ACU(ROM,*) | 1110 | ACUR |
| $* *$ | 1111 | register file |

[^21]RFILE

| mnemonic | code | full name of destination |
| :--- | :--- | :--- |
| - | 0000 | no destination |
| R1 | 0001 | register 1 |
| R2 | 0010 | register 2 |
| R3 | 0011 | register 3 |
| R4 | 0100 | register 4 |
| R5 | 0101 | register 5 |
| R6 | 0110 | register 6 |
| R7 | 0111 | register 7 |
| R8 | 1000 | register 8 |
| R9 | 1001 | register 9 |
| R10 | 1010 | register 10 |
| R11 | 1011 | register 11 |
| R12 | 1100 | register 12 |
| R13 | 1101 | register 13 |
| R14 | 1110 | register 14 |
| R15 | 1111 | register 15 |

## ACU

The ACU fields for RAMA, RAMB and ROM are identical. The content of the field has a different meaning if it is for ACU initialization or address computation.

ACU INITIALIZATION

| mnemonic | code | New values for: |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | A | S | M |  |
| AR |  | source | A | S | M |
| AAR | 001 | source | source | S | M |
| SAR | 010 | source | A | source | M |
| A | 011 | AR | Source | source | M |
| S | 100 | AR | A | S | source |
| M | 101 | AR | A | M |  |
| ASAR | 110 | source | source | source | M |
| AR1M | 111 | (source)!M | A | S |  |

ADDRESS COMPUTATION

| mnemonic | code | New values for: |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | AR | A | S | M |
|  | 000 | AR | A | S | M |
| INCA | 001 | $(\mathrm{A}+1)!\mathrm{M}$ | ( $\mathrm{A}+1)!\mathrm{M}$ | S | M |
| DECA | 010 | $(\mathrm{A}-1)!\mathrm{M}$ | ( $\mathrm{A}-1$ )! M | S | M |
| STEP | 011 | $(\mathrm{A}+\mathrm{S})!\mathrm{M}$ | $(A+S)!M$ | S | M |
| INCS | 100 | $(\mathrm{S}+1)!\mathrm{M}$ | A | (S+1)! M | M |
| A | 101 | (A)!M | A | S | M |
| S | 110 | (S) ! M | A | S | M |
| REV | 111 | $\mathrm{br}(\mathrm{A}+\mathrm{S})$ | A+S | S | M |

Note: see section 2.3.2 on ACUs and PG register for explanation of !M and br(. . . .).

MPY

| mnemonic | code | new ACR-value |
| :--- | :--- | :--- |
| - | 000 | ACR (HOLD) |
| 0 | 001 | $\mathrm{P}^{*} \mathrm{Q}$ |
| +ACR | 010 | $\mathrm{P}^{*} \mathrm{Q}+\mathrm{ACR}$ |
| -ACR | 011 | $\mathrm{P}^{*} \mathrm{Q}-\mathrm{ACR}$ |
| +ACRS | 100 | $\mathrm{P}^{*} \mathrm{Q}+\mathrm{ACR} \times 2^{-15}$ |
| -ACRS | 101 | $\mathrm{P}^{*} \mathrm{Q}-\mathrm{ACR} \times 2^{-15}$ |

MOPS

| mnemonic | code | P-input of multiplier | Q-input of multiplier |
| :---: | :---: | :---: | :---: |
| *, | 0000 | source on X-bus | source on Y-bus |
| *, -* | 0001 | source on X-bus | -(source on Y-bus) |
| MXL, * | 0010 | MXL | source on Y-bus |
| MXL, -* | 0011 | MXL | -(source on Y-bus) |
| *, MYL | 0100 | source on X-bus | MYL |
| MXL, MYL | 0101 | MXL | MYL |
| $-1,{ }^{*}$ | 0110 | -1 | -(source on Y-bus) |
| -1, * | 0111 | -1 | source on Y-bus |
| -1, MYL | 1000 | -1 | MYL |

Note: When the MPY-field contains 000, then independent of the MOPS-code the following is true:

| mnemonic | code | P-input of multiplier | Q-input of multiplier |
| :---: | :---: | :---: | :---: |
| - | $X X X X$ | $M X L$ | $M Y L$ |

* Fill in the mnemonic of the particular source (see SX and SY fields).


## NAP

The NAP field contains the address of the next instruction to be executed if a branch condition is true.

BR

| mnemonic | code | function |
| :--- | :--- | :--- |
| GOTO | 000 | goto |
| CALL | 001 | subroutine call |
| RET | 010 | return from subroutine |
| RETI | 100 | return from INT interrupt |

COND

| mnemonic | code | condition | mnemonic explanation |
| :---: | :---: | :---: | :---: |
| - | 00000x | always true |  |
| AN | 00001x | SGNM | accumulator negative |
| XO | 00010X | OOR |  |
| - | 00011x | reserved |  |
| GE or NOT LT | 00100x | $\overline{\text { N.EXOR.V }}$ | greater or equal to/ not less than |
| NOT GT or LE | 00101X | (N.EXOR.V).OR.Z | not greater than/less than or equal to |
| IFX | 00110x | IFA.AND.IFB.AND.IFC.AND.IFD. |  |
| HI or NOT LS | 00111X | C.OR.Z | higher/not less than or equal to |
| OFL | 01000X | OORL.OR.VL | system overflow |
| XOL | 01001X | OORL | extractor overflow |
| AOL | 01010X | OVFL | accumulator overflow |
| VL | 01011X | VL |  |
| Z or EQ | 01100x | Z |  |
| N | 01101X | N |  |
| C | 01110X | C |  |
| V | 01111X | V |  |
| SIX | 10000x | SIXACK |  |
| SOX | 10001x | SOXACK |  |
| SIY | 10010x | SIYACK |  |
| SOY | 10011X | SOYACK |  |
| ACU(RAMA) | 10100x | ACA |  |
| ACU(RAMB) | 10101X | ACB |  |
| ACU(ROM) | 10110x | ACR |  |
| - | 10111X | reserved |  |
| IFA | 11000x | IFA |  |
| IFB | 11001X | IFB |  |
| IFC | 11010X | IFC |  |
| IFD | 11011X | IFD |  |
| - | 11100X | reserved |  |
| - | 11101X | reserved |  |
| - | 11110X | reserved |  |
| - | 11111X | reserved |  |

$\mathrm{X}=0$ : branch takes place when condition = true
$X=1$ : branch takes place when condition $=$ false
Note: the mnemonic names GE, LT, GT, LE, HI, and LS refer to situations where the flag setting is a result of a subtraction (SUB) of operands $A$ and $B$. For example, GE means that $A$ is greater than or equal to $B$.

## DATA

Data is a 16 bit data word which is transmitted on the X and Y -bus.

### 4.0 ELECTRICAL SPECIFICATION

4.1 ABSOLUTE MAXMIMUM RATINGS

| symbol | parameter | condition | min. | max. | unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{V}_{\mathrm{DD}}$ | supply voltage |  | -0.3 | +7 | V |
| $\mathrm{~V}_{\text {I }}$ | voltage at any input |  | -0.3 | +7 | V |
| $\mathrm{~T}_{\mathrm{amb}}$ | operating ambient temperature range | PCB5010/11 | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {stg }}$ | storage temperature range | PCF5010/11 | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

4.2 DC CHARACTERISTICS

| symbol | parameter | condition | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {DD }}$ | supply voltage |  | 4.75 | 5.0 | 5.25 | V |
| $V_{\text {IH }}$ | HIGH level input voltage |  | 2 | - | $\mathrm{V}_{\mathrm{DD}}{ }^{+0.3}$ | V |
| $V_{\text {IL }}$ | LOW level input voltage |  | -0.3 | - | +0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | HIGH level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{~A} \end{aligned}$ | 2.4 | - | - | V |
| $\mathrm{v}_{\mathrm{OL}}$ | LOW level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA} \end{aligned}$ | - | - | 0.4 | V |
| ${ }^{1} \mathrm{OH}$ | HIGH level output current |  | - | - | 100 | $\mu \mathrm{A}$ |
| ${ }^{\text {IOL}}$ | LOW level output current |  | - | - | 2 | mA |
| $C_{1}$ | input pin capacitance |  | - | - | tbf | pF |
| $\mathrm{C}_{\mathrm{O}}$ | output pin capacitance |  | - | - | tbf | pF |
| P | power dissipation |  | - | - | tbf | mW |

### 4.3 AC CHARACTERISTICS

| no. | parameter | min. | max. | unit | note |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | CLK width HIGH | 60 | 1000 | ns |  |
| 2 | CLK width LOW | 65 | 1000 | ns |  |
| 3 | CLK HIGH to SYNC HIGH | 10 | 50 | ns |  |
| 4 | CLK HIGH to Ax valid | 10 | 60 | ns | $x=0 \ldots 15$ |
| 5 | CLK HIGH to R/W LOW | 10 | 60 | ns |  |
| 6 | R/W width LOW | 120 |  | ns |  |
| 7 | CLK LOW to $\overline{\text { DS }}$ LOW | 5 | 35 | ns |  |
| 8 | CLK HIGH to $\overline{\text { DS }}$ HIGH | 10 | 50 | ns |  |
| 9 | Dx set-up time | 15 |  | ns | $x=0 \ldots 15$ |
| 10 | Dx hold time | 0 |  | ns | $x=0 \ldots 15$ |
| 11 | Dx valid to $\overline{\mathrm{DS}}$ LOW | 0 |  | ns | $x=0 \ldots 15$ |
| 12 | $\overline{\text { DS HIGH to Dx invalid }}$ | 5 |  | ns | $\mathrm{x}=0 \ldots 15$ |
| 13 | WAIT set-up time | 10 |  | ns |  |
| 14 | WAIT hold time | 20 |  | ns |  |
| 15 | INT set-up time | 5 |  | ns |  |
| 16 | $\overline{\text { INT }}$ hold time | 20 |  | ns |  |
| 17 | CLK HIGH to IACK LOW |  | 60 | ns |  |
| 18 | CLK HIGH to $\overline{\text { IACK }}$ HIGH |  | 60 | ns |  |
| 19 | IFA, IFB, IFC, IFD set-up time | 5 |  | ns |  |
| 20 | IFA, IFB, IFC, IFD hold time | 20 |  | ns |  |
| 21 | RST set-up time | 10 |  | ns |  |
| 22 | $\overline{\mathrm{RST}}$ hold time | 20 |  | nis |  |
| 24 | CLK HIGH to PAx or ARRx valid | 5 | 50 | ns | $\begin{gathered} x=0 . .9 \text { or } \\ . .8 \end{gathered}$ |
| 25 | CLK HIGH to RR/W LOW |  | 50 | ns |  |
| 26 | RR/ $\bar{W}$ width LOW | 120 |  | ns |  |
| 27 | CLK LOW to RDS LOW |  | 20 | ns |  |
| 28 | CLK HIGH to $\overline{\mathrm{RDS}}$ HIGH | 10 | 40 | ns |  |
| 29 | RDx set-up time | 15 |  | ns | $x=0 \ldots 15$ |
| 30 | RDx hold time | 0 |  | ns | $x=0 \ldots 15$ |
| 31 | RDx valid to $\overline{\mathrm{RDS}}$ LOW | 0 |  | ns | $x=0 \ldots 15$ |
| 32 | $\overline{\text { RDS }}$ HIGH to RDx invalid | 5 |  | ns | $x=0 \ldots 15$ |
| 41 | COX, CIX, COY, CIY width HIGH | 125 |  | ns |  |
| 42 | COX, $\mathrm{CIX}, \mathrm{COY}, \mathrm{CIY}$ width LOW | 125 |  | ns |  |
| 43 | $\operatorname{COX}(\mathrm{Y})$ LOW to $\overline{\text { SOX }}$ (Y)RQ LOW |  | 40 | ns |  |
| 44 | COX(Y) LOW to $\overline{\text { SOX }}$ (Y)RO HIGH |  | 40 | ns |  |
| 45 | SOX(Y)EN set-up time | 40 |  | ns |  |
| 46 | SOX(Y)EN hold time | 40 |  | ns |  |
| 47 | $\operatorname{COX}(\mathrm{Y})$ LOW to next DOX(Y) valid |  | 40 | ns |  |
| 48 | SOX(Y)EN LOW to DOX(Y) valid | 10 |  | ns |  |
| 49 | SOX(Y)EN HIGH to DOX(Y) 3-state |  | 40 | ns |  |
| 53 | $\mathrm{CIX}(\mathrm{Y})$ LOW to $\mathrm{SIX}(\mathrm{Y}) \mathrm{RQ}$ LOW |  | 40 | ns |  |
| 54 | CIX(Y) LOW to SIX(Y)RO HIGH |  | 40 | ns |  |
| 55 | SIX(Y)EN set-up time | 30 |  | ns |  |
| 56 | SIX(Y)EN hold time | 10 |  | ns |  |
| 57 | DIX, DIY set-up time | 10 |  | ns |  |
| 58 | DIX, DIY hold time | 40 |  | ns |  |
| 59 | PDx set-up time | 5 |  | ns | $\mathrm{x}=0 \ldots 39$ |
| 60 | PDx hold time | 15 |  | ns | $x=0 \ldots 39$ |



Fig. 4.3-1 Program memory access timing (for PCB5011 only).


Fig. 4.3-3 Interrupt timing.


Fig. 4.3-4 Reset timing.


Fig. 4.3-5 Synchronization timing.


Fig. 4.3-6 Second parallel I/O timing (for PCB5011 only).


Note: (part of) the signals A15 - A0 can be used just as hardware controlling outputs if they are not needed for addressing external RAM.

Fig. 4.3-7 Parallel I/O timing ( $\overline{\text { WAIT }}$ inactive).


Note: as long as $\overline{\text { WAIT }}=0$ all clocked (by CLK) processor actions are suspended i.e. the internal status and all signals remain unchanged.

Fig. 4.3-8 $\overline{\text { WAIT }}$ signal timing.


Fig. 4.3-9 Serial input timing.


Fig. 4.3-10 Serial output timing.

### 5.0 PACKAGE OUTLINES

### 5.1 PCB5010 PACKAGE OUTLINE (dimensions in mm)



Fig. 5.1-1 68-lead plastic leaded-chip-carrier (PLCC) (SOT-188A) package for the PCB5010.
DEVELOPMENT DATA


Fig. 5.1-2 Pinning for the PCB5010 (PLCC).

### 5.2 PCB5011 PACKAGE OUTLINE (dimensions in mm)



Fig. 5.2-1 144-pin grid array (PGA) package for the PCB5011.

### 5.3 PIN ASSIGNMENT FOR Fig. 5.2-1

| PCB5011 signal name | pin number | PCB5011 signal name | pin number |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {DD }}$ | N8, C8 | $\overline{\text { SIXEN }}$ | C2 |
| $\mathrm{V}_{\text {SS }}$ | N9, A2 | $\overline{\text { SIXRQ }}$ | D2 |
| CLK | O2 | CIX | D3 |
| SCAN | B3 | DIY | H3 |
| $\overline{\mathrm{RST}}$ | L14 | SIYEN | J3 |
| D15 | P3 | $\overline{\text { SIYRQ }}$ | H1 |
| D14 | N4 | CIY | J1 |
| D12 | P2 | DOX | C1 |
| D11 | N3 | $\overline{\text { SOXEN }}$ | E2 |
| D9 | M3 | SOXEN | E2 |
| D8 | N2 | SOXRQ | E3 |
| D7 | L3 | COX | D1 |
| D6 | M2 |  | G1 |
| D5 | N1 | DOY | G1 |
| D4 | M1 | SOYEN | F1 |
| D3 | L2 | $\overline{\text { SOYRQ }}$ | H2 |
| D1 | K3 | SOYRQ | H2 |
| D0 | K2 | COY | G3 |
| A15 | A1 | $\overline{\text { INT }}$ | M15 |
| A14 | B2 | $\overline{\text { ACK }}$ | M14 |
| A13 | C3 C4 | SYNC | N14 |
| A11 | N5 |  |  |
| A10 | Q3 | IFA | F3 |
| A9 | P5 |  | F2 |
| A8 | O4 | IFD | G2 |
| A6 | P6 | PA9 | Q13 |
| A5 | Q5 | PA8 | P12 |
| A4 | P7 | PA7 | N11 |
| A3 | N7 | PA6 | P13 |
| A2 | Q6 | PA5 | Q14 |
| A1 | Q7 | PA4 | N12 |
| A0 | P8 | PA3 | N13 |
| $R / \bar{W}$ | J2 | PA2 | P14 |
|  |  | PA1 | 015 |
| $\overline{\text { DS }}$ | K1 | PAO | M13 |
| $\overline{\text { WAIT }}$ | P4 |  |  |
| DIX | B1 | age) |  |


| PCB5011 signal name | pin number |
| :---: | :---: |
| PD39 | C5 |
| PD38 | B4 |
| PD37 | A3 |
| PD36 | A4 |
| PD35 | B5 |
| PD34 | A5 |
| PD33 | C6 |
| PD32 | B6 |
| PD31 | B7 |
| PD30 | A6 |
| PD29 | A7 |
| PD28 | C7 |
| PD27 | A8 |
| PD26 | B8 |
| PD25 | A9 |
| PD24 | A10 |
| PD23 | C9 |
| PD22 | B9 |
| PD21 | A11 |
| PD20 | B10 |
| PD19 | C10 |
| PD18 | A12 |
| PD17 | B11 |
| PD16 | A13 |
| PD15 | C11 |
| PD14 | B12 |
| PD13 | A14 |
| PD12 | B13 |
| PD11 | C12 |
| PD10 | G15 |
| PD9 | G13 |
| PD8 | K14 |
| PD7 | L15 |
| PD6 | J14 |
| PD5 | J13 |
| PD4 | K15 |
| PD3 | J15 |
| PD2 | H14 |
| PD1 | H15 |
| PDO | H13 |
| ARR8 | Q8 |
| ARR7 | Q9 |
| ARR6 | 010 |
| ARR5 | P9 |
| ARR4 | P10 |
| ARR3 | N10 |
| ARR2 | Q11 |
| ARR1 | P11 |
| ARR0 | 012 |


| PCB5011 signal name | pin number |
| :--- | :--- |
| RD15 | F15 |
| RD14 | G14 |
| RD13 | F14 |
| RD12 | F13 |
| RD11 | E15 |
| RD10 | E14 |
| RD9 | D15 |
| RD8 | C15 |
| RD7 | D14 |
| RD6 | E13 |
| RD5 | C14 |
| RD4 | B15 |
| RD3 | D13 |
| RD2 | C13 |
| RD1 | B14 |
| RD0 | A15 |
| RR/W | L13 |
| RDS | N15 |

## VIDEO DISPLAY

SAA5350 ..... 905
SCN2670. ..... 933
SCN2671. ..... 949
Using the 2670/73 CRT terminal chip set (App Note 401) ..... 971
2670/72/73 CRT set application briefs (App Note 403) ..... 987
TEA2000 ..... 995

## SINGLE-CHIP COLOUR CRT CONTROLLER (EUROM)

## GENERAL DESCRIPTION

The SAA5350 EUROM is a single-chip VLSI NMOS crt controller capable of handling all display functions required by the CEPT videotex terminal, model A4. Only minimal hardware is required to produce a videotex terminal using EUROM - the simplest configuration needs just a microcontroller and 4 Kbytes of display memory.

## Features

- Minimal additional hardware required
- Screen formats of $40 / 80$ character by 1 -to- 25 row display
- 512 alphanumeric or graphical characters on-chip or extendable off-chip
- Serial attribute storage (STACK) and parallel attribute storage
- Dynamically redefinable character (DRCS) capability over full field
- Interfaces with 8/16-bit microprocessors with optional direct memory access
- On-chip scroll map minimizes data to be transferred when scrolling
- On-chip colour map RAM (4096 locations) and three on-chip digital-to-analogue converters allow 32 colours on-screen
- On-chip digital-to-analogue converters are non-linear to compensate for crt non-linearity
- Memory interface capable of supporting multi-page terminals. EUROM can access up to 128 Kbytes of display memory
- Programmable cursor
- Programmable local status row
- Three synchronization modes:
stand-alone built-in oscillator operating with an external 6 MHz crystal
simple slave
phase-locked slave directly synchronized from the source of text composite sync indirect synchronization allows picture-in-text displays (e.g. VCR/VLP video with text overlay)
- On-chip timing composite sync output
- Zoom feature which allows the height of any group of rows to be increased to enhance legibility


## PACKAGE OUTLINE

40-lead DIL; plastic (SOT-129).


Fig. 1 Block diagram.

## PINNING

| 1 | VSS1 |
| :--- | :--- |
| 2 | $\overline{B U F E N}$ |
| 3 | $\overline{R E}$ |

4 to 19 A16 to A1/ D15 to D0

## 20 <br> $V_{S S 2}$

21
22
23
24
25

26
REF
B
G
R
$\overline{\mathrm{VDS}}$

27

28

F1/F6
F6
VCS/OSCO
$\overline{T C S}$
$\overline{\mathrm{FS}} / \overline{\mathrm{DDA}}$

UDS
LDS
$\overline{\text { DTACK }}$
$\overline{B R}$
$\overline{\text { AS }}$
$R / \bar{W}(\bar{S} / R)$
$V_{D D}$

## Ground 0 V .

Buffer enable input to the 8-bit link-through buffer.
Register enable input. This enables A1 to A6 and UDS as inputs, and D8 to D15 as input/outputs.

Multiplexed address and data bus input/outputs. These pins also function as the 8-bit link-through buffer.
Ground ( 0 V ).
Analogue reference input.

Analogue outputs (signals are gamma-corrected).

Switching output for dot, screen (row), box and window video data; for use when video signal is present (e.g. from tv, VLP, alpha + photographic layer). This output is LOW for tv display and HIGH for text and will interface directly with a number of colour decoder ICs (e.g. TDA3560, TDA3505).
Output disable causing R, G, B and $\overline{V D S}$ outputs to go to high-impedance state. Can be used at dot-rate.
12 MHz clock output for hard-copy dot synchronization (referenced to output dots).

Sandcastle feedback output for SAA5230 teletext video processor or other circuit. Used when the display must be locked to the video source (e.g. VLP). The phase-lock part of the sandcastle waveform can be disabled to allow free-running of the SAA5230 phase-locked loop.
1 MHz or 6 MHz output.
6 MHz clock input (e.g. from SAA5230). Internal a.c. coupling is provided.
Video composite sync input (e.g. from SAA5230) for phase reference of vertical display timing when locking to a video source (e.g. VLP) or, in stand-alone sync mode, output from internal oscillator circuit (fixed frequency).
Text composite sync input/output depending on master/slave status.
Field sync pulse output or defined-display-area flag output (both referenced to output dots).
Upper data strobe input/output.
Lower data strobe output.
Data transfer acknowledge (open drain output).
Bus request to microprocessor (open drain output).
Address strobe output to external address latches.
Read/write input/output. Also serves as send/receive for the link-through buffer.
Positive supply voltage (+5V).

## PINNING (continued)



Fig. 2 Pinning diagram.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Supply voltage range (pin 40)
Maximum input voltage (except F6, $\overline{T C S}$, REF)
Maximum input voltage (F6, TCS
Maximum input voltage (REF)
Maximum output voltage
Maximum output current
Operating ambient temperature range
Storage temperature range

| $V_{\text {DD }}$ | $-0,3$ to $+7,5 \mathrm{~V}$ |
| :--- | ---: |
| $V_{\text {Imax }}$ | $-0,3$ to $+7,5 \mathrm{~V}$ |
| $V_{\text {Imax }}$ | $-0,3$ to $+10,0 \mathrm{~V}$ |
| $V_{\text {REF }}$ | $-0,3$ to $+3,0 \mathrm{~V}$ |
| $V_{\text {Omax }}$ | $-0,3$ to $+7,5 \mathrm{~V}$ |
| $I_{\text {Omax }}$ | 10 mA |
| $T_{\text {amb }}$ | -20 to $+70{ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {stg }}$ | -55 to $+125{ }^{\circ} \mathrm{C}$ |

Outputs other than CLKO, OSCO, R, G, B, and $\overline{\mathrm{VDS}}$ are short-circuit protected.

CHARACTERISTICS
$\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-20$ to $+70^{\circ} \mathrm{C}$; unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SUPPLY |  |  |  |  |  |
| Supply voltage (pin 40) | $V_{\text {DD }}$ | 4,75 | 5,0 | 5,25 | V |
| Supply current (pin 40) | ${ }^{\prime}$ DD | - | - | 350 | mA |
| INPUTS |  |  |  |  |  |
| F6 (note 1) |  |  |  |  |  |
| Slave modes (Fig. 3) |  |  |  |  |  |
| Input voltage (peak-to-peak value) | $V_{1(p-p)}$ | 1,0 | - | 7,0 | V |
| Input peaks relative to 50\% duty factor | $\pm \mathrm{V}_{\mathrm{P}}$ | 0,2 | - | 3,5 | V |
| Input leakage current at $\mathrm{V}_{\mathrm{I}}=0 \text { to } 10 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$ | ${ }^{\text {LI }}$ | - | - | 20 | $\mu \mathrm{A}$ |
| Input capacitance | $\mathrm{Cl}_{1}$ | - | - | 12 | pF |
| Stand-alone mode (Fig. 4) |  |  |  |  |  |
| Series capacitance of crystal | $\mathrm{C}_{1}$ | - | 28 | - | fF |
| Parallel capacitance of crystal | $\mathrm{C}_{0}$ | - | 7,1 | - | pF |
| Resonance resistance of crystal | $\mathrm{R}_{\mathrm{r}}$ | - | - | 60 | $\Omega$ |
| Gain of circuit | G | - | - | tbf | V/V |
| BUFEN, $\overline{\mathrm{RE}}, \overline{\mathrm{OD}}$ |  |  |  |  |  |
| Input voltage LOW | $\mathrm{V}_{\text {IL }}$ | 0 | - | 0,8 | V |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | 6,5 | V |
| Input current at $\mathrm{V}_{1}=0 \text { to } \mathrm{V}_{\mathrm{DD}}+0,3 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$ | 11 | -10 | - | +10 | $\mu \mathrm{A}$ |
| Input capacitance | $\mathrm{C}_{1}$ | - | - | 7 | pF |
| REF (Fig. 5) |  |  |  |  |  |
| Input voltage | $V_{\text {REF }}$ | 0 | 1 to 2 | 2,7 | V |
| Resistance (pin 21 to pin 20) with REF supply and R, G, B outputs OFF | $\mathrm{R}_{\text {REF }}$ | - | 125 | - | $\Omega$ |

CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OUTPUTS |  |  |  |  |  |
| SAND |  |  |  |  |  |
| Output voltage high level at $\mathrm{I}_{\mathrm{O}}=0 \text { to }-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH}}$ | 4,2 | - | $V_{\text {DD }}$ | V |
| Output voltage intermediate level at $\mathrm{i}_{\mathrm{O}}=-10 \text { to }+10 \mu \mathrm{~A}$ | $\mathrm{V}_{\text {OI }}$ | 1,3 | 2,0 | 2,7 | V |
| Output voltage low level at $\mathrm{I}_{\mathrm{O}}=0,2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,2 | V |
| Load capacitance | $C_{L}$ | - | - | 130 | pF |
| F1/F6, CLKO, $\overline{\text { DDA } / \overline{F S}}$ |  |  |  |  |  |
| Output voltage HIGH at ${ }^{\mathrm{I} O H}=-200 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | $V_{\text {DD }}$ | V |
| Output voltage LOW at $\mathrm{I}_{\mathrm{OL}}=3,2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| Load capacitance | $C_{L}$ | - | - | 50 | pF |
| [DS, $\overline{\text { AS }}$ |  |  |  |  |  |
| Output voltage HIGH at ${ }^{\mathrm{I} O H}=-200 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Output voltage LOW at $\mathrm{I}_{\mathrm{OL}}=3,2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| Load capacitance | $C_{L}$ | - | - | 200 | pF |
| $\overline{\text { DTACK }}$, $\overline{\mathrm{BR}}$. (open drain outputs) |  |  |  |  |  |
| Output voltage LOW at $\mathrm{I}_{\mathrm{OL}}=3,2 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL }}$ | 0 | - | 0,4 | V |
| Load capacitance | $C_{L}$ | - | - | 150 | pF |
| Capacitance (OFF state) | COFF | - | - | 7 | pF |
| R, G, B (note 2) |  |  |  |  |  |
| Output voltage HIGH (note 3) at $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} ; \mathrm{V}_{\mathrm{REF}}=2,7 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | - | V |
| Output voltage LOW at $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,4 | V |
| Output resistance during line blanking | ROBL | - | - | 150 | $\Omega$ |
| Output capacitance (OFF state) | $\mathrm{C}_{\text {OFF }}$ | - | - | 12 | pF |
| $\begin{aligned} & \text { Output leakage current (OFF state) } \\ & \text { at } V_{1}=0 \text { to } V_{D D^{+}} 0,3 \mathrm{~V} ; \\ & T_{\text {amb }}=25{ }^{\circ} \mathrm{C} \end{aligned}$ | IOFF | -10 | - | + 10 | $\mu \mathrm{A}$ |



CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TIMING |  |  |  |  |  |
| F6 (Fig. 3) |  |  |  |  |  |
| Rise and fall times | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | 10 | - | 80 | ns |
| Frequency | ${ }^{\text {f }}$ 6 6 | 5,9 | - | 6,1 | MHz |
| CLKO, F1/F6, R, G, B, VDS, <br> $\overline{\mathrm{FS}} / \overline{\mathrm{DDA}}, \overline{\mathrm{OD}}$ (notes 4, 5 and Fig. 6) |  |  |  |  |  |
| CLKO HIGH time | ${ }^{\text {t CLKH }}$ | 25 | - | - | ns |
| CLKO LOW time | ${ }^{\text {t CLKL }}$ | 15 | - | - | ns |
| CLKO rise and fall times | $\begin{aligned} & { }^{\mathrm{t} C L K r} \\ & \mathrm{t}_{\mathrm{CLKf}} \end{aligned}$ | - | - | 10 | ns |
| CLKO HIGH to R, G, B, $\overline{\mathrm{VDS}}$ change | ${ }^{\text {tVCH }}$ | 10 | - | - | ns |
| $R, G, B, \overline{V D S}$ valid to CLKO rise | tvoc | 10 | - | - | ns |
| CLKO HIGH to R, G, B, $\overline{\text { VDS }}$ valid | ${ }^{\text {t }} \mathrm{COV}$ | - | - | 60 | ns |
| CLKO HIGH to R, G, B, $\overline{\text { VDS }}$ floating after $\overline{\mathrm{DD}}$ fall | ${ }^{\text {t }}$ FOD | 0 | - | 30 | ns |
| Skew between outputs R, G, B, VDS | ${ }^{\text {t V S }}$ | - | - | 20 | ns |
| $R, G, B, \overline{V D S}$ rise and fall times | ${ }^{t} V_{r}, \mathrm{t}_{\mathrm{f}}$ | - | - | 30 | ns |
| CLKO HIGH to R, G, B, $\overline{\mathrm{VDS}}$ active after $\overline{\mathrm{OD}}$ rise | ${ }^{t}$ AOD | 0 | - | 60 | ns |
| CLKO HIGH to $\overline{\mathrm{FS}} / \overline{\mathrm{DDA}}$ change | ${ }^{\text {t }}$ COD | 10 | - | 55 | ns |
| $\overline{\mathrm{FS}} / \overline{\mathrm{DDA}}$ valid to CLKO rise | ${ }^{\text {t }}$ DOC | 5 | - | - | ns |
| F1 HIGH time (note 6) | ${ }^{\text {tFiH }}$ | 400 | 500 | 580 | ns |
| F1 LOW time (note 6) | ${ }^{\text {t }}$ F1L | 400 | 500 | 580 | ns |
| F6 HIGH time | ${ }^{\text {t F } 6 \mathrm{H}}$ | 40 | 83 | 120 | ns |
| F6 LOW time | ${ }^{\text {t }}$ F6L | 40 | 83 | 120 | ns |
| $\overline{\text { OD }}$ to CLKO rise set-up | ${ }^{\text {t ODS }}$ | - | - | 45 | ns |
| $\overline{O D}$ to CLKO HIGH hold | ${ }^{\text {todH }}$ | - | - | 0 | ns |
| MEMORY ACCESS TIMING (notes 7, 8, 9 and Fig. 7) |  |  |  |  |  |
| $\overline{\text { UDS }}$, $\overline{\text { LDS }}$, $\overline{\text { AS }}$ |  |  |  |  |  |
| Cycle time | $\mathrm{t}_{\text {cyc }}$ | 480 | 500 | 520 | ns |
| UDS HIGH to bus-active for address output | ${ }^{\text {t SAA }}$ | 75 | - | - | ns |
| Address valid set-up to $\overline{\text { AS }}$ fall | ${ }^{t}$ ASU | 20 | - | - | ns |
| Address valid hold from $\overline{\text { AS }}$ LOW | ${ }^{\text {t }}$ ASH | 20 | - | - | ns |
| Address float to UDS fall | ${ }^{\text {t AFS }}$ | 0 | - | - | ns |


| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{AS}}$ LOW to $\overline{\text { UDS }}$ fall delay | ${ }^{\text {t }}$ ATD | 50 | - | - | ns |
| $\overline{\text { UDS, }} \overline{\text { LDS }}$ HIGH time | thDS | 220 | - | - | ns |
| UDS, $\overline{\text { LDS }}$ LOW time | ${ }^{\text {t }}$ LDS | 200 | - | - | ns |
| $\overline{\text { AS HIGH time }}$ | thas | 125 | - | - | ns |
| $\overline{\text { AS LOW time }}$ | ${ }^{\text {t LAS }}$ | 320 | - | - | ns |
| $\overline{\text { AS LOW to } \overline{\text { UDS }} \text { HIGH }}$ | ${ }^{\text {t }}$ AUH | 305 | - | - | ns |
| Data valid set-up to $\overline{U D S}$ rise | ${ }^{\text {t }}$ DSU | 30 | - | - | ns |
| Data valid hold from UDS HIGH | ${ }^{\text {t }}$ DSH | 10 | - | - | ns |
| UDS HIGH to $\overline{\text { AS }}$ rise delay | tuAs | 0 | - | 15 | ns |
| $\overline{\mathrm{AS}}$ LOW to data valid | ${ }^{\text {t AFA }}$ | - | - | 270 | ns |
| Link-through buffers (notes 7, 8 and Fig. 8) |  |  |  |  |  |
| BUFEN LOW to output valid | ${ }^{\text {t BEA }}$ | - | - | 100 | ns |
| Link-through delay time | ${ }_{\text {t }}$ LTD | - | - | 85 | ns |
| Input data float prior to direction change | tIFR | 0 | - | - | ns |
| Output float after direction change | ${ }^{\text {tofR }}$ | - | - | 60 | ns |
| Output float after BUFEN HIGH | $t_{B E D}$ | - | - | 60 | ns |
| Microprocessor READ from EUROM (Fig. 9) |  |  |  |  |  |
| R// W HIGH set-up to $\overline{\text { UDS }}$ fall | ${ }^{\text {tr }}$ RUD | 0 | - | - | ns |
| UDS LOW to returned-data access time | tuda | - | - | 210 | ns |
| $\overline{\mathrm{RE}}$ LOW to returned data access time | ${ }^{\text {t REA }}$ | - | - | 210 | ns |
| Data valid to DTACK LOW delay | ${ }^{\text {t }}$ DTL | 40 | - | - | ns |
| $\overline{\text { DTACK LOW to } \overline{U D S} \text { rise }}$ | ${ }^{\text {t }}$ DLU | 10 | - | - | ns |
| UDS HIGH to DTACK rise | ${ }^{\text {t DTR }}$ | 0 | - | 75 | ns |
| UDS HIGH to address hold | ${ }^{\text {t DSA }}$ | 10 | - | - | ns |
| UDS HIGH to data hold | ${ }^{\text {t }}$ DSH | 10 | - | - | ns |
| UDS HIGH to $\overline{\mathrm{RE}}$ rise | tsRE | 10 | - | - | ns |
| $\overline{\text { UDS }}$ HIGH to R/W fall | tudr | 0 | - | - | ns |
| $\overline{\text { UDS LOW to } \overline{\text { DTACK }} \text { LOW }}$ | ${ }^{\text {t }}$ DSD | 250 | - | 350 | ns |
| Address valid to UDS fall | ${ }^{\text {t }}$ AUL | 0 | - | - | ns |

CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MEMORY ACCESS TIMING (continued) <br> Microprocessor WRITE to EUROM (Fig. 10) <br> Write cycle time (note 10) <br> $\mathrm{R} / \overline{\mathrm{W}}$ LOW set-up to $\overline{\mathrm{UDS}}$ fall <br> $\overline{\mathrm{RE}}$ LOW to $\overline{\mathrm{UDS}}$ fall <br> Address valid to $\overline{\text { UDS }}$ fall <br> UDS LOW time <br> Data valid to $\overline{\text { UDS }}$ rise <br>  <br> $\overline{U D S}$ HIGH to $\overline{\text { DTACK }}$ rise <br> $\overline{\text { UDS }}$ HIGH to data hold <br> $\overline{\text { UDS }}$ HIGH to address hold <br> $\overline{\text { UDS }}$ HIGH to $\overline{\mathrm{RE}}$ rise <br> $\overline{\text { UDS }}$ HIGH to R/W rise <br> F1/F6 to memory access cycle (Fig. 11) <br> UDS HIGH to F6 (component of F1/F6) rise F6 (component of F1/F6) HIGH to $\overline{\text { UDS }}$ rise <br> SYNCHRONIZATION and BLANKING $\overline{T C S}$, SAND, $\overline{\mathrm{FS}} / \overline{\mathrm{DDA}}$ <br> See Fig. 12 for timing relationships and Fig. 13 for vertical sync and blanking waveforms. | twCY <br> twUD <br> tres <br> ${ }^{t}$ ASS <br> ${ }^{\text {t LUS }}$ <br> ${ }^{t}$ DSS <br> ${ }^{t}$ DTA <br> ${ }^{t}$ DTR <br> ${ }^{t}$ DSH <br> ${ }^{t}$ DSA <br> ${ }^{\text {t }}$ SRE <br> tuDW <br> tuF6 <br> ${ }^{\text {t F6U }}$ | $\begin{aligned} & 500 \\ & 0 \\ & 30 \\ & 30 \\ & 100 \\ & 80 \\ & 0 \\ & 0 \\ & 10 \\ & 10 \\ & 10 \\ & 0 \\ & \hline \\ & 20 \\ & 40 \end{aligned}$ |  | $\begin{aligned} & 60 \\ & 75 \end{aligned}$ | ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns |

## Notes to the characteristics

1. Pin 30 must be biased externally as it is internally a.c. coupled.
2. 16 -level analogue voltage outputs.
3. Output voltage guaranteed when programmed for top level.
4. CLKO, R, G, B, F1/F6, VDS: $C_{L}=25 \mathrm{pF}$
$\overline{F S} / \overline{D D A}: C_{L}=50 \mathrm{pF}$
5. CLKO, $\mathrm{F} 1 / \mathrm{F6}, \overline{\mathrm{VDS}}, \overline{\mathrm{FS}} / \overline{\mathrm{DDA}}$ : reference levels $=0,8$ to $2,0 \mathrm{~V}$
$R, G, B$ : reference levels $=0,8$ to $2,0 \vee$ with $V_{R E F}=2,7 \mathrm{~V}$
6. These times may momentarily be reduced to a nominal 83 ns in slave-sync mode at the moment of re-synchronization.
7. $C_{L}=150 \mathrm{pF}$.
8. Reference levels $=0,8$ to $2,0 \mathrm{~V}$.
9. F6 input at 6 MHz .
10. Microprocessor write cycle times of less than 500 ns are permitted but often result in Wait States being generated,'the precise timing of DTACK will then depend on the internal synchronization time.


Fig. 3 F6 input waveform.

(a)

$7 Z 80580.1$
(b)
(1) Catalogue number of crystal: 432214304101

Fig. 4(a) Oscillator circuit for SAA5350 stand-alone sync mode and (b) equivalent circuit of crystal at resonance (see characteristics for values).


Fig. 5 Circuit arrangement giving one-of-sixteen reference voltage levels for the $\mathrm{R}, \mathrm{G}$ or B analogue outputs.


Fig. 6 Video timing.


Fig. 7 Memory access timing.


Fig. 8 Timing of link-through buffers.


Fig. 9 Timing of microprocessor read from EUROM.


Fig. 10 Timing of microprocessor write to EUROM.


Fig. 11 Timing of F1/F6 to memory access cycle.


Fig. 12 Timing of synchronization and blanking outputs; all timings are nominal and assume $\mathrm{f}_{\mathrm{F} 6}=6 \mathrm{MHz}$.

## APPLICATION INFORMATION

More detailed application information is available on request
BASIC VIDEOTEX DECODER CONFIGURATION
A basic, practical decoder configuration is shown in Fig. 14, reference should also be made to the block diagram Fig. 1.


Fig. 14 Basic videotex decoder configuration.
Character and attribute data is fetched from the external memory, processed by the row buffer fill logic according to the stack coding scheme (in stack mode) and then fed into one half of the dual display row buffer. The data fetch process takes place during one line-flyback period (per row) and, since time is required to complete the fill, the other half of the dual row buffer is used for display. The row buffers exchange functions on alternate rows - each holds the 40 columns of 32 bits required to define explicitly every character in a row.
The addresser is used for row buffer filling and for fetching screen colours, and during the display time it is also used for addressing DRCS characters.

## Timing

The timing chain operates from an external 6 MHz clock or an on-chip fixed-frequency crystal oscillator. The basic video format is 40 characters per row, $24 / 25$ rows per page and 10 video lines per row. EUROM will also operate with 20/21 rows per page and 12 video lines per row. The two extra lines per row are added symmetrically and contain background colour only for ROM-based alphanumeric characters. DRCS characters, block and smooth mosaics and line drawing characters occupy all 12 lines.
The display is generated to the normal $625-\mathrm{line} / 50 \mathrm{~Hz}$ scanning standard (interlaced or non-interlaced). In addition to composite sync ( pin 32 ) for conventional timebases, a clock output at 1 MHz or 6 MHz (pin 29) is available for driving other videotex devices, and a 12 MHz clock (pin 27) is available for hard-copy dot synchronization. A defined-display-area timing signal (pin 33) simplifies the application of external peripherals such as a light pen; this signal is nominally coincident with the character dot information.

## APPLICATION INFORMATION (continued)

## Character generation

EUROM supports eight character tables, each of (nominally) 128 characters. Four tables are in on-chip ROM and contain fixed characters and four are stored in an external RAM. The contents of the fixed character tables (Tables 0 to 3) are shown in Figs 15 and 16.

(a)

(b)

Fig. 15 On-chip characters: (a) Table 0; (b) Table 1.


Fig. 16 On-chip characters: (a) Table 2; (b) Table 3.

## APPLICATION INFORMATION (continued)

## Character generation (continued)

The 128 most commonly used characters are contained in Table 0, these are the standard upper and lower-case letters of the Roman alphabet, numerals, punctuation and the more common accented characters. In normal text transmission, Table 0 is used most of the time. Table 1 contains other accented characters. Miscellaneous characters, mathematical symbols, the line drawing character set and accents without associated symbols are contained in Table 2. Table 3 contains the block mosaics for the basic alpha-mosaic service and also the new smooth mosaics.
The four tables stored in the external RAM (Tables 4 to 7 ) are used for DRCS.

## Scroll map

The scroll map uses a 26 -byte area of on-chip RAM and functions in association with the timing chain. It maps the scan row on to the fetched memory row so allowing the stored page to be displayed in any row order. For each row, a 1-byte pointer to the display memory row is stored in the scroll map. This allows scrolling without the need for data transfer to, or from, side storage.
Additional control bits are stored, allowing 1 to 25 rows to be displayed at any location on the screen.

## Colour map and digital-to-analogue converters

The colour map RAM contains thirty-two 12-bit words that are loaded by the microprocessor and read out in three 4 -bit groups at pixel rate. Each group is fed to a non-linear (gamma-corrected) D-A converter. The resulting $R, G$ and $B$ outputs are low-impedance with peak-to-peak amplitudes controlled by the reference voltage applied at pin 21.

## Cursor

The cursor is available in the stack mode. Its position, character code, character table, foreground colour, background colour, lining and flash attributes are all software programmable via internal register bits.

## NON-VIDEOTEX APPLICATIONS

For non-Videotex applications, the device will also support the following operating modes:
Explicit fill mode. An alternative 40 character/rows mode which does not use the memory compression technique of stack coding. More display memory is required but there are no limitations on the number of display attribute changes per row.
80 characters/rows mode. When operating with 80 characters per row, the available display attributes are eight foreground colours, eight (potentially different) background colours (including transparent) as well as underline and blink.
Full field DRCS mode. This mode is not mutually exclusive to the explicit fill and 80 characters/rows modes but rather the available DRCS memory is expanded so that the whole screen can be covered, thus enabling a 'bit map'. All ROM-based characters and all display attributes remain available.

## MICROPROCESSOR and RAM BUS INTERFACE

Three types of data transfer take place at the bus interface:

- EUROM fetches data from the display memory
- The microprocessor reads from, or writes to, EUROM's internal register map
- The microprocessor accesses the display memory

EUROM access to display memory (Figs 17 and 18)
EUROM accesses the external display memory via a 16 -bit multiplexed address and data bus with a cycle time of 500 ns . The address strobe ( $\overline{\mathrm{AS}}$ ) signal from EUROM flags the bus cycle and writes the address into octal latches (74LS373). The display data is stored in bytes of upper (most-significant) and lower (least-significant) display information and is always fetched in pairs of bytes (upper + lower = 16 bits). The upper and lower display RAM sections are enabled simultaneously by the upper and lower data strobes (respectively UDS and $\overline{\mathrm{LDS}}$ ) which are always asserted together to fetch a 16 -bit word. The read/write control R/W is included although EUROM only reads from the display memory.

(1) 74LS373 octal transparent latch (3-state)

Fig. 17 Simple RAM interface circuit for display memory access.


Fig. 18 Bus timing for display memory access.

## APPLICATION INFORMATION (continued)

## EUROM access to display memory (continued)

The display memory organization uses the word/byte addressing convention adopted for the SCN68000 microprocessor series. Data fetched on the 16 -bit bus is considered in terms of bytes where the even numbered bytes use the upper (most-significant) part of the bus as shown in Fig. 19. The word addresses are numerically the same as the upper byte that they contain - there are no odd-numbered word addresses.


Fig. 19 Display memory word/byte organization.

## Warning time

As EUROM is a real-time display device, it must have direct access to the display memory with priority over the microprocessor and other peripheral devices. This is achieved by EUROM issuing a bus request $(\overline{B R})$ signal for the duration of the memory access plus a programmable advance warning time which allows the microprocessor to complete its current bus cycle.
In systems where the buses of the microprocessor and EUROM are intimately connected (connected systems), $\overline{B R}$ may be used to suspend all microprocessor activity so that EUROM can act as a dedicated DMA controller. In systems where the two buses are separated by buffers (disconnected systems), $\overline{\mathrm{BR}}$ may be used either to generate an interrupt or as a direct signal. To these ends, the warning time between the assertion of $\overline{B R}$ and the beginning of EUROM's bus activity is programmable to be between 0 and $23 \mu$ s.

## Microprocessor access to register map

EUROM has a set of internal registers which, when memory-mapped, behave as an 8-bit wide RAM connected to the upper part of the data bus (Fig. 20). The control signals UDS and R/W are reversed to become inputs and the register map is enabled by the signal $\overline{R E}$. Addresses are input via the lower part of the bus. A data transfer acknowledge signal ( $\overline{\mathrm{DTACK}}$ ) indicates to the microprocessor that the data transfer is complete.


Fig. 20 Microprocessor access to register map.
The main data and address paths used in a connected 68000 interface are shown in Fig. 21. The outputs from the octal latches (74LS373) are enabled only when the 68000 has made the bus available in response to a bus request ( $\overline{B R}$ ). When the register map is accessed data is transferred via the upper part of the bus and the microprocessor's low-order address is passed to EUROM via the octal buffers (74LS244). At the same time the bidirectional buffers (74LS245) disable the signals from the low order data bus of the 68000 .
The buffers ' 244 and ' 245 may be omitted in a 16 -bit write-only configuration where the least-significant data byte is interpreted by EUROM as an address. Here it will generally be necessary for the microprocessor to hold a (readable) 'master copy' of EUROM's scroll map contents at a location in its main memory.

## 8-bit microprocessors

Although the control bus is optimised for the SCN68000 16-bit microprocessor unit, EUROM will operate with a number of widely differing industry-standard 8,16 or more-bit microprocessors or microcontrollers (e.g. SCN68008, MAB8051). The interfacing of 8 -bit microprocessors to the 16 -bit wide display memory is made simple by EUROM's on-chip link-through buffer which provides the microprocessor with bidirectional access to the lower (odd) half of the memory. The link-through buffer is enabled by the buffer-enable signal BUFEN, and the send/receive direction is controlled by the signal $\bar{S} / R$.
The main data and address paths used in a connected 8-bit microprocessor system are shown in Fig. 22. The interface is similar to that of the 16 -bit system but here the display memory does not receive AO as an address, rather AO is used as the major enabling signal for BUFEN (enables when HIGH).

## APPLICATION INFORMATION (continued)



Fig. 21 Connected 16 -bit microprocessor system.

(1) 74LS373 octal transparent latch (3-state)
(2) 74LS244 octal buffer (3-state)

Fig. 22 Connected 8 -bit microprocessor system.

## APPLICATION INFORMATION (continued)

## Disconnected systems

For many applications it may be desirable to disconnect EUROM and the display memory from the microprocessor and its ROM, RAM and other peripherals by using isolating buffers as shown in Fig. 23. The two parts of the system then operate independently and communicate only when the microprocessor accesses EUROM's register map or the display memory.

(1) 74LS373 octal transparent latch (3-state)
(2) 74LS244 octal buffer (3-state)
(3) 75LS245 octal bus transceiver (3-state)

Fig. 23 Disconnected 8-bit system.

## Synchronization

## Stand-alone mode

As a stand-alone device (e.g. in terminal applications) EUROM can output a composite sync signal (TCS) to the display timebase IC or to a monitor. Timing is obtained from a 6 MHz on-chip oscillator using an external crystal as shown in Fig. 24.


Fig. 24 Stand-alone synchronization mode.

## Simple-slave

In the simple-slave mode EUROM synchronizes directly to another device, such as to the $\overline{\text { TCS }}$ signal from the SAA5240 European computer-controlled teletext circuit (CCT) or from another EUROM as shown in Fig. 25. EUROM's horizontal counter is reset by the falling edge of TCS. A dead time of 250 ns is built in to avoid resetting the counter at every tv line and so prevents screen jitter. Field synchronization is made using EUROM's internal field sync separator.


Fig. 25 Simple-slave (direct sync) mode.

## APPLICATION INFORMATION (continued)

## Synchronization (continued)

## Phase-locked slave

The phase-locked slave (indirect sync) mode is shown in Fig. 26. A phase-locked VCO in the SAA5230 teletext video processor provides sync to the timebases. When EUROM is active, its horizontal counter forms part of the phase control loop - a horizontal reference is fed back to the SAA5230 from the SAND output and a vertical reference is generated by feeding separated composite sync to EUROM's field sync separator via the VCS input. In the phase-locked slave mode, the display derived from EUROM can sync with that from a tv source or a local VLP player, thus giving picture-in-text display possiblities.


Fig. 26 Phase-locked slave (indirect sync) mode.

## Display Character and Graphics Generator (DCGG)

Product Specification
Originally published by Signetics February 1985

## DESCRIPTION

The Signetics SCN2670 Display Character and Graphics Generator (DCGG) is a mask-programmable 11,648-bit line select character generator. It contains 128 $10 \times 9$ characters placed in a $10 \times 16$ matrix, and has the capability of shifting certain characters, such as j, y, g, p and q , that normally extend below the baseline. Character shifting, previously requiring additional external circuitry, is now accomplished internally by the DCGG; effectively, the 9 active lines are lowered within the matrix to compensate for the character's position.

## FEATURES

- $5 \times 7$ or $7 \times 9$ character fonts
- $12810 \times 9$ matrix characters
- 256 graphic characters
- Optional thin graphics for forms
- Character and line address latches
- Internal descend logic
- 200nsec and 300 nsec character select access time versions
- Control character output inhibit logic
- Static operation - no clocks required
- Single 5V power supply
- TTL compatible inputs and outputs

BLOCK DIAGRAM


ORDERING CODE


## PIN DESCRIPTION

| MNEMONIC | PIN NO. | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| CAO-CA7 | $\begin{aligned} & 3-6 \\ & 8-11 \end{aligned}$ | 1 | Character Address: Eight bit code specifies the character or graphic pattern for which matrix data is to be supplied. In character mode ( $G M=0$ ), CA0 through CA6 select one of the 128 ROM-defined characters and CA7 is a chip enable. The outputs are active when CA7 $=1$ and are three-stated when CA7 $=0$. In graphics mode ( $G M=1$ ), the outputs are always active and CAO through CA7 select one of 256 possible graphic patterns to be output. |
| CSTROBE | 7 | 1 | Character Strobe: Used to store the character address (CAO through CA7) and graphics mode (GM) inputs into the character latch. Data is latched on the negative going edge of CSTROBE. Can be connected to the $\overline{\text { CCLK }}$ of the Signetics attributes controller chips. |
| GM | 12 | 1 | Graphics Mode: GM $=0$ (low) selects character mode; $\mathrm{GM}=1$ (high) selects graphics mode. |
| LAO - LA3 | $\begin{gathered} 1, \\ 25-27 \end{gathered}$ | 1 | Line Address: In character mode, selects one of the 16 lines of matrix data for the selected character to appear at the 10 outputs. LAO is the LSB and LA3 is the MSB. The input codes which cause each of the nine lines of character data to be output are specified as part of the programming data for both non-shifted and shifted fonts. Cycling through the nine specified counts at the LAO through LA3 inputs cause successive lines of data to be output on D0 through D9. The 7 non-specified codes for both non-shifted and shifted characters cause blanks (logic zeros) to be output. In graphics mode, the line address gates the latched graphics data directly to the outputs. |
| LSTROBE | 2 | 1 | Line Strobe: Used to store the line address data (LAO through LA3) in the line address latch. Data is latched on the negative going edge of LSTROBE. Can be connected to the BLANK output of the Signetics video display controller chips. |
| SCD | 13 | 1 | Selected Character Disable: In character mode, a high level at this input causes all outputs (regardless of line address) to be blanks (zeros) for characters for which CA6 and CA5 are both 0 . A low level input selects normal operation. Inoperative in the graphics mode. |
| D9 - D0 | 15-24 | 0 | Data Outputs: Provide the data for the specified character and line. |
| $V_{C C}$ | 28 | 1 | +5V power supply. |
| GND | 14 | 1 | Ground. |

Seven bits of an 8-bit address code are used to select 1 of the 128 available characters. The eighth bit functions as a chip enable signal. Each character is defined by a pattern of logic 1 's and 0 's stored in a $10 \times 9$ matrix. When a specific 4-bit binary line address code is applied, a word of 10 parallel bits appears at the output. The lines can be sequentially selected, providing a 9 -word sequence of 10 parallel bits per word for each character selected by the address inputs. As the line address inputs are sequentially addressed, the device will automatically place the $10 \times 9$ character in 1 of 2 pre-programmed positions on the 16 -line matrix with the positions defined by the 4 -line address
inputs. One or more of the 10 parallel outputs can be used as control signals to selectively enable functions such as half-dot shift, color selection, etc.
The SCN2670 DCGG includes latches to store the character address and line address data. A control input to inhibit character data output for certain groups of characters is also provided. The SCN2670 also includes a graphics capability, wherein the 8 -bit character code is translated directly into 256 possible user programmable graphic patterns. Thus, the DCGG can generate data for 384 distinct patterns, of which 128 are defined by the mask programmable ROM. See figure 1 for a typical applications display.

## FUNCTIONAL DESCRIPTION

The DCGG consists of nine major sections. Line and character codes are strobed into the line and character latches. The character latch outputs are presented to the three sources of data; the ROM through an address decoder, the graphics logic, and the output inhibit control. The output inhibit control (together with the SCD input) suppresses the ROM data for selected character codes. The outputs from the line latch drive the line address translation ROM which maps the character ROM data onto 9 of 16 line positions. Finally, the line select multiplexers route the ROM or graphics data to the output drivers on D0 through D9.


Figure 1. Typical Application Using The $7 \times 9$ Character Font

## Character Latch

The character latch is a 9-bit edge triggered latch used to store the character address (CAO through CA7) and graphics mode (GM) inputs. The data is stored on the falling edge of CSTROBE. Seven latched addresses (CAO through CA6) are inputs to the FOM character address decoder. In character mode ( $G M=0$ ), CA7 operates as a chip enable. The output drivers are enabled when CA7 $=1$ and are three-stated when CA7 $=0$. In graphics mode ( $\mathrm{GM}=1$ ), the output drivers are always enabled and the CAO through CA7 outputs of the latch are used to generate graphic symbols.

## Character Address Decoder

This circuit decodes the 7 -bit character address from the character latch to select one of the 128 character fonts stored in the ROM section of the DCGG.

## Read Only Memory

The 11,648-bit ROM stores the fonts for the 128 matrix-defined characters. The data for each character consists of 91 bits. Ninety bits represent the 10X9 matrix and one bit specifies whether the character data is output at the normal (unshifted) lines or at the descended (shifted) lines. The 90 data bit outputs are supplied to the line select multiplexers. The descend control bit is an input to the line address translation ROM.

## Graphics Logic

When the GM input is zero (low), the DCGG operates in the character mode. When it is one (high), it operates in the graphics mode. In graphics mode, output data is generated by the graphics logic instead of the ROM. The graphics logic maps the latched character address (CAO through CA7) to the outputs (D0 through D9) as a function of line address (LAO through LA3). For any particular line address value, two of the CA bits are output: CAO, CA2, CA4 or CA6 is output on D0 through D4 and CA1, CA3, CA5 or CA7 is output on D5 through D9. The outputs are paired: When CAO is output on DO through D4, CA1 is output on D5 through D9 and likewise for CA2-CA3, CA4-CA5 and CA6-CA7.

A ROM within the graphics logic allows the specific line numbers for which each pair of bits is output to be specified by the customer. Figure 2 illustrates the general format for graphics symbols and an example where CA7 through CAO $=H^{\prime} 65^{\prime}$. The outputs from the graphics logic go to the line select multiplexers. The multiplexers route the graphic symbol data to the outputs when GM=1.

## Thin Graphics Option

As a customer specified option, 16 of the possible graphic codes ( $H^{\prime} 80^{\prime}$ to $\mathrm{H}^{\prime} 8 \mathrm{~F}^{\prime}$ ) may be used to generate the special graphic
characters illustrated in figure 3. For each of these characters, the vertical component appears on the D4 output. The horizontal component occurs on $L_{H}$ which is specified by the customer. The vertical components specified by CAO and CA2 are output for line addresses zero through $L_{H}$ and $L_{H}$ through fifteen, respectively.

## Line Select Multiplexers

The ten line select multiplexers select ROM data as specified by the line address translation ROM when GM $=0$, or graphics data when $\mathrm{GM}=1$. The inputs to each multiplexer are the nine line outputs from the ROM, an output from the graphics logic and a logic zero (ground).

## Output Drivers

Ten output drivers with 3 -state capability serve as buffers between the line select multiplexers and external logic. The 3-state control input to these drivers is supplied from the CA7 latch when GM $=0$. When $\mathrm{GM}=1$, the outputs are always active.

## Output Inhibit Control

The output inhibit control logic operates only if $\mathrm{GM}=0$. It causes the output of the line select multiplexers to be logic zero if the SCD input is high and CA6 and CA5 of the latched character address are 00. If the SCD input is low, normal operation occurs. (This feature is useful in ASCII coded applications to selec-


Table 1. MEMORY MAP FORMAT

| 2732 Byte Address | Data |
| :---: | :---: |
| 0 | $0=$ No thin graphics $\quad 1=$ Thin graphics |
| 1 | Line address for the horizontal segment of the thin line graphics fonts (set to ' 0 ' if byte $0=$ ' 0 '). |
| 2-17 (2-11H) | Specify group number $(1-4)$ to be output at the corresponding line address ( $0-\mathrm{F}$ ). A ' 0 ' specifies no data for that address. |
| 18(12H) | Line address at which the first NONSHIFTED font data appears. |
| 19(13H) | second |
| 20(14H) | third |
| 21(15H) | fourth |
| 22(16H) | fifth |
| 23(17H) | sixth |
| 24(18H) | seventh |
| 25(19H) | eighth |
| 26(1AH) | ninth |
| 27(1BH) | Line address at which the first SHIFTED font data appears. |
| 28(1CH) | second |
| 29(1DH) | third |
| 30(1EH) | fourth |
| 31(1FH) | fifth |
| 32(20H) | sixth |
| 33(21H) | seventh |
| 34(22H) | eighth |
| 35(23H) | ninth |
| 36(24H) | Font truth table printout format |
|  | $0=$ Left to right printing of horizontal data bits D0 - D9 <br> $1=$ Left to right printing of horizontal data bits $\mathrm{D} 9-\mathrm{D} 0$ |
| 37(25H) | Font truth table printout format <br> $0=$ Top to bottom printing of vertical line addresses ( $0-\mathrm{FH}$ ) <br> $1=$ Top to bottom printing of vertical line addresses ( $\mathrm{F}-\mathrm{OH}$ ) |
| $\begin{aligned} & 38-57 \\ & (26-39 H) \end{aligned}$ | Character 0 data |
| $\begin{aligned} & 58-77 \\ & (3 A-4 D H) \end{aligned}$ | Character 1 data |
| - | - |
| - | - |
| 2578-2597 | Character 128 (7F H) data |
| (A12-A25H) |  |

tively disable character generation for nondisplayable characters such as line feed, carriage return, etc.)

## Line Address Latch

The line address latch is a 4-bit latch used to store the line address (LAO-LA3). The data is stored on the negative edge of the LSTROBE input.

## Line Address Translation ROM

This $32 \times 10$ ROM translates the 5 -bit code consisting of the 4 outputs from the line address latch and the descend control bit from the ROM into a 1 -of-10 code for the line select multiplexers. Programming information provided by the customer specifies the address which selects each line of ROM data for both shifted and non-shifted characters. Thus, there are nine line addresses which select ROM data for unshifted characters and nine addresses for shifted characters. These combinations are usually specified by the customer in either ascending or descending order. For the remaining 14 codes ( 7 each for unshifted and shifted characters), the translation ROM forces zeros at the outputs of the line select multiplexers.

This circuitry only operates if $\mathrm{GM}=0$. When $\mathrm{GM}=1$, the line select multiplexers are forced to select the outputs from the graphics logic.

Figure 4 shows an example of data outputs where the customer has specified line 1 as the first line for unshifted characters, line 4 as the first line for shifted characters and line address combinations in ascending order.


## $5 \times 7$ Design Note

The $5 \times 7$ character fonts of the 2670 C have been centered in the $10 \times 9$ character fields. Because of this centering, only the D1 through D8 data bus pins (pins 23 through 16) are to be used for the character data. D1 can be connected to the least significant bit of the Signetics Video Attributes Controller data bus (D0), D2 of the 2670C can be connected to U1 of the attributes controiler, etc. The DO and D9 pins will always be read as zero and will not be connected.

## CUSTOM PATTERN

PROGRAMMING INSTRUCTIONS
Signetics requires that the customer supply them with a 2732 EPROM containing the necessary data for specifying a custom version of the SCN2670. The 2732 will contain the data to be stored in the ROM array, the programmable line address translation ROM, thin graphics option and the graphics line font translation ROM. Signetics will no longer accept card decks.

The memory map format for programming the 2732 is contained in table 1.

Bytes 0 and 1 relate to the thin line graphics option. Thin line graphics consists of two components: a vertical and a horizontal segment. The vertical segment always occurs at the D4 output. The location of the horizontal segment (line addresses $0-15$ ) is specified by the customer in byte 1.

Bytes 2 through 17 correspond to how the graphics blocks are created from the 16 horizontal addresses. A '0' specifies no data for that address. Figure 5 shows an example of how the character field can be divided into the graphics blocks. The line addresses can be divided into a maximum of four groups.
Since line addresses $A$ through $F$ are not used, byte addresses 12 through 17 are set to ' 0 '. Line addresses 0 and 1 are part of group 1, so byte addresses 2 and 3 are set equal to ' 1 '. Line addresses 2 through 4 are in group 2, so byte addresses 4 through 6 are set equal to '2'. The same procedure is followed for the remaining line addresses. The group numbering assignments must be sequential (i.e., line address 1 cannot be in group 2 if line addresses 0 and 2 are in group 1).


Figure 4. Customer Specified Example


Figure 5. Character Field Divisions


Byte Addresses 18 through 26 are used to indicate which line address the nonshifted character fonts begin and end. The first line of the character font must occur from line address 0 to 7 . If the character font begins at line address 2, the byte addresses are set up as follows:

| BYTE ADDRESS | DATA |
| :---: | :---: |
| 18 | 2 |
| 19 | 3 |
| 20 | 4 |
| 21 | 5 |
| 22 | 6 |
| 23 | 7 |
| 24 | 8 |
| 25 | 9 |
| 26 | 10 |

Byte Addresses 27 through 35 are used to indicate which line address the shifted character fonts begin and end. Again the first line of the character font must occur from line addresses 0 through 7. The data is entered the same as for the nonshifted character fonts above.

Bytes 36 and 37 are only used for printouts of the ROM codes by Signetics.
The remaining byte addresses ( $38-2597$ ) contain the data for the 128 characters. Each character consists of 20 bytes. The format is contained in figure 6.

Character Byte 1 (CA) contains the character address (CA6-CA0).

For character byte 2, if $\mathrm{S} / \mathrm{NS}=$ ' 1 ', the character font will begin at the shifted location as specified by byte addresses 27-35. If S/ $N S=$ ' 0 ', then the character font will begin at the nonshifted location as specified by byte addresses 18-26.

The remaining character bytes define the nine line character font. The bytes are paired as each font line requires 10 bits of information to be output on lines D9 - D0 (see figure 6). Remember, when coding each line, D9 is the rightmost bit of the character line, and DO is the leftmost bit.

## Printouts

Signetics will submit the following printouts to the customer for approval:

- A repeat of all customer information.
- A separate font drawing for each of the 128 ROM characters and 256 graphics fonts. The font drawings are positioned on a $10 \times 16$ matrix as specified by the customer's translation data.


## Customer Example

A question mark has a character address of 3F hex. The character code for it is as follows:

| LO | $\times \times \times \times \mathrm{X}$ |
| :---: | :---: |
| L1 | X . . . . X |
| L2 | X . . . . . $X$ |
| L3 | $x$ |
| L4 | . XX |
| L5 | . X |
| L6 | . . X |
| L7 | - . . . . . . |
| L8 | . X |
| bit | 0123456789 |


| Character |  |  |
| :---: | :---: | :---: |
| Byte 1: 3F |  |  |
| 2: 00 |  | (nonshifted) |
| 3: 00 | 4: C7 | (Line 1) |
| 5: 00 | 6: 28 | (Line 2) |
| 7: 00 | 8: 28 | (Line 3) |
| 9: 00 | A: 08 | (Line 4) |
| B: 00 | C: 06 | (Line 5) |
| D: 00 | E: 01 | (Line 6) |
| F: 00 | 10: 01 | (Line 7) |
| 11: 00 | 12: 00 | (Line 8) |
| 13: 00 | 14: 01 | (Line 9) |

We recommend that the character fonts be created with respect to the center of the $10 \times 16$ character field (data bit D4) for optimum symmetry, especially if thin line graphics is implemented as the vertical segment is always located at bit D4.

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| PARAMETER | RATING | UNIT |
| :--- | :---: | :---: |
| Supply voltage | 6.0 | V |
| Operating ambient temperature ${ }^{2}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| All voltages with respect to ground $^{3}$ | -0.3 to +6.0 | V |

NOTES:

1. Stresses above 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 condition above those indicated in the operation section of this specification is not implied.
2. For operating at elevated temperatures, the device must be derated based on $+150^{\circ} \mathrm{C}$ maximum junction temperature and thermal resistance of $60^{\circ} \mathrm{C} / \mathrm{W}$ junction to ambient (ceramic package).
3. This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying any voltages larger than the maxima.

DC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%^{1,2,3}$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input low voltage |  |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input high voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output low voltage | $\mathrm{t}_{0}=1.6 \mathrm{~mA}$ | 0 |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output high voltage | $10=-100 \mu \mathrm{~A}$ | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}$ | $V$ |
| 1 L | Input leakage current | $\mathrm{V}_{\text {IN }}=0$ to 4.25 V |  |  | 10 | $\mu \mathrm{A}$ |
| 1 loL | Output leakage current | $\mathrm{V}_{\mathrm{O}}=0.4$ to 4 V | -10 |  | $+10$ | $\mu \mathrm{A}$ |
| ICC | Supply current | $V_{C C}=5.25 \mathrm{~V}$ |  | 35 | 80 | mA |
| $\mathrm{C}_{\mathrm{iN}}$ | Input capacitance | All other pins grounded |  |  | 10 | pF |
| Cout | Output capacitance |  |  |  | 15 | pF |

AC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%^{1,2,3,4}$

| PARAMETER |  | LIMITS |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 300ns |  | 200ns |  |  |
|  |  | Min | Max | Min | Max |  |
| $t_{\text {WS }}$ | Strobe pulse width | 100 |  | 100 |  | ns |
| tLAS | Line address set-up | 50 |  | 50 |  | ns |
| $t_{\text {LAH }}$ | Line address hold | 25 |  | 25 |  | ns |
| tcas | Character address set-up | 25 |  | 15 |  | ns |
| $t_{\text {CAH }}$ | Character address hold | 25 |  | 15 |  | ns |
| $t_{\text {ca }}$ | Character select access | 30 | 300 | 30 | 200 | ns |
| tLA | Line select access | 30 | 500 | 30 | 350 | ns |
| $t_{\text {SEL }}$ | Chip select delay |  | 250 |  | 150 | ns |
| t DES | Chip deselect delay |  | 200 |  | 125 | ns |
| $\mathrm{t}_{\mathrm{SC}}$ | Special character blank/unblank time |  | 300 |  | 200 | ns |

## NOTES:

1. Parameters are valid over operating temperature range unless otherwise specified.
2. All voltage measurements are referenced to ground. All time measurements are at the 0.8 V or 2.0 V level for inputs and outputs. Input levels are 0 V and 2.4 V .
3. Typical values are at $+25^{\circ} \mathrm{C}$, typical supply voltages and typical processing parameters.
4. Test conditions: $C_{L}=100 \mathrm{pF}$ and 1 TTL load.

## TIMING DIAGRAMS



NOTE:

1. When $G M=1, S C D$ input is inactive.


## NOTE:

1. CA7 operates as output enable only in character mode ( $\mathrm{GM}=0$ ).







20watos

# Programmable Keyboard and Communications Controller (PKCC) 

## DESCRIPTION

The Signetics SCN2671 Programmable Keyboard and Communications Controller (PKCC) is an MOS LSI device which provides a versatile keyboard encoder and an independent full duplex asynchronous communications controller. It is intended for use in microprocessor based systems and provides an eight bit data bus interface.

The keyboard encoder handles the scanning, debounce, and encoding of a keyboard matrix with a maximum of 128 keys. It provides four levels of key encoding corresponding to the separate SHIFT and CONTROL input combinations. Four keyboard rollover modes can be programmed including provisions for up to 16 latched keys. Control outputs are provided for interfacing with contact or capacitive keyboards. An eight bit keyboard status register provides status information to the CPU.

The receiver section of the communications controller accepts serial data from the RxD pin and converts it to parallel data characters. Simultaneously, the transmitter section accepts parallel data from the data bus and outputs serialized data onto the TxD pin. Received data is checked for parity and framing errors, and break conditions are flagged. Character lengths can be programmed as 5 , 6,7 , or 8 bits not including parity, start or stop bits. An internal baud rate generator (BRG) with 16 divider ratios can be used to derive the receive and/or transmit clocks. The BRG can accept an external clock or operate directly from a crystal. An eight bit communications status register provides status information to the CPU.

## FEATURES

- Keyboard Interface
- Contact or capacitive keyboard
- Up to 128 keys on an $8 \times 16$ matrix
- Encoded or unencoded operation
- Four code levels per key
- Latched key option-separate depress and release codes
- Programmable scan rate and debounce time
- Programmable rollover modes
- Programmable auto-repeat for selected keys
- Tone output-two frequencies
- Asynchronous communication interface
- Internal baud rate generator-16 rates
- Full duplex operation
- Detection of start and end of break
- Programmable break generation
- Programmable character parameters
- Auto-echo and maintenance loopback modes
- Polled or interrupt operation
- Interrupt priority controller and vector generator
- Operates directly from crystal or external clocks
- TTL compatible
- Single +5 volt power supply


## APPLICATIONS

- CRT terminals
- Hard copy terminals
- Word processing systems
- Data entry terminals
- Small business computers


## PIN CONFIGURATION



ORDERING CODE

| PACKAGES | $\mathrm{V}_{\mathbf{C C}}=5 \mathrm{~V} \pm 5 \%, \mathbf{T}_{\mathbf{A}}=\mathbf{0}^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Ceramic DIP | SCN2671AC1140 |
| Plastic DIP | SCN2671AC1N40 |
| Plastic LCC | SCN2671AC1A44 |

## BLOCK DIAGRAM



## PIN DESCRIPTION

| MNEMONIC | PIN <br> NO. | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| D0-D7 | $\begin{aligned} & 16-19 \\ & 23-26 \end{aligned}$ | 1/0 | Data Bus: 8-bit three-state bidirectional data bus. All data, command and status transfers are made using this bus. D0 is the least significant bit; D7 is the most significant bit. |
| AO-A2 | 31-33 | 1 | Address Lines: Used to select internal PKCC registers or commands. |
| $\overline{\mathrm{RD}}$ | 29 | 1 | Read Strobe: When low, gates the selected PKCC register onto the data bus if $\overline{\mathrm{CE}}$ is also low. |
| $\overline{W R}$ | 28 | 1 | Write Strobe: When low, gates the contents of the data bus into the selected PKCC register if $\overline{\mathrm{CE}}$ is also low. |
| $\overline{C E}$ | 30 | 1 | Chip Enable: When high, places the D0 - D7 output drivers in a three-state condition. If $\overline{\mathrm{CE}}$ is low, data transfers are enabled in conjunction with the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs. |
| $\overline{\text { INTR }}$ | 22 | 0 | Interrupt Request: Several conditions may be programmed to request an interrupt to the CPU. It is an active low open-drain output. This pin will be inactive after power on reset or a master reset command. |
| $\overline{\text { INTA }}$ | 27 | 1 | Interrupt Acknowledge: Used to indicate that an interrupt request has been accepted by the CPU. When $\overline{\text { INTA }}$ goes low, the PKCC outputs an 8 -bit address vector on D0 - D7 corresponding to the highest priority interrupt currently active. |
| $\overline{\text { XINTR }}$ | 21 | 1 | External Interrupt: An active low external interrupt input to the PKCC interrupt priority resolver. |
| TxC | 34 | 1/0 | Transmitter Clock: The function of this pin depends on bit 7 of the baud rate control register (BRR7). If external transmitter clock is selected ( $B R R 7=0$ ), it is an input for the transmitter clock. If internal transmitter clock is selected (BRR7 = 1), this pin is an output which is a multiple of the actual baud rate ( 1 X , 16 X ) as selected by BRR5. The data is transmitted on the falling edge of TxC. It is an input after power on and after master reset or communications reset commands. |
| RxC | 35 | 1/0 | Receiver Clock: The function of this pin depends on BRR6. If external receiver clock is selected ( $B R R 6=0$ ), it is an input for the receiver clock. If internal receiver clock is selected (BRR6 $=1$ ), this pin is an output which is a multiple of the actual baud rate $(1 X, 16 X)$ as selected by BRR4. The received data is sampled on the rising edge of RxC . It is an input after power on and after master reset or communications reset commands. |
| TxD | 38 | 0 | Transmitter Data: This output is the transmitted serial data; t.ie least significant bit is transmitted first. This pin is high after power on reset or a reset command that affects the transmitter. |
| RxD | 39 | 1 | Receiver Data: This input is the serial data input to the receiver. The least significant bit is received first. |
| $\begin{aligned} & \text { XTAL1, } \\ & \text { XTAL2/BRCLK } \end{aligned}$ | 36,37 | 1 | Connections for Crystal: Provides an on-chip clock generator for the internal baud rate generator and the keyboard interface logic. If an external clock is provided, use XTAL2 as the clock input. See figures 20 and 21. All timing parameters such as keyboard scan time, tone frequency, and baud rate assume a clock input at the specified BRG input frequency. If this frequency is different the timing parameters will vary proportionately. |
| KRO-KR2 | 10-8 | 0 | Keyboard Row Scan: Decoded externally; selects one of eight rows. |
| KCO-KC3 | 7-4 | 0 | Keyboard Column Scan: Decoded externally; selects one of 16 columns. |
| KRET | 15 | 1 | Key Return: An active high level indicates that the key being scanned is closed. |
| $\overline{\text { SHIFT }}$ | 12 | 1 | SHIFT Key: Active low input from the SHIFT key. The combination of SHIFT and CONTROL inputs select one of four possible codes from the internal key encoding ROM. |
| $\overline{\text { CONTROL }}$ | 13 | 1 | CONTROL Key: Active low input from the CONTROL key. The combination of SHIFT and CONTROL inputs select one of four possible codes from the internal key encoding ROM. |
| REPEAT | 11 | 1 | REPEAT Key: Active low input from the REPEAT key. Causes the key depression currently active to be repeated at a rate of approximately 15 times per second. |
| KCLK | 3 | 0 | Keyboard Clock: High frequency (approximately 400 kHz ) output used to scan capacitive keyboards. |
| KDRES | 2 | 0 | Key Detect Reset: Resets the analog detector before scanning a key. Used for capacitive keyboards. |
| $\overline{\mathrm{HYS}}$ | 1 | 0 | Hysteresis Output: Sent to the analog detector for capacitive keyboard applications. A low indicates the key currently being scanned has been recognized on previous scan cycles. |
| TONE | 14 | 0 | Square Wave Output: Used for tone generation. |
| $V_{\text {CC }}$ | 40 | 1 | +5V power supply. |
| $V_{S S}$ | 20 | 1 | Ground. |

The PKCC has an interrupt mask register to selectively enable certain keyboard and communications status bits to generate interrupts. Priority encoded interrupt vectoring is available. Upon receipt of an interrupt acknowledge, an interrupt vector will be output on D0 - D7 reflecting the source of the interrupt. The interrupt source can also be read from an inteĭrupt status register.

## FUNCTIONAL DESCRIPTION

The PKCC consists of six major sections (see blook diagram). These are the transmitter, receiver, timing, operation control, keyboard encoder, and a priority encoded interrupt control unit. These sections communicate with each other via an internal data bus and an internal control bus. The internal data bus interfaces to the microprocessor data bus via a bidirectional data bus buffer.

## Operation Control

This functional block stores configuration and operation commands from the CPU and generates appropriate signals to various internal sections to control the overall device operation It contains read and write circuits to permit communications with the microprocessor via the data bus and contains mode registers KMR and CMR, the command decoder, and status registers KSR and CSR. Details of operating modes and status information are presented in the Operation section of this data sheet. The register addressing is specified in table 1.

## Timing

The PKCC contains a baud rate generator (BRG) which is programmable to accept external transmit or receive clocks or to divide an external clock to perform data communications. The unit can generate 16 baud rates, any of which can be selected for full duplex operation. The external clock to the baud rate generator can be applied directly to the XTAL2 input (see figure 21) or can be generated internally by connecting a crystal across the XTAL1, XTAL2 input pins. The clock input is also utilized by the keyboard encoder section. Thus, a clock must be provided even if external transmitter and receiver clocks are used.

## Receiver

The receiver accepts serial data on the FxD pin, converts this serial input to parallel format, checks for break conditions, framing and parity errors, and loads an "assembled" character in the receive holding register for access by the CPU.

## Transmitear

The transmitter accepts parallel data loaded by the CPU into the transmit holding register and converts it to a serial bit stream framed by the start bit, calculated parity bit (if speci-

Table 1. REGISTER ADDRESSING

| $\overline{\mathbf{C E}}$ | $\mathbf{A 2}$ | $\mathbf{A 1}$ | $\mathbf{A 0}$ | $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ | FUNCTION |
| :---: | :---: | :---: | :--- | :--- | :--- |
| 1 | X | X | X | X | Three-state data bus |
| 0 | 0 | 0 | 0 | $\overline{\mathrm{WR}}$ | Reset command (see table 6) <br> 0 |
| 0 | 0 | 0 | $\overline{\mathrm{RD}}$ | Read interrupt status register (ISR) |  |
| 0 | 0 | 0 | 1 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | Read/write communications mode register (CMR) |
| 0 | 0 | 1 | 0 | $\overline{\mathrm{WR}}$ | Write transmit holding register (TxHR) |
| 0 | 0 | 1 | 0 | $\overline{\mathrm{RD}}$ | Read receiver holding register (RxHR) |
| 0 | 0 | 1 | 1 | $\overline{\mathrm{WR}}$ | Write baud rate mode register (BRR) |
| 0 | 0 | 1 | 1 | $\overline{\mathrm{RD}}$ | Read communications status register (CSR) |
| 0 | 1 | 0 | 0 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | Read/write interrupt mask register (IMR) |
| 0 | 1 | 0 | 1 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | Read/write keyboard mode register (KMR) |
| 0 | 1 | 1 | 0 | $\overline{\overline{R D}}$ | Read keyboard holding register (KHR) |
| 0 | 1 | 1 | 1 | $\overline{\mathrm{RD}}$ | Read keyboard status register (KSR) |
| 0 | 1 | 1 | 1 | $\overline{\mathrm{WR}}$ | Miscellaneous commands (see description) |

NOTE:
$X=$ don't care.
fied), and stop bit(s). The composite serial stream of data is transmitted on the TxD output pin.

## Keyboard Encoder

The keyboard encoder provides encoded scanning signals for a matrix keyboard. Key depressions are detected on the KRET input. The debounced and verified key codes (or matrix addresses) are loaded into the key holding register for access by the CPU. Figures 1 and 2 illustrate the PKCC interface to contact and capacitive keyboards, respectively.

## Interrupt Control

The interrupt controller unit contains a software programmable interrupt mask register which selectively enables status conditions from the keyboard encoder and communication controller to generate interrupts. The interrupts are priority encoded and individually generate an eight bit vector which is output on the data bus in response to a CPU interrupt acknowledge on the INTA input pin.

## OPERATION

## Keyboard Encoder

The keyboard is continuously scanned by KCO-KC3 and KRO-KR2 which are decoded externally to handle 128 possible keys (see figures 1 and 2). KCO - KC3 select one of 16 columns and KRO-KR2 multiplex the eight row return lines into the KRET pin. Debouncing is accomplished by remembering a 1 state at the KRET pin when a key is being addressed and verifying it one scan later. Once the key is verified, a key code is loaded into the keyboard data register (KDR). If the keyboard holding register (KHR) is empty, the contents of the KDR will be transferred to the KHR immediately; if the KHR is full (i.e., the CPU has not read the previous key code), the transfer will be held off until the KHR is read. The data transfer to the KHR causes key-
board data ready (KRDY) to be set in the keyboard status register.
For capacitive keyboards, the high frequency output KCLK can be used to gate the column scan to the keyboard (see figure 2). The key detector reset (KDRES) output resets the analog detector prior to scanning each key location. The output from the analog multiplexer is sensed and then latched in the analog detector. The $\overline{\mathrm{HYS}}$ output controls the sense level. A 0 will lower the sense level causing hysteresis, and a 1 will raise the sense level with no hysteresis.

The REPEAT input enables the keyboard logic to recognize any key repeatedly, 15 times per second. Additionally, certain keys can be programmed to repeat automatically if depressed for more than one-half second.

A square wave is output on the TONE pin when the CPU issues a ring tone command to the PKCC.

## Keyboard Mode Register

Operating modes are selected by programming the keyboard mode register (KMR), see figure 3. Bit KMR7 is used for testing the device. For normal operation, this bit should always be written to a 0 . Bits KMR6 - KMR5 select the rollover modes for keyboard processing:

N-key Rollover: In this mode, the code corresponding to each key depression is loaded into the KDR as soon as that key is debounced, independent of the release of other keys. Two or more closures occurring within one scan cycle are considered to be simultaneous, which will set keyboard error in the keyboard status register (KSR1). As soon as the keyboard holding register is empty, the code in the KDR is transferred to the KHR and the KRDY status bit is set (KSRO).

N-Key Rollover With Latched Keys: This mode is the same as regular N -key rollover,

except that the keys which are assigned to row 0 of the keyboard matrix $(K R 2-K R 0=000)$ produce a code both
when depressed and when released. The codes are independent of the states of the inputs at SHIFT and CONTROL. If one or
more of the latched keys are depressed when the keyboard is enabled (after a keyboard reset), the corresponding codes will be sent out as the keys are scanned and debounced. Note that simultaneous latched keys will not set KERR (KSR1) and that latched keys will not be auto-repeat and will not be affected by the $\overline{R E P E A T}$ input.

Two-Key Rollover: The first key code is loaded into the KDR immediately and the second code is loaded only after the first key is released. Simultaneous keys will set KERR (KSR1), if three or more keys remain closed at any given time, the KERR bit will also be set. All keys must then be released before the next KRET will be processed.

Two-Key Inhibit: All keys must be released between keystrokes; otherwise, KERR (KSR1) will be set.

Bit KMR4 specifies the key encoding mode. Each key is assigned four 8 -bit codes, corresponding to the states of the SHIFT and CONTROL inputs. If the encoded mode is programmed, the row/column address of the detected key is used to load one of the four key codes into the KDR. See table 2 for key code assignments. If the non-encoded mode is programmed, the row/column addrest is loaded directly into the KDR with the following format:


Table 2. STANDARD KEY CODES (HEX)

| $\begin{aligned} & \text { COLUMN } \\ & \text { (KC3-KC0) } \end{aligned}$ | ROW (KR2-KR0) |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 |  | 3 |  | 4 |  | 5 |  | 6 |  | 7 |  |
| 0 | $\begin{array}{\|l\|l} \hline \text { EO } \\ \text { FO } \\ \text { FO } \\ \hline \end{array}$ | $\begin{aligned} & \hline \text { CO } \\ & \text { DO } \\ & \text { CO } \\ & \text { DO } \end{aligned}$ | $\begin{array}{\|l} \hline 1 \mathrm{~B} \\ 1 \mathrm{~B} \\ 1 \mathrm{~B} \\ 1 \mathrm{~B} \end{array}$ | $\begin{aligned} & \hline \text { ESC } \\ & \text { ESC } \\ & \text { ESC } \\ & \text { ESC } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 09 \\ & 09 \\ & 09 \\ & 09 \end{aligned}$ | $\begin{aligned} & \text { HT } \\ & H T \\ & H T \\ & H T \end{aligned}$ | $\begin{array}{\|l\|} \hline 1 F \\ 1 F \\ 1 F \\ 1 F \\ \hline \end{array}$ | $\begin{aligned} & \text { US } \\ & \text { US } \\ & \text { US } \\ & \text { US } \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 A \\ & 1 A \\ & 5 A \\ & 7 A \end{aligned}$ | $\begin{aligned} & \hline \text { SUB } \\ & \text { SUB } \\ & z \\ & z \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 30 \\ 30 \\ 30 \\ 30 \end{array}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 2 B \\ & 3 B \\ & 2 B \\ & 3 B \\ & \hline \end{aligned}$ |  |
| 1 | $\begin{aligned} & \text { E1 } \\ & \text { F1 } \\ & \text { E1 } \\ & \text { F1 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{D} 1 \\ & \mathrm{C} 1 \\ & \mathrm{D} 1 \end{aligned}$ | $\begin{array}{\|l\|} \hline 21 \\ 31 \\ 21 \\ 31 \\ \hline \end{array}$ | $\begin{aligned} & ! \\ & 1 \\ & ! \\ & 1 \end{aligned}$ | $\begin{array}{\|l\|} \hline 11 \\ 11 \\ 51 \\ 71 \end{array}$ | $\begin{aligned} & \mathrm{DC1} \\ & \mathrm{DC1} \\ & \mathrm{Q} \\ & \mathrm{q} \\ & \hline \end{aligned}$ | $\begin{aligned} & 01 \\ & 01 \\ & 41 \\ & 61 \end{aligned}$ | $\begin{aligned} & \mathrm{SOH} \\ & \mathrm{SOH} \\ & \mathrm{~A} \\ & \mathrm{a} \end{aligned}$ | $\begin{array}{\|l\|} \hline 18 \\ 18 \\ 58 \\ 78 \\ \hline \end{array}$ | $\begin{aligned} & \text { CAN } \\ & \text { CAN } \\ & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & 3 D \\ & 2 D \\ & 3 D \\ & 2 D \\ & \hline \end{aligned}$ | $\begin{aligned} & = \\ & = \\ & = \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 2 A \\ 3 A \\ 2 A \\ 3 A \\ \hline \end{array}$ |  |
| 2 | $\begin{array}{\|l\|l} \mathrm{E} 2 \\ \text { F2 } \\ \mathrm{E} 2 \\ \text { F2 } \end{array}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{D} 2 \\ & \mathrm{C} 2 \\ & \mathrm{D} 2 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 22 \\ 32 \\ 22 \\ 32 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & \prime \prime \\ & 2 \end{aligned}$ | $\begin{aligned} & 17 \\ & 17 \\ & 57 \\ & 77 \end{aligned}$ | ETB <br> ETB <br> w <br> $w$ | $\begin{array}{\|l\|} \hline 13 \\ 13 \\ 53 \\ 73 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{DC3} \\ & \mathrm{DC} 3 \\ & \mathrm{~S} \\ & \mathrm{~s} \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 03 \\ 03 \\ 43 \\ 63 \\ \hline \end{array}$ | ETX <br> ETX <br> C <br> c | $\begin{aligned} & \hline 1 \mathrm{E} \\ & 1 \mathrm{E} \\ & 7 \mathrm{E} \\ & 5 \mathrm{E} \end{aligned}$ | $\begin{gathered} \hline \text { RS } \\ \text { RS } \\ \sim \\ \hline \end{gathered}$ | $\begin{aligned} & 1 F \\ & 1 F \\ & 7 F \\ & 5 F \end{aligned}$ |  |
| 3 | $\begin{aligned} & \text { E3 } \\ & \text { F3 } \\ & \text { E3 } \\ & \text { F3 } \end{aligned}$ | $\begin{array}{\|l} \hline \text { C3 } \\ \text { D3 } \\ \text { C3 } \\ \hline \end{array}$ | $\begin{array}{\|l} \hline 23 \\ 33 \\ 23 \\ 33 \\ \hline \end{array}$ | $\begin{aligned} & \# \\ & \# \\ & 3 \\ & \# \\ & 3 \end{aligned}$ | $\begin{array}{\|l\|} \hline 05 \\ 05 \\ 45 \\ 65 \\ \hline \end{array}$ | ENQ <br> ENQ <br> E | 04 <br> 04 <br> 44 <br> 64 | $\begin{aligned} & \hline \text { EOT } \\ & \text { EOT } \\ & \mathrm{D} \\ & \mathrm{~d} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 16 \\ & 16 \\ & 56 \\ & 76 \end{aligned}$ | $\begin{aligned} & \text { SYN } \\ & \text { SYN } \\ & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{array}{\|l\|} \hline 1 \mathrm{C} \\ 1 \mathrm{C} \\ 7 \mathrm{C} \\ 5 \mathrm{C} \\ \hline \end{array}$ | $\begin{aligned} & \text { FS } \\ & \text { FS } \\ & i \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 1 \mathrm{~B} \\ 1 \mathrm{~B} \\ 7 \mathrm{~B} \\ 5 \mathrm{~B} \end{array}$ |  |
| 4 | $\begin{array}{\|l\|l\|} \hline \text { F4 } \\ \text { F4 } \\ \text { E4 } \\ \text { F4 } \end{array}$ | $\begin{aligned} & \text { C4 } \\ & \text { D4 } \\ & \text { C4 } \\ & \text { D4 } \end{aligned}$ | $\begin{array}{\|l\|} \hline 24 \\ 34 \\ 24 \\ 34 \\ \hline \end{array}$ | $\begin{aligned} & \$ \\ & 4 \\ & \$ \\ & 4 \end{aligned}$ | $\begin{array}{\|l} 12 \\ 12 \\ 52 \\ 72 \\ \hline \end{array}$ | $\begin{aligned} & \hline \text { DC2 } \\ & \text { DC2 } \\ & \text { R } \\ & \hline \end{aligned}$ | 06 <br> 06 <br> 46 <br> 66 | $\begin{aligned} & \text { ACK } \\ & \text { ACK } \\ & \mathrm{F} \\ & \mathrm{f} \end{aligned}$ | $\begin{aligned} & 02 \\ & 02 \\ & 42 \\ & 62 \end{aligned}$ | STX <br> STX <br> B <br> b | $\begin{array}{\|l\|} \hline 08 \\ 08 \\ 08 \\ 08 \\ \hline \end{array}$ | $\begin{aligned} & \hline \mathrm{BS} \\ & \mathrm{BS} \\ & \mathrm{BS} \\ & \mathrm{BS} \\ & \hline \end{aligned}$ | $\begin{aligned} & 10 \\ & 10 \\ & 70 \\ & 5 D \end{aligned}$ |  |
| 5 | $\begin{aligned} & \text { E5 } \\ & \text { F5 } \\ & \text { E5 } \\ & \text { F5 } \end{aligned}$ | $\begin{aligned} & \text { C5 } \\ & \text { D5 } \\ & \text { C5 } \\ & \text { D5 } \end{aligned}$ | $\begin{array}{\|l\|} \hline 25 \\ 35 \\ 25 \\ 35 \\ \hline \end{array}$ | $\begin{aligned} & \% \\ & \hline \% \\ & \% \\ & 5 \end{aligned}$ | $\begin{array}{\|l\|} \hline 14 \\ 14 \\ 54 \\ 74 \\ \hline \end{array}$ | DC4 <br> DC4 <br> T <br> t | $\begin{array}{\|l\|} \hline 07 \\ 07 \\ 47 \\ 67 \\ \hline \end{array}$ | $\begin{aligned} & \hline \mathrm{BEL} \\ & \mathrm{BEL} \\ & \mathrm{G} \\ & \mathrm{~g} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 0 \mathrm{E} \\ & 0 \mathrm{E} \\ & 4 \mathrm{E} \\ & 6 \mathrm{E} \end{aligned}$ | $\begin{aligned} & \text { SO } \\ & \text { SO } \\ & \mathrm{N} \\ & \mathrm{n} \\ & \hline \end{aligned}$ | $\begin{array}{\|l} \hline 10 \\ 10 \\ 50 \\ 70 \\ \hline \end{array}$ | $\begin{aligned} & \hline \mathrm{DLE} \\ & \mathrm{DLE} \\ & \mathrm{p} \\ & \mathrm{p} \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 08 \\ 08 \\ 08 \\ 08 \\ \hline \end{array}$ | BS BS BS BS |
| 6 | $\begin{array}{\|l\|} \hline \text { E6 } \\ \text { F6 } \\ \text { E6 } \\ \text { F6 } \\ \hline \end{array}$ | $\begin{array}{\|l} \hline \text { C6 } \\ \text { D6 } \\ \text { C6 } \\ \text { D6 } \end{array}$ | $\begin{array}{\|l} \hline 26 \\ 36 \\ 26 \\ 36 \\ \hline \end{array}$ | $\begin{aligned} & \& \\ & 6 \\ & 8 \\ & 6 \end{aligned}$ | $\begin{array}{\|l} \hline 19 \\ 19 \\ 59 \\ 79 \\ \hline \end{array}$ | $\begin{aligned} & \text { EM } \\ & \text { EM } \\ & \mathrm{y} \\ & \hline \end{aligned}$ | $\begin{array}{l\|} \hline 08 \\ 08 \\ 48 \\ 68 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{BS} \\ & \mathrm{BS} \\ & \mathrm{H} \\ & \mathrm{~h} \end{aligned}$ | $\begin{aligned} & \hline 0 \mathrm{D} \\ & 0 \mathrm{D} \\ & 4 \mathrm{D} \\ & 6 \mathrm{D} \end{aligned}$ | $\begin{aligned} & \text { CR } \\ & \mathrm{CR} \\ & \mathrm{M} \\ & \mathrm{~m} \end{aligned}$ | $\begin{aligned} & \hline 00 \\ & 00 \\ & 60 \\ & 40 \\ & \hline \end{aligned}$ | NUL NUL (a) | $\begin{array}{\|l\|} \hline 09 \\ 09 \\ 09 \\ 09 \\ \hline \end{array}$ | $\begin{array}{r} \mathrm{HT} \\ \mathrm{HT} \\ * \\ * \\ \mathrm{HT} \\ \mathrm{HT} \\ \hline \end{array}$ |
| 7 | $\begin{array}{\|l} \hline \text { E7 } \\ \text { F7 } \\ \text { E7 } \\ \text { F7 } \end{array}$ | $\begin{aligned} & \text { C7 } \\ & \text { D7 } \\ & \text { C7 } \\ & \text { D7 } \end{aligned}$ | $\begin{array}{\|l\|} \hline 27 \\ 37 \\ 27 \\ 37 \\ \hline \end{array}$ | $\begin{aligned} & 7 \\ & 7 \end{aligned}$ | $\begin{aligned} & 15 \\ & 15 \\ & 55 \\ & 75 \end{aligned}$ | NAK NAK $u$ $u$ | $\begin{aligned} & \hline 0 \mathrm{~A} \\ & 0 \mathrm{~A} \\ & 4 \mathrm{~A} \\ & 6 \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \mathrm{LF} \\ & \mathrm{LF} \\ & \mathrm{j} \\ & \mathrm{j} \end{aligned}$ | $\begin{aligned} & 3 \mathrm{C} \\ & 2 \mathrm{C} \\ & 3 \mathrm{C} \\ & 2 \mathrm{C} \end{aligned}$ | '< | $\begin{aligned} & \hline 7 F \\ & 7 F \\ & 7 F \\ & 7 F \end{aligned}$ | $\begin{aligned} & \hline \mathrm{DEL} \\ & \mathrm{DEL} \\ & \mathrm{DEL} \\ & \mathrm{DEL} \\ & \hline \end{aligned}$ | 20 <br> 20 <br> 20 <br> 20 | SP SP SP SP |
| 8 | $\begin{array}{\|l\|} \hline E 8 \\ F 8 \\ E 8 \\ F 8 \\ \hline \end{array}$ | $\begin{array}{\|l} \hline \mathrm{CB} \\ \mathrm{D} 8 \\ \mathrm{CB} \\ \mathrm{D} 8 \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 28 \\ 38 \\ 28 \\ 38 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 8 \\ & 1 \\ & 8 \end{aligned}$ | $\begin{array}{\|l} \hline 09 \\ 09 \\ 49 \\ 69 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{HT} \\ & \mathrm{HT} \\ & 1 \\ & i \end{aligned}$ | $0 B$ <br> $O B$ <br> $4 B$ <br> $6 B$ | $\begin{aligned} & \mathrm{VT} \\ & \mathrm{VT} \\ & \mathrm{~K} \\ & \mathrm{k} \end{aligned}$ | $\begin{aligned} & 3 \mathrm{E} \\ & 2 \mathrm{E} \\ & 3 \mathrm{E} \\ & 2 \mathrm{E} \end{aligned}$ | $\begin{aligned} & > \\ & > \end{aligned}$ | OA OA OA OA | $\begin{aligned} & \mathrm{LF} \\ & \mathrm{LF} \\ & \mathrm{LF} \\ & \mathrm{LF} \end{aligned}$ | $O B$ <br> $O B$ <br> $O B$ <br> $O B$ <br> $O$ | $\begin{aligned} & \mathrm{VT} \\ & \mathrm{VT} \\ & \mathrm{VT} \\ & \mathrm{VT} \end{aligned}$ |
| 9 | $\begin{array}{\|l\|} \hline \text { E9 } \\ \text { F9 } \\ \text { E9 } \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{C} 9 \\ & \mathrm{D} 9 \\ & \mathrm{C9} \\ & \mathrm{D9} \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 29 \\ 39 \\ 29 \\ 39 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 9 \\ & 9 \\ & 9 \end{aligned}$ | $\begin{array}{\|l} \hline 0 F \\ 0 F \\ 4 F \\ 6 F \end{array}$ | $\begin{aligned} & \mathrm{SI} \\ & \mathrm{SI} \\ & \mathrm{O} \\ & \mathrm{o} \end{aligned}$ | $\begin{aligned} & \hline 0 \mathrm{C} \\ & 0 \mathrm{C} \\ & 4 \mathrm{C} \\ & 6 \mathrm{C} \end{aligned}$ | $\begin{aligned} & \text { FF } \\ & \text { FF } \\ & \mathbf{L} \\ & \hline \end{aligned}$ | $\begin{aligned} & 3 F \\ & 2 F \\ & 3 F \\ & 2 F \end{aligned}$ | $\begin{aligned} & ? \\ & \text { ? } \\ & ? \end{aligned}$ | $\begin{aligned} & O D \\ & O D \\ & O D \\ & O D \end{aligned}$ | CR <br> CR <br> CR <br> CR | $\begin{array}{\|l\|} \hline O A \\ O A \\ O A \\ O A \end{array}$ | $\begin{array}{r} \hline \mathrm{LF} \\ \hline \mathrm{LF} \\ \times \mathrm{LF} \\ \times \mathrm{LF} \\ \hline \end{array}$ |
| A | $\begin{aligned} & \text { EA } \\ & \text { FA } \\ & E A \\ & F A \end{aligned}$ | CA <br> DA <br> CA <br> DA | $\begin{array}{\|l} 37 \\ 37 \\ 37 \\ 37 \\ \hline \end{array}$ | $\begin{aligned} & 7 \\ & 7 \\ & 7 \\ & 7 \end{aligned}$ | $\begin{array}{\|l} 34 \\ 34 \\ 34 \\ 34 \end{array}$ | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 4 \end{aligned}$ | $\begin{array}{\|l\|} \hline 31 \\ 31 \\ 31 \\ 31 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 30 \\ & 30 \\ & 30 \\ & 30 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline A 0 \\ B O \\ A O \\ B O \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} \hline A 6 \\ B 6 \\ A 6 \\ B 6 \\ \hline \end{array}$ |  |
| B | $\begin{array}{\|l\|} \hline E B \\ F B \\ \mathrm{FB} \\ \mathrm{FB} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \mathrm{CB} \\ \mathrm{DB} \\ \mathrm{CB} \\ \mathrm{DB} \\ \hline \end{array}$ | $\begin{array}{\|l} 38 \\ 38 \\ 38 \\ 38 \\ \hline \end{array}$ | $\begin{aligned} & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | $\begin{aligned} & 35 \\ & 35 \\ & 35 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 5 \\ & 5 \end{aligned}$ | $\begin{array}{\|l\|} \hline 32 \\ 32 \\ 32 \\ 32 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \mathrm{E} \\ & 2 \mathrm{E} \\ & 2 \mathrm{E} \\ & 2 \mathrm{E} \end{aligned}$ |  | $\begin{array}{\|l\|l} \hline A 1 \\ B 1 \\ \text { A1 } \\ \text { A1 } \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} \hline A 7 \\ \text { B7 } \\ \text { A7 } \\ \text { B7 } \end{array}$ |  |
| C | $\begin{array}{\|l\|} \hline \text { EC } \\ \text { FC } \\ \text { EC } \\ \text { FC } \end{array}$ | $\begin{array}{\|l} \hline \mathrm{CC} \\ \mathrm{DC} \\ \mathrm{CC} \\ \mathrm{DC} \\ \hline \end{array}$ | $\begin{array}{\|l} 39 \\ 39 \\ 39 \\ 39 \\ \hline \end{array}$ | $\begin{aligned} & 9 \\ & 9 \\ & 9 \\ & 9 \end{aligned}$ | $\begin{array}{\|l} 36 \\ 36 \\ 36 \\ 36 \\ \hline \end{array}$ | $\begin{aligned} & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | $\begin{array}{\|l\|} \hline 33 \\ 33 \\ 33 \\ 33 \\ \hline \end{array}$ | $\begin{aligned} & \mathbf{3} \\ & \mathbf{3} \\ & \mathbf{3} \\ & \mathbf{3} \end{aligned}$ | $\begin{array}{\|l\|} \hline \mathrm{BF} \\ \mathrm{AF} \\ 9 \mathrm{~F} \\ 8 \mathrm{~F} \end{array}$ |  | $\begin{array}{\|l\|l} \hline A 2 \\ B 2 \\ A 2 \\ B 2 \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} \hline A B \\ B 8 \\ A B \\ A B \\ \hline \end{array}$ |  |
| D | $\begin{array}{\|l\|} \hline \text { ED } \\ \text { FD } \\ \text { ED } \\ \text { FD } \end{array}$ | $\begin{array}{\|l\|} \hline \mathrm{CD} \\ \mathrm{DD} \\ \mathrm{CD} \\ \mathrm{DD} \\ \hline \end{array}$ | $\begin{array}{\|l} \hline 90 \\ 90 \\ 90 \\ 90 \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} \hline 93 \\ 93 \\ 93 \\ 93 \\ \hline \end{array}$ |  | $\begin{aligned} & \hline 82 \\ & 82 \\ & 82 \\ & 82 \\ & \hline \end{aligned}$ |  | $\begin{array}{\|l} 95 \\ 95 \\ 95 \\ 95 \\ \hline \end{array}$ |  | A3 <br> B3 <br> A3 <br> B3 |  | A9 <br> A9 <br> B9 <br> A9 <br> B9 |  |
| E | $\begin{array}{\|l\|} \hline \mathrm{EE} \\ \mathrm{FE} \\ \mathrm{EE} \\ \mathrm{FE} \end{array}$ | CE <br> DE <br> CE <br> DE | $\begin{array}{\|l} \hline 91 \\ 91 \\ 91 \\ 91 \\ \hline \end{array}$ |  | $\begin{array}{\|l\|} \hline 80 \\ 80 \\ 80 \\ 80 \\ \hline \end{array}$ |  | 84 <br> 84 <br> 84 <br> 84 |  | $\begin{array}{\|l\|} \hline 81 \\ 81 \\ 81 \\ 81 \end{array}$ |  | $\begin{array}{\|l\|} \hline \text { A4 } \\ \text { B4 } \\ \text { A4 } \\ \text { B4 } \end{array}$ |  | $\begin{array}{\|l\|} \hline A A \\ B A \\ A A \\ B A \\ \hline \end{array}$ |  |
| F | EF FF EF FF | $\begin{aligned} & \mathrm{CF} \\ & \mathrm{DF} \\ & \mathrm{CF} \\ & \mathrm{DF} \\ & \hline \end{aligned}$ | $\begin{aligned} & 92 \\ & 92 \\ & 92 \\ & 92 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \hline 94 \\ & 94 \\ & 94 \\ & 94 \end{aligned}$ |  | 83 <br> 83 <br> 83 <br> 83 |  | $\begin{array}{\|l} \hline 96 \\ 96 \\ 96 \\ 96 \\ \hline \end{array}$ |  | A5 <br> B5 <br> A5 <br> B5 |  | AB |  |
| This row contains the <br> latched <br> keys when that mode is se- <br> lected <br> (KMR6, KMR5 $=00$ ) |  |  |  |  |  |  |  |  |  |  | T800320 |  |  |  |



Figure 3. Keyboard Mode Register Format

Bit KMR3 enables the auto-repeat mode. In this mode, if a key that is programmed for auto-repeat is depressed for longer than onehalf second, the key code will be loaded into the KDR approximately 15 times per second until that key is released. Only the non-control key codes will auto-repeat, i.e. CONTROL $=1$. Table 2 specifies the auto-repeat keys.

KMR2 and KMR1 select the key matrix size and debounce time (scan rate). The keyboard row outputs (KR2, KR1, KR0) always scan from 0 to 7. The column outputs (KC3, KC2, KC1, KC0) scan from 0 to 15 for a 128 key matrix and from 0 to 9 for an 80 key matrix.
KMRO selects between a 1 kHz and 2 kHz frequency to be output on the TONE pin in response to a ring tone command.

## Keyboard Status Register

The keyboard status register (KSA) provides operational feedback to the CPU. Its format is illustrated in figure 4.
KSR7, 6 and 4 reflect the state of the inputs at the corresponding pins. CONTROL and $\overline{\text { SHIFT }}$ are latched at the time the key is accepted. As the verified codes are loaded into the KDR, the corresponding states of $\overline{\text { CONTROL }}$ and SHIFT are loaded into the KSR. $\overline{R E P E A T}$ is updated on every matrix sample. The status bits are the complements of the input levels.


KSR5 reflects the state of the internal shift lock flag which is controlled by the set/reset shift lock commands.

KSR3 indicates that the keyboard controller is enabied. It is controlied by the set/clear keyboard enable command.
Keyboard overrun (KSR2) is set when both the KHR and KDR are full and a third key is validated. The originai content of the KHR is preserved and the content of the KDR is overwritten with the new key code. This bit can be specified (by IMR1) to generate an interrupt and is cleared by the reset command with D2 $=1$.

Keyboard error (KSR1) is set when the operator depresses more keys than are allowed in the selected rollover mode, or when keys are depressed simultaneously (within one scan cycle). This bit can be specified (by IMR3) to generate an interrupt and is cleared by the reset command with D1 $=1$.

Keyboard data ready (KSRO) is set when the key code or address is transferred from the KDR to the KHR. This bit can be specified (by IMR2) to generate an interrupt. It is cleared when the CPU reads the KHR.

## Communications Controller

The communications controller section of the PKCC comprises a fuil duplex asynchronous receiver/transmitter (UART) with a baud rate generator. Registers associated with these elements are the communications mode register (CMR), the baud rate control register (BRR), and the communications status register (CSR).

## Receiver

The receiver accepts serial data on the RxD pin, converts the serial input to parallel format, checks for start bit, stop bit, parity bit (if any), or break condition, and presents the assembled character to the CPU. The receiver looks for a high to low (mark to space) transition of the start bit on the RxD input pin. If a transition is detected, the state of the RxD pin is sampled again after a delay of one half of the bit time. If RxD is then high, the start bit is invalid and the search for a valid start bit begins again. If $\mathrm{RxD}_{\mathrm{x}}$ is still low, a valid start bit is assumed and the receiver continues to sample the input at one bit time intervals at the theoretical center of the bit, until the proper number of data bits and the parity bit (if any) have been assembled, and one stop bit has been detected. The least significant bit is received first. The data is then transferred to the receive holding register (RxHR) and the RxRDY bit in the CSR is set to a 1. If the character length is less than eight bits, the most significant unused bits in the RxHR are set to zero.

After the stop bit is detected, the receiver will immediately look for the next start bit. However, if a non-zero character was received without a stop bit (i.e. framing error) and R×D remains low for one half of the bit period after the stop bit was sampled, then the space is interpreted as a start bit.

The parity error, framing error and overrun error (if any) are strobed into the CSR at the received character boundary. If a break condition is detected (RxD is low for the entire character including the stop bit) only one character consisting of all zeros will be transferred to the RxHR and the received break bit in the CSR is set to 1 (RxRDY is not set when a break is received). The RxD input must return to a high condition for one bit time before a search for the next start bit begins

## Transmitter

The transmitter accepts parallel data from the CPU and converts it to a serial bit stream on the $T_{X D}$ output pin. It automatically sends a start bit followed by the data bits, an optional parity bit, and the programmed number of stop bits. The least significant bit is sent first. Following the transmission of the stop bits, if


Figure 5. Communications Mode Register Format
new character is not available in the transmit holding register (TxHR), the TxD output remains high and the TxEMT bit in the CSR will be set to 1. Transmission resumes and the TxEMT bit is cleared when the CPU loads a new character into the TxHR. The transmitter can be forced to send a continuous low condition by a transmit break command.

If the transmitter is disabled, it continues operating until the character currently being transmitted is completely sent out.

## Communication Mode Register

Figure 5 illustrates the bit format of the CMR, which controls the operational mode of the cormmunications controller and the character parameters.

Bits CMR1 - CMRO select a character length of $5,6,7$, or 8 bits. The character length does not include the parity, start, or stop bits.
CMR2 selects the transrnitted character framing as one or two stop bits. The receiver always checks for one stop bit.

The parity format is selected by bits CMR4 and CMR3. If parity or force parity is selected, a parity bit is added to the transmitted character and the receiver performs a parity check on incoming data. CMR5 selects odd or even parity and determines the polarity of the parity bit in the force parity mode.

The bits in the mode register affecting character assembly and disassembly (CMR5-CMR0) can be changed dynamically and affect the characters currently being assembled in RxSR and transmitted by TxSR. To affect assembly of a received character,
the CMR must be updated within $n-1$ bit times of the receipt of that character's start bit. To affect a transmitted character, the CMR must be updated within $n-1$ bit times of transmitting that character's start bit. ( $n=$ the smaller of the new and old character lengths).
The UART can operate in one of four modes, as illustrated in figure 6 . The operating modes are selected by bits CMR7 and CMR6, which should only be changed when both the transmitter and receiver are disabled. CMR7CMR6 $=00$ is the normal mode, with the transmitter and receiver operating independently. CMR7-CMR6 $=01$ places the UART in the automatic echo mode, which automatically retransmits the received data. The following conditions are true while in automatic echo mode:

1. Data assembled by the receiver is automatically placed in the transmit holding register and retransmitted on the TxD output.
2. The receive clock is used for the transmitter.
3. The receiver must be enabled, but the transmitter need not be enabled.
4. Status bit TxRDY is not set. TxEMT operates normally.
5. The receiver parity is checked, but is not regenerated for transmission, i.e., transmitted parity bit is as received.
6. Only the first character of a break condition is echoed; the TxD output will go high until the next received character is assembled.
7. CPU to receiver communication continues normally, but the CPU to transmitter link is disabled.

(a)

(b)

(c)

(d)
(d) Remote loopback mode.

Figure 6. Operating Modes of the 2671 UART

Two diagnostic modes can also be configured. In local loopback mode (CMR7CMR6 = 10):

1. The transmitter output is internally connected to the receiver input.
2. The transmit clock is used for the receiver.
3. The $T x D$ output is held high.
4. The RxD input is ignored.
5. The transmitter must be enabled, but the receiver need not be enabled.
6. CPU to transmitter and receiver communications continue normally.
The second diagnostic mode is the remote loopback mode (CMR7-CMR6 = 11). In this mode:
7. Data assembled by the receiver is automatically placed in the transmit holding register and retransmitted on the TxD output.
8. The receive clock is used for the transmitter.
9. No data is sent to the local CPU, but the error status conditions (parity and framing) are set if required.
10. The received parity is checked, but is not regenerated for transmission, i.e., transmitted parity bit is as received.
11. The receiver must be enabled, but the transmitter need not be enabled.

## Baud Rate Control Register

The baud rate control register (BRR) controls the frequency generated by the baud rate generator (BRG) and the clock source used by the receiver and transmitter. Its format is illustrated in figure 7.

BRR3 - BRR0 select one of sixteen frequencies to be generated by the BRG. See table 3.

BRR7 and BRR6 select the source of the transmit and receive clocks. If external clocks are chosen, (BRR7 $=0$ or BRR6 $=0$ ), then the clock rate factor is determined by BRR5 and BRR4. The external clock input(s) should be the desired baud rate multiplied by the clock rate factor.

If internal clock(s) are specified, (BRR7 $=1$ or BRR $6=1$ ), the clock is supplied by the internal baud rate generator at the selected baud rate. The clock rate factor for internally generated clocks is always 16. Pins 35 and 34 become outputs for transmit or receive clocks, respectively. See table 4 for the description and selection of these outputs.


Figure 7. Baud Pate Control Register Format

Table 3. SAUD RATE GENERATOR CHARACTERISTICS (BRCLK $=4.9152 \mathrm{MHz}$ )

| 8月r3-0 | BAUD RATE | ACTUAL FREQUENCY 16X CLOCK | PERCENT ERROR | DIVISOR |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 50 | 0.8 kHz | - | 6144 |
| 0001 | 110 | 1.7598 | -0.01 | 2793 |
| 0010 | 134.5 | 2.152 | - | 2284 |
| 0011 | 150 | 2.4 | - | 2048 |
| 0100 | 200 | 3.2 | - | 1536 |
| 0101 | 300 | 4.8 | - | 1024 |
| 0110 | 600 | 9.6 | - | 512 |
| 0111 | 1050 | 16.8329 | $+0.20$ | 292 |
| 1000 | 1200 | 19.2 | - | 256 |
| 1001 | 1800 | 28.7438 | -0.20 | 171 |
| 1010 | 2000 | 31.9168 | -0.26 | 154 |
| 1011 | 2400 | 38.4 | - | 128 |
| 1100 | 4800 | 76.8 | -- | 64 |
| 1101 | 9600 | 153.6 | - | 32 |
| 1110 | 19200 | 307.2 | - | 16 |
| 1111 | 38400 | 614.4 | - | 8 |

Table 4. BAUD RATE CONTROL REGISTER

| BR47 - <br> B IR4 | CLOCK SOURCE |  | PIN FUNCTIONS |  | $\begin{gathered} \text { BRR3 - BRRO } \\ \text { BAUD RATE SELECTION } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | TxC | RxC | $\begin{gathered} \text { PIN } \\ 34 \end{gathered}$ | $\begin{gathered} \text { PIN } \\ 35 \end{gathered}$ |  |
| 00** | E | E | TxC | RxC | The baud rates are |
| 01** | E | 1 | TxC | $1 \times$ | listed in table 3. |
| 10** | 1 | E | 16X | RxC |  |
| 1100 | 1 | 1 | 1x | $1 \times$ |  |
| 1101 | 1 | 1 | 1 X | 16X |  |
| 1110 | 1 | 1 | 16X | $1 \times$ |  |
| 1111 | 1 | 1 | 16 X | 16X |  |

## NOTES:

1. ${ }^{* *}=$ Clock rate factor for external clocks: $00=16 \mathrm{X}$

$$
\begin{aligned}
& 01=32 x \\
& 10=64 x \\
& 11=1 X
\end{aligned}
$$

2. $E=$ External clock.
3. $1=$ Internal clock (BRG).
4. $1 X$ and 16 X are clock outputs at 1 or 16 times the actual baud rate. For receive, the 1 X output is the actual data sample clock.
5. BRR7-BRR6 $=01$ or 10 not permitted in automatic echo or remote loopback modes unless BRR $5-$ BRR4 $=00$.

## Communications Status Register

Figure 8 illustrates the bit format of the communications status register (CSR), which provides UART status to the CPU.
Receiver ready (CSR0) indicates that a received character is assembled and transferred to the RxHR and is ready to be read by the CPU. This bit can be specified (by IMRO) to generate an interrupt and is reset by reading the RxHR.
Transmitter ready (CSR1) indicates that the TxHR is empty and ready to be loaded with a character. This bit will be cleared when the TxHR is loaded and has not yet transferred the character to the transmit shift register (TxSR). TxRDY is reset when the transmitter is disabled. It will be set when the transmitter is enabled, provided that no data was loaded into the TxHR during the time the transmitter was disabled. This bit can be specified (by IMR7) to generate an interrupt.

Transmitter empty (CSR2) indicates that the transmitter has underrun, i.e., both the TxHR and TxSR are empty. This bit can only be set after transmission of at least one character, and is cleared when the TxHR is loaded by the CPU. TxEMT is reset when the transmitter is disabled. This bit can be specified (by IMR6) to generate an interrupt.
CSR3 will be set when the PKCC receives a command to transmit a break. This bit will be cleared after the break is completed.

Received break (CSR4) indicates that an all zero character of the programmed length has been received without a stop bit. Breaks originating in the middle of a received character can be detected. This bit is cleared when


Figure 8. Communications Status Register Format

RxD returns to a high state for at least one bit time.
Receiver overrun (CSR5) indicates that the previous character in the RxHR has not been read by the CPU and that a new character has been loaded into the RxHR. This bit is cleared by a reset command with D3 $=1$.

Framing error (CSR6) indicates that the stop bit has not been detected. The stop bit check is made in the middle of the first stop bit position. This bit is cleared by a reset command with D3 $=1$.

Parity error (CSR7) indicates that a character was received with incorrect parity when 'with parity' or 'force parity' is enabled. This bit is cleared by a reset command with $D 3=1$.

## Interrupt Controller

The SCN2671 contains a maskable interrupt status register (ISR) which can be enabled to generate an active low interrupt request on the INTR output. The eight interrupt condi-
tions in the ISR are individually enabled by writing a 1 into the corresponding bit of the interrupt mask register (IMR).

Each of the interrupt conditions is assigned a priority and a vector. When an enabled ISR bit is set, the SCN2671 asserts the INTR output. If the CPU activates the INTA input, the SCN 2671 responds by placing the corresponding 8 -bit vector on the data bus ( $D 7-\mathrm{DO}$ ). If multiple interrupts are pending, the vector corresponds to the condition with the highest priority. The interrupt will persist until all pending interrupt conditions are cleared.
The ISP can also be polled by reading at address $A 2-A 0=000$. All pending interrupt conditions which are enabled by the IMR will be read independent of priority.

The bit assignments of the ISR and IMR and corresponding vectors and priorities are listed in table 5.

Table 5. INTERRUPT MASK REGISTER (IMR) AND INTERRUPT STATUS REGISTER (ISR)

| BIT IN IMR/ISR | INTERRUPT CONDITION | PRIORITY | VECTOR ON D7-DO |  | CONDITION RESET BY: |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | BINARY | HEX |  |
| IMRO/ISRO | RxRDY | 1 | 11001111 | CF | Read RxHR |
| IMR1/ISR1 | KOVR | 2 | 11010111 | D7 | Reset CMD ( $\mathrm{D} 2=1$ ) |
| IMR2/ISR2 | KRDY | 3 | 11011111 | DF | Read KHR |
| IMR3/ISR3 | KERR | 4 | 11100111 | E7 | Reset CMD ( $\mathrm{D1}^{\text {= }}$ 1) |
| IMR4/ISR4 | XINT ${ }^{1}$ | 5 | 11101111 | EF | External |
| IMR5/ISR5 | $\triangle$ BREAK $^{2}$ | 6 | 11110111 | F7 | Reset CMD ( $\mathrm{D} 4=1$ ) |
| IMR6/ISR6 | TxEMT | 7 | 11000111 | C7 | Load TxHR |
| IMR7/ISR7 | TxRDY | 8 | 11000111 | C7 | Load TxHR |

## NOTES:

1. XINT is an input from an external interrupt source, active low (pin 21).
2. $\triangle$ BREAK refers to the change of a received break condition.


## COMMANDS

In addition to the control exercised by programming of the PKCC control registers, several functions can be performed by executing command operations. There are two classes of commands which are initiated by writing to the SCN2671 at address $\mathrm{A} 2-\mathrm{A} 0=000$ (reset command) and address A2-A0 = 111 (miscellaneous commands). Individual commands are specified by the bit pattern on the data bus ( $\mathrm{D7} 7$ - D0).

## Reset Commands

The reset command bit format is illustrated in figure 9 and the detail command descriptions are given in table 6.

A reset command with D7-D0 $=111$ XXXX1 is a master reset for the SCN2671. This command must be given following a power on condition to release the internal power on reset latch which deactivates the SCN2671 on power up.

## Miscellaneous Commands

The miscellaneous command format is illustrated in figure 10.
The transmit break commands force a break (steady low output) on the TxD pin immediately or after the character in the TxSR (if any) is transmitted. A timed break lasts for approximately 200 ms , and a character break lasts for one character time including parity and stop bit time. In either case, TxRDY
(CSR1) will be set at the beginning of the break which can be extended indefinitely (by 200 ms or one character time increments) by reasserting the command in response to TxRDY. Note that these commands reset TxRDY. When a transmit break command is asserted, CSR3 will be set. The bit will be cleared after the break is completed.
The ring tone commands cause the tone generator to output a square wave on the TONE output. The tone durations are specified by the commands:

Ring tone short $=25 \mathrm{~ms}$
Ring tone long $=100 \mathrm{~ms}$
The tone frequency is either 1 kHz or 2 kHz , as specified by KMRO.

Table 6. RESET COMMAND DESCRIPTION

| COMMAND | RESETS | COMMENTS |
| :---: | :---: | :---: |
| Keyboard reset | $\begin{aligned} & \text { KMR7 - KMR0 } \\ & \text { KSR5, KSR3 - KSR0 } \\ & \text { IMR3 - IMR1 } \end{aligned}$ | The keyboard controller is reset, ignoring the input at KRET. |
| KERR reset | KSR1 | Keyboard error status bit reset. |
| KOVR reset | KSR2 | Keyboard overrun status bit reset. |
| Communications error reset | CSR7-CSR5 | Resets the receiver overrun, parity, and framing error status bits. |
| Break detect change reset | ISR5 | Resets the break detect change bit in the interrupt status register. |
| Set RxE | See note. | Enables receiver operation. |
| Reset RxE | CSR7 - CSR4, CSR0 See note. | Disables the receiver. |
| Set TxE | See note. | Enables transmitter operation. |
| Reset TxE | CSR3-CSR1 <br> See note. | Disables the transmitter. Sets the TxD output to a 1 after transmitting the character in TxSR. |
| Communications reset | CMR, CSR, BRR, <br> TxE, RxE, IMR7-IMR5, IMRO | Resets the communication controller. The RxD input is ignored and the TxD output is set to a 1. |
| Master reset | CMR, CSR, BRR, <br> TxE, RxE, KMR, <br> KSR5, KSR3-KSR0, <br> IMR7-IMRO <br> Releases the internally latched power on reset. | Resets the keyboard and communication controllers. Inputs at KRET and RxD are ignored and the TxD output is set to a 1 . |

NOTE:
Command does not affect the CMR or the BRR.


The set/clear shift lock commands control the state of the internal shift lock flip flop. When shift lock is set, the keyboard controller encodes all key depressions as if the SHIFT input was asserted. The state of the shift lock flip flop is reflected in KSR5.
The set keyboard enable command enables the keyboard controller and sets KSR3 in the keyboard status register. THe clear keyboard enable command resets KSR3 and disables key processing at the KRET input. The keyboard controller is not reset by this command, and the current state of the keyboard (key
depressions and latched key states) is preserved internally. When the keyboard is subsequently enabled, key processing resumes, old and new keys are debounced, and latched keys are encoded if there has been a change in their state.

## MASK PROGRAMMABLE OPTIONS

Characteristics of certain portions of the PKCC are internally programmed by means of
a read only memory. The items which can be programmed are:

- Key codes
- Auto-repeat keys
- Scan times, tone frequency, and tone duration
- Baud rates
- Interrupt vectors

Consult your local Signetics representative for costs, minimum quantities, and data submission requirements for customized versions of the PKCC.

ABSOLUTE MAXIMUM RATINGS

| PARAMETER | RATING | UNIT |
| :--- | :---: | :---: |
| Operating ambient temperature ${ }^{2}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| All voltages with respect to ground $^{3}$ | -0.5 to +6.0 | V |

DC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% 4.5 .6$

| PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{H}} \end{aligned}$ | Input low voltage Input high voltage XTAL1, XTAL2/BRCLK All other inputs |  |  | $\begin{aligned} & 4.0 \\ & 2.0 \end{aligned}$ |  | 0.8 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ <br> $\mathrm{V}_{\mathrm{OH}}$ | Output low voltage <br> Output high voltage (except INTR) | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ | 2.4 |  | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| IIL ${ }^{\text {xTLLL }}$ <br> ${ }_{\mathrm{IXTLIH}}$ | ```Input leakage current (except XTAL1, XTAL2/BRCLK) Input low current XTAL1 XTAL2/BRCLK}\mp@subsup{}{}{7 input high current XTAL1 XTAL2/BRCLKK``` | $\begin{gathered} V_{I N}=0 \text { to } V_{C C} \\ V_{I N}=0 \\ V_{I N}=V_{C C} \end{gathered}$ | $\begin{aligned} & -10 \\ & -80 \\ & -4.0 \end{aligned}$ | $\begin{gathered} -30 \\ -1.5 \\ \\ 30 \\ 0.2 \end{gathered}$ | 10 $\begin{aligned} & 80 \\ & 1.0 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu A$ <br> mA <br> $\mu \mathrm{A}$ <br> mA |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LL}} \\ & \mathrm{I} C \mathrm{C} \end{aligned}$ | Data bus 3-state leakage current Power supply current | $\mathrm{V}_{\mathrm{O}}=0$ to $\mathrm{V}_{\mathrm{CC}}$ | -10 |  | $\begin{gathered} 10 \\ 150 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ |

AC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%^{4,5,6}$

| PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Read, timing (See figure 11) |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{AS}} \quad$ Address set-up to $\overline{\mathrm{RD}}$ |  | 50 |  |  | ns |
| $\mathrm{t}_{\text {cs }} \quad \overline{\mathrm{CE}}$ set-up to $\overline{\mathrm{RD}}$ |  | 50 |  |  | ns |
| tpw $\quad \overline{\mathrm{RD}}$ pulse width |  | 250 |  |  | ns |
| $\mathrm{t}_{\mathrm{AH}} \quad$ Address hold from $\overline{\mathrm{RD}}$ |  | 20 |  |  | ns |
| $\mathrm{t}_{\mathrm{CH}} \quad \overline{\mathrm{CE}}$ hold from $\overline{\mathrm{RD}}$ | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ | 0 |  |  | ns |
| tDD Data delay for read |  |  |  | 200 | ns |
| $\mathrm{t}_{\mathrm{DF}} \quad$ Data bus floating time for read | $C_{L}=150 \mathrm{pF}$ | 10 |  | 100 | ns |
| $\mathrm{t}_{\text {AD1 }} \quad$ Access delay from any read to next read or write |  | 250 |  |  | ns |
| Write timing (See figure 12) |  |  |  |  |  |
| $t_{\text {AS }} \quad$ Address setting to $\overline{\mathrm{WR}}$ |  | 50 |  |  | ns |
| $\mathrm{t}_{\text {cs }} \quad \overline{\mathrm{CE}}$ set-up to WR |  | 50 |  |  | ns |
| tpw $\quad \overline{\text { WR pulse width }}$ |  | 250 |  |  | ns |
| $\mathrm{t}_{\mathrm{AH}} \quad$ Address hold from $\overline{\mathrm{WR}}$ |  | 20 |  |  | ns |
| $\mathrm{t}_{\mathrm{CH}} \quad \overline{\mathrm{CE}}$ hold from $\overline{\mathrm{WR}}$ |  | 0 |  |  | ns |
| $t_{\text {DS }}$ Data set-up |  | 100 |  |  | ns |
| $\mathrm{t}_{\mathrm{DH}} \quad$ Data hold |  | 10 |  |  | ns |
| $\mathrm{t}_{\text {AD2 }} \quad$ Access delay from any write to next read or write |  | 250 |  |  | ns |
| Access delay from reset command to next read or write |  | 1.0 |  |  | $\mu \mathrm{s}$ |

AC ELECTRICAL CHARACTERISTICS (Continued)

| PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Interrupt acknowledge timing (see figure 13)  <br> $t_{P W I}$ $\overline{N N T A}$ pulse width <br> $t_{D D I}$ Data delay time for interrupt vector <br> $t_{D F I}$ Data bus floating time after $\overline{\text { INTA }}$ <br> $t_{A D I}$ $\overline{I N T A}$ to $\overline{I N T A}$ access delay | $\begin{aligned} & C_{L}=150 \mathrm{pF} \\ & C_{L}=150 \mathrm{pF} \end{aligned}$ | $\begin{gathered} 300 \\ \\ 10 \\ 300 \end{gathered}$ |  | $\begin{aligned} & 250 \\ & 100 \end{aligned}$ | ns ns ns ns |
| ```INTR reset timing (see figure 14) t Read RxHR (RxRDY) Read KHR (KRDY) Reset commands (KOVR,KERR,BREAK) Load TxHR (TxEMT,TxRDY) Mask bit reset``` |  |  |  | $\begin{aligned} & 400 \\ & 400 \\ & 450 \\ & 400 \\ & 300 \end{aligned}$ |  |
|  | $\begin{aligned} & C_{L}=150 \mathrm{pF} \\ & C_{L}=150 \mathrm{pF} \\ & C_{L}=150 \mathrm{pF} \\ & C_{L}=150 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & 12.0 \\ & 55.0 \end{aligned}$ | $409$ <br> 20 <br> 80 | $\begin{aligned} & 400 \\ & 400 \\ & 600 \\ & 400 \end{aligned}$ | kHz <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> ns <br> ns <br> ns <br> ns |
|  | $\begin{aligned} & C_{\mathrm{L}}=150 \mathrm{pF} \\ & C_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ <br> Clock rate factor $=16 \mathrm{X}, 32 \mathrm{X}, 64 \mathrm{X}$ Clock rate factor $=1 X$ | $\begin{aligned} & 200 \\ & 200 \\ & \\ & 70 \\ & 70 \\ & 1.0 \\ & \\ & 350 \\ & 350 \end{aligned}$ | 0 4.9152 | 300 <br> 5.075 <br> 1.3 <br> 1.0 | ns ns ns ns ns ns MHz <br> MHz <br> MHz ns ns |

NOTES:

1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is stress rating only and functional operation of the device at these or at any other condition above those indicated in the operation section of this specification is not implied.
2. For operating on elevated temperatures, the device must be operated based on $+150^{\circ} \mathrm{C}$ maximum function temperature.
3. This product includes circuitry specifically designed for the protection of its internal devices from damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying any voltages larger than the rated maxima.
4. Parameters are valid over operating temperature range unless otherwise specified.
5. All voltage measurements are referenced to ground $\left(\mathrm{V}_{\mathrm{SS}}\right)$. All input signals swing between 0.4 V and 2.4 V with a transition time of 20 ns maximum and time measurements are referenced at input voltages of $0.8 \mathrm{~V}, 2.0 \mathrm{~V}$ and at output voltages of $0.8 \mathrm{~V}, 2.0 \mathrm{~V}$ as appropriate, unless otherwise specified.
6. Typical values are at $+25^{\circ} \mathrm{C}$, typical supply voltages and typical processing parameters.
7. XTAL2 input currents are measured with XTAL grounded.
8. See figures 20 and 21 for XTAL1, WTAL2 connections for driving XT.AL2 with an external clock. input levels for XTAL1 and XTAL2 are $\mathrm{V}_{\mathbb{I L}} \leqslant 0.8 \mathrm{~V}, \mathrm{~V}_{1 H} \geqslant 4.0 \mathrm{~V}$, and $t_{\mathrm{BRL}}$ and $\mathrm{t}_{\mathrm{BRH}}$ are measured at these levels.


Figure 11. Read Timing


Figure 12. Write Timing


Figure 13. Interrupt Acknowledge Timing






$$
C=15-25 \mathrm{pF}
$$

Figure 20. Crystal Connections BRG Clock

Table 7. REGISTER FORMAT SUMMARY

|  | 7 | 6 5 | 4 | 3 | 2 |  | 1 |  | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Test Mode | Rollover modes | Keyboard | Auto repeat |  |  |  |  | Tone select |
|  | 1 = Enable | $00=\mathrm{N}$-key with latched keys | $0=$ Encoded | $0=$ Disable | KMR2 | KMR1 | Key Matrix Size | Scan Time | $0=1 \mathrm{kHz}$ |
| KMR | $0=$ Disable | $\begin{aligned} & 01=\text { N-key } \\ & 10=\text { Two keys } \\ & 11=\text { Two key inhibit } \end{aligned}$ | $\begin{gathered} 1= \\ \text { Nonen- } \\ \text { coded } \end{gathered}$ | 1 = Enable | 0 0 1 1 | 0 1 0 1 | $\begin{gathered} 128 \\ 128 \\ 80 \\ 80 \end{gathered}$ | 10 ms <br> 2.5 ms <br> 6.4 ms <br> 1.6 ms | $1=2 \mathrm{kHz}$ |


| CONTROL | SHIFT | SHIFT <br> LOCK | REPEAT | Keyboard <br> Enabled | KOVR | KERR | KRDY |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


|  | Operating Mode | Parity | Parity Mode | Stop Bi | Character Length |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CMR | $\begin{aligned} & 00=\text { Normal } \\ & 01=\text { Auto echo } \\ & 10=\text { Local loopback } \\ & 11=\text { Remote loopback } \end{aligned}$ | $\begin{aligned} & 0=\begin{array}{c} \text { Odd/ } \\ \text { force } 0 \end{array} \\ & 1=\begin{array}{c} \text { Even/ } \\ \text { force } 1 \end{array} \end{aligned}$ | $00=$ With parity <br> $01=$ Force parity <br> $10=$ No parity <br> $11=$ Not allowed | $\begin{aligned} & 0=\text { Two } \\ & 1=\text { One } \end{aligned}$ | $\begin{aligned} & 00=8 \\ & 01=5 \\ & 10=6 \\ & 11=7 \end{aligned}$ |


|  | Tx Clock source | Rx Clock source | Clock rate factor for external clocks | Baud rate select (BRR3-BRR0 in hex) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BRR | $\begin{gathered} 0=\text { External } \\ 1=\begin{array}{c} \text { Internal } \\ (B R G) \end{array} \end{gathered}$ | $\begin{gathered} 0=\text { External } \\ 1=\begin{array}{c} \text { Internal } \\ (B R G) \end{array} \end{gathered}$ | $\begin{aligned} & 00=16 X \\ & 01=32 X \\ & 10=64 X \\ & 11=1 X \end{aligned}$ <br> For internal clocks these bits specify the output frequency on pins 34 and 35 (table 4). | $\begin{aligned} & 0=50 \\ & 1=110 \\ & 2=134.5 \\ & 3=150 \end{aligned}$ <br> (BRCLK $=$ | $\begin{aligned} & 4=200 \\ & 5=300 \\ & 6=600 \\ & 7=1050 \end{aligned}$ <br> 152 MHz ) | $\begin{aligned} & 8=1200 \\ & 9=1800 \\ & A=2000 \\ & B=2400 \end{aligned}$ | $\begin{aligned} & C=4800 \\ & D=9600 \\ & E=19200 \\ & F=38400 \end{aligned}$ |


| CSR | Parity error | Framing <br> error | Overrun <br> error | Received <br> break | Transmit <br> break | TxEMT | TxRDY |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | RxRDY |  |
| :--- |

IMR/ISR

| TXRDY | TXEMT | BREAK <br> CHANGE | XINT | KERR | KRDY | KOVR | RxRDY |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| Reset Command Format | $00 X=$ No effect $101=$ Reset TxE <br> $010=$ Set RxE $110=$ Set TxE <br> $011=$ Reset RxE and RxE  <br> $100=$ Set TxE 111 <br> $=$ Communica- <br>   <br> tions reset  |  |  | Break detect change reset | Communications error reset | KOVR reset | KERR reset | Keyboard reset |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Miscellaneous Commands Format | Clear keyboard enable | Set keyboard enable | Clear shift lock | Set shift lock | Ring tone long | Ring tone short | Transmit timed break | Transmit character break |

## Signetics

## Microprocessor Products

## INTRODUCTION

Microprocessors and LSI have had a dramatic impact on the implementation and capabilities of alphanumeric CRT terminals. The first generation of CRT terminals were little more than 'glass teletypes'. Current designs, implemented with microprocessors, are characterized by an abundance of sophisticated features that were previously not economically feasible: a universal hardware design that can adapt to different user requirements simply by changing software or firmware; programmability to provide end users with the flexibility to execute specialized routines; and local intelligence and storage which off-loads the host CPU by permitting data manipulation and verification at the terminal site.

Just as the impact of microcomputers has been felt in the functional capabili-
ties of terminals, advances in semiconductor technology have revolutionized the hardware implementation. Designs that previously consisted of 100 to 200 ICs can now be realized with a few dozen MSI and LSI devices. The majority of the LSI manufacturers' effort with respect to CRT terminals has been concentrated in the 'CRT controller' area. These circuits provide the character timing, display addressing, and sync generation functions required by all terminals. However, these controllers need to be supported by many other external circuits to implement a complete terminal.

The purpose of this application note is to provide information on the use of four new Signetics CRT terminal products which, when combined with standard CPUs, memories, and TTL, allow the implementation of a wide spectrum of CRT terminal capabilities in as few as 15 total packages. These devices are:

AN401 Using the 2670/71/72/77 CRT Terminal Chip Set
Application Note


Figure 1. CRT Terminal Block Diagram
and 'intelligent') terminals start with the same base, but append additional circuits to provide more features and capabilities. The following sections describe the functions of each of the major blocks.

## Character Timing and Sync Generation

The major function of this block is to generate the horizontal and vertical timing signals required to produce the TV raster on the CRT monitor. Other functions include the generation of display memory addresses in synchronism with the monitor scan and in accordance with a defined screen format (characters per row, scan lines per row and rows per screen), generation of a cursor signal at the appropriate scan position, and generation of video blanking signals during retrace intervals.

## I/O Interface

In its simplest form, this block provides an interface to a keyboard to identify the key depressed and a serial communications link, normally operating in an asynchronous format, between the terminal and the host computer. Although these functions could be performed programmatically by the terminal CPU system, removing these functions to intelligent controllers unburden the system CPU and allow it to be used more effectively to provide additional features with a relatively small cost impact.

## Character and Graphics <br> Generation

These circuits convert the data stored in the display memory to the line by line dot patterns required to display the data on the CRT monitor.

## Video Timing and Visual Attributes

This section contains the high speed (dot rate) circuits necessary to convert the parallel data from the character and graphics generation circuits to the serial video stream required by the CRT. Also included are circuits to sum visual display attributes such as blinking, high/low intensity, reverse video, and underlining into the video stream.

## SIGNETICS' CRT CHIP SET

As mentioned previously, the Signetics CRT 'set' consists of four circuits. The functions of these circuits correspond closely to the four major CRT terminal blocks described above. The circuits have been partitioned so as to allow each to be used independent of the others, allow several alternative methods of implementing the display memory interface so that the hardware can be tailored to the system requirements, provide a full complement of programmable capabilities, and minimize the number of support circuits required.

The following sections give a brief description of each of the circuits. The reader is referred
to the individual data sheets for full operational details.

## 2670 Display Character and Graphics Generator (DCGG)

The DCGG, figure 2, is a mask-programmable 11,648-bit line select character generator. It contains $12810 \times 9$ characters placed in a $10 \times 16$ matrix, and has the capability of shifting certain characters, such as $j, y, g, p$ and $q$, that normally extend below the baseline; effectively, the 9 active lines are lowered within the matrix to compensate for the character's position.
Seven bits of an 8-bit address code are used to select 1 of the 128 available characters. The eighth bit functions as a chip enable signal. Each character is defined by a pattern of logic 1s and 0 s stored in a $10 \times 9$ matrix. When a specific 4 -bit binary line address code is applied, a word of 10 parallel bits appears to the output. The lines can be sequentially selected, providing a 9 -word sequence of 10 parallel bits per word for each character selected by the address inputs. As the line address inputs are sequentially addressed, the device will automatically place the $10 \times 9$ character in 1 of 2 preprogrammed positions on the 16 -line matrix with the positions defined by the 4 -line address inputs. One or more of the 10 parallel outputs can be used as control signals to selectively enable functions such as half-dot shift, color selection, etc.


Figure 2. 2670 Display Character and Graphics Generator

The 2670 DCGG includes latches to store the character address and line address data. A control input to inhibit character data output for certain groups of characters is also provided. The 2670 also includes a graphics capability, wherein the 8 -bit character code is translated directly into 256 possible user programmable graphic patterns. Thus, the DCGG can generate data for 384 distinct patterns, of which 128 are defined by the mask programmable ROM.

## 2671 Programmable Keyboard and Communications Controller (PKCC)

The 2671, figure 3, is an MOS LSI device which provides a versatile keyboard interface and also functions as an asynchronous communications controller. It is intended for use in microprocessor based systems and provides an eight bit data bus interface.

The keyboard controller handles the scanning, debounce, and encoding of mechanical or capacitive keyboards with a maximum of 128 keys utilizing any of four programmable rollover modes. A mask programmable ROM provides four levels of key encoding, corresponding to the separate shift and control input combinations. An eight bit keyboard status register transmits status information to the CPU. Programmable features include rollover mode, scan rate and debounce time, coded or uncoded operation, and automatic repeat operation.
The communications section of the PKCC is a universal asynchronous receiver and transmitter (UART). The receiver accepts serial input data and converts it to parallel data characters. Simultaneously, the transmitter accepts parallel data from the CPU data bus and outputs it in serialized form. Received data is checked for parity and framing errors, and break conditions are flagged. Character lengths can be programmed as $5,6,7$, or 8 bits not including parity, start or stop bits. An internal baud rate generator (BRG) operating from an external clock or directly from a crystal can be used to derive one of sixteen receive and/or transmit clocks. An eight bit communications status register provides status information to the CPU.

The PKCC has an interrupt mask register to selectively enable keyboard and communications status bits to generate interrupts. Priority encoded interrupt vectoring is available. Upon receipt of an interrupt acknowledge, a mask programmable interrupt vector will be output on the data bus reflecting the source of the interrupt. The mask enabled interrupt sources can also be read directly.

## 2672 Programmable Video Timing Controller (PVTC)

The 2672 PVTC, figure 4, is a programmable device designed for use in CRT terminals and display systems that employ raster scan techniques. The PVTC generates the vertical and horizontal timing signals necessary for the display of interlaced or non-interlaced data on a CRT monitor. Also, the 2672 provides consecutive addressing to a user specified display buffer memory domain and controls the CPU-display buffer interface for various buffer configuration modes. A variety of operating modes, display formats, and timing profiles can be implemented by programming the control registers in the PVTC.

The CPU initializes the 2672 control and timing registers for the desired timing profiles and memory configuration. The PVTC provides the handshake control for CPU access to the display buffer. One of four memory access modes may be programmed: independent mode, transparent mode, shared mode, and row mode. These modes are described in the System Configurations section of this application note.

In all modes, the PVTC provides addresses for the display buffer which outputs the character codes to the 2670 Display Character and Graphics Generator (DCGG) and visual attribute codes to the 2673 Video Attributes Controller (VAC). The DCGG and PVTC supply the dot data and sync timing to the VAC which generates the serialized video.

Programmable features of the PVTC include screen format (characters/row, rows/screen, scan lines/row), horizontal and vertical timing parameters, cursor type (block or underline) and blink rate, character blink rate, interlaced or non-interlaced operation, and single or double height characters.
The PVTC is capable of producing interrupts based upon several internal conditions. By using these interrupts (or by polling the equivalent status register) display features such as non-consecutive buffer addressing for split screen operation, multiple cursors, horizontal and vertical scrolling, and smooth vertical scroll can be implemented.

## 2677 Video and Attributes Controller (VAC)

The 2677, figure 5 , is a bipolar LSI device designed for CRT terminals and display systems that employ raster scan techniques. It contains a high speed video shift register, field and character attributes logic, attribute latch, cursor format logic and half dot shift control, and can be programmed for a light or dark screen background.

The VAC visual attribute capabilities are reverse video, character blank, blink, underline,
highlight, and light pen strike-thru or, optionally, graphics. Each attribute has a separate control input which is latched internally when the AFLAG input is asserted. If the AMODE input is low, the attributes are valid for one character time. If AMODE is high, the attributes remain valid until the field is terminated by strobing in a new attributes set. The attributes are double buffered on a row by row basis internally so that field attributes can extend across character row boundaries thereby eliminating the necessity of starting each row with an attribute set.
The horizontal dot frequency is the basic timing input element to the VAC; internally, this clock is divided down to provide a character clock output for system synchronization. Ten bits of dot data are parallel loaded into the video shift register on each character boundary. The video data is shifted out on three outputs at the dot frequency. On the video output, the video is presented as a three level signal representing low, medium and high intensities, and the three intensities are also encoded on the two TTL compatible video outputs.

## SYSTEM CONFIGURATIONS

The PVTC supports four common system configurations of display buffer memory interface, designated the independent, transparent, shared, and row buffer modes. The first three modes utilize a single or multiple page RAM and differ primarily in the means used to transfer display data between the RAM and the CPU. The row buffer mode makes use of a single row buffer (which can be a shift register or a small RAM) that is updated in real time to contain the appropriate display data.

## Independent Mode

The CPU to RAM interface configuration for this mode is illustrated in figure 6. Transfer of data between the CPU and display memory is accomplished via a bidirectional latched port and is controlled by the PVTC signals read data buffer ( $\overline{\mathrm{RDE}}$ ), write data buffer ( $\overline{\mathrm{WDB}}$ ), and buffer chip enable ( $\overline{\mathrm{BCE}}$ ). This mode provides a non-contention type of operation that does not require address multiplexers. The CPU does not address the memory directly - the read or write operation is performed at the address contained in the cursor address register or the pointer address register as specified by the CPU. The PVTC enacts the data transfers during blanking intervals in order to prevent visual disturbances of the displayed data.
The CPU manages the data transfers by supplying commands to the PVTC. The commands used are:

1. Read/Write at pointer address.



Figure 4. 2672 Programmable Video Timing Controller


Figure 5. 2677 Video and Attributes Controller
2. Read/Write at cursor address (with optional increment of address).
3. Write from cursor address to pointer address.

The operational sequence for a write to memory operation is:

The CPU loads data to be written into the display memory into the interface latch.
2. The CPU writes the destination address into the PVTC's cursor or pointer registers.
3. The CPU checks the PVTC 'RDFLG' status bit to assure that any previous operation has been completed.
4. The CPU issues a 'write at cursor with/ without increment' or a 'write at pointer' command to the PVTC.


Figure 6. Independent Buffer Mode Configuration
5. The PVTC negates 'RDFLG', outputs the specified address, and generates control signals to perform requested operation. Data is copied from the interface latch into the memory.
6. The PVTC sets its 'RDFLG' status to indicate that the write operation is completed.

Similarly, a read operation proceeds as follows:

1. Steps 2 and 3 as above.
2. The CPU issues a 'read at cursor with/ without increment' or 'read at pointer' command.
3. The PVTC negates 'RDFLG', outputs the specified address, and generates control signals to perform the read operation. Data is copied from the memory to the interface latch and the PVTC sets its 'RDFLG' status to indicate that the operation is completed.
4. The CPU checks the 'RDFLG' status to see if the read is completed.
5. The CPU reads the data from the interface latch.

Loading the same data into a block of display memory is accomplished via the 'write from cursor to pointer' command:

1. The CPU loads the data to be written into the display memory into the interface latch.
2. The CPU writes the beginning address of the memory block into the PVTC's cursor address register and the ending address of the block into the pointer address register.
3. The CPU checks the 'RDFLG' status bit to assure that any previous operation has been completed.
4. The CPU issues a 'write from cursor to pointer' command to the PVTC.
5. The PVTC negates 'RDFLG' and outputs block addresses and control signals to copy the data from the interface latch into the specified block of memory.
6. the PVTC sets its 'RDFLG' status to indicate that the block write is completed.

Similar sequences can be implemented on an interrupt driven basis using the READY interrupt output from the PVTC to inform the CPU that a previously requested command has been completed.

Two timing sequences are possible for the 'read/write at cursor/pointer' commands. If the command is given during the active display window (defined as first scan line of the first character row to the last scan line of the last character row), the operation takes place during the next horizontal blanking interval. If the command is given during the vertical blanking interval, or while the display has been commanded blanked, the operation takes place immediately.

For the 'write from cursor to pointer' operation, the PVTC's BLANK output is asserted automatically and remains asserted until the horizontal retrace interval following completion of the command. The memory is filled at a rate of one location per two character times, plus a small amount of overhead.

## Shared and Transparent Buffer Modes

In these modes the display buffer RAM is a part of the CPU memory domain and is addressed directly by the CPU. Both modes use the same hardware configuration with the CPU accessing the display buffer via threestate drivers (see figure 7). The processor bus request ( $\overline{\text { PBREQ }}$ ) control signal informs the PVTC that the CPU is requesting access to the display buffer. In response to this request, the PVTC raises bus acknowledge ( $\overline{\mathrm{BACK}}$ ) until its bus external ( $\overline{\mathrm{BEXT}}$ ) output has freed the display address and data busses for CPU access. $\overline{B A C K}$, which can be used as a 'hold' input to the CPU, is then lowered to indicate that the CPU can access the buffer.

In transparent mode, the PVTC delays the granting of the buffer to the CPU until a vertical or horizontal blanking interval, thereby causing minimum disturbance of the display. In shared mode, the PVTC will blank the display and grant immediate access to the CPU.

## Row Buffer Mode

Figure 8 shows the hardware implementation for the row buffer mode. During the first scan line (line 0 ) of each character row, the PVTC halts the CPU and DMA's the next row of character data from the system memory to the row buffer memory. The PVTC then releases the CPU and displays the row buffer data for the programmed number of scan lines. The bus request ( $\overline{\mathrm{BREQ}}$ ) control signal


Figure 7. PVTC Shared or Transparent Buffer Modes


Figure 8. Row Buffer Mode Configuration
informs the CPU that character addresses and the memory bus control (MBC) signal will start at the next falling edge of BLANK. The CPU must release the address and data busses before this time to prevent bus contention. After the row of character data is transferred to the CPU, BREQ returns high to grant memory control back to the CPU.

## A MINIMUM CHIP COUNT TERMINAL IMPLEMENTATION

Figure 9 is the schematic of a minimum chip count CRT terminal using the four CRT set devices. Only 15 IC packages are required for the complete implementation, including all keyboard encoding and RS-232 level conversion for the serial interface. Despite this low
chip count the terminal is capable of providing an impressive array of features including:

Display Format:

- 24 or 25 character rows
- 80 characters per row


## Character Format:

- $7 \times 9$ dot matrix character in a $9 \times 12$ character block
- 96 ASCII alphanumeric characters
- 32 special symbols
- Block graphics
- Line drawing character set

Cursor:

- Underline or block cursor
- Optional blinking

Keyboard:

- 128 keys maximum
- Non-encoded
- Cursor control keys
- Numeric keypad

Serial Interface:

- Full or half duplex
- RS-232 compatible
- 16 baud rates with internal baud rate generator
- Character or block transmission

6 66



Operating Modes:

- Normal
- Transparent (displays graphic and control characters)
- Page or scroll with optional smooth scroll

Visual Attributes:

- Blink
- Reverse video
- Highlight
- Underline
- Non-display

The system utilizes the independent buffer mode to minimize hardware requirements. The dual port interface to the $2 \mathrm{~K} \times 8$ display buffer is via a Signetics $8 \times 31$ bidirectional latch. This may be replaced by a unidirectional latch such as the 74LS374 if reading of the FAM's contents by the CPU is not required.

The operating program for the terminal is contained in the internal ROM of the 8049 microcomputer, which also provides the RAM required by the system program. Since the maiority of the terminal's features are tailored by firmware, the ROM size can be increased, either internally or externally, to support additiona! functions. ${ }^{1}$

## BASIC TERMINAL SOFTWARE

The software for a microcomputer based terminal is closely tied to the system hardware configuration and its characteristics. If an interrupt driven mode of operation is desired, the system hardware/software design must be capable of prioritizing the interrupts so that the system will correctly service interrupts from different sources. In a typical system, there are three interrupt sources: the keyboard, the communications interface, and the video timing controller. The latter must usually be assigned the highest priority since failure to service an interrupt from the video timing controller on a timely basis may result in visual perturbations on the display. The keyboard and datacomm interrupts can, in most cases, absorb some time delay before they are serviced since they include one or more levels of data buffers.

Often, a multi-level interrupt structure will be required so that a high priority interrupt requiring immediate service can be serviced even while the system is in the process of servicing a lower priority interrupt.

A simplified flowchart for the software for an interrupt driven terminal is shown in figure 10. After application of power, the microprocessor first performs a system initialization routine which consists of five parts:

1. Clear the microcomputer's scratchpad RAM.
2. Initialize the 2672 PVTC for the desired screen format, monitor timing parameters, cursor parameters, and display start address.
3. Clear the CRT display by loading a non display-code (usually an ASCII 'space', 20 hex) into the buffer memory.
4. Initialize the 2671 PKCC for the desired keyboard and serial interface modes.
5. Read any mode switches (e.g., full or half duplex, baud rate, cursor type, etc.) and set system parameters as required.
The processor can now enable its interrupts and wait in a loop until an interrupt is received. When this happens, the processor first determines the source of the interrupt and then performs the required system operation.

An interrupt from the CRT timing controller usually indicates that some information is required for proper screen refresh operation. For example, the PVTC may issue a 'split screen' interrupt to indicate that a new address must be loaded into its screen start registers in order for the next character row to be displayed from other than the next sequential address in memory. The CPU must service this interrupt within a finite time in order for the display to operate correctly.
An interrupt from the keyboard interface may be either a displayable character or a control function. Displayable characters are usually transmitted to the host computer and also placed into the buffer memory for display on the terminal. Certain control characters, such as cursor control keys or keyboard error codes, may cause only local actions, while others will also require transmission to the host.

An interrupt from the data communications interface may also be a displayable character or a system control character. In either case the microprocessor must determine the type of character and perform the necessary system operation.

## A DESIGN EXAMPLE

A fully operational emulation of an IBM 3101 terminal was designed and constructed using the Signetics CRT chip set. The terminal incorporates the majority of the 3101's functions. Selected functions were not incorporated due to program memory limitations. For example, the tabbing functions were developed and tested but were left out in deference to the block transmission functions.

## Table 1. TERMINAL FEATURES

Display Screen Format

- 2000 character screen capacity ( 25 rows $\times 80$ columns)
-- Operator information area (25th line)
- Block-shaped cursor with optional blinking

Displayable Graphic Set

- 95 ASCII characters for nontransparent mode
- 128 characters for transparent mode
$-7 \times 9$ character matrix in $9 \times 12$ field

Keyboard

- 63-key main keyboard
- 12-key control key cluster
- 12-key numeric keypad
- Keyboard lock/unlock under software control
- Keyboard clicker
- Typamatic operation

Edit Functions

- Cursor controls: up, down, left, right, home
- Cursor address read and write
- Erase functions: erase EOL, erase EOS, clear screen

Visual Attributes
-- Highlighted field

- Blinking field
- Non-displayed field
- Underlined field

Modes of Operation

- Transmission modes: character or block (page or line)
- Normal or transparent

Line Protocol

- Asynchronous
- 7-bit ASCII with programmable parity
- One or two stop bits
- Full or half duplex
- Online or local
- Programmable line turnaround character for block mode (EOT/ ETX/CR/XOFF)
- EIA RS232 interface
- Communication line speed: 50 to 9,600 baud

Screen Refresh Rate
$-60 \mathrm{~Hz}$

More features could have been included by selecting another of the numerous microprocessor devices on the market with greater program memory capacity. Major features of

[^22]

## the terminal are summarized in table 1.

## Terminal Hardware

The block diagram of the 8035 based terminal is illustrated in figure 11. It is an expanded version of the logic shown in figure 9, the major difference being a larger display RAM, to provide up to two pages of screen data, and the addition of several input ports to handie the large number of option and set-up switches. The terminal's software is contained in 4 K of program storage external to the 8035.

The 2672 PVTC is programmed to operate in the independent buffer mode with the CPU isolated from the display RAM by two 74LS364 eight-bit latches, which provide the path for data transfers between the CPU and FAM. The PVTC, responding to commands from the CPU, completely controls the data transfer. To avoid display interference, the PVTC is instructed to complete the access during a blanking interval. For massive display updates (clear screen, load form, etc.) the PVTC is instructed to blank the display and service the data transfer immediately and continuously. Additional memory contention circuitry is not necessary since the PVTC provides all of the timing and addressing (via cursor and pointer) necessary to complete the transfer. An interrupt from the PVTC informs the CPU when an operation is completed.

The PVTC addresses the display buffer memory, which contains both character and attribute data. An attribute byte is identified by the software by setting bit 7 of the byte to a logic 1. The RAM data outputs are applied to the 2670 DCGG, which provides the character dot data information, and to the 2673 VAC .

The VAC is hardwired to operate in the field attributes mode for this application. An attribute character occupies a screen position but is not displayed unless the $A C D$ input to the VAC $C$ is asserted. Bit 7 of the character byte identifies a character as an attribute character if it is a 1 . When bit 7 on the RAM data bus is a 1 , the attribute byte is latched into the VAC to begin a new attributes field. Since the attributes are double buffered in the VAC, only one byte (at any character position) is required to specify a field.

The bipolar VAC circuit serializes the dot data from the DCGG into a 17.5 MHz data stream for the monitor. Two TTL-level video outputs
provide three levels of video: black, white, and gray.

The PKCC provides the asynchronous data communications link at one of sixteen selectable baud rates. The PKCC addresses two 74LS145s which act as a 4-to-16 decoder to drive a $16 \times 8$ matrix keyboard. Key depressions are detected on the KRET input from a 74LS151 8-to-1 multiplexer. Each key depression is debounced, encoded according to the states of the SHIFT and CONTROL inputs, and presented to the CPU. Repeat and 'typomatic' (auto-repeat) functions are processed automatically by the PKCC.

## Memory Allocation

The 4 K bytes of available buffer memory were allocated as follows (all addresses are in hex):

- 0000 to 004 F : display data for row 25, status line
- 0050 to 0075: not used
- 0076 to 007F: CPU scratchpad
- 0080 to 07FF: display data for rows 1 to 24
- 0800 to 0FFF: not used, available for second page of display data

The PVTC's 'display buffer first address' and 'display buffer last address' registers are loaded with the values 0080 and 07FF respectively so as to cause this portion of the RAM to act as a circular buffer. Initially the display data is organized in the RAM as follows:

- 0080 to 00CF: row 1 data
- 00D0 to 011F: row 2 data


## -

- 
- 07B0 to 07FF: row 24 data

When a scroll operation is required, the CPU changes the value in the PVTC's 'screen start' register from 0080 to 00D0. This effectively shifts the displayed data up one row. Upon reaching the specified last buffer address (which is now the last character in row 23), the PVTC automatically changes the addressing sequence to resume starting at 0080 for the 24th row. The display data is now organized:


- 07B0 to 07FF: row 23 data


## - 0080 to 00CF: row 24 data

The CPU can clear the previous data in 0080 to 00CF so that a blank row appears in the 24th position.

The status line (row 25) data is kept in a separate section of RAM to eliminate the necessity of moving the data whenever the scrolling operation described above occurs. Thus, the PVTC must be instructed to change its addressing sequence at the beginning of the 25th row. This is accomplished by use of the split screen row interrupt capability. IR10, the 'split screen interrupt row' register, is initialized so as to cause an interrupt to be issued at the beginning of row 24. The CPU responds to this interrupt by changing the value in the screen start register to 0000. The PVTC then uses this value as the starting address of the next (25th) row, causing the status line to be displayed in that position. The CPU must re-load the screen start register before the end of the vertical blanking interval with the correct value for the first character to be displayed on the screen.

## Terminal Software

Because the 8035 microcomputer used in the terminal provides only a single interrupt level, a totally interrupt driven software design could not be used. The interrupt was assigned to the PVTC to service the split screen interrupt described above and the operations required to implement the smooth scroll feature. The keyboard and datacomm functions are serviced by polling the PKCC status register. Both the keyboard interface and UART receiver are double buffered in the PKCC, preventing overrun even if they are not serviced immediately.
The program generally follows the typical program flow described previously. At system reset the 8035 interrupts are disabled, data memory and display memory are cleared to zeroes, and both the PVTC and PKCC are master reset through software commands. The system option switches are then read and stored and the PVTC and PKCC internal registers are initialized for the selected operation. Finally, the initial data for the status line is loaded, the PVTC, UART, and keyboard are enabled, and the CPU interrupt is enabled. The program then enters a loop where the PKCC is checked for keyboard or UART entries. If an entry has occurred, the character is fetched and stored in a software controlled FIFO (first-in-first-out) memory which is

[^23]
eight bytes deep for both receiving or transmitting characters (the need for the FIFO is described below). If either FIFO has an entry, the program proceeds to a character recognition routine which checks for the type of character (displayable or control) and the appropriate handling subroutine (ESC sequence, control sequence, cursor control, character display, etc.) is called. If the FIFO's are empty, the polling routine checks the option switches for any changes since reset entry and if so reconfigures the system as necessary.

The need from the FIFOs results from the method used to effect the clear row function required when a scroll is performed. Although the PVTC includes a 'clear from cursor to pointer' command that can be used to clear a block of memory rapidly, the display is temporarily blanked during this operation. This would cause undesirable flashes on the display. Instead, the program does the function by a repetitive loop using the 'write at cursor and increment' command. Since the write occurs only once per scan line during the active display window, a worst case total of approximately 80 scan line times is required to execute the routine. This would limit the maximum received character rate to approximately one per 80 scan lines or about 240 characters per second ( 2400 baud). To over-
come this limitation, the PKCC is also polled each time through the clear line subroutine loop, and any entries from the receiver or keyboard are stored in the appropriate FIFO. Since the FIFO is eight deep, this allows eight characters to be received in the same time, increasing the maximum baud rate to 19,200 . (Other program limitations actually reduce the maximum baud rate to 9600 baud). However, this does not increase the rate at which characters which cause a scroll function to occur, such as a line feed, can be received. Each character of this type must be followed by 'fill' characters in order for data rates higher than 2400 baud to be used.
An interrupt from the PVTC will occur when the display scan reaches the row count programmed in its split screen address register, row address 24 (for the 24th row). In response to the interrupt, the CPU loads the screen start registers with the address of the status line (0000) and enables the PVTC's line zero interrupt. This causes another interrupt at the beginning of display of the status line. At this time the CPU reloads the screen start register with the proper address to begin the next display frame and disables the line zero interrupt.

If scrolling is required the screen start register value is incremented by 80 (popping off the
top row) and the effective bottom row cleared to nulls. If soft scrolling is selected, additional functions are performed during the interrupt routines. To begin the operation, the line zero interrupt routine adds ten lines to the vertical back porch. This causes the next active screen display to begin ten scan lines later than normal and gives the effect of the display moving up two scan lines (12 lines per character row-10) instead of jumping up 12 lines. If nothing else were changed, however, the bottom of the display would move down ten lines. thus, during the row 24 interrupt the number of scan lines per character row is changed to two (12-10), causing only the first two scan lines of that row to be shown. The next line zero interrupt (at row 25) restores the lines per row count back to 12 to keep the whole status line showing, and now changes the vertical back porch to 8 . The display moves up two more scan lines and at the next row 24 interrupt four scan lines are shown. The process continues in this manner, providing the effect of the entire display, except for the status line, smoothly scrolling up over a selected interval of six frames, or one tenth of a second.

## Timing Calculation Example

The AVDC register values need to be calculated to provide suitable drive signals for the selected monitor. In the following example,


Figure 12. Horizontal and Vertical Timing

## Using the 2670/71/72/77 CRT Terminal Chip Set

each character will be contained in a 8 dot by 10 line field with a total of 24 rows displayed.

The total number of active scan lines will be $10 \times 24$ or 240 . An estimate of the horizontal refresh rate required for the monitor can be made using the following formula assuming a screen refresh rate of 60 Hz with a vertical retrace of 10 percent of the active scan lines:
Horizontal frequency $=$
$(60) \times(240) \times(1.1)=15,840 \mathrm{~Hz}$
In order to calculate the IR register values of the AVDC, the CRT monitor characteristics need to be obtained. An NEC monitor was used for the worksheet. The major timing specifications for the monitor are:

| Horizontal frequency: | 15.75 KHz |
| :--- | :--- |
| Horizontal retrace: | $15.5 \mu \mathrm{~s}$ |
| Horizontal sync width: | $4.76 \mu \mathrm{~s}$ |
| Vertical frequency: | 60 Hz |
| Vertical retrace: | 1.43 ms |
| Vertical sync width: | 0.19 ms |

Monitor timing definitions are shown in figure 12. The worksheet illustrated in table 2 can be used to compute the required timing and associated PVTC register values. Some rough guesses are required initially and several iterations through the worksheet may be required.

The worksheet can be used to determine the dot clock frequency required given the monitor characteristics above, the number of characters per row, the number of dots per character, the number of character rows per screen, and the number of scan lines per character row. The horizontal sync width was estimated by the ratio of the sync width time with respect to the retrace time given in the monitor information above. The horizontal and vertical front and back porches were estimated from the remaining time left during the retrace.

Table 2. TIMING WORKSHEET

| 1. | Horizontal Character Block (number of dots) | 8 |  |
| :---: | :---: | :---: | :---: |
| 2. | Vertical Character Block (number of scan lines) | 10 | (IRO) |
| 3. | Vertical Refresh Rate, Hz | 60 |  |
| 4. | Horizontal Line Rate, KHz | 15.75 |  |
| 5. | Characters Per Row | 64 | (IR5) |
| 6. | Character Rows Per Screen | 24 | (IR4) |
| 7. | Total Active Video Scan Lines (step $2 \times$ step 6) | 240 |  |
| 8. | Total Scan Lines Per Frame (step $4 /$ step 3) | 262.5 |  |
| 9. | Vertical Retrace Interval (step 8-step 7) | . 22.5 |  |
| 10. | Vertical Front Porch (number of scan lines) | 8 | (IR3) |
| 11. | Vertical Back Porch (number of scan lines) | 12 | (IR3) |
| 12. | Vertical Sync Width (number of scan lines) | 3 |  |
| 13. | Horizontal Scan Line Rate, us (1 / step 4) | 63.5 |  |
| 14. | Horizontal Active Video Time, us | 48 |  |
| 15. | Horizontal Retrace Time, us | 15.5 |  |
| 16. | Horizontal Retrace Time (character time units) (step 15 / [step 14 / step 5]) | 20.7 |  |
| 17. | Horizontal Back Porch (character time units) | 7 | (IR2) |
| 18. | Horizontal Sync Width (character time units) | 6 | (IR2) |
| 19. | Horizontal Front Porch (character time units) | 8 |  |
| 20. | Total Character Time Units in One Horizontal Scan Line (add steps 5, 17, 18, and 19) | 85 |  |
| 21. | Equalizing Constant ([step $20 / 2$ ]- [2 X step 18]) | 31 | (IR1) |
| 22. | Character Clock Rate, MHz (step 20 X step 4) | 1.339 |  |
| 23. | Character Period, us (1/ step 22) | 0.747 |  |
| 24. | Scan Line Period, us (step 23 X step 20) | 63.50 |  |
| 25. | Dot Clock Rate, MHz (step $22 \times$ step 1) | 10.712 |  |

## Signetics

## Microprocessor Products

## INTRODUCTION

The Signetics CRT chip set consists of four LSI devices which, when combined with standard microcomputer, memory, and TTL products, permit the implementation of a CRT terminal in as few as 15 total packages. The four LSI devices are:

## 2670 Display Character and Graphics Generator (DCGG)

The 2670 is a mask programmable line select character generator which contains the dot patterns for $12810 \times 9$ characters. It also provides a semigraphics capability wherein the 8 -bit character code is translated directly into 256 graphic patterns useful for presenting data such as graphs and forms on the CRT display. Additional features of the DCGG include character and line address latches, internal descend logic and thin line graphics.

## 2671 Programmable Keyboard and Communications Controller (PKCC) <br> The 2671 provides a versatile keyboard

 interface and an asynchronous communications interface in a single package. The keyboard section handles the scanning, debounce, and encoding of mechanical or capacitive keyboards with up to 128 keys utilizing any of four programmable rollover modes. An internal ROM provides any of four key codes for a depressed key. The communications section is a universal asynchronous receiver and transmitter (UART) with programmable character length, parity, and stop bits. A baud rate generator providing 16 standard communications frequencies which operates directly from a crystal is also incorporated in the 2671.
## 2672 Programmable Video Timing Controller (PVTC)

The 2672 is designed for use in CRT terminals and other display systems that employ raster scan techniques. It generates the vertical and horizontal timing for the CRT monitor, and provides the ad-

AN403

# 2670/71/72/73 CRT Set Application Briefs <br> Application Note 

dressing for the display buffer memory The CPU to display buffer interface can be programmed for several different modes of operation, including full screen buffer, rnultiple page buffer, or row buffer, as required by the application. Programmable features of the PVTC include screen format (characters per row, scan lines per row, rows per screen), horizontal and vertical timing parameters, cursor type, interlaced or non-interlaced operation, and character and cursor blink timing.

## 2673 Video and Attributes Controller

The 2673 is a bipolar LSI device that contains the high speed timing circuits required in CRT terminal systems. Included on the 2673 are a dot clock counter, video shift register, field and character attributes logic, and cursor display circuits. The 2673 attributes capabilities are reverse video, character blank, blink, underline, highlight, light pen, and graphics. The device provides both TIL and analog video outputs and operates at dot frequencies up to 25 MHz .

Individual data sheets are avaiiable which describe each of the devices in full detail. A previously published application note entitled 'Using the 2670/ 71/72/73 CRT Terminal Chip Set' (AN401), describes the implementation of CRT terminals using the chip set. The purpose of this application note is to provide information on the implementation of special end-product features.

## SMOOTH (SOFT) SCROLLING

Scrolling is used in CRT terminals to provide the effect of an "endless page" on which the data can be written. In normal implementations, once the screen fills up, the space for the next row of data is provided by removing the top row and moving all the remaining rows up by one row, thus creating a blank data row at the bottom of the
screen into which the new information is placed. (The process may be reversed if the new data is to be written at the top of the screen). This technique creates a readability problem when viewing data which is being received at a relatively high speed, since the rows are jumping up (or down) at a fast rate. Smooth or soft scrolling improves readability by moving the data in scan line increments instead of in whole row jumps, thus creating the effect of a sheet of paper slowly being moved through the viewing area. One system restriction of providing the smooth scrolling feature is that the rate at which new rows of data can be received is limited to the rate at which the display is being moved. Thus, successive line feeds must be separated by a minimum number of real or dummy 'fill' characters in order to allow the display to keep up with the received data. The number of fill characters will be a function of the number of scan lines per character row, the scroll rate, and the communications line speed, and may also be affected by the inclusion of software and/or hardware features such as a data buffer in the systern design.

When using the CRT chip set, smooth scrolling can be implemented in software only, or with a combination of hardware and software.

## Software Only Method

The software only method of smooth scrolling uses the 2672 's capability to program the scan lines per row and the vertical back porch, and the ability to program an interrupt to occur at any row by programming the row value into the split screen register, IR10. Three limitations of this method are:

1. Scrolling must be in an upward direction.
2. The screen area that is scrolled must start at the top of the display but can end at any row.
3. The minimum scrolling increment is two scan lines.

The flowchart in figure 1 shows the steps necessary for scrolling starting at the top of the screen and ending at character row $23^{1}$, with an additional non-scroiling row at row 24. The IR10 value is set to 23, to cause an interrupt to occur at row 23. This interrupt routine then enables the line zero interrupt, so that another interrupt occurs at row 24. The line zero (row 24) interrupt routine disables the line zero interrupt so that another line zero interrupt is not asserted until the split screen (row 23) interrupt routine enables it again.

When a scroll is desired, the system software changes the screen start address to the new value (normally an address ' $n$ " characters higher than the previous value, where " $n$ " is the number of characters per row) and sets a scroll flag. The top row disappears and normally the display would jump up by one row. However, the line zero interrupt routine notes that the scroll flag is set and adds the value "s-2" ( $\mathrm{s}=\mathrm{scan}$ lines/row) to the vertical back porch (IR3). This causes the next active screen display to begin " s -2" lines later than normal and gives the effect of the display moving up two scan lines instead of jumping a full row. If nothing else were changed, however, the bottom of the display would move down the same number of scan lines. Thus, during the split screen interrupt routine the number of scan lines per character row (IR0) is changed to two, causing only the first two scan lines of that row (which is the new row) to be displayed and maintaining the proper value for the total scan lines. The next line zero interrupt restores the lines per row value back to its normal state to display the whole of the last character row, and now decreases the vertical back porch increment by two. The display moves up two more scan lines and at the next split screen interrupt four scan lines are allowed. The process continues in this manner until the scroll is completed.

Note that the CPU must complete the split screen interrupt routine within two scan line times.

## Hardware/Software Method

The hardware/software method of smooth scroll removes the restrictions of the software only method. The scrolling region can begin and end at any character row, scrolling can be performed in either the up or down direction, and the minimum scroll increment can be one scan line.

A block diagram of the required hardware for the case of full screen scroll is illustrated in figure 2. When scrolling is required, the CPU writes the number of scan lines to scroll into the 4 -bit latch during the vertical retrace interval. The scan line adder detects when
the sum of the offset and the scan line address is greater than the programmed number of scan lines per row and causes the RAM address to be automatically offset to the next character row by the n-bit RAM address adder. The CPU adjusts the value in the scan lines to scroll latch at desired intervals, e.g., each vertical retrace, to effect the smooth scroll. When the scroll is completed, the screen start address is changed to the new value required for the top character row.
If only a partial screen scroll is required, the hardware must be modified to cause the offset to be applied only during the scrolling area. The lines to scroll latch of figure 2 is replaced by the circuit shown in figure 3. The software is written with split screen interrupts at the row before the first row which is to be scrolled (interrupt 1) and at the last scrolled row (interrupt 2). The required program actions are as follows:

1. During vertical retrace, the screen start address for the non-scrolled region at the top of the screen is loaded and IR10 is loaded with the row number required for interrupt 1.
2. During interrupt 1, a new screen start address for the scrolled region is loaded (if required), IR10 is loaded with the value required for interrupt 2, and the lines to scroll latch is loaded with five bits of data consisting of the four bit lines to scroll value plus an asserted 'scroll' bit. The hardware will cause the scan line offset to be applied to the adder at the beginning of the next character row, as required.
3. During interrupt 2, a new screen start address for the non-scrolled region at the bottom of the screen is loaded (if required), and the 'scroll' bit is negated. The hardware will cause the scan line offset to be removed from the adder at the beginning of the next character row, as required. If the scroll region extends to the bottom of the visible screen, this interrupt is not required. Note that the time required to service this interrupt will determine the minimum number of scan lines per scrolling increment.

## HORIZONTAL SCROLL

Horizontal scrolling allows the terminal to be used to read or write pages which are wider than the actual screen width. For example, if an actual page width of 132 characters is to be displayed on a terminal with a capacity of 80 characters per row, horizontal scrolling can be used to display any desired 80character "window" of the 132-character row. The window can be moved in response to operator keyboard commands, allowing all

132 columns to be observed. The CRT set capabilities allow horizontal scrolling in single or multiple character increments to be implemented using software only. As described in the 2672 data sheet, changing the contents of the screen start address register during a particular row, say row ' $n$ ', will cause the display of the next row, ' $n+1$ '', to begin from the new address. This feature, together with the capability to interrupt at every row via the line zero interrupt, can be used to update the contents of the screen start register once each row to effect the horizontal scroll. The software operations required are as follows (see figure 4):

1. During the vertical retrace interval, the screen start register is initialized with the starting memory address of the display page plus the desired horizontal scroll (in characters).
2. The line zero interrupt is enabled. During each interrupt service the value in the screen start address is incremented by the actual (not display) page width. This may be done either by referencing a table of starting addresses or by performing the required addition.

## COLOR DISPLAY INTERFACE

Figure 5 illustrates the block diagram of a color monitor interface. Eight coiors for foreground and background with three attributes are supplied. The system operates in the character attribute mode with a 16-bit word of data for each character: seven bits for character select, six bits for color select, and three bits for other attributes.
The two 74LS374s delay the color information by two CCLKs to allow for the two CCLK delays of dot data through the DCGG and VAC. The video output of the VAC selects foreground or background color (active dot or not) for each character cell via the 74LS157 multiplexer. A variable CCLK delay may be required to synchronize the delay of the color information through the latches to the delay of the video data from the VAC.

## EXTERNAL VIDEO SYNC

Some applications require overlaying of characters on an existing video display. An example of this is the addition of subtitles to a picture display. Figure 6 illustrates a simple technique of externally synchronizing the 2672 PVTC to an external video source. The dot clock to the 2673 VAC is stopped (character clock falling edge) at the start of the PVTC's sync interval and restarted upon occurrence of the external sync signal. The sync timing programmed in the 2672 must be slightly faster than the external sync rate.

[^24]


NOTES:

1. Hardwire adder inputs to number of characters per row.
2. Carry logic asserts output when output of adder exceeds normal scan lines/row.

Figure 2. Smooth Scroll Hardware Block Diagram


Figure 3. Partial Screen Smooth Scroll Modification


## SCAN LINE COUNT GREATER THAN 16

Certain applications may require more scan lines than the 16 scan lines per character row (non-interlaced) which the 2672 can provide. Figure 7 shows the hardware required to obtain up to 32 scan lines per character row. The PVTC must be programmed for double height character rows. This causes the scan line count outputs from the 2672 (DADD4DADD7) to increment once every two scan lines. The external flip-flop toggles each scan line to provide a fifth bit of scan line count information for the character generator. The technique permits any even value of scan lines per character row from 2 to 32 to be obtained.

## BIT MAPPED GRAPHICS

Figure 8 illustrates an implementation of a bit mapped display with the chip set. In this
configuration, the contents of the memory will be displayed without character generator translations. Thus, each bit in the memory corresponds to a single pixel on the display. Each horizontal scan line is defined by a contiguous set of bytes in the RAM. The data is written in groups of 8 bits by the CPU and is accessed by the PVTC in groups of 8 bits. The character generator of a normal alphanumeric configuration is replaced by an 8 -bit latch to implement the one CCLK delay normally provided by the 2670 . The PVTC can be programmed for one scan line/row to cause the memory addressing to proceed without repetition of addresses in each row.

The PVTC can be programmed to a maximum of 256 characters/row and 128 rows/screen. Thus, a 2048 by 128 bit map is possible. If more than 128 dots are required vertically, the PVTC can be programmed for more than one scan line/row and the scan line outputs can be used as part of the RAM address,
creating several segments of memory. For example, if 256 lines are required, the PVTC must be programmed for two lines/row. The use of LAO as part of the memory address creates two segments. The CPU writes the data for odd scan lines in one segment of the memory and the data for even scan lines in the other. As the PVTC accesses the RAM the scan line count will go from 0 to 1 addressing the even and then odd portion of the RAM for each character row.
Figure 8 shows the DCGG as optional. By using the 2672's split screen capability and changing 2672 parameters, the CPU can enable the DCGG to be active for a portion of the screen thereby incorporating both bitmapped and alphanumeric sections on the same display.


BD00210S
Figure 5. Color Display Block Diagram


Figure 6. External Sync Lock


Figure 7. Greater Than 16 Scan Lines Per Row


AF00690S
Figure 8. Implementation of Bit Mapped Display

## PAL/NTSC COLOUR ENCODER

## GENERAL DESCRIPTION

The TEA2000 is a monolithic integrated circuit, which encodes colour information and provides composite video output for driving a VHF or UHF modulator.

## Features

- European PAL and American NTSC/M standard selectable
- Internal generation of burst timing and PAL-switch-function
- 6 bit binary TTL compatible input provides 64 different colours
- TTL compatible colour blanking input
- TTL compatible sync input

QUICK REFERENCE DATA

| Supply voltage | $V_{11-9}$ | typ. | 12 V |
| :---: | :---: | :---: | :---: |
| Supply current at $\mathrm{V}_{11-9}=12 \mathrm{~V}$ | 111 | typ. | 55 mA |
| Input voltage pins 1,2,3,4,5,14,16,17,18 | $\begin{aligned} & V_{I L} \\ & V_{I H} \end{aligned}$ | max. $\min$. | $\begin{aligned} & 0,8 \mathrm{~V} \\ & 2,0 \mathrm{~V} \end{aligned}$ |
| Composite video output (sync tip to white) | $V_{6-9}$ (p-p) | typ. | 2,0 V |
| Operating temperature range | Tamb | 0 to $+70{ }^{\circ} \mathrm{C}$ |  |

## PACKAGE OUTLINE

18-lead DIL; plastic with internal heat spreader (SOT-102HE).


Fig. 1 Block diagram.

## PINNING

1. Red 1 binary input
2. Green 0 binary input
3. Green 1 binary input
4. Blue 0 binary input
5. Blue 1 binary input
6. Composite video output
7. Luminance output to delay line
8. Luminance input from delay line
9. Ground 0 volt
10. Chrominance band limiting
11. Supply voltage
12. $\}$ Oscillator inputs $\left\{\begin{array}{l}7,16 \mathrm{MHz} \text { crystal for NTSC } \\ 8,86 \mathrm{MHz} \text { crystal for PAL }\end{array}\right.$
13. PAL/NTSC switch
14. Ramp
15. Composite sync input ( $\overline{\mathrm{CSYNC}})$
16. Composite blanking input (CBLNK)
17. Red 0 binary input

## FUNCTIONAL DESCRIPTION

The TEA2000 PAL/NTSC colour encoder and video summer integrated circuit has an internal oscillator from which the ( $R-Y$ ) and ( $B-Y$ ) waveforms are generated. The TEA2000 accepts timing signals (composite sync, composite blanking) and a 6 bit binary coded input giving colour information. The inputs are organized as 2 bits per primary colour and gamma correction is applied to the resultant luminance and chrominance levels. Each of the equally spaced intensity levels (for each primary colour) is combined with those of the other primary colours. This produces 64 output colours comprising a wide range of saturated and desaturated colours, black, white and two levels of grey. The resultant output is a composite video signal compatible with the PAL and NTSC/M standards.

## PIN DESCRIPTION

R0, R1, G0, G1, B0, B1, pins 18, 1,2,3,4 and 5.
These are the red, green and blue logic inputs. 2 bits per primary colour. These inputs are TTL compatible.
$\overline{C S Y N C, ~ p i n ~} 16$.
Composite sync input requiring a negative logic signal, TTL compatible. For PAL operation the field sync must include line sync information.

XTALA, XTALB, pins 12 and 13.
Oscillator inputs. A crystal in series with a trimmer capacitor is connected between pins 12 and 13. The output of the oscillator is divided to provide the four subcarrier phases required in the encoder. The crystal frequencies are:

PAL mode $8,867238 \mathrm{MHz}$
NTSC mode $7,15909 \mathrm{MHz}$

LUMO, LUMI, pins 7 and 8.
Luminance output and input. The combined luminance and sync signal appearing at pin 7 must be d.c. coupled to pin 8 via an appropriate luminance delay line or resistor network. Resistors must have a tolerence of $\pm 5 \%$, or better, as they affect the d.c. level at COVO, pin 6.

CHRBL, pin 10.
Chrominance filtering can be accomplished by connecting a chrominance frequency tuned filter $(4,43 \mathrm{MHz}$ or $3,57 \mathrm{MHZ})$, via a blocking capacitor to pin 10 . This point is the chrominance summing junction and has a nominal internal impedance of $1,5 \mathrm{k} \Omega$. If a filter is used at this point then the delay caused to the chrominance signal should be compensated by an appropriate luminance delay line.

COVO, pin 6.
Composite video output is internally buffered giving a nominal output voltage swing of 2 V sync-white and a nominal sync 5 V level.

PL/ $\overline{\mathbf{N T}}$, pin 14.
PAL/NTSC, select input selects PAL mode when HIGH and NTSC mode when LOW. This input is TTL compatable. An internal pull-up resistor selects PAL if the pin is not connected.

RAMP, pin 15.
Ramp timing component connection. A capacitor and resistor connected to pin 15 provide timing information for the colour burst and for PAL phase switching. Alternative components may be used to optimise for NTSC operation.
$V_{C C}, \operatorname{pin} 11$.
12 volt supply.
GND, pin 9.
Ground connection, zero volts.
CBLNK, pin 17.
Blanking input when high, switches off colour inputs. CBLNK must be high during sync and colour burst unless colour inputs are all low at this time. This input is TTL compatible.

## RATINGS

Limiting values in accordance with Absolute Maximum System (IEC 134)

| Supply voltage $\mathrm{V}_{11-9}$ | max. | 13,2 |
| :---: | :---: | :---: |
| Voltages, pin 1,2,3,4,5,14,16,17,18 | max. | $\mathrm{V}_{11-9}$ |
| Storage temperature | -20 | +125 |
| Operating ambient temperature |  | + 70 |

## CHARACTERISTICS

$\mathrm{V}_{11-9}=12 \mathrm{~V}$; $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$; measured in Fig. 3 unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply |  |  |  |  |  |
| Supply voltage | $\mathrm{V}_{11-9}$ | 10,8 | 12 | 13,2 | V |
| Supply current $\mathrm{V}_{11-9}=12 \mathrm{~V}$ | 111 | - | 55 | - | mA |
| Oscillator stability, pins 12 and 13 |  |  |  |  |  |
| Crystal type 432214304051 <br> $\mathrm{V}_{\mathrm{P}}=10,8$ to 12 V |  | - | +50 | - | Hz |
| $V \mathrm{P}=12$ to $13,2 \mathrm{~V}$ |  | - | -50 | - | Hz |
| Digital inputs |  |  |  |  |  |
| $\overline{\text { CSYNC, CBLNK, PL/ } \overline{N T} \text { pins } 16,17,14}$ RO,R1,G0,G1,B0,B1 pins 18, 1,2,3,4,5 |  |  |  |  |  |
| $\mathrm{V}_{\text {IN }}$ (LOW) | $V_{\text {IL }}$ | -0,5 | - | 0,8 | V |
| $V_{\text {IN }}$ (HIGH) | $\mathrm{V}_{\text {IH }}$ | 2 | - | $\mathrm{V}_{11} 19$ | V |
| Input capacitance | $\mathrm{C}_{\mathrm{i}}$ | - | - | 10 | pF |
| Input rise and fall times | $\mathrm{tr}_{\mathrm{r}} \mathrm{tf}$ | - | - | 200 | ns |
| $\overline{\text { CSYNC }}, \mathrm{CBLNK}, \mathrm{RO}, \mathrm{R} 1, \mathrm{GO}, \mathrm{G} 1, \mathrm{BO}, \mathrm{B} 1$ pins $16,17,18,1,2,3,4,5$ |  |  |  |  |  |
| Input current d.c. for $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ | IIL | - | - | -100 | $\mu \mathrm{A}$ |
| Input current d.c. for $\mathrm{V}_{\mathrm{IN}}=2 \mathrm{~V}$ | IIH | - | - | 20 | $\mu \mathrm{A}$ |
| Input current d.c. for $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ | 1 IL | - | - | -500 | $\mu \mathrm{A}$ |
| Input current d.c. for $\mathrm{V}_{\text {IN }}=2 \mathrm{~V}$ | IIH | - | - | -200 | $\mu \mathrm{A}$ |
| Composite video output, pin 6 |  |  |  |  |  |
| Output amplitude (sync tip-white) | $V_{6-9}$ (p-p) | - | 2 | - | V |
| Sync tip level | V6-9 | - $\overline{4}$ | 5 | - | V |
| Output load resistor | R6-9 | 0,47 | 1 | - | $\mathrm{k} \Omega$ |
| Variation of output amplitude $\mathrm{T}_{\mathrm{amb}}=0 \text { to }+70^{\circ} \mathrm{C}$ | $V_{(p-p)}$ | - | - | tbf | \% |
| Over supply range $V_{11-9}=10,8 \text { to } 13,2 \mathrm{~V}$ | $\Delta \mathrm{V}$ | - | - | tbf | \% |
| Output impedance (with $1 \mathrm{k} \Omega$ load) | $\mathrm{R}_{\mathrm{L}}$ | - | 15 | - | $\Omega$ |
| Residual chrominance on white | $\Delta \mathrm{V}_{\text {rms }}$ | - | 30 | - | mV |
| Tolerance on luminance amplitude | $\Delta \mathrm{V}$ | - | 10 | - | \% |
| Tolerance on chrominance amplitude | $\Delta \mathrm{V}$ | - | 10 | - | \% |
| Tolerance on chrominance phase | $\Delta \mathrm{O}$ | - | tbf | - | \% |
| Chrominance band limiting, pin 10 Internal resistance | R10-11 | - | 1,5 | - | k $\Omega$ |
| Luminance delay, pins 7 and 8 |  |  |  |  |  |
| Nominal series resistor ( $\pm 5 \%$ ) | RS | - | 1,2 | - | k $\Omega$ |
| Nominal load resistor at luminance input ( $\pm 5 \%$ ) | $R_{L}$ | - | 1 | - | k $\Omega$ |
| Ramp timing, pin 15 (see Fig. 4) |  |  |  |  |  |
| With external RC circuit <br> $\mathrm{R}=36 \mathrm{k} \Omega ; \mathrm{C}=330 \mathrm{pF}$ (note 1) |  |  |  |  |  |
| Start of burst from line sync | tb | - | 5,7 | -- | $\mu \mathrm{s}$ |
| Burst width | $t_{w}$ | - | 2,5 | - | $\mu \mathrm{s}$ |
| Threshold for seperation of equalizing pulses and sync pulses | t | 36 | 44 | 56 | $\mu \mathrm{s}$ |

Note: 1. A figure of 5 pF is assumed for external capacitance. This figure includes temperature dependence of the components.

X1 (PAL) $=8,867238 \mathrm{MHz}$
X1 (NTSC) $=7,159100 \mathrm{MHz}$
C* $=5,6 \mathrm{pF}$ only for mask version 1

| COMPONENT | PAL | NTSC |
| :--- | :--- | :--- |
| L1 | $15 \mu \mathrm{H}$ | $18 \mu \mathrm{H}$ |
| C1 | 82 pF | 100 pF |
| L2 | $\mathrm{DL270}$ | $\mathrm{DL330}$ |
| R1 | $430 \Omega$ | $510 \Omega$ |
| R2 | $510 \Omega$ | $750 \Omega$ |
| M1 | UM1233 | UM1622 |
| LKA | o/c | made |

Component list for Fig. 2.


Fig. 3 Ramp timing.

## SPEECH/SOUND SYNTHESIZERS

MEA8000 ..... 1005
OM8200 ..... 1019
OM8201 ..... 1023
OM8210 ..... 1025
PCF8200 ..... 1029
SAA1099 ..... 1043

## VOICE SYNTHESIZER

## GENERAL DESCRIPTION

The MEA8000 is a 24 -pin N-MOS integrated circuit for generating good quality speech from digital code with a programmable bit rate. The circuit is primarily intended for applications in microprocessor controlled systems, where the speech code is stored separately.

## Features

- Interfaces easily with most popular microprocessors and microcomputer
- 8-bit wide data bus
- 32-bit wide data buffer holding speech frame codes
- Digital filter of 8 th order with 3 programmable formant frequencies, one fixed formant frequency, and 4 programmable formant bandwidths
- Programmable amplitudes
- Programmable duration of each frame; 8, 16, 32 or 64 ms
- Synthesis occupies less than 1\% of control processor time
- Capable of sophisticated unvoiced sound generation
- Crystal controlled oscillator or external (TTL) clock
- Minimal external audio filter requirement
- Single +5 V power supply


## QUICK REFERENCE DATA

| parameter | condition | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | pin 13 | $V_{\text {DD }}$ | 4,5 | 5,0 | 5,5 | V |
| Supply current | no audio load | ${ }^{\prime} \mathrm{DD}$ | - | 30 | 50 | mA |
| Inputs |  |  |  |  |  |  |
| Input voltage | HIGH | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | $V_{\text {DD }}$ | V |
| Input voltage | LOW | $V_{\text {IL }}$ | -0,5 | - | 0,8 | v |
| Input capacitance |  | $C_{1}$ | - | - | 7 | pF |
| Outputs |  |  |  |  |  |  |
| Output voltage | ${ }^{-1} \mathrm{OH}=100 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | - | V |
| Output voltage | $\mathrm{I}^{\mathrm{OL}}=1,6 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,4 | V |
| Capacitance |  | $\mathrm{C}_{\mathrm{L}}$ | - | - | 30 | pF |
| Operating ambient temperature range |  | Tamb | 0 | - | + 70 | ${ }^{\circ} \mathrm{C}$ |

## PACKAGE OUTLINE

24-lead DIL; plastic (SOT-101A).


Fig. 1 Block diagram.

## PINNING

| 1 | $\frac{\mathrm{V}_{\mathrm{SS}}}{\mathrm{REO}}$ | ground data request |
| :---: | :---: | :---: |
| 3 | D7 |  |
| 4 | D6 |  |
| 5 | D5 |  |
| 6 | D4 | data bus |
| 7 | D3 | data bus |
| 8 | D2 |  |
| 9 | D1 |  |
| 10 | D0 |  |
| 11 | A0 | data/control input |
| 12 | $\overline{\mathrm{CE}}$ | chip enable |
| 13 | $V_{\text {DD }}$ | supply voltage |
| 14 | REQEN | request enable input |
| 15 | N.C. | not connected |
| 16 | OSC IN | internal oscillator |
| 17 | OSC OUT | internal oscillator |
| 18 | CLK IN | clock input |
| 19 | REF | reference current |
| 20 | OUT | speech output |
| 21 | CLK OUT | internal clock output |
| 22 | $\overline{\mathrm{R}} / \mathrm{W}$ | read/write |
| 23 | $\bar{W}$ | write |
| 24 | TEST | test use only |



Fig. 2 Pinning diagram.

| FUNCTIONAL DESCRIPTION (pin number) |  |  |
| :---: | :---: | :---: |
| Control |  |  |
| D0 to D7 | (10 to 3) | Data bus to which command or speech can be written. |
| D7 | (3) | Data port via which the status can be read. |
| $\overline{\mathrm{CE}}$ | (12) | Chip enable (chip select). |
| $\bar{W}$ | (23) | Write. |
| $\overline{\mathrm{R}} / \mathrm{W}$ | (22) | Read/Write <br> The control signals $\bar{W}$ and $\bar{R} / W$ allow connections to most microcomputers or microprocessors (see timing diagrams). |
| A0 | (11) | Data/control input: discriminates between speech code input buffer ( $A 0={ }^{\prime} 0^{\prime}$ ) and command register ( $A 0={ }^{\prime} 1$ ') during a 'write' operation. |
| $\overline{\mathrm{REO}}$ | (2) | Data request (open drain output); output signal which follows inverse of the status REQ bit, but only if enabled by either the ROE bit in the command register or the external REOEN pin. |
| $\overline{\text { REQEN }}$ | (14) | Request enable input; $\overline{\text { REOEN }}=$ ' 0 ' enables the status REQ output, independent of the status of the command register. |

## Timing

OSC IN
OSC OUT

Connections for internal clock oscillator; nominal crystal frequency 4 MHz .
Clock input for external clock, TTL compatible, 4 MHz .
A buffered output for the internal clock cycle (which is equal to CLK divided by 3). May be used as a clock, for a microprocessor, for example.

Output
REF
OUT
Input pin for biasing the audio output level. This reference current can be derived from a resistor to the positive supply.
Speech output; this output is a 64 kHz pulse, modulated in both width and amplitude. It is configured as a current sink with a saturating voltage of about 3 V .

## Supply

$V_{D D}$
$V_{S S}$
TEST

NC (15)
Single supply voltage, nominally 5 V , but battery operation is possible.

## Ground.

Used for testing purposes. Changes other pin functions. Must be tied to ground for user operation.

HANDLING
Inputs and outputs are protected against electrostatic charge in normal handling. However, to be totally safe, it is desirable to take normal precautions appropriate to handling MOS devices (see 'Handling MOS Devices').

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

| parameter | conditions | symbol | min. | max. | unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Supply voltage range |  | $\mathrm{V}_{\mathrm{DD}}$ | $-0,5$ | +7 | V |
| Voltage with respect to $\mathrm{V}_{\mathrm{SS}}$ | on any pin | $\mathrm{V}_{\mathrm{I}}$ | $-0,5$ | +7 | V |
| Output voltage | pins 2 and 20 | $\mathrm{~V}_{\text {REQ }}, \mathrm{V}_{\mathrm{OUT}}$ |  | 15 | V |
| Storage temperature range |  | $\mathrm{T}_{\text {stg }}$ | -20 | +125 | ${ }^{\circ} \mathrm{C}$ |
| Operating ambient temperature range |  | $\mathrm{T}_{\mathrm{amb}}$ | 0 | +70 | $\mathrm{o}^{\circ} \mathrm{C}$ |

## CHARACTERISTICS

$T_{a m b}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$, unless otherwise specified; all voltages referenced to $\mathrm{V}_{\mathrm{SS}}$

| parameter | conditions | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  |  |  |  |  |  |
| Supply voltage | note 1 | $V_{\text {DD }}$ | 4,5 | 5,0 | 5,5 | V |
| Supply current | no audio load | ${ }^{\prime} \mathrm{DD}$ | - | 30 | 50 | mA |
| Inputs <br> D0 to D7, AO, $\overline{C E}, \bar{W}$, $\bar{R} / W, \overline{R E Q E N}$, CLK IN |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| Input voltage HIGH |  | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | $\mathrm{V}_{\text {DD }}$ | V |
| Input voltage LOW |  | $V_{I L}$ | -0,5 | - | 0,8 | V |
| Input leakage current | note 2 | $l_{\text {IR }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Input capacitance |  | $\mathrm{Cl}_{1}$ | - | - | 7 | pF |
| Outputs |  |  |  |  |  |  |
| D7 (I/O), CLK OUT |  |  |  |  |  |  |
| Output voltage HIGH | $-\mathrm{I}^{\text {OH }}=100 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2,4 | - | - | V |
| Output voltage LOW | $\mathrm{I}^{\mathrm{OL}}=1,6 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,4 | V |
| Output load capacitance |  | $\mathrm{C}_{\mathrm{L}}$ | - | - | 50 | pF |
| $\overline{\mathrm{REO}}$ |  |  |  |  |  |  |
| Output voltage HIGH | open drain | $\mathrm{V}_{\mathrm{OH}}$ | - | - | 13,2 | V |
| Output voltage LOW | $\mathrm{I}_{\mathrm{OL}}=1,6 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0,4 | V |
| Output load capacitance |  | $\mathrm{C}_{\mathrm{L}}$ | - | - | 50 | pF |
| Audio output |  |  |  |  |  |  |
| Reference current | pin 19; note 8 | IREF | - | - | 0,3 | mA |
| Output current | pin 20; <br> peak value |  |  |  |  |  |
|  | $\mathrm{I}_{\text {REF }}=0 \mathrm{~mA}$ | I IOUT | - | 100 | - | $\mu \mathrm{A}$ |
|  | $\mathrm{I}_{\text {REF }}=0,1 \mathrm{~mA}$ | Iout | - | 1,7 | - | mA |
|  | $\mathrm{I}_{\text {REF }}=0,3 \mathrm{~mA}$ | IOUT | - | 5 | - | mA |
| Output voltage | pin 20; for linear operation; note 3; |  |  |  |  |  |
|  | $\mathrm{I}_{\text {REF }}=0,1 \mathrm{~mA}$ | V OUT | 2,5 | - | 13,2 | V |
| Oscillator |  |  |  |  |  |  |
| Crystal frequency | internal | ${ }^{\text {f }}$ TTAL | - |  | 4,00 | MHz |
| Clock frequency | external | ${ }^{\text {f CLK }}$ | - |  | 4,00 | MHz |

TIMING CHARACTERISTICS (note 4) (Figs 6 and 7)

| parameter | condition | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write enable |  | twr | 200 | - | - | ns |
| Address set-up |  | ${ }^{t}$ AS | 30 | - | - | ns |
| Address hold |  | ${ }^{t}$ AH | 30 | - | - | ns |
| Data set-up for write |  | ${ }^{t} \mathrm{DS}$ | 150 | - | - | ns |
| Data hold for write |  | ${ }^{\text {t }}$ H | 30 | - | - | ns |
| Request hold | note 5 | ${ }^{\text {t }} \mathrm{RH}$ | - | - | 350 | ns |
| Request next | note 6 clock frequency $=3,84 \mathrm{MHz}$ | $\mathrm{t}_{\mathrm{RN}}$ | - | - | 3 | $\mu \mathrm{s}$ |
| Read enable |  | ${ }^{\text {t }}$ RD | 200 | - | - | ns |
| Data delay for read | note 7 | ${ }^{\text {t }}$ D | - | - | 150 | ns |
| Data floating for read | note 7 | ${ }^{\text {t }}$ DF | - | - | 150 | ns |
| Request valid before write |  | ${ }^{\text {t }} \mathrm{R}$ V | 0 | - | - | ns |
| Request output enable response |  | ${ }^{\text {troE }}$ | - | - | 750 | ns |
| Control set-up |  | ${ }^{\text {t }} \mathrm{CS}$ | 20 | - | - | ns |
| Control hold |  | ${ }^{t} \mathrm{CH}$ | 20 | - | - | ns |

## Notes

1. The circuit will continue to operate from a supply of up to $6,5 \mathrm{~V}$, but without necessarily meeting the specification.
2. This is also valid for $\mathrm{V}_{\mathrm{DD}}=0 \mathrm{~V}$.
3. This permits the connection of the output load to a supply higher than that supplying the synthesizer.
4. Timing reference level is $1,5 \mathrm{~V}$.
5. An external pull-up resistor is required, as this is an open drain output.

The time ( $\mathrm{t}_{\mathrm{RH}}$ ) to reach $2,0 \mathrm{~V}$ is specified at a load to 5 V of $3,3 \mathrm{k} \Omega$ and 50 pF .
6. Between two data write operations of one speech frame.
7. Levels greater than $2,0 \mathrm{~V}$ for a ' 1 ' or less than $0,8 \mathrm{~V}$ for a ' 0 ' are reached with a load of one TTL input and 50 pF .
8. Typical voltage level at the REF pin is $2,5 \mathrm{~V}$.

## OPERATION PRINCIPLE

The MEA8000 has been designed for a vocal tract modelling technique of voice synthesis. This method gives the lowest possible bit rate for speech quality which is acceptable for most industrial applications.
Figure 3 shows a simplified electronic model of the human vocal tract as a formant synthesizer. A combination of a periodic signal, representing the pitch of the original speech, and an aperiodic signal, representing the unvoiced sound in the speech. Both these signals are fed to a variable filter comprising four resonantors (via an amplifier which controls the amplitude of the synthesized sound). The resonators model the sound in accordance with the formats in the original speech. Each resonator is controlled by two parameters, one for the resonant frequency and one for the bandwidth. The information required to control the synthesizer is:

- pitch
- amplitude
- voice/unvoiced source selector
- filter control
excitation source (vocal cords)
spectrum shaping (vocal tract)

A good replica of the original speech is obtained by periodic updating of this control information.


Fig. 3 Electronic model of human vocal tract.

## OPERATION

Speech is generated by suitable filtering of a relatively low frequency sawtooth waveform for voiced sounds, or of random noise for unvoiced sounds. New parameters for both the digital waveform generator and the digital filter are supplied to the synthesizer in coded groups of 4 bytes via the data bus. The code group also contains the duration of the next speech frame to be produced ( $8,16,32$ or 64 ms ).
The output sample rate is 64 kHz or 8 times the internal sample rate with linear interpolation in between. This greatly reduces the need for an external analogue output filter.

## Modes of operation

1. STOP mode: characterised by a silent output and the status $\overline{\mathrm{REO}}$ bit set to ' 1 '. This mode is entered from power up or by STOP command. The mode is entered automatically if at the end of an active speech frame the next four parameter bytes are not yet received while the CONT bit in the command register is a ' 0 '. In the latter case the final speech frame will be repeated once but with a decaying amplitude and the same pitch.
2. ACTIVE mode: a speech sample is being produced.
3. CONTINUOUS mode: entered if an active speech frame is finished and new data is not supplied in time while the CONT bit in the command register is a ' 1 '. The synthesizer will repeat the last speech frame indefinitely until all four new data bytes are received, or a STOP command, or a reset of the CONT bit.

## Speech code input buffer

Speech code is written to the synthesizer when $\overline{C E}$ and $\bar{W}$ are both ' $0^{\prime}$, while $\bar{R} / W=' 1$ ' and $A 0={ }^{\prime} 0^{\prime}$. Also the status $\overline{R E Q}$ bit must read a ' 1 ', otherwise the synthesizer is still busy and will not react to a data write operation.
Starting from the STOP mode, the first data will be interpreted as a starting value for the PITCH. Thereafter every four successive data bytes are treated as a group of speech code. The coded speech frame format is shown in Fig. 4.


Fig. 4 Format of coded speech frame.

| Code | bits | parameter |
| :--- | :--- | :--- |
| PITCH | 8 | initial value for pitch |
| FD | 2 | speech frame duration |
| PI | 5 | pitch increment (rate of change) or noise selection |
| AMPL | 4 | amplitude |
| FM1 | 5 | frequency of 1st formant |
| FM2 | 5 | frequency of 2nd formant |
| FM3 | 3 | frequency of 3rd formant |
| FM4 | 2 | frequency of 4th formant (fixed) |
| BW1 | 2 | bandwidth of 1st formant |
| BW2 | 2 | bandwidth of 2nd formant |
| BW3 | 2 | bandwidth of 3rd formant |
| BW4 | bandwidth of 4th formant |  |

During each data write operation, the status REQ bit will be cleared to ' 0 '.
It appears within a few microseconds, requesting the next byte of the group.
The request for the first byte of the next group always appears shortly after the beginning of the current speech frame, and all four bytes must be provided before it finishes. This leaves the control circuit (i.e. microprocessor) enough time to use polling, instead of interrupts, as the minimum time of a speech is 8 ms .

When in the STOP mode the synthesizer will commence producing sound after receipt of $1+4$ bytes.

## Status bit

The status bit is accessed at $\overline{C E}=\bar{R} / W={ }^{\prime} 0^{\prime}$.
The status of $\bar{W}$ and $A 0$ are arbitrary.
Pin D7 reveals the request for a (next) speech code byte: ' 0 ' $=$ busy, ' 1 ' = request for data.

## Command register

A command is written to the synthesizer at $\overline{C E}=\bar{W}={ }^{\prime} 0^{\prime}$ while $A 0=\bar{R} / W={ }^{\prime} 1^{\prime}$.

$\left.\begin{array}{|l|l|l|l|l|l|l|}\hline \text { D7 } & \text { D6 } & \text { D5 } & \text { D4 } & \text { D3 } & \text { D2 } & \text { D1 }\end{array}\right]$ D0 | STOP |
| :--- |

STOP Stop mode. This results in an immediate reset of the synthesizer to the STOP mode. The ROE and CONT are not affected by this command.
CONT Continuous mode. This bit can be set or cleared only if the corresponding CONT enable bit is programmed as a ' 1 '. In the continuous mode the synthesizer will not revert to the STOP mode if all four parameters are not received before the end of the current speech frame, but repeat it indefinitely.
If CONT = ' 1 ' the last frame will be repeated once with decaying amplitude and the same pitch before the stop mode is entered.
ROE Request Output Enable. This can be set or cleared only if the corresponding ROE enable bit is a ' 1 '. ROE determines whether the request in the status bit appears on the $\overline{\operatorname{REO}}$ pin.
Note: the same can be achieved by connecting the $\overline{\operatorname{REQEN}}$ pin (request enable) to a ' 0 '.
After power on, the command register bits CONT and ROE will both be zero. Thus power on equals the command $00011010=1 \mathrm{~A}$ (hexadecimal).

## Control signals

With the three control signals $\overline{C E}, \bar{W}$ and $\overline{\mathrm{R}} / \mathrm{W}$ the synthesizer is made compatible with most microprocessors and microcomputers.

| $\overline{\mathrm{CR}}$ | $\bar{W}$ | $\bar{R} / W$ | AO |  | Operation |
| :--- | :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 1 | 0 |  | WRITE DATA |
| 0 | 0 | 1 | 1 |  | WRITE COMMAND |
| 0 | X | 0 | x |  | READ STATUS |
| 0 | 1 | 1 | X |  | 3-STATE DATA BUS |
| 1 | X | x | x |  | $\}$ |

## Power supply

During (slow) power up or power down the circuit will not produce any spurious sound. As soon as the supply is high enough for reliable operation, the circuit will be in the STOP mode with $R O E=C O N T={ }^{\prime} 0$ '.

## Timing diagrams

The control signals $\overline{C E}, \bar{R} / W$ and $\bar{W}$ have been specified to enable easy interface to most microprocessors and microcomputers. For instance, with connection to an MAB8048 microcomputer the $\bar{R} / W$ and $\bar{W}$ inputs can be used as the $\overline{R D}$ and $\overline{W R}$ strobe inputs.


Fig. 5 Typical waveforms of the control signals.


Fig. 6 Read timing.


Fig. 7 Write timing.

(a)
(a) Minimum system of single chip microcomputer with voice ROM on board.

(b) MEA8000 as a microprocessor peripheral.

(c) Applications using separate voice ROMs.

Fig. 8 Typical applications.


Fig. 9 Typical output applications.


Fig. 10 Oscillator/clock configurations.

## LOW COST SPEECH DEMONSTRATION BOARD

## GENERAL DESCRIPTION

The low cost speech demonstration board is designed to add voice output to existing card based electronic equipment with the minimum of additional effort and components. The majority of components used are of the CMOS type with low power consumption making the board suitable for battery operation.
Applications include speech evaluation and speech demonstration.

## FEATURES

- PCF8200 speech synthesizer
- Male and female speech of very high quality
- CMOS technology
- Extended operating temperature range
- Programmable speaking speed
- Low current consumption
- All major components use CMOS technoiogy (PCF8200, 80C39 and 27C64)
- Very large vocabulary up to 12 minutes
- 4 EPROM sockets
- EPROM selection for 27C16 to 27C256
- Low data rates for synthesizer (average 1500 bits per second)
- Easy interfacing
- 8-bit parallel data bus/key switch input
- Volume control, speaker connection
- Control signals (e.g. RESET, BUSY etc etc)
- Simple operating modes
- ROM selection
- Word sequence within a ROM
- Repeat last utterence
- Control software is readily customizeable
- To implement parameter download from external source
- Single Eurocard size PC board
- Single +5 V supply
- Low cost


## APPLICATIONS

- OEM design-in
- May be simply used with many card systems for speech evaluation
- Speech demonstration
- Particularly simple when used with the OM8201 (Speech Demonstration Box)



## OPERATION

## HARDWARE DESCRIPTION

The main controlling microprocessor is an 80 C 39 running at 6 MHz . This device supplies all of the main controlling signals for the board operation and the interfacing to any external system. Four sockets are provided for EPROMS which contain speech coding. These may be 27 C 16 types, through to 27C256 types; the sockets will be a low insertion force type to allow for easy customizing. The board will be supplied with one socket occupied by a 27C64 which will contain the control program and some speech examples. All four EPROM sockets must contain the same EPROM type.

The speech synthesizer PCF8200 converts the coding into a speech output. This synthesizer has been designed to simulate the human vocal tract using five formants for male and four formants for female speech. Periodic updating of the parameters for these formants can produce very high quality speech.
The output of the synthesizer can be fed into an audio amplifier, TDA7050, via a resistor-capacitor filter network which provides a frequency cut-off above 5 kHz of about 25 dB . The configuration of the audio amplifier used on this board gives an output of 140 mW peak power into a $25 \Omega$ speaker from a 5 V supply.
Connections are made to the board via a standard DIN/IEC connector. This allows access to the 8 -bit parallel data bus so that speech coding from an external source may be used, if implemented, and allows the selection of speech phrases by an external system, such as a microcomputer or even a bank of switches. The same connector also permits the addition of a volume control, loudspeaker, a high impedance audio output, and power supply. The control signals RESET, BUSY, WAIT and DS are also taken to the outside of the board. There is also a loudspeaker plug on the board.

All components are contained on a standard single Eurocard, and therefore suitable for rack mounted equipment.

## SOFTWARE DESCRIPTION

All the software required to operate the board is contained in the only EPROM supplied. The software is written in modular from so that it is possible for a customer to alter or add to any particular function which suits his applications. An industrial standard microprocessor was chosen so that readily available development systems could be used to facilitate this modification.
There are four main modes of operation:

- ROM Selection
- Word Sequence
- Repeat Word
- Speaking Speed Selection

These modes are all controlled by software.
ROM Selection mode permits access to an individual EPROM and pronounces the first utterence from that EPROM.
Word Sequence gives the next word (activated by repeated access to the same EPROM) and if continually exercised will keep looping on the words in that EPROM.
The Repeat Word command allows indefinate repetition of the last utterance pronounced.
The Speaking Speed Selection allows the utterence to be pronounced at a different speed.
The software also controls the address sequencing within the utterance and ensures that the required data is supplied to the synthesizer.

There are also some examples of words/utterences encoded in the remainder of the supplied EPROM. These words are intended for demonstration purposes and will show the features of the synthesizer when selected. The main features being illustrated are:

- Male speech in several languages
- Female speech in several languages
- Programmable speaking speed


## ORDERING INFORMATION

Product name: Low Cost Speech Demonstration Board
Type number: OM8200
Ordering code: 933754130000
Orders should be placed with your local Philips/Signetics agency.

## SPEECH DEMONSTRATION BOX

## GENERAL DESCRIPTION

Speech demonstration box OM8201 is designed to be used in conjunction with the low cost speech demonstration board OM8200. The box contains all the necessary components to drive the board. The combination of these two components make an extremely attractive demonstration unit.

## FEATURES

- Low cost
- Can use unmodified OM8200 board which allows access to all features of the OM8200
- Single +9 V supply
- Low power consumption therefore permits battery operation
- External power supplies may also be used
- Voltage is regulated and dropped to a standard +5 V for the OM8200 board
- Simple mechanical construction
- Allows easy access to the OM8200 for changing EPROMS
- Contains all peripherals needed to drive the OM8200


## HARDWARE DESCRIPTION

The box contains a set of eight keypad switches which are connected to the data bus. Four switches can select which EPROM your speech data is derived from. Repeated pressing of an EPROM switch increments the expression number which will be uttered. To repeat the last expression, a separate switch must be activated.
It is possible in the PCF8200 to change the rate of speaking to $73 \%, 123 \%$ or $145 \%$ of the normal speed. A switch has been included on the box which will sequence through the speed options making the same utterance every time.

One of the two remaining switches is the master reset for the program and the other is for future enhancements of the box.

Included in the box are, the volume control for the amplifier, the loudspeaker, and a high impedance audio output.
The final piece of electronics is the power supply. This can be supplied from a +9 V internal battery or from a +9 V external supply. The +9 V is regulated to $\mathrm{a}+5 \mathrm{~V}$ supply which is then fed to other parts of the box and to the OM8200.

The box is of simple construction and allows easy access to the OM8200 for changing of EPROMS.

## SOFTWARE DESCRIPTION

There is no software in the OM8201. The software of the OM8200 may be used in an unmodified form without any problems. However, if changes have been made to the control program of the OM8200 then different functions for the switches of the box can be achieved.


Fig. 1 Schematic diagram.

## ORDERING INFORMATION

Product name: Speech Demonstration Box
Type number: OM8201
Ordering code: $\quad 933754140000$
N.B. OM8200 must be ordered as well if this box is to be used in demonstration mode. The order number for the OM8200 is 933754130000.

Orders should be placed with your local Philips/Signetics agent.

## SPEECH ANALYSIS/EDITING SYSTEM

## GENERAL DESCRIPTION

The OM8210 is a speech analysing/editing system, and comprises of a speech adapter box and associated software. The system uses either the HP9816S or IBM-PC personal computer.
The OM8210 and the computer function together to produce speech coding for the PCF8200.
The system has many commands available, mostly single key operations, which gives it flexability.

## FEATURES

- Input sampling of analogue speech signals
- Speech analysis
- Graphic parameter representation
- Parameter editing screen
- Conversion of parameters to PCF8200 synthesizer
- EPROM programming
- Parameter storage on floppy disc
- Speech output via PCF8200 voice synthesizer


Fig. 1 Block diagram.

## HARDWARE DESCRIPTION

The hardware for the OM8210 is contained in an attractive box with access to all the interconnections (IEC 625, interface loudspeaker, headphones, tape input, and EPROM socket), from the front panel. There are four single Eurocards and a power supply forming the speech adapter box.
These cards are:

- Analogue Card
- Synthesizer Card
- EPROM Card
- Control Card


## Analogue Card

On this card, the level of the recorded audio input signal is adjusted by an electronic potentiometer. Before the audio is sampled, frequencies higher than half the sampling frequency are removed by a switched capacitor filter of the type normally used for codecs. A 12-bit analogue-to-digital converter (ADC) produces the digital samples that are sent to the control card. An 8-bit digital-to-analogue converter (DAC) on the analogue card allows the sampled speech to be output. The audio input signal, the sampled speech and the synthesized speech are selected by an analogue multiplexer, filtered, and adjusted for volume before reproduction by a loudspeaker.
The use of integrated electronic potentiometers and codec filters substantially reduces the number of components required while maintaining high performance.

## Synthesizer Card

This card accommodates the PCF8200 voice synthesizer and a small amount of peripheral components and a socket for the MEA8000 voice synthesizer.

## EPROM Programmer Card

This card allows four different types of EPROM (2716, 2732, 2732A and 2764) to be programmed under software control. All the hardware to generate the programming voltages and the programming waveforms are on this card.

## Control Card

This card performs three functions:

- IEC 625/IEEE 488 interface
- Control sequencer
- Clock generator

The IEC/IEEE interface is a simple talker/listener implementation with a HEF4738 circuit.
An FPLA control sequencer provides the handshake signals for IEC/IEEE interface and the chip enable signals for the rest of the system (the ADC, the DAC, the synthesizer and control circuits).
The filter sampling frequency is generated with a software programmable PLL frequency synthesizer. The speech sampling frequency is derived from the filter sampling frequency by frequency division. Hence, the filter frequency cut-off and the sample rate of the ADC and the DAC are automatically linked.
The hardware includes all the necessary cables, adapter plug, loudspeaker, headphone and power supply.

## SOFTWARE DESCRIPTION

The software for this speech coding system has been developed and arranged for optimum user convenience. There are eight modes available.
Each mode and each command in the mode is selected by single key entries. Commands that can destroy data have to be confirmed before they are executed. More than 100 commands are available. The modes are:

Sample Mode | Samples and digitizes the recorded speech, the amplitude can be checked and |
| :--- |
| speech segments selected. The sampled speech is stored in a memory and can |
| be displayed or made audible. |
| Generates speech parameters from samples. The analysis selects the voiced/ |
| unvoiced sections, extracts the formants ( 5 for male and 4 for female), |
| amplitude, and the pitch, and quantisizes the speech parameters. |
| Speech parameters are displayed graphically on the VDU and can be edited to |
| correct errors in the analysis, improve speech quality by altering contours, |
| or amplitudes, concatenate sounds and optimize data rate by editing the frame |
| duration. |
| Parameter |
| Edit Mode |

Generates PCF8200 code and permits the arrangement of utterences in the
optimum order of application. This mode also generates the address map at the
head of the EPROM.

## Computer System

The following equipment is required to make a complete Hewlett Packard based editing system:

- HP9816S-630 (optimum computer type) or HP9817
- HP9121D (dual floppy disc)
- Additional memory card for the HP9816S (512 K bytes total required)

The following equipment is required to make a complete IBM based editing system:

- IBM-PC or PC-XT or Philips P3100
- Additional memory (512 K recommended)
- Display graphics card (Hercules monochrome)
- IEEE488 card (Tecmar Rev. D.)


## ORDERING INFORMATION

| Product name: | Speech Analysis/Editing System |
| :--- | :--- |
| Type number: | OM8210 |
| Ordering code: | 933756150112 |

The computer system should be purchased from your local agents.
The OM8210 should be ordered through your local Philips/Signetics agent.

## VOICE SYNTHESIZER

## GENERAL DESCRIPTION

The PCF8200 is a CMOS integrated circuit for generating good quality speech from digital code with a programmable bit rate. The circuit is primarily intended for applications in microprocessor controlled systems, where the speech code is stored separately.
Applications include automotive, telephony, personal computers, annunciators, aids for the handicapped, and general industrial devices.

## Features

- Male and female speech with good quality
- Speech-band from 0 to 5 kHz
- Bit-rate between 455 bits/second and 4545 bits/second
- Programmable frame duration
- Programmable speaking speed
- CMOS technology
- Operating temperature range -40 to $+85^{\circ} \mathrm{C}$
- Single 5 V supply with low power consumption and power-down stand-by mode
- Interfaces easily with most popular microcomputers and microprocessors through 8 bit parallel bus or $1^{2} \mathrm{C}$ bus
- Software readable status word (parallel bus or $I^{2} \mathrm{C}$ bus)
- BUSY-signal and $\overline{\mathrm{REO}}$-signal hardware readable
- Internal low-pass filter and 11-bit D/A converter


## QUICK REFERENCE DATA

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $V_{\text {DD }}$ | - | 5 | - | V |
| Supply current | ${ }^{1} \mathrm{DD}$ | - | 12 | \# | mA |
| Supply current (stand-by) | $1 \mathrm{DD}(\mathrm{SB})$ | - | 1 | - | $\mu \mathrm{A}$ |
| Inputs |  |  |  |  |  |
| Input voltage | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | $V_{\text {DD }}$ | V |
| Input voltage | $V_{\text {IL }}$ | 0 | - | 0,8 | V |
| Input capacitance | $C_{1}$ | - | 7 | - | pF |
| Outputs (D5 to D7) |  |  |  |  |  |
| Output voltage high | $\mathrm{V}_{\mathrm{OH}}$ | 3,5 | - | $V_{\text {DD }}$ | V |
| Output voltage low | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| Load capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | - | 80 | pF |
| Operating ambient temperature range | $\mathrm{T}_{\mathrm{amb}}$ | -40 | - | $+85$ | ${ }^{\circ} \mathrm{C}$ |

## \# Value not yet available.

PACKAGE OUTLINE
24-lead DIL; plastic (SOT-101A).


Fig. 1 Block diagram.


## FUNCTIONAL DESCRIPTION

The synthesizer has been designed for a vocal tract modelling technique of voice synthesis. An excitation signal is fed to a series of resonators. Each resonator simulates one of the formants in the original speech. It is controlled by two parameters, one for the resonant frequency and one for the bandwidth. Five formants are needed for male speech and four for female speech. The output of this system is defined by the excitation signal, the amplitude values and the resonator settings. By periodic updating of all parameters very high quality speech can be produced.

## OPERATION

Speech characteristics change quite slowly, therefore the control parameters for the speech synthesizer can be adequately updated every few tens of milliseconds with interpolation during the interval to ensure a smooth changeover from one parameter value to the next. In the PCF8200 the standard-frame duration can be set to $8,8,10,4,12,8$ or 17,6 milliseconds with the speed-option, speaking speed, in the commandregister.
The duration of each individual speech frame is programmable to be 1,2,3 or 5 times the standard-frame duration.

|  | 10 | 01 | 00 | 11 | FSO, FS1 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 00 | 8,8 | 10,4 | 12,8 | 17,6 | ms |
| 01 | 17,6 | 20,8 | 25,6 | 35,2 | ms |
| 10 | 26,4 | 31,2 | 38,4 | 52,8 | ms |
| 11 | 44,0 | 52,0 | 64,0 | 88,0 | ms |

FD1, FD0
Table 1. Frame duration as a function of speed-option (FS1, FSO) and frame-duration (FD1, FD0).
The excitation signal is a random noise source for unvoiced sounds and a programmable pulse generator for voiced sounds. Both sources have an amplitude modulator which is updated 8 times in one speechframe by linear interpolation. The pitch is updated every $1 / 8$ of a standard frame.
The excitation signal is filtered with a five formant filter for male speech and a four formant filter for female speech. The formant filter is a cascade of all second-order sections. The control parameters, formantfrequency and formant-bandwidth, are updated eight times per speech frame by linear interpolation. A block diagram of the formant synthesizer is shown in Fig. 3.
The filter output is upsampled to 80 kHz and filtered with a digital low-pass filter. Before the signal is digital to analogue converted (DAC), with an 11-bit switched capacitor DAC, the signal is multiplied with a DAC-amplitude factor. The use of a digital filter means that no external audio filtering is required for low-medium applications and minimal filtering is required for those applications requiring very high quality speech.


Fig. 3 Block diagram of formant synthesizer.

## DATA FORMAT

Three types of format are used for data transfer to the synthesizer.

## DAC-amplitude factor

The DAC-amplitude factor is one byte, which is used to optimize the digital speech signal to the 11 -bit DAC. It is the first byte after a STOP or a BADSTOP or $\mathrm{V}_{\mathrm{DD}}$ on. Table 2 indicates the amplitude factor.

| byte | factor | dB |
| :--- | :--- | ---: |
| 01110000 | 3,5 | 10,88 |
| 10110000 | 3,25 | 10,24 |
| 00110000 | 3,0 | 9,54 |
| 11010000 | 2,75 | 8,97 |
| 01010000 | 2,5 | 7,96 |
| 10010000 | 2,25 | 7,04 |
| 00010000 | 2,0 | 6,02 |
| 11100000 | 1,75 | 4,86 |
| 01100000 | 1,5 | 3,52 |
| 10100000 | 1,25 | 1,94 |
| 00100000 | 1,0 | 0,00 |
| 11000000 | 0,75 | $-2,50$ |
| 01000000 | 0,5 | $-6,02$ |
| 10000000 | 0,25 | $-12,04$ |
| 00000000 | 0,0 |  |
| 11110000 | $H E X$ code FO is not allowed as a DAC amplitude |  |

Table 2 DAC amplitude factor.

## Start pitch

The second byte after a STOP or BADSTOP, or $\mathrm{V}_{\mathrm{DD}}$ on is the start pitch. It is a one byte start value for the on-chip pitch-period generator.

## Frame Data

The frame data is a five byte block which contains the filter and source information:

| pitch increment/decrement value | 5 bits |
| :--- | :--- |
| amplitude | 4 bits |
| frame duration | 2 bits |
| frequency of 1 st formant | 5 bits |
| frequency of $2 n d$ formant | 5 bits |
| frequency of 3 rd formant | 3 bits |
| frequency of 4th formant | 3 bits |
| frequency of 5 th formant | 1 bit |
| bandwidth of 1 st formant | 3 bits |
| bandwidth of 2nd formant | 3 bits |
| bandwidth of 3rd formant | 2 bits |
| bandwidth of 4 th formant | 2 bits |
| bandwidth of 5 th formant | 2 bits |

The frame-data bits are organized as shown in Fig. 4.

## PCF8200



It is not allowed to set byte 0 to the hexadecimal value 00 .
Fig. 4 Format of frame-date.

## CONTROL FORMAT

## Command Write

A command write consists of two bytes, and it may occur before a data block. The four bits which can be written are shown in Fig. 5.


Fig. 5 Control write: first byte fixed, second byte control.

## FSO, FS1 speed option

| FS1 | FSO | speech <br> speed | standard-frame <br> duration |
| :--- | :--- | :--- | :---: |
| 0 | 0 | $100 \%$ | $12,8 \mathrm{~ms}$ |
| 0 | 1 | $145 \%$ | $8,8 \mathrm{~ms}$ |
| 1 | 0 | $123 \%$ | $10,4 \mathrm{~ms}$ |
| 1 | 1 | $73 \%$ | $17,6 \mathrm{~ms}$ |

## $\overline{\mathrm{M}} / \mathrm{F}$, male/female option

$\bar{M} / \mathrm{F} \quad=0$ male quantization table
$=1$ female quantization table
STOP
STOP $=1$ stop; repeat last complete frame with amplitude $=0$ (no excitation signal)
$=0$ if the frame data is not sent within the duration of a half frame, there will be a BADSTOP:

1. $\overline{\mathrm{REQ}}=1 \mathrm{STOP}=0$
2. Repeat last frame with amplitude $=0$
3. $B U S Y=0$

## Status Read

Three status bits can be read out at any time without a preceding byte (00).
This is shown in Fig. 6.


Fig. 6 Status read.
$\overline{\mathrm{REQ}}=1$ No data required
$=0$ Synthesizer requesting for new data
BUSY $=1$ Busy (an utterance is pronounced)
$=0$ Idle, $\overline{\mathrm{REQ}}$ will set to 1 ; the synthesizer is in STOP or BADSTOP mode
STOP The STOP bit is the same as the stop bit written to the synthesizer during a command write.
STOP $=1$, BUSY $=0$ stopped by the user. STOP $=0$, BUSY $=0$ BADSTOP because the data was not sent in time.

After initial power-up the status/command register is set to the following status:
FS0, FS1 $=0 \quad$ Standard-frame duration of $12,8 \mathrm{~ms}$
$\bar{M} / F \quad=0 \quad$ Male quantization table
STOP $=0$
BUSY $=0$ Idle
$\overline{\mathrm{REQ}}=1$ No data required

## INTERFACE PROTOCOL

Data can be written to the synthesizer when $\overline{\mathrm{REQ}}=0$ or, when $\overline{\mathrm{REQ}}=1$ and $\mathrm{BUSY}=0$. Figure 7 shows the interface protocol of the synthesizer.

In parallel mode the synthesizer is activated by sending the DAC-amplitude factor. In serial mode the DAC-amplitude factor can be sent as soon as the synthesizer is powered-up.
The $I^{2} \mathrm{C}$ transmitter/receiver will then acknowledge. When the request for the pitch-byte occurs the byte must be provided within the duration of a half standard frame. If the byte is not provided in time a BADSTOP will be generated.

During each data write operation, the status bit $\overline{R E Q}$ will be set to ' 1 '.
Within a frame data block, it disappears within a few microseconds, asking for the next byte of that block. If the bytes of frame data are not provided within the time-duration of a half frame, a BADSTOP will be generated.

## $1^{2} \mathrm{C}$ ADDRESS

On chip there is a $1^{2} \mathrm{C}$ slave receiver/transmitter with the address:

$$
\begin{array}{llllllll}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
0 & 0 & 1 & 0 & 0 & 0 & 0 & R / W
\end{array}
$$

## POWER UP

The synthesizer will be set to power-up on a parallel-write sequence.
PAR-mode: The input-latches are active so they can receive the first byte
SER-mode: The $I^{2} \mathrm{C}$ transmitter/receiver will not acknowledge until the synthesizer has poweredup. To power up the synthesizer a parallel write sequence (Fig. 9) must be made to the synthesizer by using external logic for the control lines; at least one line must be toggled, $\overline{C E}$, while $\bar{W}=0$ and $\overline{\mathrm{R}} / W=1$.
The synthesizer can be set to permanent power-up by hard-wired control pins ( $\overline{C E}=0, \bar{R} / W=1, \bar{W}=0$ ).

## POWER DOWN MODE

When BUSY = 0 the synthesizer will be set to power-down. In the power-down mode the status/command register will be retained.
In power-down mode the clock-oscillator is switched off. After initial $\mathrm{V}_{\mathrm{DD}}$ the synthesizer is in powerdown mode.

## HANDLING

All inputs and outputs are protected against electrostatic charge under normal handling conditions.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

| parameter | conditions | symbol | min. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | any pin with respect to $\mathrm{V}_{\mathrm{SS}}$ | $V_{\text {DD }}$ | -0,3 | 7,5 | V |
| Input voltage | any pin with respect to $\mathrm{V}_{\mathrm{SS}}$ | $V_{1}$ | -0,3 | 7,5 | V |
| Output voltage | any pin with respect to $V_{S S}$ | $\mathrm{V}_{0}$ | -0,3 | 7,5 | $\checkmark$ |
| D.C. input diode current | $\begin{aligned} & \mathrm{V}_{1}<\mathrm{V}_{\mathrm{SS}} \\ & \mathrm{~V}_{\mathrm{I}}>\mathrm{V}_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & -I_{I K} \\ & I_{I K} \end{aligned}$ | - | $\begin{aligned} & 20 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| D.C. output diode current | $\begin{aligned} & \mathrm{v}_{\mathrm{O}}<\mathrm{v}_{\mathrm{SS}} \\ & \mathrm{v}_{\mathrm{O}}>\mathrm{v}_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & \text {-IOK } \\ & \text { IOK } \end{aligned}$ | - | $\begin{aligned} & 20 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Operating ambient temperature range |  | Tamb | -40 | 85 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $\mathrm{T}_{\text {stg }}$ | -55 | 125 | ${ }^{\circ} \mathrm{C}$ |

## CHARACTERISTICS

$T_{\text {amb }}=-45$ to $+85^{\circ} \mathrm{C}$; supply voltage ( $\mathrm{V}_{\mathrm{DD}}$ to $\mathrm{V}_{\mathrm{SS}}$ ) $=4,5$ to $5,5 \mathrm{~V}$ with respect to $\mathrm{V}_{\mathrm{SS}}$, unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply |  |  |  |  |  |
| Supply voltage | $V_{\text {DD }}$ | 4,5 | 5,0 | 5,5 | V |
| Supply current | ${ }^{\text {I D D }}$ | - | 10 | - | mA |
| Standby current | ${ }^{\prime} \mathrm{DD}(\mathrm{SB})$ | - | 200 | - | $\mu \mathrm{A}$ |
| Inputs |  |  |  |  |  |
| $\overline{C E}, \bar{R} / W, \bar{W}$ |  |  |  |  |  |
| Input voltage HIGH | $V_{\text {IH }}$ | 2,0 | - | $V_{\text {DD }}$ | V |
| Input voltage LOW | $V_{\text {IL }}$ | 0 | - | 0,8 | V |
| Input leakage current $v_{\text {in }}=0 \text { to } 5,5 \mathrm{~V}$ | IIR | -10 | - | 10 | $\mu \mathrm{A}$ |
| Rise and fall times (note 2) | $t_{\text {rf }}$ | - | - | 50 | ns |
| Input capacitance | $C_{1}$ | - | - | 7 | pF |
| OSCI |  |  |  |  |  |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 2,2 | - | $V_{\text {DD }}$ | V |
| Input voltage LOW | $V_{\text {IL }}$ | 0 | - | 0,8 | V |
| Input leakage current $V_{\text {in }}=0 \text { to } 5,5 \mathrm{~V}$ | IIR | -10 | - | 10 | $\mu \mathrm{A}$ |
| Rise and fall times (note 2) | $\mathrm{trf}^{\text {r }}$ | - | - | 50 | ns |
| Input capacitance | $\mathrm{Cl}_{1}$ | - | - | 7 | pF |
| PARALLEL MODE |  |  |  |  |  |
| Input Characteristics (D0 to D7) |  |  |  |  |  |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | $V_{\text {DD }}$ | V |
| Input voltage LOW | $V_{\text {IL }}$ | 0 | - | 0,8 | V |
| Input leakage current$\left(V_{\text {in }}=0 \text { to } 5,5 \mathrm{~V}\right.$ |  |  |  |  |  |
| Input capacitance | $C_{1}$ | - | - | 7 | pF |
| Output Characteristics (D5 to D7 only) |  |  |  |  |  |
| Output voltage HIGH $\left(I_{\mathrm{OH}}=-100 \mu \mathrm{~A}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | 3,5 | - | $V_{\text {DD }}$ | V |
| Output voltage LOW $\left(\mathrm{I}_{\mathrm{OL}}=3,2 \mathrm{~mA}\right)$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| Load capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | - | 80 | pF |
| Rise and fall times (note 3) | $\mathrm{t}_{\mathrm{rf}}$ | - | - | 50 | ns |
| SERIAL MODE |  |  |  |  |  |
| Input characteristics (SDA and SDL) |  |  |  |  |  |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 3,0 | - | $V_{D D}$ | V |
| Input voltage LOW | $V_{\text {IL }}$ | 0 | - | 1,5 | V |
| Input leakage current $\left(\mathrm{V}_{\text {in }}=0\right.$ to $5,5 \mathrm{~V}$, output off) | liR | -10 | - | 10 | $\mu \mathrm{A}$ |
| Input capacitance | $C_{1}$ | - | - | 10 | pF |


| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Output Characteristics (SDA only, open drain) |  |  |  |  |  |
| Output voltage LOW $\left(I_{O L}=3 \mathrm{~mA}\right)$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| OSCILLATOR |  |  |  |  |  |
| Crystal frequency | ${ }^{\text {f }}$ XTAL | - | 6 | 6,1 | MHz |
| VREF |  |  |  | $V_{D D}{ }^{-1,5}$ |  |
| Reference voltage | $V_{\text {REF }}$ | 1,9 | - | $\frac{1,25}{}$ | V |
| Input leakage current (active) | $I_{1 R}$ | - | 5 | - | $\mu \mathrm{A}$ |
| Outputs |  |  |  |  |  |
| REQ, BUSY |  |  |  |  |  |
| Output voltage HIGH $\left(I_{O H}=100 \mu \mathrm{~A}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | 3,5 | - | $V_{\text {DD }}$ | V |
| Output voltage LOW $\left(\mathrm{I}_{\mathrm{QL}}=3,2 \mathrm{~mA}\right)$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| Load capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | - | 80 | pF |
| Rise and fall times (note 3) | $t_{\text {rf }}$ | - | - | 50 | ns |
| OUT |  |  |  |  |  |
| Output voltage | V OUT | 0,66 |  | $1,34 \times V_{\text {REF }}$ | V |
| Minimum external load |  |  | - | - | $\Omega$ |
| Timing characteristics (note 1) (Figs 8 and 9) |  |  |  |  |  |
| Write enable | tWR | 200 | - | - | ns |
| Data set-up for write | ${ }^{\text {t }} \mathrm{DS}$ | 150 | - | - | ns |
| Data hold for write | ${ }^{t} \mathrm{DH}$ | 30 | - | - | ns |
| Read enable | ${ }^{\text {t }} \mathrm{RD}$ | 200 | - | - | ns |
| Data delay for read (note 2) | ${ }^{t} \mathrm{DD}$ | - | - | 150 | ns |
| Data floating for read (note 2) | ${ }^{\text {t }} \mathrm{DF}$ | - | - | 150 | ns |
| Control set-up | ${ }^{\text {t }} \mathrm{CS}$ | 0 | - | - | ns |
| Control hold | ${ }^{t} \mathrm{CH}$ | 0 | - | - | ns |
| REO new (new byte of the same speech frame) | ${ }^{\text {t }} \mathrm{RN}$ | - | \# ( $\approx 3)$ |  | $\mu \mathrm{s}$ |
| REQ Valid | ${ }^{t} R \mathrm{~V}$ | 0 | - | - | ns |
| REQ Hold | ${ }^{\text {tr }}$ R | - | 250 | \# | ns |

## NOTES TO THE CHARACTERISTICS

1. Timing reference level is $1,5 \mathrm{~V}$; supply $5 \mathrm{~V} \pm 10 \%$; temperature range of $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$.
2. Levels greater than 2 V for a ' 1 ' or less than $0,8 \mathrm{~V}$ for a ' 0 ' are reached with a load of one TTL input and 50 pF .
3. Rise and fall times between $0,6 \mathrm{~V}$ and $2,2 \mathrm{~V}$ levels.


Fig. 7 Interface protocol.

## Timing diagrams

The control signals $\overline{C E}, \bar{R} / W$ and $\bar{W}$ have been specified to enable easy interface to most microprocessors and microcomputers. For instance with connection to an MAB8048 microcomputer the $\bar{R} / W$ and $\bar{W}$ inputs can be used as the RD and WR strobe inputs.


Typical connection of control signals.


Fig. 8 Read timing.


Fig. 9 Write timing.


Fig. 10 Typical application configuration with parallel interface.


Fig. 11 Typical application configuration with series interface.


Fig. 12 An example of an output configuration.


Fig. 13 Oscillator clock configurations.

## MICROPROCESSOR CONTROLLED STEREO SOUND GENERATOR FOR SOUND EFFECTS AND MUSIC SYNTHESIS

## GENERAL DESCRIPTION

The SAA1099 is a monolithic integrated circuit designed for generation of stereo sound effects and music synthesis.

## Features

- Six frequency generators
eight octaves per generator
256 tones per octave
- Two noise generators
- Six noise/frequency mixers
- Twelve amplitude controllers
- Two envelope controllers
- Two 6-channel mixers/current sink analogue output stages
- TTL input compatible
- Readily interfaces to 8-bit microcontroller
- Minimal peripheral components
- Simple output filtering


## Applications

- Consumer games systems
- Home computers
- Electronic organs
- Arcade games
- Toys
- Chimes/alarm clocks


## QUICK REFERENCE DATA

| Supply voltage (pin 18) | VDD | typ. | 5 | V |
| :---: | :---: | :---: | :---: | :---: |
| Supply current (pin 18) | IDD | typ. | 70 |  |
| Reference current (pin 6) | Iref | typ. | 25 |  |
| Total power dissipation | $P_{\text {tot }}$ |  | 500 | mW |
| Operating ambient temperature range | $\mathrm{T}_{\text {amb }}$ |  | $+70$ |  |

## PACKAGE OUTLINE

18-lead DIL; plastic (SOT-102ME).


Fig. 1 Block diagram.

## PINNING



Fig. 2 Pinning diagram.

## PIN DESIGNATION

| 1 | $\overline{W R}$ | Write Enable: active LOW input which operates in conjunction with $\overline{\mathrm{CS}}$ and AO to allow writing to the internal registers. |
| :---: | :---: | :---: |
| 2 | $\overline{\mathrm{CS}}$ | Chip Select: active LOW input to identify valid $\overline{\mathrm{WR}}$ inputs to the chip. This input also operates in conjunction with $\overline{W R}$ and $A 0$ to allow writing to the internal registers. |
| 3 | A0 | Control/Address select: input used in conjunction with $\overline{\mathrm{WR}}$ and $\overline{\mathrm{CS}}$ to load data to the control register ( $\mathrm{A} 0=0$ ) or the address buffer ( $\mathrm{A} 0=1$ ). |
| 4 | OUTR | Right channel output: a 7 -level current sink analogue output for the 'right' component. This pin requires an external load resistor. |
| 5 | OUTL | Left channel output: a 7 -level current sink analogue output for the 'ieft' component. This pin requires an external load resistor. |
| 6 | $I_{\text {ref }}$ | Reference current supply: used to bias the current sink outputs. |
| 7 | $\overline{\text { DTACK }}$ | Data Transfer Acknowledge: open drain output, active LOW to acknowledge successful data transfer. On completion of the cycle DTACK is set to inactive, |
| 8 | CLK | Clock: input for an externally generated clock at a nominal frequency of 8 MHz . |
| 9 | $\mathrm{V}_{\text {SS }}$ | Ground: 0 V . |
| 10-17 | D0-D7 | Data: Data bus input. |
| 18 | $V_{\text {DD }}$ | Power supply: + 5 V typical. |

## FUNCTIONAL DESCRIPTION

The following sections provide a detailed functional description of the SAA1099 as shown in the block diagram, Fig. 1.

## Frequency generators

Six frequency generators can each select one of 8 octaves and one of 256 tones within an octave. A total frequency range of 31 Hz to $7,81 \mathrm{kHz}$ is available. The outputs may also control noise or envelope generators. All frequency generators have an enable bit which switches them on and off, making it possible to preselect a tone and to make it inaudible when required. The frequency generators may be synchronized using the frequency reset bit.
The frequency ranges per octave are:

| Octave | Frequency range |
| :---: | :--- |
| 0 | 31 Hz to 61 Hz |
| 1 | 61 Hz to 122 Hz |
| 2 | 122 Hz to 244 Hz |
| 3 | 245 Hz to 488 Hz |
| 4 | 489 Hz to 977 Hz |
| 5 | 978 Hz to $1,95 \mathrm{kHz}$ |
| 6 | $1,96 \mathrm{kHz}$ to $3,91 \mathrm{kHz}$ |
| 7 | $3,91 \mathrm{kHz}$ to $7,81 \mathrm{kHz}$ |

## Noise generators

The two noise generators both have a programmable output. This may be a software controlled noise via one of the frequency controlled generators or one of three pre-defined noises. There is no tone produced by the frequency generator when it is controlling the noise generator. The noise produced is based on double the frequency generator output, i.e. a range of 61 Hz to $15,6 \mathrm{kHz}$. In the event of a pre-defined noise being chosen, the output of noise generator 0 can be mixed with frequency generator 0,1 and 2; and the output of noise generator 1 can be mixed with frequency generator 3,4 and 5. In order to produce an equal level of noise and tone outputs (when both are mixed) the amplitude of the tone is increased. The three pre-defined noises are based on a clock frequency of $7,8 \mathrm{kHz}, 15,6 \mathrm{kHz}$ or $31,25 \mathrm{kHz}$.

## Noise/frequency mixers

Six noise/frequency mixers each with four selections

- Channel off
- Frequency only
- Noise only
- Noise and frequency

Each mixer channel has one of the frequency generator outputs fed to it, three channels use noise generator 0 and the other three use noise generator 1 .

## Amplitude controllers

Each of the six channel outputs from the mixer is split up into a right and left component giving effectively twelve amplitude controllers. An amplitude of 16 possible levels is assigned to each of the twelve signals. With this configuration a stereo effect can be achieved by varying only the amplitude component. The moving of a sound from one channel to the other requires, per tone, only one update of the amplitude register contents.
When an envelope generator is used, the amplitude levels are restricted. The number of levels available is then reduced to eight. This is achieved by disabling the least significant bit (LSB) of the amplitude control.

## Envelope controllers

Two of the six tone generators are under envelope control. This applies to both the left and right outputs from the tone generator.
The envelope has the following eight possible modes:

- Amplitude is zero
- Single attack
- Single decay
- Single attack-decay (triangular)
- Maximum amplitude
- Continuous attack
- Continuous decay
- Continuous attack-decay

The timing of the envelope controllers is programmable using one of the frequency generators (see Fig. 1). When the envelope mode is selected for a channel its control resolution is halved for that channel from 16 levels to 8 levels by rounding down to the nearest even level.
There is also the capability of controlling the 'right' component of the channel with inverse of the 'left' component, which remains as programmed.
A direct enable permits the start of an envelope to be defined, and also allows termination of an envelope at any time. The envelope rate may be controlled by a frequency channel (see Fig. 1), or by the microprocessor writing to the address buffer register. If the frequency channel controlled is OFF ( $\mathrm{NE}=\mathrm{FE}=0$ ) the envelope will appear at the output, which provides an alternative 'non-square' tone capability. In this event the frequency will be the envelope rate, which provided the rate is from the frequency channel, will be a maximum of 1 kHz . Higher frequencies of up to 2 kHz can be obtained by the envelope resolution being halved from 16 levels to 8 levels. Rates quoted are based on the input of a 8 MHz clock.

## Six-channel mixers/current sink analogue output stages

Six channels are mixed together by the two mixers allowing each one to control one of six equally weighted current sinks, to provide a seven level analogue output.

## Command/control select

In order to simplify the microprocessor interface the command and control information is multiplexed. To select a register in order to control frequencies, amplitudes, etc. the command-register has to be loaded. The contents of this register determines to which register the data is written in the next control-cycie. If a continuous update of the control-register is necessary, only the control-information has to be written (the command-information does not change).
If the command/control select (AO) is logic 0 , the byte transfer is control; if A0 is logic 1 , the byte transfer is command.

## Interface to microprocessor

The SAA1099 is a data bus based I/O peripheral. Depending on the value of the command/control signal (AO) the $\overline{C S}$ and $\overline{W R}$ signals control the data transfer from the microprocessor to the SAA 1099. The data-transfer-acknowledge ( $\overline{\mathrm{DTACK}}$ ) indicates that the data transfer is completed. When, during the write cycle, the microprocessor recognizes the $\overline{\text { DTACK, }}$, the bus cycle will be completed by the processor.

## SAA1099

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage (pin 18)
Maximum input voltage
at $V_{D D}=4,5$ to $5,5 \mathrm{~V}$
Maximum output current
Total power dissipation
Storage temperature range
Operating ambient temperature range
Electrostatic handling*

| $V_{\text {DD }}$ | $-0,3$ to $+7,5 \mathrm{~V}$ |
| :---: | :---: |
| $V_{1}$ | $-0,3$ to $+7,5 \mathrm{~V}$ |
| $V_{1}$ | $-0,5$ to $+7,5 \mathrm{~V}$ |
| 10 | max. $\quad 10$ |
| $\mathrm{P}_{\text {tot }}$ | 500 |
| $\mathrm{T}_{\text {stg }}$ | -55 to +125 |
| T ${ }_{\text {amb }}$ | 0 to +70 |
| $\mathrm{V}_{\text {es }}$ | -1000 to +1000 |

[^25]
## D.C. CHARACTERISTICS

$V_{D D}=5 \mathrm{~V} \pm 10 \%$; $\mathrm{T}_{\mathrm{amb}}=0$ to $70^{\circ} \mathrm{C}$; unless otherwise specified

| parameter | symbol | min . | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply |  |  |  |  |  |
| Supply voltage | $V_{\text {DD }}$ | 4,5 | 5,0 | 5,5 | V |
| Supply current | IDD | - | 70 | 100 | mA |
| Reference current (note 1) | $I_{\text {ref }}$ | 100 | 250 | 400 | $\mu \mathrm{A}$ |
| INPUTS |  |  |  |  |  |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | 6,0 | V |
| Input voltage LOW | $V_{\text {IL }}$ | -0,5 | - | 0,8 | V |
| Input leakage current | $\pm \mathrm{I}_{\mathrm{LI}}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Input capacitance | $C_{1}$ | - | - | 10 | pF |
| OUTPUTS ${ }^{\text {DTACK }}$ (open drain; note |  |  |  |  |  |
|  |  |  |  |  |  |
| Output voltage LOW at $\mathrm{I}_{\mathrm{OL}}=3,2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ | 0 | - | 0,4 | V |
| Voltage on pin 7 (OFF state) | $V_{7-9}$ | -0,3 | - | 6,0 | V |
| Output capacitance (OFF state) | $\mathrm{C}_{0}$ | - | - | 10 | pF |
| Load capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | - | 150 | pF |
| Output leakage current (OFF state) | - ILO | - | - | 10 | $\mu \mathrm{A}$ |
| Audio outputs (pins 4 and 5) |  |  |  |  |  |
| With fixed $I_{\text {ref }}$ ( note 3) |  |  |  |  |  |
| One channel on | ${ }^{1} 01 / I_{\text {ref }}$ | 90 | - | 120 | \% |
| Six channels on | ${ }^{106} / 6 \times\left.\right\|_{\text {ref }}$ | 85 | - | 110 | \% |
| With $I_{\text {ref }}=250 \mu A ; R_{L}=1,5 \mathrm{k} \Omega( \pm 5 \%)$ |  |  |  |  |  |
| One channel on | ${ }^{1} 11^{\prime} /{ }_{\text {ref }}$ | 90 | - | 110 | \% |
| Six channels on | ${ }^{106 / 6 x I_{\text {ref }}}$ | 85 | - | 105 | \% |
| Output current one channel on | ${ }^{1} 01$ | 225 | - | 275 | $\mu \mathrm{A}$ |
| Output current six channels on | ${ }^{1} 06$ | 1,3 | - | 1,6 | mA |
| With resistor supplying $\mathrm{I}_{\text {ref }}$ ( ( ${ }^{\text {ate 4) }}$ |  |  |  |  |  |
| Output current one channel on | ${ }^{1} 1$ | 150 | - | 350 | $\mu \mathrm{A}$ |
| Output current six channels on | ${ }^{1} 06$ | 0,9 | - | 1,9 | mA |
| Load resistance | $\mathrm{R}_{\mathrm{L}}$ | 600 | - | - | $\Omega$ |
| D.C. leakage current all channels off | - ${ }_{\text {LO }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Maximum current difference between left and right current sinks (note 5) | $\pm \mathrm{I}_{\text {Omax }}$ | - | - | 15 | \% |
| Signal-to-noise ratio (note 6) | S/N | - | tbf | - | dB |

## A.C. CHARACTERISTICS

$V_{D D}=5 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{amb}}=0$ to $70^{\circ} \mathrm{C}$; timing measurements taken at $2,0 \mathrm{~V}$ for a logic 1 and $0,8 \mathrm{~V}$ for a logic 0 unless otherwise specified (see waveforms Figs 3 and 4)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bus interface timing (see Fig. 3) |  |  |  |  |  |
| A0 set-up time to $\overline{C S}$ fall | ${ }^{\mathrm{t}}$ ASC | 0 | - | - | ns |
| $\overline{\mathrm{CS}}$ LOW to $\overline{W R}$ fall | ${ }^{\text {t }}$ CSW | 30 | - | - | ns |
| A0 set-up time to $\overline{W R}$ fall | ${ }^{\text {t ASW }}$ | 50 | - | - | ns |
| $\overline{W R}$ LOW time | twL | 100 | - | - | ns |
| Data bus valid to $\overline{\mathrm{WR}}$ rise | $t_{\text {BSW }}$ | 100 | - | - | ns |
| $\overline{\text { DTACK }}$ fall delay from $\overline{W R}$ fall (note 7) | ${ }^{\text {t }}$ DFW | 0 | - | 85 | ns |
| AO hold time from $\overline{\text { WR }}$ HIGH | ${ }^{\text {t }}$ AHW | 0 | - | - | ns |
| $\overline{\mathrm{CS}}$ hold time from $\overline{\text { WR HIGH }}$ | ${ }^{\text {t }}$ CHW | 0 | - | - | ns |
| Data bus hold time from $\overline{\text { WR }}$ HIGH | tDHW | 0 | - | - | ns |
| $\overline{\text { DTACK }}$ rise delay from $\overline{\text { WR }}$ HIGH | ${ }^{\text {t }}$ DRW | 0 | - | 100 | ns |
| Bus cycle time (note 8) | ${ }^{t} \mathrm{CY}$ | ${ }^{4 t}$ CLK | - | - |  |
| Bus cycle time (note 9) | ${ }^{t} \mathrm{CY}$ | ${ }^{16 t}$ CLK | - | - |  |
| Clock input timing (see Fig. 4) |  |  |  |  |  |
| Clock period | ${ }^{\text {t CLK }}$ | 120 | 125 | 255 | ns |
| Clock LOW time | t LOW | 55 | - | - | ns |
| Clock HIGH time | thigh | 55 | - | - | ns |

## Notes to the characteristics

1. Using an external constant current generator to provide a nominal $I_{\text {ref }}$ or external resistor connected to $V_{\text {DD }}$.
2. This output is short-circuit protected to $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$.
3. Measured with $I_{\text {ref }}$ a constant value between 100 and $400 \mu \mathrm{~A}$; load resistance $\left(R_{L}\right)$ allowed to match E12 (5\%) in all applications via:

$$
R_{L}=0,6\left[I_{\mathrm{ref}}\right]^{-1}-16\left[I_{\mathrm{ref}}\right]^{-0,5} \pm 12 \%
$$

4. Measured with $R_{r e f}=10 \mathrm{k} \Omega( \pm 5 \%)$ connected between $I_{\text {ref }}$ and $V_{D D} ; R_{L}=1,5 \mathrm{k} \Omega( \pm 5 \%)$; OUTR and OUTL short-circuit protected to $\mathrm{V}_{\mathrm{SS}}$.
5. Left and right outputs must be driven with identical configuration.
6. Sample tested value only.
7. This timing parameter only applies when no wait states are required; otherwise parameter is invalid.
8. The minimum bus cycle time of four clock periods is for loading all registers except the amplitude registers.
9. The minimum bus cycle time of 16 clock periods is for loading the amplitude registers. In a system using DTACK it is possible to achieve minimum times of 500 ns . Without $\overline{\text { TTACK }}$ the parameter given must be used.


Fig. 3 Bus interface waveforms.


Fig. 4 Clock input waveform.

## APPLICATION INFORMATION

## Device operation

The SAA 1099 uses pulse width modulation to achieve amplitude and envelope levels. The twelve signals are mixed in an analogue format ( 6 'left' and 6 'right') before leaving the chip. The amplitude and envelope signals chop the output at a minimum rate of $62,5 \mathrm{kHz}$, compared with the highest tone output of $7,81 \mathrm{kHz}$. Simple external low-pass filtering is used to remove the high frequency components.

Rates quoted are based on the input of a 8 MHz clock.
A data bus based write only structure is used to load the on-board registers. The data bus is used to load the address for a register, and subsequently the data to that register. Once the address is loaded multiple data loads to that register can be performed.
The selection of address or data is made by the single address bit AO, as shown in register maps Table 1 and Table 2.
The bus control signals $\overline{W R}$ and $\overline{\mathrm{CS}}$ are designed to be compatible with a wide range of microprocessors, a DTACK output is included to optimise the interface with an S68000 series microprocessor. In most bus cycles DTACK will be returned immediately, this applies to all register address load cycles and all except amplitude data load cycles. With respect to amplitude data, a number of wait cycles may need to be performed, depending on the time since the previous amplitude load. $\overline{\text { DTACK }}$ will indicate the number of required waits.

## Register description (see Tables 2 and 3)

The amplitudes are assigned with 'left' and 'right' components in the same byte, on a channel by channel basis. The spare locations that are left between blocks of registers is to allow for future expansion, and should be written as zero's. The tone within an octave is defined by eight bits and the octave by three bits. Note that octaves are paired ( $0 / 1,2 / 3 \mathrm{etc}$.). The frequency and noise enables are grouped together for ease of programming. The controls for noise 'colour' (clock rate) are grouped in one byte.
The envelope registers are positioned in adjacent locations. There are two types of envelope controls, direct acting controls and buffered controls. The direct acting controls always take immediate effect, and are:

- Envelope enable (reset)
- Envelope resolution (16/8 level)

The buffered controls are acted upon only at the times shown in Fig. 5 and control selection of:

- Envelope clock source
- Waveform type
- Inverted/non-inverted 'right' component

Table 1 External memory map

| select <br> AO | data bus inputs |  |  |  |  |  |  |  | operations |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | data for internal registers |
| 1 | X | X | X | A4 | A3 | A2 | A1 | A0 | internal register address |

Where $\mathrm{X}=$ don't care state.

Table 2 Internal register map


Where:
All don't cares ( $X$ ) should be written as zero's.
00 to 1 F block of registers repeats eight times in the block between addresses 00 to FF (full internal memory map).

## APPLICATION INFORMATION (continued)

Table 3 Register description

| bit | description |
| :---: | :---: |
| ARn3; ARn2; <br> ARn1; ARn0 $(n=0,5)$ | 4 bits for amplitude control of right channel 0000 minimum amplitude (off) 1111 maximum amplitude |
| $\begin{aligned} & \text { ALn3; ALn2; } \\ & \text { ALn1; ALn0 } \\ & (\mathrm{n}=0,5) \end{aligned}$ | 4 bits for amplitude control of left channel <br> 0000 minimum amplitude (off) <br> 1111 maximum amplitude |
| $\begin{aligned} & \text { Fn7 to Fn0 } \\ & (\mathrm{n}=0,5) \end{aligned}$ | 8 bits for frequency control of the six frequency generators 00000000 lowest frequency $\begin{array}{llllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 & \text { highest frequency }\end{array}$ |
| $\begin{aligned} & \text { On2; On1; On0 } \\ & (n=0,5) \end{aligned}$ | 3 bits for octave control  <br> 0 0 0 lowest octave $(31 \mathrm{~Hz}$ to 61 Hz$)$  <br> 0 0 1 $(61 \mathrm{~Hz}$ to 122 Hz$)$ <br> 0 1 0 $(122 \mathrm{~Hz}$ to 244 Hz$)$ <br> 0 1 1 $(245 \mathrm{~Hz}$ to 488 Hz$)$ <br> 1 0 0 $(489 \mathrm{~Hz}$ to 977 Hz$)$ <br> 1 0 1 $(978 \mathrm{~Hz}$ to $1,95 \mathrm{kHz})$ <br> 1 1 0 $(1,96 \mathrm{kHz}$ to $3,91 \mathrm{kHz})$ <br> 1 1 1 highest octave <br>  $(3,91 \mathrm{kHz}$ to $7,81 \mathrm{kHz})$   |
| $\begin{aligned} & \text { FEn } \\ & (\mathrm{n}=0,5) \end{aligned}$ | frequency enable bit (one tone per generator) FEn $=0$ indicates that frequency ' $n$ ' is off |
| $\begin{aligned} & \text { NEn } \\ & (\mathrm{n}=0,5) \end{aligned}$ | noise enable bit (one tone per generator) $N E n=0$ indicates that noise ' $n$ ' is off |
| $\begin{aligned} & \mathrm{Nn} 1 ; \mathrm{Nn0} \\ & (\mathrm{n}=0,1) \end{aligned}$ | 2 bits for noise generator control. <br> These bits select the noise generator rate (noise 'colour') |



## Note

All rates given are based on the input of a 8 MHz clock.

## APPLICATION INFORMATION (continued)



Fig. 5 Envelope waveforms.

Notes to Fig. 5
(1) The level at this time is under amplitude control only ( $\mathrm{En} 7=0$; no envelope).
(2) When the generator is active ( $\mathrm{En7}=1$ ) the maximum level possible is $7 / 8$ ths of the amplitude level.
(3) After position (3) the buffered controls will be acted upon when loaded.
(4) At positions (4) the buffered controls will be acted upon if already loaded.
(5) Waveforms ' $a$ ' to ' $h$ ' show the left channel ( $\mathrm{EnO}=0$; left and right components have the same envelope).
Waveform ' $i$ ' shows the right channel ( $\mathrm{EnO}=1$; right component inverse of envelope applied to left).


Fig. 6 Typical application circuit diagram.

## $I^{2} \mathrm{C}$-bus peripherals

PCB8582 ..... 1061
PCF8566 ..... 1069
PCF8570 ..... 1099
PCF8571 ..... 1111
PCF8573 ..... 1123
PCF8574 ..... 1141
PCF8576 ..... 1155
PCF8577. ..... 1191
PCF8577A ..... 1191
PCF8583 ..... 1207
PCF8591 ..... 1225

User manual 1986 *
"Single-chip 8-bit Microcontrollers"
Available on request

* Includes $1^{2}$ C-bus specification


Purchase of Philips $1^{2} \mathrm{C}$ components conveys a licence under the Philips $I^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$ system provided the system conforms to the $1^{2} \mathrm{C}$ specification defined by Philips.

+3
\%

## STATIC CMOS EEPROM (256 x 8 BIT)

## GENERAL DESCRIPTION

The PCB8582 is a 2 K -bit 5 V electrically erasable programmable read only memory (EEPROM) organized as 256 by 8 bits. It is designed in a floating gate CMOS technology.
As data bytes are received and transmitted via the serial $1^{2} \mathrm{C}$ bus, an eight pin DIL package is sufficient. Up to eight PCB8582 devices may be connected to the $1^{2} \mathrm{C}$ bus.

Chip select is accomplished by three address inputs.

## Features

- Non-volatile storage of 2 K -bit organized as $256 \times 8$
- Only one power supply required (5 V)
- On chip voltage multiplier for erase/write
- Serial input/output bus ( $1^{2} \mathrm{C}$ )
- Automatic word address incrementing
- Low power consumption
- One point erase/write timer
- Power on reset
- 10000 erase/write cycles per byte
- 10 years non-volatile data retention
- Infinite number of read cycles
- Pin and address compatible to PCF8570, PCF8571 and PCD8572
- A version for extended temperature range, -40 to $+85^{\circ} \mathrm{C}$, in preparation: PCF8582.


## PACKAGE OUTLINE

PCB8582P: 8-lead DIL; plastic (SOT-97AE).


Fig. 1 Block diagram.


Fig. 2 Pinning diagram.

1 AO
2 A1 address inputs/test
3 A2 mode select
4 VSS ground
5 SDA
6 SCL
$1^{2} \mathrm{C}$ bus lines
7 RC input for timer constant
8 VDD positive supply

## FUNCTIONAL DESCRIPTION

## Characteristics of the $\mathrm{I}^{2} \mathrm{C}$ bus

The $\mathrm{I}^{2} \mathrm{C}$ bus is intended for communication between different ICs. The serial bus consists of two bi-directional lines, one for data signals (SDA), and one for clock signals (SCL). Both the SDA and the SCL lines must be connected to a positive supply voltage via a pull-up resistor.
The following protocol has been defined:
Data transfer may be initiated only when the bus is not busy.
During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as control signals.
Accordingly, the following bus conditions have been defined:
Bus not busy: both data and clock lines remain HIGH.
Start data transfer: a change in the state of the data line, from HIGH to LOW, while the clock is HIGH defines the start condition.
Stop data transfer: a change in the state of the data line, from LOW to HIGH, while the clock is HIGH, defines the stop condition.
Data valid: the state of the data line represents valid data when, after a start condition, the data line is stable for the duration of the HIGH period of the clock signal. The data on the line may be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.
Each data transfer is initiated with a start condition and terminated with a stop condition; the number of the data bytes, transfered between the start and stop conditions is limited to two bytes in the ERASE/WRITE mode and unlimited in the READ mode. The information is transmitted in bytes and each receiver acknowledges with a ninth bit.
Within the $\mathrm{I}^{2} \mathrm{C}$ bus specifications a low-speed mode ( 2 kHz clock rate) and a high-speed mode ( 100 kHz clock rate) are defined. The PCB8582 operates in both modes.
By definition a device that gives out a signal is called a "transmitter", and the device which receives the signal is called a "receiver". The device which controls the signal is called the "master". The devices that are controlled by the master are called "slaves".
Each word of eight bits is followed by one acknowledge bit. This acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed is obliged to generate an acknowledge after the reception of each byte.
Also, a master receiver must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter.
The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the high period of the acknowledge related clock pulse.
Set-up-and hold times must be taken into account. A master receiver must signal an end of data to the slave transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this case the transmitter must leave the data line HIGH to enable the master generation of the stop condition.

## Note

$\longrightarrow$ The general characteristics and detailed specification of the $I^{2} \mathrm{C}$ bus is available on request.

## $I^{2} \mathrm{C}$ bus protocol

The $1^{2} \mathrm{C}$ bus configuration for different READ and WRITE cycles of the PCB8582 are shown in Fig. 3.


Fig. 3(a) Slave receiver ERASE/WRITE mode.
(1.) After this stop condition the erase/write cycle starts and the bus is free for another transmission; the duration of the erase/write cycle is approximatly 20 ms if only one byte is written, and 40 ms , if two bytes are written. During the erase/write cycle the slave receiver does not send an acknowledge bit if addressed via $I^{2} \mathrm{C}$ bus.
$\rightarrow$ (2.) The second data byte is voluntary. It is not allowed to erase/write more than two bytes.


Fig. 3(b) Master reads PCB8582 slave after setting word address.
(WRITE word address; READ data).

Note: The slave address is defined in accordance with the $I^{2} \mathrm{C}$ bus specification as:

| 1 | 0 | 1 | 0 | A 2 | A 1 | A 0 | $\mathrm{R} / \overline{\mathrm{W}}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |



Fig. 3(c) Master reads PCB8582 slave immediately after first byte (READ mode).
$1^{2} \mathrm{C}$ bus timing


Fig. $41^{2} \mathrm{C}$ bus, timing.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage
Voltage, on any input pin (input impedance $500 \Omega$ )
Operating temperature range
Storage temperature range
Current into any input pin
Output current
$V_{D D}$

Tamb
$T_{\text {stg }}$
II
${ }^{1} 0$
$\mathrm{V}_{\mathrm{I}} \quad \mathrm{V}_{\mathrm{SS}}-0,8$ to $\mathrm{V}_{\mathrm{DD}}+0,8 \mathrm{~V}$
$-0,3$ to 7 V

0 to $+70{ }^{\circ} \mathrm{C}$ -65 to +150 oC

1 mA
10 mA

## CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=0$ to $+70^{\circ} \mathrm{C}$, unless otherwise specified.


## Notes to the characteristics

1. Selection of the chip address is done by connecting the $A 0, A 1$, and $A 2$ inputs either to $V_{S S}$ or $V_{D D}$.
2. A transmitter must internally provide a hold time to bridge the undefined region (maximum 300 ns ) of the falling edge of SCL.
3. Endurance (number of erase/write cycles), $\mathrm{NE} / \mathrm{W}$, is $10^{4} \mathrm{E} / \mathrm{W}$ cycles.


Purchase of Philips $1^{2} \mathrm{C}$ components conveys a license under the Philips ${ }^{\prime} 1^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $1^{2} \mathrm{C}$ specifications defined by Philips.

50


## UNIVERSAL LCD DRIVER FOR LOW MULTIPLEX RATES

## GENERAL DESCRIPTION

The PCF8566 is a peripheral device which interfaces to almost any liquid crystal display (LCD) having low multiplex rates. It generates the drive signals for any static or multiplexed LCD containing up to four backplanes and up to 24 segments and can easily be cascaded for larger LCD applications. The PCF8566 is compatible with most microprocessors/microcontrollers and communicates via a two-line bidirectional bus ( $\left.I^{2} \mathrm{C}\right)$. Communication overheads are minimized by a display RAM with auto-incremented addressing, by hardware subaddressing and by display memory switching (static and duplex drive modes).

## Features

- Single-chip LCD controller/driver
- Selectable backplane drive configuration: static or $2 / 3 / 4$ backplane multiplexing
- Selectable display bias configuration: static, $1 / 2$ or $1 / 3$
- Internal LCD bias generation with voltage-follower buffers
- 24 segment drives: up to twelve 8 -segment numeric characters; up to six 15 -segment alphanumeric characters; or any graphics of up to 96 elements
- $24 \times 4$-bit RAM for display data storage
- Auto-incremented display data loading across device subaddress boundaries
- Display memory bank switching in static and duplex drive modes
- Versatile blinking modes
- LCD and logic supplies may be separated
- 3 V to 6 V power supply range
- Low power consumption
- Power-saving mode for extremely low power consumption in battery-operated and telephone applications
- $1^{2} \mathrm{C}$ bus interface
- TTL/CMOS compatible
- Compatible with any 4 -bit, 8 -bit or 16 -bit microprocessors/microcontrollers
- May be cascaded for large LCD applications (up to 1536 segments possible)
- Cascadable with the 40 segment LCD driver PFC8576
- Optimized pinning for single plane wiring in both single and multiple PCF8566 applications
- Space-saving 40-lead plastic mini-pack (VSO-40; SOT-158A)
- No external components required (even in multiple device applications)
- Manufactured in silicon gate CMOS process


Purchase of Philips $\left.\right|^{2} \mathrm{C}$ components conveys a license under the Philips $\left.\right|^{\prime}{ }^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specification defined by Philips.

## PACKAGE OUTLINES

PCF8566T: 40-lead mini-pack; (VSO-40; SOT-158A).
PCF8566P: 40-lead DIL; plastic (SOT-129).


Fig. 1 Block diagram.
DEVELOPMENT DATA


Fig. 2 Pinning diagram.

## PINNING

| 1 | SDA | $1^{2} \mathrm{C}$ bus data input/output |
| :---: | :---: | :---: |
| 2 | SCL | $1^{2} \mathrm{C}$ bus clock input/output |
| 3 | SYNC | cascade synchronization input/output |
| 4 | CLK | external clock input/output |
| 5 | $V_{\text {DD }}$ | positive supply voltage |
| 6 | OSC | oscillator input |
| 7 | A0 |  |
| 8 | A1 | $1^{2} \mathrm{C}$ bus subaddress inputs |
| 9 | A2 |  |
| 10 | SAO | $1^{2} \mathrm{C}$ bus slave address bit 0 input |
| 11 | $\mathrm{V}_{\text {SS }}$ | logic ground |
| 12 | $V_{\text {LCD }}$ | LCD supply voltage |
| 13 | BPO |  |
| 14 | BP2 | LCD backplane outputs |
| 15 | BP1 | LCD backplane outputs |
| 16 | BP3 |  |
| 17 | SO |  |
| to | to | LCD segment outputs |
| 40 | S23 |  |

## FUNCTIONAL DESCRIPTION

The PCF8566 is a versatile peripheral device designed to interface any microprocessor to a wide variety of ! -CDs. It can directly drive any static or multiplexed LCD containing up to four backplanes and up to 24 segments. The display configurations possible with the PCF8566 depend on the number of active backplane outputs required; a selection of display configurations is given in Table 1.

Table 1 Selection of display configurations

| active back- <br> plane outputs | no. of <br> segments | 7-segment <br> numeric | 14 -segment <br> alphanumeric | dot matrix |
| :--- | :---: | :--- | :--- | :---: |
| 4 | 96 | 12 digits + <br> 12 indicator <br> symbols | 6 characters + <br> 12 indicator <br> symbols | 96 dots <br> $(4 \times 24)$ |
| 3 | 72 | 9 digits + <br> 9 indicator <br> symbols | 4 characters + <br> 16 indicator <br> symbols | 72 dots <br> $(3 \times 24)$ |
| 2 | 48 | 6 digits + <br> 6 indicator <br> symbols | 3 characters + <br> 6 indicator <br> symbols | 48 dots <br> $(2 \times 24)$ |
| 1 | 24 | 3 digits + <br> 3 indicator <br> symbols | 1 characters + <br> 10 indicator <br> symbols | 24 dots |

All of the display configurations given in Table 1 can be implemented in the typical system shown in Fig. 3. The host microprocessor/microcontroller maintains the two-line $1^{2} \mathrm{C}$ bus communication channel with the PCF8566. The internal oscillator is selected by tying OSC (pin 6) to $\mathrm{V}_{\text {SS }}$. The appropriate biasing voltages for the multiplexed LCD waveforms are generated internally. The only other connections required to complete the system are to the power supplies ( $V_{D D}, V_{S S}$ and $V_{L C D}$ ) and to the LCD panel chosen for the application.


Fig. 3 Typical system configuration.

## Power-on reset

At power-on the PCF8566 resets to a defined starting condition as follows:

1. All backplane outputs are set to $V_{D D}$.
2. All segment outputs are set to $V_{D D}$.
3. The drive mode ' $1: 4$ multiplex with $1 / 3$ bias' is selected.
4. Blinking is switched off.
5. Input and output bank selectors are reset (as defined in Table 5).
6. The $I^{2} \mathrm{C}$ bus interface is initialized.
7. The data pointer and the subaddress counter are cleared.

Data transfers on the $I^{2} \mathrm{C}$ bus should be avoided for 1 ms following power-on to allow sompletion of the reset action.

## LCD bias generation

The full-scale LCD voltage ( $\mathrm{V}_{\mathrm{op}}$ ) is obtained from $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$. The LCD voltage may be temperature compensated externally through the $V_{\text {LCD }}$ supply to pin 12. Fractional LCD biasing voltages are obtained from an internal voltage divider of three series resistors connected between $V_{D D}$ and $V_{L C D}$. The centre resistor can be switched out of circuit to provide a $1 / 2$ bias voltage level for the $1: 2$ multiplex configuration.

## LCD voltage selector

The LCD voltage selector coordinates the multiplexing of the LCD according to the selected LCD drive configuration. The operation of the voltage selector is controlled by MODE SET commands from the command decoder. The biasing configurations that apply to the preferred modes of operation, together with the biasing characteristics as functions of $V_{o p}=V_{D D}-V_{L C D}$ and the resulting discrimination ratios (D), are given in Table 2.

Table 2 Preferred LCD drive modes: summary of characteristics

| LCD drive mode | LCD bias <br> configuration | $\frac{V_{\text {off(rms) }}}{V_{\text {op }}}$ | $\frac{V_{\text {on }}(r m s)}{V_{\text {op }}}$ | $D=\frac{V_{\text {on }}(r m s)}{V_{\text {off(rms) }}}$ |
| :--- | :--- | :--- | :--- | :--- |
| static (1 BP) | static (2 levels) | 0 | 1 | $\infty$ |
| $1: 2$ MUX (2 BP) | $1 / 2$ (3 levels) | $\sqrt{2 / 4}=0,354$ | $\sqrt{10 / 4=0,791}$ | $\sqrt{5}=2,236$ |
| $1: 2$ MUX (2 BP) | $1 / 3$ (4 levels) | $1 / 3=0,333$ | $\sqrt{5 / 3}=0,745$ | $\sqrt{5}=2,236$ |
| $1: 3$ MUX (3 BP) | $1 / 3$ (4 levels) | $1 / 3=0,333$ | $\sqrt{33 / 9}=0,638$ | $\sqrt{33 / 3}=1,915$ |
| $1: 4$ MUX (4 BP) | $1 / 3(4$ levels) | $1 / 3=0,333$ | $\sqrt{3 / 3}=0,577$ | $\sqrt{3}=1,732$ |

## LCD voltage selector (continued)

A practical value for $\mathrm{V}_{\mathrm{op}}$ is determined by equating $\mathrm{V}_{\mathrm{off}}(\mathrm{rms})$ with a defined LCD threshold voltage $\left(V_{\text {th }}\right)$, typically when the LCD exhibits approximately $10 \%$ contrast. In the static drive mode a suitable choice is $V_{\text {op }} \gtrsim 3 V_{\text {th }}$.
Multiplex drive ratios of $1: 3$ and $1: 4$ with $1 / 2$ bias are possible but the discrimination and hence the contrast ratios are smaller ( $\sqrt{3}=1,732$ for $1: 3$ multiplex or $\sqrt{21} / 3=1,528$ for $1: 4$ multiplex). The advantage of these modes is a reduction of the LCD full scale voltage $V_{o p}$ as follows:

1 : 3 multiplex ( $1 / 2$ bias) : $\mathrm{V}_{\mathrm{op}}=\sqrt{6} \mathrm{~V}_{\text {off }}(\mathrm{rms})=2,449 \mathrm{~V}_{\text {off }}(\mathrm{rms})$
$1: 4$ multiplex ( $1 / 2$ bias) : $\mathrm{V}_{\mathrm{op}}=4 \sqrt{3} / 3 \mathrm{~V}_{\text {off }}(\mathrm{rms})=2,309 \mathrm{~V}_{\mathrm{off}}(\mathrm{rms})$
These compare with $\mathrm{V}_{\mathrm{op}}=3 \mathrm{~V}_{\mathrm{off}(\mathrm{rms})}$ when $1 / 3$ bias is used.

## LCD drive mode waveforms

The static LCD drive mode is used when a single backplane is provided in the LCD. Backplane and segment drive waveforms for this mode are shown in Fig. 4.


Fig. 4 Static drive mode waveforms: $\mathrm{V}_{\mathrm{Op}}=\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$.

When two backplanes are provided in the LCD the 1:2 multiplex drive mode applies. The PCF8566 allows use of $1 / 2$ or $1 / 3$ bias in this mode as shown in Figs 5 and 6.


Fig. 5 Waveforms for $1: 2$ multiplex drive mode with $1 / 2$ bias: $V_{o p}=V_{D D}-V_{L C D}$.

LCD drive mode waveforms (continued)


Fig. 6 Waveforms for $1: 2$ multiplex drive mode with $1 / 3$ bias: $V_{o p}=V_{D D}-V_{L C D}$.

The backplane and segment drive wavefront for the $1: 3$ multiplex drive mode (three LCD backplanes) and for the 1:4 multiplex drive mode (four LCD backplanes) are shown in Figs 7 and 8 respectively.

（a）WAVEFORMS AT DRIVER
BP2
BP1
BPO
$s_{n+1}$
$S_{n+2}$

（b）RESULTANT WAVEFORMS AT LCD SEGMENT

Fig． 7 Waveforms for 1：3 multiplex drive mode： $\mathrm{V}_{\mathrm{op}}=\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$ ．

LCD drive mode waveforms (continued)


Fig. 8 Waveforms for $1: 4$ multiplex drive mode: $V_{o p}=V_{D D}-V_{L C D}$.

## Oscillator

The internal logic and the LCD drive signals of the PCF8566 or PCF8576 are timed either by the built-in oscillator or from an external clock.
The clock frequency ( ${ }^{\mathrm{C}} \mathrm{CLK}$ ) determines the LCD frame frequency and the maximum rate for data reception from the $1^{2} \mathrm{C}$ bus. To allow $1^{2} \mathrm{C}$ bus transmissions at their maximum data rate of 100 kHz , ${ }^{\mathrm{f}} \mathrm{CLK}$ should be chosen to be above 125 kHz .
A clock signal must alwavs be supplied to the device: removing the clock may freeze the LCD in a d.c. state.

## Internal clock

When the internal oscillator is used, OSC (pin 6) should be tied to $\mathrm{V}_{\mathrm{SS}}$. In this case, the output from CLK (pin 4) provides the clock signal for cascaded PCF8566s and PCF8576s in the system.

## External clock

The condition for external clock is made by tying OSC (pin 6) to VDD; CLK (pin 4) then becomes the external clock input.

## Timing

The timing of the PCF8566 organizes the internal data flow of the device. This includes the transfer of display data from the display RAM to the display segment outputs. In cascaded applications, the synchronization signal SYNC maintains the correct timing relationship between the PCF8566s in the system. The timing also generates the LCD frame frequency which it derives as an integer multiple of the clock frequency (Table 3). The frame frequency is set by MODE SET commands when internal clock is used, or by the frequency applied to pin 4 when external clock is used.

Table 3 LCD frame frequencies

| PCF8566 mode | fframe | nominal $f_{\text {frame }}(\mathrm{Hz})$ |
| :--- | :--- | :---: |
| normal mode | $\mathrm{f}_{\mathrm{CLK}} / 2880$ | 64 |
| power-saving mode | $\mathrm{f}^{\text {CLK/480 }}$ | 64 |

The ratio between the clock frequency and the LCD frame frequency depends on the mode in which: the device is operating. In the power-saving mode the reduction ratio is six times smaller; this allove the clock frequency to be reduced by a factor of six. The reduced clock frequency results in a significant reduction in power dissipation. The lower clock frequency has the disadvantage of increasing the response time when large amounts of display data are transmitted on the $1^{2} \mathrm{C}$ bus. When a device is unable to 'digest' a display data byte before the next one arrives, it holds the SCL line low until the first display data byte is stored. This slows down the transmission rate of the $\mathrm{I}^{2} \mathrm{C}$ bus but no data loss occurs.

## PCF8566

## Display latch

The display latch holds the display data while the corresponding multiplex signals are generated. There is a one-to-one relationship between the data in the display latch, the LCD segment outputs and one column of the display RAM.

## Shift register

The shift register serves to transfer display information from the display RAM to the display latch while previous data are displayed.

## Segment outputs

The LCD drive section includes 24 segment outputs S 0 to S 23 (pins 17 to 40 ) which should be connected directly to the LCD. The segment output signals are generated in accordance with the multiplexed backplane signals and with the data resident in the display latch. When less than 24 segment outputs are required the unused segment outputs should be left open.

## Backplane outputs

The LCD drive section includes four backplane outputs BPO to BP3 which should be connected directly to the LCD. The backplane output signals are generated in accordance with the selected LCD drive mode. If less than four backplane outputs are required the unused outputs can be left open. In the $1: 3$ multiplex drive mode BP3 carries the same signal as BP1, therefore these two adjacent outputs can be tied together to give enhanced drive capabilities. In the $1: 2$ multiplex drive mode BPO and BP2, BP1 and BP3 respectively carry the same signals and may also be paired to increase the drive capabilities. In the static drive mode the same signal is carried by all four backplane outputs and they can be connected in parallel for very high drive requirements.

## Display RAM

The display RAM is a static $24 \times 4$-bit RAM which stores LCD data. A logic 1 in the RAM bit-map indicates the 'on' state of the corresponding LCD segment; similarly, a logic 0 indicates the 'off' state. There is a one-to-one correspondence between the RAM addresses and the segment outputs, and between the individual bits of a RAM word and the backplane outputs. The first RAM column corresponds to the 24 segments operated with respect to backplane BPO (Fig. 9). In multiplexed LCD applications the segment data of the second, third and fourth column of the display RAM are time-multiplexed with $\mathrm{BP} 1, \mathrm{BP} 2$ and BP 3 respectively.


Fig. 9 Display RAM bit-map showing direct relationship between display RAM addresses and segment outputs, and between bits in a RAM word and backplane outputs.

When display data are transmitted to the PCF8566 the display bytes received are stored in the display RAM according to the selected LCD drive mode. To illustrate the filling order, an example of a 7 -segment numeric display showing all drive modes is given in Fig. 10; the RAM filling organization depicted applies equally to other LCD types.

With reference to Fig. 10, in the static drive mode the eight transmitted data bits are placed in bit 0 of eight successive display RAM addresses. In the $1: 2$ multiplex drive mode the eight transmitted data bits are placed in bits 0 and 1 of four successive display RAM addresses. In the $1: 3$ multiplex drive mode these bits are placed in bits 0,1 and 2 of three successive addresses, with i, 2 of the third address left unchanged. This last bit may, if necessary, be controlled by an additional transfer to this address but care should be taken to avoid overriding adjacent data because full bytes are always transmitted. In the $1: 4$ multiplex drive mode the eight transmitted data bits are placed in bits $0,1,2$ and 3 of two successive display RAM addresses.

## Data pointer

The addressing mechanism for the display RAM is realized using the data pointer. This allows the loading of an individual display data byte, or a series of display data bytes, into any location of the display RAM. The sequence commences with the initialization of the data pointer by the LOAD DATA POINTER command. Following this, an arriving data byte is stored starting at the display RAM address indicated by the data pointer thereby observing the filling order shown in Fig. 10. The data pointer is automatically incremented according to the LCD configuration chosen. That is, after each byte is stored, the contents of the data pointer are incremented by eight (static drive mode), by four (1:2 multiplex drive mode), by three ( $1: 3$ multiplex drive mode) or by two (1 : 4 multiplex drive mode).

## Subaddress counter

The storage of display data is conditioned by the contents of the subaddress counter. Storage is allowed to take place only when the contents of the subaddress counter agree with the hardware subaddress applied to A0, A1 and A2 (pins 7, 8, and 9). A0, A1 and A2 should be tied to $V_{S S}$ or VDD. The subaddress counter value is defined by the DEVICE SELECT command. If the contents of the subaddress counter and the hardware subaddress do not agree then data storage is inhibited but the data pointer is incremented as if data storage had taken place. The subaddress counter is also incremented when the data pointer overflows.
The storage arrangements described lead to extremely efficient data loading in cascaded applications. When a series of display bytes are being sent to the display RAM, automatic wrap-over to the next PCF8566 occurs when the last RAM address is exceeded. Subaddressing across device boundaries is successful even if the change to the next device in the cascade occurs within a transmitted character.


Fig. 10 Relationships between LCD layout, drive mode, display RAM filling order

## Output bank selector

This selects one of the four bits per display RAM address for transfer to the display latch. The actual bit chosen depends on the particular LCD drive mode in operation and on the instant in the multiplex sequence. In 1:4 multiplex, all RAM addresses of bit 0 are the first to be selected, these are followed by the contents of bit 1 , bit 2 and then bit 3 . Similarly in $1: 3$ multiplex, bits 0,1 and 2 are selected sequentially. In $1: 2$ multiplex, bits 0 then 1 are selected and, in the static mode, bit 0 is selected.

The PCF8566 includes a RAM bank switching feature in the static and $1: 2$ multiplex drive modes. In the static drive mode, the BANK SELECT command may request the contents of bit 2 to be selected for display instead of bit 0 contents. In the $1: 2$ drive mode, the contents of bits 2 and 3 may be selected instead of bits 0 and 1. This gives the provision for preparing display information in an alternative bank and to be able to switch to it once it is assembled.

## Input bank selector

The input bank selector loads display data into the display RAM according to the selected LCD drive configuration. Display data can be loaded in bit 2 in static drive mode or in bits 2 and 3 in $1: 2$ drive mode by using the BANK SELECT command. The input bank selector functions independently of the output bank selector.

## Blinker

The display blinking capabilities of the PCF8566 are very versatile. The whole display can be blinked at frequencies selected by the BLINK command. The blinking frequencies are integer multiples of the clock frequency; the ratios between the clock and blinking frequencies depend on the mode in which the device is operating, as shown in Table 4.
An additional feature is for an arbitrary selection of LCD segments to be blinked. This applies to the static and 1:2 LCD drive modes and can be implemented without any communication overheads. By means of the output bank selector, the displayed RAM banks are exchanged with alternate RAM banks at the blinking frequency. This mode can also be specified by the BLINK command.
In the 1:3 and 1:4 multiplex modes, where no alternate RAM bank is available, groups of LCD segments can be blinked by selectively changing the display RAM data at fixed time intervals.
If the entire display is to be blinked at a frequency other than the nominal blinking frequency, this can be effectively performed by resetting and setting the display enable bit $E$ at the required rate using the MODE SET command.

Table 4 Blinking frequencies

| blinking mode | normal operating <br> mode ratio | power-saving <br> mode ratio | nominal blinking frequency <br> ${ }^{f}$ blink (Hz) |
| :--- | :--- | :--- | :--- |
| off | - | - | blinking off |
| 2 Hz | ${ }^{\mathrm{f}} \mathrm{CLK} / 92160$ | ${ }^{\mathrm{f}} \mathrm{CLK} / 15360$ | 2 |
| 1 Hz | ${ }^{\mathrm{f}} \mathrm{CLK} / 184320$ | ${ }^{\mathrm{f}} \mathrm{CLK} / 30720$ | 1 |
| $0,5 \mathrm{~Hz}$ | ${ }^{\mathrm{f}} \mathrm{CLK} / 368640$ | ${ }^{\mathrm{f}} \mathrm{CLK} / 61440$ | 0,5 |

## CHARACTERISTICS OF THE $I^{2} \mathrm{C}$ BUS

The $\mathrm{I}^{2} \mathrm{C}$ bus is for 2 -way, 2 -line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 11 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 12 Definition of start and stop conditions.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is a "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 13 System configuration.

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 14 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Note

The general characteristics and detailed specification of the $I^{2} \mathrm{C}$ bus are described in a separate data sheet (serial data buses) in handbook: ICs for digital systems in radio, audio and video equipment.

## PCF8566 $\mathrm{I}^{2} \mathrm{C}$ bus controller

The PCF8566 acts as an $I^{2} \mathrm{C}$ slave receiver. It does not initiate $I^{2} \mathrm{C}$ bus transfers or transmit data to an $1^{2} \mathrm{C}$ master receiver. The only data output from the PCF8566 are the acknowledge signals of the selected devices. Device selection depends on the $1^{2} \mathrm{C}$ bus slave address, on the transferred command data and on the hardware subaddress.
In single device applications, the hardware subaddress inputs AO, A1 and A2 are normally left open or tied to $V_{S S}$ which defines the hardware subaddress 0 . In multiple device applications $A 0, A 1$ and A2 are tied to $V_{S S}$ or VDD according to a binary coding scheme such that no two devices with a common $1^{2} \mathrm{C}$ slave address have the same hardware subaddress.
In the power-saving mode it is possible that the PCF8566 is not able to keep up with the highest transmission rates when large amounts of display data are transmitted. If this situation occurs, the PCF8566 forces the SCL line LOW until its internal operations are completed. This is known as the 'clock synchronization feature' of the $\mathrm{I}^{2} \mathrm{C}$ bus and serves to slow down fast transmitters. Data loss does not occur.

## Input filters

To enhance noise immunity in electrically adverse environments, RC low-pass filters are provided on the SDA and SCL lines.

## $1^{2} \mathrm{C}$ bus protocol

Two $1^{2} \mathrm{C}$ bus slave addresses ( 0111110 and 0111111 ) are reserved for PCF8566. The least-significant bit of the slave address that a PCF8566 will respond to is defined by the level tied at its input SAO (pin 10). Therefore, two types of PCF8566 can be distinguished on the same $\mathrm{I}^{2} \mathrm{C}$ bus which allows:
(a) up to 16 PCF8566s on the same $I^{2} C$ bus for very large LCD applications;
(b) the use of two types of LCD multiplex on the same $I^{2} \mathrm{C}$ bus.

The $I^{2} \mathrm{C}$ bus protocol is shown in Fig. 15. The sequence is initiated with a start condition ( S ) from the $1^{2} \mathrm{C}$ bus master which is followed by one of the two PCF8566 slave addresses available. All PCF8566s with the corresponding SAO level acknowledge in parallel the slave address but all PCF8566s with the alternative SAO level ignore the whole $I^{2} \mathrm{C}$ bus transfer. After acknowledgement, one or more command bytes $(\mathrm{m})$ follow which define the status of the addressed PCF8566s. The last command byte is tagged with a cleared most-significant bit, the continuation bit $C$. The command bytes are also acknowledged by all addressed PCF8566s on the bus.
After the last command byte, a series of display data bytes ( $n$ ) may follow. These display data bytes are stored in the display RAM at the address specified by the data pointer and the subaddress counter. Both data pointer and subaddress counter are automatically updated and the data are directed to the intended PCF8566 device. The acknowledgement after each byte is made only by the (A0, A1, A2) addressed PCF8566. After the last display byte, the $I^{2} \mathrm{C}$ bus master issues a stop condition (P).


Fig. $15 I^{2} \mathrm{C}$ bus protocol.

## Command decoder

The command decoder identifies command bytes that arrive on the $I^{2} \mathrm{C}$ bus. All available commands carry a continuation bit C in their most-significant bit position (Fig. 16). When this bit is set, it indicates that the next byte of the transfer to arrive will also represent a command. If the bit is reset, it indicates the last command byte of the transfer. Further bytes will be regarded as display data.


7291471

Fig. 16 General format of command byte.
The five commands available to the PCF8566 are defined in Table 5.

Command decoder (continued)
Table 5 Definition of PCF8566 commands

DEVELOPMENT DATA


## Display controller

The display controller executes the commands identified by the command decoder. It contains the status registers of the PCF8566 and coordinates their effects. The controller is also responsible for loading display data into the display RAM as required by the filling order.

## Cascaded operation

In large display configurations, up to 16 PCF8566s can be distinguished on the same $I^{2} \mathrm{C}$ bus by using the 3-bit hardware subaddress (A0, A1, A2) and the programmable $I^{2} C$ slave address (SA0). It is also possible to cascade up to 16 PCF8566s. When cascaded, several PCF8566s are synchronized so that they can share the backplane signals from one of the devices in the cascade. Such an arrangement is costeffective in large LCD applications since the backplane outputs of only one device need to be throughplated to the backplane electrodes of the display. The other PCF8566s of the cascade contribute additional segment outputs but their backplane outputs are left open (Fig. 17).

The $\overline{S Y N C}$ line is provided to maintain the correct synchronization between all cascaded PCF8566s. This synchronization is guaranteed after the power-on reset. The only time that $\overline{S Y N C}$ is likely to be needed is if synchronization is accidently lost (e.g. by noise in adverse electrical environments; or by the definition of a multiplex mode when PCF8566s with differing SAO levels are cascaded). $\overline{\text { SYNC }}$ is organized as an input/output pin; the output section being realized as an open-drain driver with an internal pull-up resistor. A PCF8566 asserts the SYNC line at the onset of its last active backplane signal and monitors the SYNC line at all other times. Should synchronization in the cascade be lost, it will be restored by the first PCF8566 to assert SYNC. The timing relationships between the backplane waveforms and the $\overline{S Y} \overline{N C}$ signal for the various drive modes of the PCF8576 are shown in Fig. 18. The waveforms are identical with the parent device PCF8576. Casadability between PCF8566s and PCF8576s is possible, giving cost effective LCD applications.


Fig. 17 Cascaded PCF8566 configuration.


Fig. 18 Synchronization of the cascade for the various PCF8566 drive modes.

For single plane wiring of PCF8566s, see section "APPLICATION INFORMATION".

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

| Supply voltage range; see note | $V_{\text {DD }}$ | $-0,5$ to +7 V |
| :---: | :---: | :---: |
| LCD supply voltage range | $\mathrm{V}_{\text {LCD }}$ | $\mathrm{V}_{\mathrm{DD}}-7$ to $\mathrm{V}_{\mathrm{DD}} \mathrm{V}$ |
| Input voltage range (SCL; SDA; <br> A0 to A2; OSC; CLK; $\overline{\text { SYNC; }}$ SAO) | $v_{1}$ | $\mathrm{V}_{\text {SS }}-0,5$ to $\mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}$ |
| Output voltage range ( S 0 to S 23 ; BPO to BP3) | $\mathrm{V}_{0}$ | $\mathrm{V}_{\text {LCD }}{ }^{-0,5}$ to $\mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}$ |
| D.C. input current | $\pm 1$ | max. 20 mA |
| D.C. output current | $\pm 10$ | max. 25 mA |
| $\mathrm{V}_{\text {DD }}, \mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\text {LCD }}$ current | $\pm \mathrm{I}_{\mathrm{DD}}, \pm \mathrm{I}_{\text {SS }}{ }^{ \pm} \mathrm{I}_{\text {LCD }}$ | max. $\quad 50 \mathrm{~mA}$ |
| Power dissipation per package | $\mathrm{P}_{\text {tot }}$ | max. 400 mW |
| Power dissipation per output | $\mathrm{P}_{\mathrm{O}}$ | max. 100 mW |
| Storage temperature range | $\mathrm{T}_{\text {stg }}$ | -65 to $+150{ }^{\circ} \mathrm{C}$ |

## Note

Inputs and outputs are protected against electrostatic discharges in normal handling. However, to be totally safe, it is advised to take handling precautions appropriate to handling MOS devices (see 'Handling MOS devices').

## D.C. CHARACTERISTICS

$V_{S S}=0 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=3$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{LCD}}=\mathrm{V}_{\mathrm{DD}}-3$ to $\mathrm{V}_{\mathrm{DD}}-6 \mathrm{~V}$;
$T_{a m b}=-40$ to $+85{ }^{\circ} \mathrm{C}$; unless otherwise specified

| parameter | symbol | min . | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Operating supply voltage | VDD | 3 | - | 6 | V |
| LCD supply voltage | VLCD | VDD -6 | - | $V_{D D}-3$ | V |
| Operating supply current (normal mode) at f CLK $=200 \mathrm{kHz}$ (note 1) | IDD | - | - | 180 | $\mu \mathrm{A}$ |
| Power-saving mode supply current at $\mathrm{V}_{\mathrm{DD}}=3,5 \mathrm{~V}$; $\mathrm{V}_{\mathrm{LCD}}=0 \mathrm{~V}$; ${ }^{f} C L K=35 \mathrm{kHz} ; A 0, A 1$ and $A 2$ tied to $\mathrm{V}_{\mathrm{SS}}$ (note 1) | ILP | - | - | 60 | $\mu \mathrm{A}$ |


A.C. CHARACTERISTICS (note 5)
$V_{S S}=0 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=3$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{LCD}}=\mathrm{V}_{\mathrm{DD}}-3$ to $\mathrm{V}_{\mathrm{DD}}-6 \mathrm{~V}$;
$T_{a m b}=-40$ to $+85^{\circ} \mathrm{C}$; unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Oscillator frequency (normal mode) (note 6) | ${ }^{\text {f CLK }}$ | 125 | 200 | 315 | kHz |
| Oscillator frequency (power-saving mode) at $\mathrm{V}_{\mathrm{DD}}=3,5 \mathrm{~V}$ | ${ }^{\text {f CLKLP }}$ | 21 | 31 | 48 | kHz |
| CLK HIGH time | ${ }^{\text {t CLKH }}$ | 1 | - | - | $\mu \mathrm{s}$ |
| CLK LOW time | ${ }^{\text {t CLKL }}$ | 1 | - | - | $\mu \mathrm{s}$ |
| $\overline{\text { SYNC }}$ propagation delay | tpSYNC | - | - | 400 | ns |
| $\overline{\text { SYNC LOW time }}$ | ${ }^{\text {tSYNCL }}$ | 1 | - | - | $\mu \mathrm{s}$ |
| Driver delays with test loads at $\mathrm{V}_{\mathrm{LCD}}=\mathrm{V}_{\mathrm{DD}}-5 \mathrm{~V}$ | tPLCD | - | - | 30 | $\mu \mathrm{S}$ |
| $\mathrm{I}^{2} \mathrm{C}$ bus |  |  |  |  |  |
| Bus free time | tBUF | 4,7 | - | - | $\mu \mathrm{s}$ |
| Start condition hold time | thD; STA | 4 | - | - | $\mu \mathrm{s}$ |
| SCL LOW time | t LOW | 4,7 | - | - | $\mu \mathrm{s}$ |
| SCL HIGH time | thigh | 4 | - | - | $\mu \mathrm{s}$ |
| Start condition set-up time (repeated start code only) | ${ }^{\text {t }}$ SU; STA | 4,7 | - | - | $\mu \mathrm{s}$ |
| Data hold time | thD; DAT | 0 | - | - | $\mu \mathrm{s}$ |
| Data set-up time | tSU; DAT | 250 | - | - | ns |
| Rise time | $\mathrm{t}_{\mathrm{R}}$ | - | - | 1 | $\mu \mathrm{s}$ |
| Fall time | ${ }^{\text {t }}$ F | - | - | 300 | ns |
| Stop condition set-up time | tSU; STO | 4,7 | - | - | $\mu \mathrm{S}$ |

## Notes to characteristics

1. Outputs open; inputs at $\mathrm{V}_{S S}$ or $\mathrm{V}_{\mathrm{DD}}$; external clock with $50 \%$ duty factor; $\mathrm{I}^{2} \mathrm{C}$ bus inactive.
2. Resets all logic when $\mathrm{V}_{\mathrm{DD}}<\mathrm{V}_{\text {REF }}$.
3. Periodically sampled, not $100 \%$ tested.
4. Outputs measured one at a time.
5. All timing values referred to $\mathrm{V}_{\mathrm{IH}}$ and $\mathrm{V}_{\mathrm{IL}}$ levels with an input voltage swing of $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\text {DD }}$.
6. At $\mathrm{f}_{\mathrm{CLK}}<125 \mathrm{kHz}, \mathrm{I}^{2} \mathrm{C}$ bus maximum transmission speed is derated.


Fig. 19 Test loads.

DEVELOPMENT DATA


Fig. 20 Driver timing waveforms.


Fig. $21 \mathrm{I}^{2} \mathrm{C}$ bus timing waveforms.


Fig. 23 Typical characteristics of LCD outputs.


Fig. 24 Single plane wiring of packaged PCF8566s.

## $256 \times 8$-BIT STATIC RAM

## GENERAL DESCRIPTION

The PCF8570 is a low power 2048-bit static CMOS RAM organized as 256 words by 8 -bits. Addresses and data are transferred serially via a two-line bidirectional bus $\left(I^{2} \mathrm{C}\right)$. The built-in word address register is incremented automatically after each written or read data byte. Three address pins A0, A1, A2 are used for programming the hardware address, allowing the use of up to eight devices connected to the bus without additional hardware.

## Features

- Operating supply voltage
- Low data retention voltage
- Low standby current
- Power saving mode

2,5 V to 6 V
min. $1,0 \mathrm{~V}$
max. $15 \mu \mathrm{~A}$
typ. 50 nA

- Serial input/output bus ( $1^{2} \mathrm{C}$ )
- Address by 3 hardware address pins
- Automatic word address incrementing
- 8-lead DIL package


## Applications

- Telephony
- Radio and television
- Video cassette recorder
- General purpose

RAM expansion for stored numbers in repertory dialling (e.g. PCD3343 applications) channel presets

RAM expansion for the microcontroller families MAB8400 and PCF84C00


Fig. 1 Block diagram.

## PACKAGE OUTLINES

PCF8570P: 8-lead DIL; plastic (SOT-97AE).
PCF8570T: 8-lead mini-pack plastic (SO-8L; SOT-176).

## PINNING

| 1 to 3 | A0 to A2 | address inputs |
| :--- | :--- | :--- |
| 4 | VSS | negative supply <br> 5 |
| SDA serial data line <br> 6 SCL | serial clock line$I^{2} \mathrm{C}$ bus |  |
| 7 | TEST | test input for test speed-up; must be connected to $V_{\text {SS }}$ when not in use <br> (power saving mode, see Figs 14 and 15) |
| 8 | Vositive supply |  |



Fig. 2 Pinning diagram.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage range (pin 8)
Voltage range on any input
D.C. input current (any input)
D.C. output current (any output)

Supply current (pin 4 or pin 8)
Power dissipation per package
Power dissipation per output
Storage temperature range
Operating ambient temperature range

| $V_{D D}$ | $-0,8$ to $+8,0 \mathrm{~V}$ |  |
| :--- | ---: | ---: |
| $\mathrm{~V}_{\mathrm{I}}$ | $-0,8$ to $\mathrm{V}_{\mathrm{DD}}+0,8 \mathrm{~V}$ |  |
| $\pm \mathrm{I}_{\mathrm{I}}$ | max. | 10 mA |
| $\pm \mathrm{I}_{\mathrm{O}}$ | max. | 10 mA |
| $\pm \mathrm{I}_{\mathrm{DD}} ; \mathrm{I}_{\mathrm{SS}}$ | max. | 50 mA |
| $\mathrm{P}_{\text {tot }}$ | max. | 300 mW |
| P | max. | 50 mW |
| $\mathrm{~T}_{\text {stg }}$ |  | -65 to $+150{ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {amb }}$ |  | -40 to $+85^{\circ} \mathrm{C}$ |

## CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | symbol | min . | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply |  |  |  |  |  |
| Supply voltage | $\mathrm{V}_{\text {DD }}$ | 2,5 | - | 6 | V |
| Supply current at |  |  |  |  |  |
| $\begin{aligned} & V_{1}=V_{S S} \text { or } V_{D D} \\ & \text { operating at } f_{S C L}=100 \mathrm{kHz} \end{aligned}$ | IDD | - | - | 200 | $\mu \mathrm{A}$ |
| standby at $\mathrm{f}_{\text {SCL }}=0 \mathrm{~Hz}$ | IDDO | - | - | 15 | $\mu \mathrm{A}$ |
| standby at T amb $=-25$ to $+70^{\circ} \mathrm{C}$ | IDDO | - | - | 5 | $\mu \mathrm{A}$ |
| Power-on reset voltage level* | VPOR | 1,5 | 1,9 | 2,3 | V |
| Inputs; input/output SDA |  |  |  |  |  |
| Input voltage LOW** | $\mathrm{V}_{\text {IL }}$ | -0,8 | - | $0,3 \times V_{\text {DD }}$ | V |
| Input voltage HIGH** | $\mathrm{V}_{\text {IH }}$ | $0,7 \times V_{D D}$ | - | $V_{D D}+0,8$ | V |
| Output current LOW at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | ${ }^{1} \mathrm{OL}$ | 3 | - | - | mA |
| Output leakage current HIGH at $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{DD}}$ | ${ }^{1} \mathrm{OH}$ | - | - | 250 | nA |
| Input leakage current at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ | $\pm 1$ | - | - | 250 | nA |
| Clock frequency (Fig. 7) | ${ }^{\text {f SCL }}$ | 0 | - | 100 | kHz |
| Input capacitance (SCL, SDA) at $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{SS}}$ | $\mathrm{C}_{1}$ | - | - | 7 | pF |
| Tolerable spike width on bus | ${ }^{\text {t }}$ W | - | - | 100 | ns |
| LOW $V_{\text {DD }}$ data retention |  |  |  |  |  |
| Supply voltage for data retention | $V_{\text {DDR }}$ | 1 | - | 6 | V |
| Supply current at $\mathrm{V}_{\text {DDR }}=1 \mathrm{~V}$ | IDDR | - | - | 5 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Supply current at } V_{D D R}=1 \mathrm{~V} ; \\ & T_{\text {amb }}=-25 \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ | ${ }^{\prime}$ DDR | - | - | 2 | $\mu \mathrm{A}$ |
| Power saving mode (Figs 14 and 15) |  |  |  |  |  |
| Supply current at $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$; TEST $=V_{\text {DDR }}$ | ${ }^{\prime}$ DDR | - | 50 | 400 | nA |

* The power-on reset circuit resets the $I^{2} \mathrm{C}$ bus logic when $\mathrm{V}_{\mathrm{DD}}<\mathrm{V}_{\text {POR }}$.
** If the input voltages are a diode voltage above or below the supply voltage $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ an input current will flow; this current must not exceed $\pm 0,5 \mathrm{~mA}$.


## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ BUS

The I ${ }^{2} \mathrm{C}$ bus is for 2 -way, 2 -line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 3 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 4 Definition of start and stop conditions.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 5 System configuration.

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set-up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 6 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Timing specifications

Within the $I^{2} \mathrm{C}$ bus specifications a high-speed mode and a low-speed mode are defined. The device operates in both modes and the timing requirements are as follows:

## High-speed mode

Masters generate a bus clock with a maximum frequency of 100 kHz . Detailed timing is shown in Fig. 7.


Fig. 7 Timing of the high-speed mode.
Where:

| tBUF | $t \geqslant t_{\text {LOWmin }}$ | The minimum time the bus must be free before a new transmission can start |
| :---: | :---: | :---: |
| thD; STA | $\mathrm{t} \geqslant \mathrm{t}$ HIGHmin | Start condition hold time |
| ${ }_{\text {t }}$ LOW min | $4,7 \mu \mathrm{~s}$ | Clock L.OW period |
| thighmin | $4 \mu \mathrm{~s}$ | Clock HIGH period |
| ${ }^{\text {t }}$ SU; STA | $t \geqslant t_{\text {LOWmin }}$ | Start condition set-up time, only valid for repeated start code |
| ${ }^{\text {thD }}$; DAT | $\mathrm{t} \geqslant 0 \mu \mathrm{~s}$ | Data hold time |
| ${ }^{\text {t }}$ SU; DAT | $t \geqslant 250 \mathrm{~ns}$ | Data set-up time |
| ${ }_{\text {t }} \mathrm{R}$ | $\mathrm{t} \leqslant 1 \mu \mathrm{~s}$ | Rise time of both the SDA and SCL line |
| ${ }^{\text {t }}$ F | $t \leqslant 300 \mathrm{~ns}$ | Fall time of both the SDA and SCL line |
| tSU; STO | $\mathrm{t} \geqslant \mathrm{t}_{\text {LOW }}$ min | Stop condition set-up time |

## Note

All the timing values refer to $\mathrm{V}_{\mathrm{IH}}$ and $\mathrm{V}_{\mathrm{IL}}$ levels with a voltage swing of $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{DD}}$.


Fig. 8 Complete data transfer in the high-speed mode.
Where:

| Clock t LOWmin | $4,7 \mu \mathrm{~s}$ |
| :---: | :--- |
| tHIGHmin | $4 \mu \mathrm{~s}$ |

The dashed line is the acknowledgement of the receiver

Mark-to-space ratio
Max. number of bytes
Premature termination of transfer
Acknowledge clock bit

1:1 (LOW-to-HIGH)
unrestricted
allowed by generation of STOP condition
must be provided by the master

## Low-speed mode

Masters generate a bus clock with a maximum frequency of 2 kHz ; a minimum LOW period of $105 \mu \mathrm{~s}$ and a minimum HIGH period of $365 \mu$ s. The mark-to-space ratio is $1: 3$ LOW-to-HIGH. Detailed timing is shown in Fig. 9.


Fig. 9 Timing of the low-speed mode.

Timing specifications (continued)
Where:

| tbuF | $t \geqslant 105 \mu \mathrm{~s}$ ( t LOWmin) |
| :---: | :---: |
| thD; STA | $t \geqslant 365 \mu$ ( $\mathrm{t}_{\text {HIGHmin }}$ ) |
| t LOW | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| thigh | $390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| tsu; STA | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ * |
| thD; DAT | $\mathrm{t} \geqslant 0 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ SU; DAT | $t \geqslant 250 \mathrm{~ns}$ |
| ${ }_{\text {tR }}$ | $\mathrm{t} \leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ F | $\mathrm{t} \leqslant 300 \mathrm{~ns}$ |
| ${ }^{\text {tsu }}$; STO | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |

## Note

All the timing values refer to $\mathrm{V}_{I H}$ and $\mathrm{V}_{I L}$ levels with a voltage swing of $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{DD}}$. For definitions see high-speed mode.


Fig. 10 Complete data transfer in the low-speed mode.
Where:

| Clock tLOWmin | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| :--- | :--- |
| ${ }^{\text {tHIGHmin }}$ | $390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| Mark-to-space ratio | $1: 3$ (LOW-to-HIGH) |
| Start byte | 00000001 |
| Max. number of bytes | 6 |
| Premature termination of transfer | not allowed |
| Acknowledge clock bit | must be provided by master |
| Note |  |

The general characteristics and detailed specification of the $\mathrm{I}^{2} \mathrm{C}$ bus are described in a separate data sheet (serial data buses) in handbook "ICs for digital systems in radio, audio and video equipment".

[^26]
## Bus protocol

Before any data is transmitted on the $I^{2} \mathrm{C}$ bus, the device which should respond is addressed first. The addressing is always done with the first byte transmitted after the start procedure. The $I^{2} \mathrm{C}$ bus configuration for different PCF8570 READ and WRITE cycles is shown in Fig. 11.


Fig. 11(a) Master transmits to slave receiver (WRITE mode).


Fig. 11(b) Master reads after setting word address (WRITE word address; READ data).


Fig. 11(c) Master reads slave immediately after first byte (READ mode).

## APPLICATION INFORMATION

The PCF8570 slave address has a fixed combination 1010 as group 1 , while group 2 is fully programmable (see Fig. 12).

| 1 | 0 | 1 | 0 | $A 2$ | $A 1$ | $A 0$ | $R / \bar{W}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | group $1 \longrightarrow$ group $2 \longrightarrow$ | 7287030.1 |  |  |  |  |  |

Fig. 12 PCF8570 address.


Fig. 13 PCF8570 application diagram.

## Note

$\mathrm{A} 0, \mathrm{~A} 1$, and A 2 inputs must be connected to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ but not left open.

## POWER SAVING MODE

With the condition TEST = V ${ }_{\text {DDR }}$, the PCF8570 goes into the power saving mode and the $1^{2} \mathrm{C}$ bus logic is reset.


Where:
${ }^{\mathrm{t}} \mathrm{SU} \geqslant 4 \mu \mathrm{~s}$
Fig. 14 Timing for power saving mode.
$\mathrm{t}_{\mathrm{HD}} \geqslant 4 \mu \mathrm{~s}$


Fig. 15 Application example for power saving mode.

## Note to Fig. 15

1. In the operating mode, TEST $=0$.
2. In the power saving mode, TEST $=\mathrm{V}_{\text {DDR }}$.

Purchase of Philips' $I^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specification defined by Philips.

## $128 \times 8$-BIT STATIC RAM

## GENERAL DESCRIPTION

The PCF8571 is a low power 1024 -bit static CMOS RAM organized as 128 words by 8 -bits. Addresses and data are transferred serially via a two-line bidirectional bus ( $1^{2} \mathrm{C}$ ). The built-in word address register is incremented automatically after each written or read data byte. Three address pins A0, A1, A2 are used for programming the hardware address, allowing the use of up to eight devices connected to the bus without additional hardware.

## Features

- Operating supply voltage
- Low data retention voltage
- Low standby current
- Power saving mode
$2,5 \mathrm{~V}$ to 6 V
$\min .1,0 \mathrm{~V}$
max. $5 \mu \mathrm{~A}$
typ. 50 nA
- Serial input/output bus ( $\left.I^{2} \mathrm{C}\right)$
- Address by 3 hardware address pins
- Automatic word address incrementing
- 8-lead DIL package


## Applications

- Telephony
- Radio and television
- Video cassette recorder
- General purpose

RAM expansion for stored numbers in repertory dialling (e.g. PCD3340 applications) channel presets

RAM expansion for the microcomputer families MAB8400 and PCF84C00


## PACKAGE OUTLINES

Fig. 1 Block diagram.
PCF8571P : 8-lead DIL; plastic (SOT-97AE).
PCF8571D : 8-lead DIL; ceramic (cerdip) (SOT-151A).
PCF8571T : 8-lead mini-pack (SO-8L; SOT-176).

## PINNING

| 1 to 3 | A0 to A2 | address inputs |
| :---: | :---: | :---: |
| 4 | $\mathrm{V}_{\text {SS }}$ | negative supply |
| 5 | SDA | serial data line $1^{2} \mathrm{C}$ bus |
| 6 | SCL | serial clock line ${ }^{2} \mathrm{C}$ bus |
| 7 | TEST | test input for test speed-up; must be connected to $\mathrm{V}_{\text {SS }}$ when not in use (power saving mode, see Fig. 14 and 15) |
| 8 | $V_{\text {DD }}$ | positive supply |



Fig. 2 Pinning diagram.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)


## CHARACTERISTICS

$V_{D D}=2,5$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SUPPLY |  |  |  |  |  |
| Supply voltage | $V_{\text {DD }}$ | 2,5 | - | 6 | V |
| Supply current |  |  |  |  |  |
| $\begin{aligned} & V_{1}=V_{S S} \text { or } V_{D D} \\ & \text { operating at } f_{S C L}=100 \mathrm{kHz} ; \end{aligned}$ | ${ }^{\text {I D D }}$ | - | - | 200 | $\mu \mathrm{A}$ |
| standby at $\mathrm{f}_{\text {SCL }}=0 \mathrm{~Hz}$ | IDDO | - | - | 15 | $\mu \mathrm{A}$ |
| standby at $\mathrm{T}_{\text {amb }}=-25$ to $70{ }^{\circ} \mathrm{C}$ | 'DDO | - | - | 5 | $\mu \mathrm{A}$ |
| Power-on reset voltage level at $\mathrm{V}_{\mathrm{SCL}}=\mathrm{V}_{\mathrm{SDA}}=\mathrm{V}_{\mathrm{DD}}$ | $V_{\text {POR }}$ | 1,5 | 1,9 | 2,3 | V |
| Inputs; input/output SDA |  |  |  |  |  |
| Input voltage LOW** | $V_{\text {IL }}$ | -0,8 | - | $0,3 \times V_{D D}$ | V |
| Input voltage HIGH** | $V_{\text {IH }}$ | $0,7 \times V_{\text {DD }}$ | - | $V_{D D}+0,8$ | V |
| Output current LOW at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | ${ }^{1} \mathrm{OL}$ | 3 | - | - | mA |
| Output leakage current HIGH at $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{DD}}$ | ${ }^{1} \mathrm{OH}$ | - | - | 250 | nA |
| Input leakage current at $V_{1}=V_{D D}$ or $V_{S S}$ | $\pm 11$ | - | - | 250 | nA |
| Clock frequency (Fig. 7) | ${ }^{\text {f SCL }}$ | 0 | - | 100 | kHz |
| Input capacitance (SCL, SDA) at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ | $\mathrm{Cl}_{1}$ | - | - | 7 | pF |
| Tolerable spike width on bus | ${ }^{\text {tsw }}$ | - | - | 100 | ns |
| LOW $\mathrm{V}_{\mathrm{DD}}$ data retention |  |  |  |  |  |
| Supply voltage for data retention | $V_{\text {DDR }}$ | 1 | - | 6 | V |
| Supply current at $\mathrm{V}_{\text {DDR }}=1 \mathrm{~V}$ | ${ }^{\prime}$ DDR | - | - | 5 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Supply current at } V_{D D R}=1 \mathrm{~V} ; \\ & T_{a m b}=-25 \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ | ${ }^{\prime}$ DDR | - | - | 2 | $\mu \mathrm{A}$ |
| Power saving mode (Fig. 14) |  |  |  |  |  |
| Supply current at $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$; TEST $=V_{\text {DDR }}$ | ${ }^{\prime}$ DDS | - | 50 | 200 | nA |

* The power-on reset circuit resets the $I^{2} \mathrm{C}$ bus logic when $\mathrm{V}_{\mathrm{DD}}<\mathrm{V}_{\mathrm{POR}}$.
** If the input voltages are a diode voltage above or below the supply voltage $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ an input current will flow: this current must not exceed $\pm 0,5 \mathrm{~mA}$.


## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ BUS

The $I^{2} \mathrm{C}$ bus is for 2-way, 2-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 3 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 4 Definition of start and stop conditions.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 5 System configuration.

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set-up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 6 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Timing specifications

Within the $I^{2} \mathrm{C}$ bus specifications a high-speed mode and a low-speed mode are defined. The PCF8571 operates in both modes and the timing requirements are as follows:

## High-speed mode

Masters generate a bus clock with a maximum frequency of 100 kHz . Detailed timing is shown in Fig. 7.


Fig. 7 Timing of the high-speed mode.
Where:

| ${ }^{\text {t BUF }}$ | $t \geqslant t_{\text {LOWmin }}$ | The minimum time the bus must be free before a new transmission can start |
| :---: | :---: | :---: |
| ${ }^{\text {thD }}$; STA | $\mathrm{t} \geqslant \mathrm{t}$ HIGHmin | Start condition hold time |
| ${ }^{\text {t LOWmin }}$ | $4,7 \mu \mathrm{~s}$ | Clock LOW period |
| ${ }_{\text {thighmin }}$ | $4 \mu \mathrm{~s}$ | Clock HIGH period |
| ${ }^{\text {t SU }}$; STA | $t \geqslant t_{\text {LOWmin }}$ | Start condition set-up time, only valid for repeated start code |
| ${ }^{\text {t HD }}$; DAT | $t \geqslant 0 \mu \mathrm{~s}$ | Data hold time |
| ${ }^{\text {t }}$ SU; DAT | $\mathrm{t} \geqslant 250 \mathrm{~ns}$ | Data set-up time |
| $t_{r}$ | $t \leqslant 1 \mu \mathrm{~s}$ | Rise time of both the SDA and SCL line |
| $\mathrm{t}_{\mathrm{f}}$ | $t \leqslant 300 \mathrm{~ns}$ | Fall time of both the SDA and SCL line |
| ${ }^{\text {tSU }}$; STO | $t \geqslant t_{\text {LOWmin }}$ | Stop condition set-up time |

## Note

All the timing values refer to $V_{I H}$ and $V_{I L}$ levels with a voltage swing of $V_{S S}$ to $V_{D D}$.


Fig. 8 Complete data transfer in the high-speed mode.
Where:

| Clock t LOWmin | $4,7 \mu \mathrm{~s}$ |
| :---: | :--- |
| t HIGHmin | $4 \mu \mathrm{~s}$ |

The dashed line is the acknowledgement of the receiver

Mark-to-space ratio
Max. number of bytes
Premature termination of transfer
Acknowledge clock bit

1:1 (LOW-to-HIGH)
unrestricted
allowed by generation of STOP condition
must be provided by the master

## Low-speed mode

Masters generate a bus clock with a maximum frequency of 2 kHz ; a minimum LOW period of $105 \mu \mathrm{~s}$ and a minimum HIGH period of $365 \mu$ s. The mark-to-space ratio is $1: 3$ LOW-to-HIGH. Detailed timing is shown in Fig. 9.


Fig. 9 Timing of the low-speed mode.

Timing specifications (continued)
Where:

| tBUF | $\mathrm{t} \geqslant 105 \mu \mathrm{~s}$ ( $\mathrm{t}_{\text {LOWmin }}$ ) |
| :---: | :---: |
| tHD; STA | $\mathrm{t} \geqslant 365 \mu \mathrm{~s}\left(\mathrm{t}_{\mathrm{HIGHmin}}\right)$ |
| tLOW | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| ${ }^{\text {tHIGH }}$ | $390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| ${ }^{\text {t SU; STA }}$ | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ * |
| ${ }^{\text {tHD }}$; DAT | $\mathrm{t} \geqslant 0 \mathrm{~s}$ |
| ${ }^{\text {t }}$ SU; DAT | $\mathrm{t} \geqslant 250 \mathrm{~ns}$ |
| $t_{r}$ | $t \leqslant 1 \mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{f}}$ | $\mathrm{t} \leqslant 300 \mathrm{~ns}$ |
| ${ }^{\text {t }}$ SU; STO | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |

## Note

All the timing values refer to $V_{I H}$ and $V_{I L}$. levels with a voltage swing of $V_{S S}$ to $V_{D D}$. For definitions see high-speed mode.


Fig. 10 Complete data transfer in the low-speed mode.

Where:

Clock thowmin
${ }^{\mathrm{t}} \mathrm{HIGHmin}$
Mark-to-space ratio
Start byte
Max. number of bytes
Premature termination of transfer
Acknowledge clock bit
$130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$
$390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$
1:3 (LOW-to-HIGH)
00000001
6
not allowed
must be provided by master

## Note

The general characteristics and detailed specification of the $I^{2} \mathrm{C}$ bus are described in a separate data sheet (serial data buses) in handbook "ICs for digital systems in radio, audio and video equipment".

[^27]
## Bus protocol

Before any data is transmitted on the $I^{2} \mathrm{C}$ bus, the device which should respond is addressed first. The addressing is always done with the first byte transmitted after the start procedure. The $I^{2} \mathrm{C}$ bus configuration for different PCF8571 READ and WRITE cycles is shown in Fig. 11.


Fig. 11(a) Master transmits to slave receiver (WRITE mode).


Fig. 11(b) Master reads after setting word address (WRITE word address; READ data).


Fig. 11(c) Master reads slave immediately after first byte (READ mode).

## Note

$$
X=\text { don't care bit. }
$$

## APPLICATION INFORMATION

The PCF8571 slave address has a fixed combination 1010 as group 1 , while group 2 is fully programmable (see Fig. 12).

| 1 | 0 | 1 | 0 | $A 2$ | $A 1$ | $A 0$ | $R / \bar{W}$ |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: |
|  | group $1 \longrightarrow$ group $2 \longrightarrow$ | 7287030.1 |  |  |  |  |  |

Fig. 12 PCF8571 address.


Fig. 13 PCF8571 application diagram.

## Note

A0, A1, and A2 inputs must be connected to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\text {SS }}$ but not left open.

## POWER SAVING MODE

With the condition TEST $=\mathrm{V}_{\text {DDR }}$, the PCF8571 goes into the power saving mode and $\mathrm{I}^{2} \mathrm{C}$ bus logic is reset.


Where:
${ }^{\mathrm{t}} \mathrm{SU} \geqslant 4 \mu \mathrm{~s}$
$\mathrm{t}_{\mathrm{HD}} \geqslant 4 \mu \mathrm{~s}$
Fig. 14 Timing for power saving mode.


Fig. 15 Application example for power saving mode.

## Note

1. In the operating mode, TEST $=0$.
2. In the power saving mode, TEST $=V_{\text {DDR }}$.


Purchase of Philips' $I^{2} \mathrm{C}$ components conveys a license under the Philips $I^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specifications defined by Philips.

## CLOCK/CALENDAR WITH SERIAL I/O

## GENERAL DESCRIPTION

The PCF8573 is a low threshold, monolithic CMOS circuit that functions as a real time clock/calendar in the Inter IC ( $\left.I^{2} \mathrm{C}\right)$ bus-oriented microcomputer systems. The device includes an addressable time counter and an addressable alarm register, both for minutes, hours, days and months. Three special control/status flags, COMP, POWF and NODA, are also available. Information is transferred serially via a two line bidirectional bus ( $\left.1^{2} \mathrm{C}\right)$. Back-up for the clock during supply interruptions is provided by a $1,2 \mathrm{~V}$ nickel cadmium battery. The time base is generated from a $32,768 \mathrm{kHz}$ crystal-controlled oscillator.

## Features

- Serial input/output bus ( $I^{2} \mathrm{C}$ ) interface for minutes, hours, days and months
- Additional pulse outputs for seconds and minutes
- Alarm register for presetting a time for alarm or remote switching functions
- Battery back-up for clock function during supply interruption
- Crystal oscillator control $(32,768 \mathrm{kHz})$

QUICK REFERENCE DATA

| Supply voltage range (clock) | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 1}$ | 1,1 to $6,0 \mathrm{~V}$ |  |
| :--- | :--- | ---: | ---: |
| Supply voltage range ( $1^{2} \mathrm{C}$ interface) | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}$ | 2,5 to $6,0 \mathrm{~V}$ |  |
| Crystal oscillator frequency | $\mathrm{f}_{\mathrm{OSC}}$ | typ. | $32,768 \mathrm{kHz}$ |

## PACKAGE OUTLINES

PCF8573P: 16-lead DIL; plastic (SOT-38).
PCF8573T: 16 -lead mini-pack; plastic (SO-16L; SOT-162A).


Fig. 1 Block diagram.

## PINNING



Fig. 2 Pinning diagram.

| 1 | A0 | address input |
| :---: | :---: | :---: |
| 2 | A1 | address input |
| 3 | COMP | comparator output |
| 4 | SDA | serial data line $\\|^{12} \mathrm{C}$ bus |
| 5 | SCL | serial clock line |
| 6 | EXTPF | enable power fail flag input |
| 7 | PFIN | power fail flag input |
| 8 | $\mathrm{V}_{\text {SS2 }}$ | negative supply $2\left(I^{2} \mathrm{C}\right.$ interface) |
| 9 | MIN | one pulse per minute output |
| 10 | SEC | one pulse per second output |
| 11 | FSET | oscillator tuning output |
| 12 | TEST | test input; must be connected to $\mathrm{V}_{\mathrm{SS} 2}$ when not in use |
| 13 | OSCI | oscillator input |
| 14 | OSCO | oscillator input/output |
| 15 | $\mathrm{V}_{\text {SS1 }}$ | negative supply 1 (clock) |
| 16 | $\mathrm{V}_{\text {DD }}$ | common positive supply |

## FUNCTIONAL DESCRIPTION

## Oscillator

The PCF8573 has an integrated crystal-controlled oscillator which provides the timebase for the prescaler. The frequency is determined by a single $32,768 \mathrm{kHz}$ crystal connected between OSCl and OSCO. A trimmer is connected between OSCl and $V_{\text {DD }}$.

## Prescaler and time counter

The prescaler provides a 128 Hz signal at the FSET output for fine adjustment of the crystal oscillator without loading it. The prescaler also generates a pulse once a second to advance the seconds counter. The carry of the prescaler and the seconds counter are available at the outputs SEC, MIN respectively, and are also readable via the $I^{2} \mathrm{C}$ bus. The mark-to-space ratio of both signals is $1: 1$. The time counter is advanced one count by the falling edge of output signal MIN. A transition from HIGH to LOW of output signal SEC triggers MIN to change state. The time counter counts minutes, hours, days and months, and provides a full calendar function which needs to be corrected once every four years. Cycle lengths are shown in Table 1.

Table 1 Cycle length of the time counter

| unit | number of bits | counting cycle | carry for following unit | content of month counter |
| :---: | :---: | :---: | :---: | :---: |
| minutes hours days | 766 | 00 to 59 | $59 \rightarrow 00$ |  |
|  |  | 00 to 23 | $23 \rightarrow 00$ |  |
|  |  | 01 to 28 | $28 \rightarrow 01$ |  |
|  |  |  | or $29 \rightarrow 01$ | 2 (see note) |
|  |  | 01 to 30 | $30 \rightarrow 01$ | 4, 6, 9, 11 |
|  |  | 01 to 31 | $31 \rightarrow 01$ | 1, 3, 5, 7, 8, 10, 12 |
| months | 5 | 01 to 12 | $12 \rightarrow 01$ |  |

Note: Day counter may be set to 29 by a write transmission with EXECUTE ADDRESS.

## Alarm register

The alarm register is a 24 -bit memory. It stores the time-point for the next setting of the status flag COMP. Details of writing and reading of the alarm register are included in the description of the characteristics of the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Comparator

The comparator compares the contents of the alarm register and the time counter, each with a length of 24 bits. When these contents are equal the flag COMP will be set 4 ms after the falling edge of MIN. This set condition occurs once at the beginning of each minute. This information is latched, but can be cleared by an instruction via the $I^{2} \mathrm{C}$ bus. A clear instruction may be transmitted immediately after the flag is set and will be executed. Flag COMP information is also available at the output COMP. The comparison may be based upon hours and minutes only if the internal flag NODA (no date) is set. Flag NODA can be set and cleared by separate instructions via the $I^{2} \mathrm{C}$ bus, but it is undefined until the first set or clear instruction has been received. Both COMP and NODA flags are readable via the $1^{2} \mathrm{C}$ bus.

## FUNCTIONAL DESCRIPTION (continued)

## Power on/power fail detection

If the voltage $V_{D D}-V_{S S 1}$ falls below a certain value the operation of the clock becomes undefined. Thus a warning signal is required to indicate that faultless operation of the clock is not guaranteed. This information is latched in a flag called POWF (Power Fail) and remains latched after restoration of the correct supply voltage until a write procedure with EXECUTE ADDRESS has been received. The flag POWF can be set by an internally generated power fail level-discriminator signal for application with ( $V_{D D}-V_{S S 1}$ ) greater than $V_{T H 1}$, or by an externally generated power fail signal for application with ( $V_{D D}-V_{S S 1}$ ) less than $V_{T H 1}$. The external signal must be applied to the input PFIN. The input stage operates with signals of any slow rise and fall times. Internally or externally controlled POWF can be selected by input EXTPF as shown in Table 2.

Table 2 Power fail selection

| EXTPF | PFIN | function |
| :---: | :---: | :--- |
| 0 | 0 | power fail is sensed internally |
| 0 | 1 | test mode |
| 1 | 0 | power fail is sensed externally |
| 1 | 1 | no power fail sensed |

0 : connected to $\mathrm{V}_{\mathrm{SS} 1}$ (LOW)
1 : connected to $\mathrm{V}_{\text {DD }}$ (HIGH)
The external power fail control operates by absence of the $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}$ supply. Therefore the input levels applied to PFIN and EXTPF must be within the range of $\mathrm{V}_{\mathrm{DD}}{ }^{-V_{S S 1}}$. A LOW level at PFIN indicates a power fail. POWF is readable via the $I^{2} \mathrm{C}$ bus. A power on reset for the $I^{2} \mathrm{C}$ bus control is generated on-chip when the supply voltage $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}$ is less than $\mathrm{V}_{\mathrm{TH}}$.

## Interface level shifters

The level shifters adjust the 5 V operating voltage ( $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}$ ) of the microcontroller to the internal supply voltage ( $V_{D D}-V_{S S 1}$ ) of the clock/calendar. The oscillator and counter are not influenced by the $V_{D D}-V_{S S 2}$ supply voltage. If the voltage $V_{D D}-V_{S S 2}$ is absent $\left(V_{S S 2}=V_{D D}\right)$ the output signal of the level shifter is HIGH because $V_{D D}$ is the common node of the $V_{D D}-V_{S S 2}$ and the $V_{D D}-V_{S S 1}$ supplies. Because the level shifters invert the input signal, the internal circuit behaves as if a LOW signal is present on the inputs. FSET, SEC, MIN and COMP are CMOS push-pull output stages. The driving capability of these outputs is lost when the supply voltage $V_{D D}-V_{S S 2}=0$.

## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ BUS

The $\mathrm{I}^{2} \mathrm{C}$ bus is for 2-way, 2-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer (see Fig. 3)

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 3 Bit transfer.

## Start and stop conditions (see Fig. 4)

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 4 Definition of start and stop conditions.

## System configuration (see Fig. 5)

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 5 System configuration.

## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ bus (continued)

## Acknowledge (see Fig. 6)

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition. (See Fig. 13 and Fig. 14.)


Fig. 6 Acknowledgement on the $I^{2} \mathrm{C}$ bus.

## Timing specifications

Within the $I^{2} \mathrm{C}$ bus specifications a high-speed mode and a low-speed mode are defined. The PCF8573 operates in both modes and the timing requirements are as follows:

## High-speed mode

Masters generate a bus clock with a maximum frequency of 100 kHz . Detailed timing is shown in Fig. 7.


Fig. 7 Timing of the high-speed mode.

Where:

| tBUF | $t \geqslant t_{\text {LOW }}$ min | The minimum time the bus must be free before a new transmission can start |
| :---: | :---: | :---: |
| ${ }^{\text {t HD }}$; STA | $\mathrm{t} \geqslant \mathrm{t}$ HIGHmin | Start condition hold time |
| ${ }^{\text {t LOW min }}$ | $4,7 \mu \mathrm{~s}$ | Clock LOW period |
| ${ }^{\text {thighmin }}$ | $4 \mu \mathrm{~s}$ | Clock HIGH period |
| ${ }^{\text {t SU }}$; STA | $t \geqslant t_{\text {LOW }}$ min | Start condition set-up time, only valid for repeated start code |
| thD; DAT | $t \geqslant 0 \mu \mathrm{~s}$ | Data hold time |
| ${ }^{\text {t }}$ SU; DAT | $t \geqslant 250 \mathrm{~ns}$ | Data set-up time |
| ${ }^{\text {t } R}$ | $t \leqslant 1 \mu \mathrm{~s}$ | Rise time of both the SDA and SCL line |
| ${ }^{\text {t }}$ F | $\mathrm{t} \leqslant 300 \mathrm{~ns}$ | Fall time of both the SDA and SCL line |
| ${ }^{\text {t SU; STO }}$ | $t \geqslant t_{\text {LOW }}$ min | Stop condition set-up time |

## Note

All the values refer to $V_{I H}$ and $V_{I L}$ levels with a voltage swing of $V_{D D}$ to $V_{S S 2}$.


Fig. 8 Complete data transfer in the high-speed mode.
Where:

Clock thowmin
${ }^{t}$ HIGHmin
$4,7 \mu \mathrm{~s}$
$4 \mu \mathrm{~s}$

The dashed line is the acknowledgement of the receiver

Mark-to-space ratio
Max. number of bytes
Premature termination of transfer
Acknowledge clock bit

1:1 (LOW-to-HIGH)
unrestricted
allowed by generation of STOP condition must be provided by the master

## CHARACTERISTICS OF THE I ${ }^{2}$ C BUS (continued)

## Low-speed mode

Masters generate a bus clock with a maximum frequency of 2 kHz ; a minimum LOW period of $105 \mu \mathrm{~s}$ and a minimum HIGH period of $365 \mu$ s. The mark-to-space ratio is $1: 3$ LOW-to-HIGH. Detailed timing is shown in Fig. 9.


Fig. 9 Timing of the low-speed mode.
Where:

| $t_{\text {BUF }}$ | $t \geqslant 105 \mu \mathrm{~s}$ ( $\mathrm{L}_{\text {LOW }} \mathrm{min}$ ) |
| :---: | :---: |
| ${ }_{\text {t HD }}$ S STA | $\mathrm{t} \geqslant 365 \mu \mathrm{~s}$ ( t HIGHmin) |
| t LOW | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ HIGH | $390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ SU; STA | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s} *$ |
| thD; DAT | $t \geqslant 0 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ SU; DAT | $\mathrm{t} \geqslant 250 \mathrm{~ns}$ |
| ${ }_{\text {t }} \mathrm{R}$ | $t \leqslant 1 \mu \mathrm{~s}$ |
| ${ }^{\text {t }}$ F | $\mathrm{t} \leqslant 300 \mathrm{~ns}$ |
| tSU; STO | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |

## Note

All the values refer to $V_{I H}$ and $V_{I L}$ levels with a voltage swing of $V_{D D}$ to $V_{S S 2}$, for definitions see high-speed mode.

[^28]

Fig. 10 Complete data transfer in the low-speed mode.
Where:

| Clock tLOWmin | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| :--- | :--- |
| $\mathrm{t}_{\text {HIGH min }}$ | $390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| Mark-to-space ratio | $1: 3$ (LOW-to-HIGH) |
| Start byte | 00000001 |
| Max. number of bytes | 6 |
| Premature termination of transfer | not allowed |
| Acknowledge clock bit | must be provided by master |

## Note

The general characteristics and detailed specification of the $I^{2} \mathrm{C}$ bus are described in a separate data sheet (serial data buses) in handbook: ICs for digital systems in radio, audio and video equipment.

## ADDRESSING

Before any data is transmitted on the $\mathrm{I}^{2} \mathrm{C}$ bus, the device which should respond is addressed first. The addressing is always done with the first byte transmitted after the start procedure.

## Slave address

The clock/calendar acts as a slave receiver or slave transmitter. Therefore the clock signal SCL is only an input signal, but the data signal SDA is a bidirectional line. The clock calendar slave address is shown in Fig. 11.
MSB

| 1 | 1 | 0 | 1 | 0 | $A 1$ | $A 0$ | $R / \bar{W}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Fig. 11 Slave address.
The subaddress bits A0 and A1 correspond to the two hardware address pins A0 and A1 which allows the device to have 1 of 4 different addresses.

## Clock/calendar READ/WRITE cycles

The $I^{2} \mathrm{C}$ bus configuration for different clock/calendar READ and WRITE cycles is shown in Fig. 12 and Fig. 13.


Fig. 12 Master transmitter transmits to clock/calendar slave receiver.
The write cycle is used to set the time counter, the alarm register and the flags. The transmission of the clock/calendar address is followed by the MODE-POINTER-WORD which contains a CONTROL-nibble (Table 3) and an ADDRESS-nibble (Table 4). The ADDRESS-nibble is valid only if the preceding CONTROL-nibble is set to EXECUTE ADDRESS. The third transmitted word contains the data to be written into the time counter or alarm register.

Table 3 CONTROL-nibble

|  | C2 | C1 | C0 | function |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | execute address |
| 0 | 0 | 0 | 1 | read control/status flags |
| 0 | 0 | 1 | 0 | reset prescaler, including seconds counter; without carry for minute counter |
| 0 | 0 | 1 | 1 | time adjust, with carry for minute counter (see note) |
| 0 | 1 | 0 | 0 | reset NODA flag |
| 0 | 1 | 0 | 1 | set NODA flag |
| 0 | 1 | 1 | 0 | reset COMP flag |

## Note

If the seconds counter is below 30 there is no carry. This causes a time adjustment of max. -30 s .
From the count 30 there is a carry which adjusts the time by max. +30 s .
Table 4 ADDRESS-nibble

|  | B2 | B1 | B0 | addressed to: |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | time counter hours |
| 0 | 0 | 0 | 1 | time counter minutes |
| 0 | 0 | 1 | 0 | time counter days |
| 0 | 0 | 1 | 1 | time counter months |
| 0 | 1 | 0 | 0 | alarm register hours |
| 0 | 1 | 0 | 1 | alarm register minutes |
| 0 | 1 | 1 | 0 | alarm register days |
| 0 | 1 | 1 | 1 | alarm register months |

At the end of each data word the address bits $B 1, B 0$ will be incremented automatically provided the preceding CONTROL-nibble is set to EXECUTE ADDRESS. There is no carry to B2.
Table 5 shows the placement of the BCD upper and lower digits in the DATA byte for writing into the addressed part of the time counter and alarm register respectively.

Table 5 Placement of BCD digits in the DATA byte

| MSB |  |  |  |  |  | DATA |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| upper digit |  |  |  | Lower digit |  |  |  |  |  |  |
| UD | UC | UB | UA | LD | LC | LB | LA | addressed to: |  |  |
| X | X | D | D | D | D | D | D | hours |  |  |
| X | D | D | D | D | D | D | D | minutes |  |  |
| X | X | D | D | D | D | D | D | days |  |  |
| X | X | X | D | D | D | D | D | months |  |  |

Where " X " is the don't care bit and " D " is the data bit.
Acknowledgement response of the clock calendar as slave receiver is shown in Table 6.

(1) The master receiver must signal an end of data to the slave transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave.

Fig. 13 Master transmitter reads clock/calendar after setting mode pointer.
To read the addressed part of the time counter and alarm register, plus information from specified control/status flags, the BCD digits in the DATA byte are organized as shown in Table 7.

(1) The master receiver must signal an end of data to the slave transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave.

Fig. 14 Master reads clock/calendar immediately after first byte.
The status of the MODE-POINTER-WORD concerning the CONTROL-nibble remains unchanged until a write to MODE POINTER condition occurs.

ADDRESSING (continued)
Table 6 Slave receiver acknowledgement

| mode pointer |  |  |  |  |  |  |  | acknowledge on byte |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | address | mode pointer | data |
|  | C2 | C1 | CO |  | B2 | B1 | B0 |  |  |  |
| 0 | 0 | 0 | 0 | 0 | x | x | x | yes | yes | yes |
| 0 | 0 | 0 | 0 | 1 | X | X | X | yes | no | no |
| 0 | 0 | 0 | 1 | X | X | X | X | yes | yes | no |
| 0 | 0 | 1 | 0 | X | X | X | X | yes | yes | no |
| 0 | 0 | 1 | 1 | X | X | X | X | yes | yes | no |
| 0 | 1 | 0 | 0 | X | X | X | X | yes | yes | no |
| 0 | 1 | 0 | 1 | X | X | X | X | yes | yes | no |
| 0 | 1 | 1 | 0 | X | X | X | X | yes | yes | no |
| 0 | 1 | 1 | 1 | X | X | X | X | yes | no | no |
| 1 | X | X | X | X | X | X | X | yes | no | no |

Where " X " is the don't care bit.
Table 7 Organization of the BCD digits in the DATA byte

| MSB |  |  | DATA |  |  |  | LSB |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| upper digit |  |  |  | lower digit |  |  |  |  |
| UD | UC | UB | UA | LD | LC | LB | LA | addressed to |
| 0 | 0 | D | D | D | D | D | D | hours |
| 0 | D | D | D | D | D | D | D | minutes |
| 0 | 0 | D | D | D | D | D | D | days |
| 0 | 0 | 0 | D | D | D | D | D | months |
| 0 | 0 | 0 | * | ** | NODA | COMP | POWF | control/status flags |

Where: " $D$ " is the data bit.

* $=$ minutes.
** $=$ seconds.


## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage ranges

Voltage on pins 4 and 5
Voltage on pins 6, 7, 13 and 14
Voltage on any other pin
Input current
Output current
Power dissipation per output
Total power dissipation per package
Operating ambient temperature range
Storage temperature range

| $V_{D D}-V_{S S 1}$ | $-0,3$ to +8 V |
| :--- | :--- |
| $V_{D D}-V_{S S 2}$ | $-0,3$ to +8 V |

$\mathrm{V}_{\mathrm{SS} 2}-0,8$ to $\mathrm{V}_{\mathrm{DD}}+0,8 \mathrm{~V}$ *
$\mathrm{V}_{\mathrm{SS} 1}-0,6$ to $\mathrm{V}_{\mathrm{DD}}+0,6 \mathrm{~V}$
$\mathrm{V}_{\mathrm{SS} 2}-0,6$ to $\mathrm{V}_{\mathrm{DD}}+0,6 \mathrm{~V}$
max. $\quad 10 \mathrm{~mA}$
max.
10 mA
max.
100 mW
max.
200 mW
-40 to $+85{ }^{\circ} \mathrm{C}$
-55 to $+125{ }^{\circ} \mathrm{C}$

## HANDLING

Inputs and outputs are protected against electrostatic charge in normal handling. However, to be totally safe, it is desirable to take normal precautions appropriate to handling MOS devices (see 'Handling MOS Devices').

* Impedance min. $500 \Omega$.


## CHARACTERISTICS

$\mathrm{V}_{\mathrm{SS} 2}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified. Typical values at $\mathrm{T}_{\mathrm{amb}}=+25^{\circ} \mathrm{C}$

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply |  |  |  |  |  |
| Supply voltage ( $1^{2} \mathrm{C}$ interface) | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\text {SS2 }}$ | 2,5 | 5 | 6,0 | V |
| Supply voltage (clock) | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\text {SS } 1}$ | 1,3 | 1,5 | $\left(\mathrm{V}_{\text {DD }}-\mathrm{V}_{\text {SS2 }}\right)$ | V |
| Supply voltage (clock) at $\mathrm{t}_{\mathrm{HD}}>500 \mathrm{~ns}$ | $\mathrm{V}_{\text {DD }}-\mathrm{V}_{\text {SS } 1}$ | 1,1 | 1,5 | $\left(\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\text {SS2 }}\right)$ | V |
| $\begin{aligned} & \text { Supply current } V_{S S 1} \\ & \text { at } V_{D D}-V_{S S 1}=1,5 \mathrm{~V} \\ & \text { at } V_{D D}-V_{S S 1}=5 \mathrm{~V} \end{aligned}$ | -ISS1 | - | 3 | 10 | $\mu \mathrm{A}$ |
|  | -ISS1 | - | 12 | 50 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Supply current } V_{S S 2} \\ & \text { at } V_{D D}-V_{S S 2}=5 \mathrm{~V} \\ & \text { (IO }=0 \mathrm{~mA} \text { on all outputs) } \end{aligned}$ | ${ }^{-1}$ SS2 | - | - | 50 | $\mu \mathrm{A}$ |
| Inputs SCL, SDA, A0, A1, TEST |  |  |  |  |  |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | $0,7 \times V_{\text {DD }}$ | - | - | v |
| Input voltage LOW | $\mathrm{V}_{\text {IL }}$ | - | - | $0,3 \times V_{\text {DD }}$ | V |
| Input leakage current at $V_{1}=V_{S S 2}$ to $V_{D D}$ | $\pm 11$ | - | - | 1 | $\mu \mathrm{A}$ |
| Inputs EXTPF, PFIN |  |  |  |  |  |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}-\mathrm{V}_{\text {SS } 1}$ | $0,7 \times\left(V_{D D}-V_{S S 1}\right)$ | - | - | v |
| Input voltage LOW | $\mathrm{V}_{\text {IL }}-\mathrm{V}_{\text {SS }}$ |  | - | $0,3 \times\left(\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{S S 1}\right)$ | V |
| Input leakage current at $V_{1}=V_{S S 1}$ to $V_{D D}$ | $\pm 11$ | - | - | 1 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { at } T_{a m b}=25{ }^{\circ} \mathrm{C} ; \\ & \mathrm{V}_{1}=\mathrm{V}_{\mathrm{SS} 1} \text { to } \mathrm{V}_{\mathrm{D}} \end{aligned}$ | $\pm 11$ | - | - | 0,1 | $\mu \mathrm{A}$ |
| Outputs SEC, MIN, COMP, FSET (normal buffer outputs) |  |  |  |  |  |
| $\begin{aligned} & \text { Output voltage } \mathrm{HIGH} \\ & \text { at } \mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}=2,5 \mathrm{~V} ; \\ & -\mathrm{I}_{\mathrm{O}}=0,1 \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $V_{D D}-0,4$ | - | - | V |
| $\begin{aligned} & \text { at } \mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}=4 \text { to } 6 \mathrm{~V} ; \\ & -\mathrm{I}_{\mathrm{O}}=0,5 \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $V_{D D}-0,4$ | - | - | V |
| Output voltage LOW at $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}=2,5 \mathrm{~V}$. |  |  |  |  |  |
| $\mathrm{I}_{\mathrm{O}}=0,3 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0,4 | V |
| $\begin{aligned} & \text { at } \mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}=4 \text { to } 6 \mathrm{~V} ; \\ & \mathrm{I}_{\mathrm{O}}=1,6 \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0,4 | V |

CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Output SDA <br> ( N -channel open drain) |  |  |  |  |  |
| $\begin{aligned} & \text { Output " } O^{\prime \prime} \text { ": } I_{O}=3 \mathrm{~mA} \\ & \text { at } V_{D D}-V_{S S 2}=2,5 \text { to } 6 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0,4 | V |
| Output "OFF" (leakage current) at $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}=6 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=6 \mathrm{~V}$ | ${ }^{1} 0$ | - | - | 1 | $\mu \mathrm{A}$ |
| Internal threshold voltage |  |  |  |  |  |
| Power failure detection | $\mathrm{V}_{\mathrm{TH} 1}$ | 1 | 1,2 | 1,4 | V |
| $\begin{aligned} & \text { Power "ON" reset } \\ & \text { at } \mathrm{V}_{\mathrm{SCL}}=\mathrm{V}_{\mathrm{SDA}}=\mathrm{V}_{\mathrm{DD}} \end{aligned}$ | $\mathrm{V}_{\mathrm{TH} 2}$ | 1,5 | 2,0 | 2,5 | V |
| Rise and fall times of input signals |  |  |  |  |  |
| Input EXTPF | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | - | 1 | $\mu \mathrm{s}$ |
| Input PFIN | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | - | $\infty$ | $\mu \mathrm{s}$ |
| Input signals except EXTPF and PFIN between $\mathrm{V}_{\text {IL }}$ and $\mathrm{V}_{\text {IH }}$ levels rise time | $\mathrm{tr}_{r}$ | - | - | 1 | $\mu \mathrm{s}$ |
| fall time | $\mathrm{t}_{\mathrm{f}}$ | - | - | 0,3 | $\mu \mathrm{S}$ |
| Frequency at SCL$\text { at } \mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS} 2}=4 \text { to } 6 \mathrm{~V}$ |  |  |  |  |  |
| Pulse width LOW (see Figs 7 and 9) | t LOW | 4,7 | - | - | $\mu \mathrm{S}$ |
| Pulse width HIGH (see Figs 7 and 9) | ${ }^{\text {t HIGH }}$ | 4 | - | - | $\mu \mathrm{s}$ |
| Noise suppression time constant at SCL and SDA input | TI | 0,25 | 1 | 2,5 | $\mu \mathrm{S}$ |
| Input capacitance (SCL, SDA) | $\mathrm{C}_{1}$ | - | - | 7 | pF |
| Oscillator |  |  |  |  |  |
| Integrated oscillator capacitance | $\mathrm{C}_{\text {out }}$ | - | 40 | - | pF |
| Oscillator feedback resistance | $\mathrm{R}_{\mathrm{f}}$ | - | 3 | - | $\mathrm{M} \Omega$ |
| $\begin{aligned} & \text { Oscillator stability for: } \\ & \qquad\left(V_{D D}-V_{S S 1}\right)=100 \mathrm{mV} \\ & \text { at } V_{D D}-V_{S S 1}=1,55 \mathrm{~V} ; \\ & T_{\text {amb }}=25^{\circ} \mathrm{C} \end{aligned}$ | f/fosc | - | $2 \times 10^{-6}$ | - | - |
| Quartz crystal parameters |  |  |  |  |  |
| Frequency $=32,768 \mathrm{kHz}$ |  |  |  |  |  |
| Series resistance | $\mathrm{R}_{S}$ | - | - | 40 | $k \Omega$ |
| Parallel capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | 9 | - | pF |
| Trimmer capacitance | $\mathrm{C}_{\text {T }}$ | 5 | - | 25 | pF |

Purchase of Philips $\left.\right|^{\prime}{ }^{2} \mathrm{C}$ components conveys a license under the Philips ${ }^{\prime}{ }^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specifications defined by Philips.

## APPLICATION INFORMATION



Fig. 15 Application example of the PCF8573 clock/calendar.


Fig. 16 Application example of the PCF8573 with common $\mathrm{V}_{\mathrm{SS} 1}$ and $\mathrm{V}_{\mathrm{SS} 2}$ supply.

## REMOTE 8-BIT I/O FOR $1^{2} \mathrm{C}$ BUS

## GENERAL DESCRIPTION

The PCF8574 is a single-chip silicon gate CMOS circuit. It provides remote I/O expansion for the MAB8400 and PCF8500 microcomputer families via the two-line serial bidirectional bus ( $1^{2} \mathrm{C}$ ). It can also interface microcomputers without a serial interface to the $\mathrm{I}^{2} \mathrm{C}$ bus (as a slave function only). The device consists of an 8 -bit quasi-bidirectional port and an $\mathrm{I}^{2} \mathrm{C}$ interface.
The PCF8574 has low current consumption and includes latched outputs with high current drive capability for directly driving LEDs. It also possesses an interrupt line (INT) which is connected to the interrupt logic of the microcomputer on the $\mathrm{I}^{2} \mathrm{C}$ bus. By sending an interrupt signal on this line, the remote I/O can inform the microcomputer if there is incoming data on its ports without having to communicate via the $\mathrm{I}^{2} \mathrm{C}$ bus. This means that the PCF8574 can remain a simple slave device.

## Features

- Operating supply voltage $2,5 \mathrm{~V}$ to 6 V
- Low stand-by current consumption max. $10 \mu \mathrm{~A}$
- Bidirectional expander
- Open drain interrupt output
- 8 -bit remote $\mathrm{I} / \mathrm{O}$ port for the $\mathrm{I}^{2} \mathrm{C}$ bus
- Peripheral for the MAB8400 and PCF8500 microcomputer families
- Latched outputs with high current drive capability for directly driving LEDs
- Address by 3 hardware address pins for use of up to 8 devices (up to 16 possible with mask option)


Fig. 1 Block diagram.

## PACKAGE OUTLINES

PCF8574P: 16-lead DIL; plastic (SOT-38).
PCF8574T: 16-lead mini-pack; plastic (SO-16L; SOT-162A).

PINNING

| AO 1 | PCF8574 | 16 | $V_{D D}$ |
| :---: | :---: | :---: | :---: |
| A1 2 |  | 15 | SDA |
| A2 3 |  | 14 | SCL |
| PO 4 |  | 13 | INT |
| P1 5 |  | 12 | P7 |
| P2 6 |  | 11 | P6 |
| P3 7 |  | 10 | P5 |
| $\checkmark \mathrm{SS} 8$ |  | 9 | P4 |
|  | 72875 |  |  |

Fig. 2 Pinning diagram.

| 1 to 3 | A0 to A2 | address inputs |
| :--- | :--- | :--- |
| 4 to 7 | PO to P3 |  |
| 9 to 12 | P4 to P7 | 8-bit quasi-bidirectional I/O port |
| 8 | V $_{\text {SS }}$ | negative supply |
| 13 | $\overline{\text { INT }}$ | interrupt output |
| 14 | SCL | serial clock line |
| 15 | SDA | serial data line |
| 16 | VDD | positive supply |



Fig. 3 Simplified schematic diagram of each port.

## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ BUS

The $I^{2} \mathrm{C}$ bus is for 2-way, 2-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 4 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 5 Definition of start and stop conditions.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 6 System configuration.

## CHARACTERISTICS OF THE $\mathrm{I}^{2} \mathrm{C}$ BUS (continued)

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 7 Acknowledgement on the $I^{2} \mathrm{C}$ bus.

## Timing specifications

Within the $I^{2} \mathrm{C}$ bus specifications a high-speed mode and a low-speed mode are defined. The PCF8574 operates in both modes and the timing requirements are as follows:

## High-speed mode

Masters generate a bus clock with a maximum frequency of 100 kHz . Detailed timing is shown in Fig. 8.


Fig. 8 Timing of the high-speed mode.

Where:

| ${ }_{\text {t }}$ buF | $t \geqslant t$ LOWmin | The minimum time the bus must be free before a new transmission can start |
| :---: | :---: | :---: |
| ${ }^{\text {t HD }}$; STA | $\mathrm{t} \geqslant \mathrm{t}$ HIGHmin | Start condition hold time |
| ${ }^{\text {t }}$ LOWmin | $4,7 \mu \mathrm{~s}$ | Clock LOW period |
| thighmin | $4 \mu \mathrm{~s}$ | Clock HIGH period |
| ${ }^{\text {t }}$ SU; STA | $t \geqslant t_{\text {LOWmin }}$ | Start condition set-up time, only valid for repeated start code |
| ${ }^{\text {thD }}$; DAT | $\mathrm{t} \geqslant 0 \mu \mathrm{~s}$ | Data hold time |
| ${ }^{\text {t }}$ SU; DAT | $t \geqslant 250 \mathrm{~ns}$ | Data set-up time |
| ${ }^{\text {t }}$ R | $t \leqslant 1 \mu \mathrm{~s}$ | Rise time of both the SDA and SCL line |
| ${ }^{\text {t }}$ F | $t \leqslant 300 \mathrm{~ns}$ | Fall time of both the SDA and SCL line |
| ${ }^{\text {t }}$ SU; STO | $t \geqslant \mathrm{t}$ LOWmin | Stop condition set-up time |

## Note

All the values refer to $V_{I H}$ and $V_{I L}$ levels with a voltage swing of $V_{S S}$ to $V_{D D}$.


Fig. 9 Complete data transfer in the high-speed mode.
Where:
$\begin{array}{cl}\text { Clock t LOWmin } & 4,7 \mu \mathrm{~s} \\ \mathrm{t}_{\text {HIGHmin }} & 4 \mu \mathrm{~s}\end{array}$
The dashed line is the acknowledgement of the receiver

Mark-to-space ratio
Max. number of bytes
Premature termination of transfer
Acknowledge clock bit

1: 1 (LOW-to-HIGH)
unrestricted
allowed by generation of STOP condition
must be provided by the master

## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ BUS (continued)

## Low-speed mode

Masters generate a bus clock with a maximum frequency of 2 kHz ; a minimum LOW period of $105 \mu \mathrm{~s}$ and a minimum HIGH period of $365 \mu$ s. The mark-to-space ratio is $1: 3$ LOW-to-HIGH. Detailed timing is shown in Fig. 10.


Fig. 10 Timing of the low-speed mode.
Where:
tBUF
thD; STA
t LOW
${ }^{\text {thigh }}$
${ }^{\text {t }}$ SU; STA
thD; DAT
tSU; DAT
${ }^{t}$ R
${ }^{\mathrm{t}} \mathrm{F}$
tSU; STO

$$
\begin{aligned}
& t \geqslant 105 \mu \mathrm{~s}(\mathrm{t} \text { LOWmin }) \\
& t \geqslant 365 \mu \mathrm{~s}(\mathrm{t} \text { HIGHmin }) \\
& 130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s} \\
& 390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s} \\
& 130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}^{*} \\
& \mathrm{t} \geqslant 0 \mu \mathrm{~s} \\
& \mathrm{t} \geqslant 250 \mathrm{~ns} \\
& \mathrm{t} \leqslant 1 \mu \mathrm{~s} \\
& \mathrm{t} \leqslant 300 \mathrm{~ns} \\
& 130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}
\end{aligned}
$$

## Note

All the values refer to $V_{I H}$ and $V_{I L}$ levels with a voltage swing of $V_{S S}$ to $V_{D D}$, for definitions see high-speed mode.

* Only valid for repeated start code.


Fig. 11 Complete data transfer in the low-speed mode.

Where:

| Clock tLOWmin | $130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| :--- | :--- |
| t HIGHmin | $390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$ |
| Mark-to-space ratio | $1: 3$ (LOW-to-HIGH) |
| Start byte | 00000001 |
| Maximum number of bytes | 6 |
| Premature termination of transfer | not allowed |
| Acknowledge clock bit | must be provided by master |

## Note

The general characteristics and detailed specification of the $I^{2} \mathrm{C}$ bus are described in a separate data sheet (serial data buses) in handbook: ICs for digital systems in radio, audio and video equipment.


Fig. 12 WRITE mode (output port).


Fig. 13 READ mode (input port).

## Note

A LOW-to-HIGH transition of SDA, while SCL is HIGH is defined as the stop condition (P). Transfer of data can be stopped at any moment by a stop condition. When this occurs, data present at the last acknowledge phase is valid (output mode). Input data is lost.

## Interrupt (see Figs 14 and 15)

The PCF8574 provides an open drain output ( $\overline{\mathrm{INT}}$ ) which can be fed to a corresponding input of the microcomputer. This gives these chips a type of master function which can initiate an action elsewhere in the system.


Fig. 14 Application of multiple PCF8574s with interrupt.
An interrupt is generated by any rising or falling edge of the port inputs in the input mode. After time $\mathrm{t}_{\text {iv }}$ the signal INT is valid.
Resetting and reactivating the interrupt circuit is achieved when data on the port is changed to the original setting or data is read from or written to the port which has generated the interrupt. Resetting occurs as follows:

- In the READ mode at the acknowledge bit after the rising edge of the SCL signal.
- In the WRITE mode at the acknowledge bit after the HIGH to LOW transition of the SCL signal.

Each change of the ports after the resettings will be detected and after the next rising clock edge, will be transmitted as INT.
Reading from or writing to another device does not affect the interrupt circuit.


Fig. 15 Interrupt generated by a change of input to port P5.

FUNCTIONAL DESCRIPTION (continued)
Quasi-bidirectional I/O ports (see Fig. 16)
A quasi-bidirectional port can be used as an input or output without the use of a control signal for data direction. The bit designated as an input must first be loaded with a logic 1 . In this mode only a current source to $\mathrm{V}_{\mathrm{DD}}$ is active. An additional strong pull-up to $\mathrm{V}_{\mathrm{DD}}$ allows fast rising edges into heavily loaded outputs. These devices turn on when an output changes from LOW to HIGH, and are switched off by the negative edge of SCL. SCL should not remain HIGH when a short-circuit to $V_{S S}$ is allowed (input mode).


Fig. 16 Transient pull-up current $\mathrm{I}_{\mathrm{OHt}}$ while P3 changes from LOW-to-HIGH and back to LOW.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage range
Input voltage range (any pin)
D.C. current into any input
D.C. current into any output
$\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ current
Total power dissipation
Power dissipation per output
Storage temperature range
Operating ambient temperature range

| $\mathrm{V}_{\text {DD }}$ | $-0,5$ to +7 |  |
| :---: | :---: | :---: |
| $V_{1}$ | $\mathrm{V}_{\text {SS }}$ |  |
| $\pm 11$ | max. | 20 |
| $\pm 10$ | max. |  |
| $\pm \mathrm{I}_{\text {D }}$; ISS | max. | 100 |
| $\mathrm{P}_{\text {tot }}$ | max. | 400 |
| $\mathrm{P}_{0}$ | max. | 100 |
| $\mathrm{T}_{\text {stg }}$ |  | +150 |
| Tamb |  | +85 |

## CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2,5$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply (pin 16) |  |  |  |  |  |
| Supply voltage | $\mathrm{V}_{\text {DD }}$ | 2,5 | - | 6 | V |
| Supply current at $\mathrm{V}_{\mathrm{DD}}=6 \mathrm{~V}$; no load, inputs at $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{SS}}$ operating; (SCL $=100 \mathrm{kHz}$ ) standby | $\begin{aligned} & \text { IDD } \\ & \text { IDDO } \end{aligned}$ | - | 40 1,5 | 100 10 | ${ }_{\mu}^{\mu} \mathrm{A}$ |
| Power-on reset voltage level (note 1) | $\mathrm{V}_{\text {REF }}$ | - | 1,3 | 2,4 | V |
| Input SCL; input/output SDA (pins 14; 15) |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IL }}$ | -0,5 V | - | 0,3V ${ }_{\text {DD }}$ | V |
| Input voltage HIGH | $\mathrm{V}_{\mathrm{IH}}$ | $0,7 V_{\text {DD }}$ | - | $\mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}$ | V |
| Output current LOW at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | ${ }^{\text {IOL }}$ | 3 | - | - | mA |
| Input/Output leakage current | \| $\mathrm{L} \mathrm{L} \mid$ | - | - | 100 | nA |
| Clock frequency (see Fig. 8) | ${ }^{\text {f SCL }}$ | - | - | 100 | kHz |
| Tolerable spike width at SCL and SDA input | $\mathrm{t}_{\text {s }}$ | - | - | 100 | ns |
| Input capacitance (SCL, SDA) at $V_{1}=V_{S S}$ | $C_{1}$ | - | - | 7 | pF |
| I/O ports (pins 4 to 7; 9 to 12) |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IL }}$ | -0,5 V | - | $0,3 V_{\text {DD }}$ | $v$ |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | $0,7 V_{\text {DD }}$ | - | $\mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}$ | V |
| Maximum allowed input current through protection diode at $\mathrm{V}_{1} \geqslant \mathrm{~V}_{\mathrm{DD}}$ or $\leqslant \mathrm{V}_{\mathrm{SS}}$ | $\pm \mathrm{I}_{\text {IHL }}$ | - | - | 400 | $\mu \mathrm{A}$ |
| Output current LOW at $\mathrm{V}_{\mathrm{OL}}=1 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | ${ }^{\text {IOL }}$ | 10 | 30 | - | mA |
| Output current HIGH at $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{SS}}$ (current source only) | $-^{-1} \mathrm{OH}$ | 30 | 100 | 300 | $\mu \mathrm{A}$ |
| Transient pull-up current HIGH during acknowledge (see Fig. 16) at $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{SS}}$ | $-\mathrm{IOHt}$ | - | 0,5 | - | mA |
| Input/Output capacitance | $\mathrm{C}_{1 / \mathrm{O}}$ | - | - | 10 | pF |
| Port timing; $\mathrm{C}_{\mathrm{L}} \leqslant 100 \mathrm{pF}$ (see Figs 12 and 13) |  |  |  |  |  |
| Output data valid | $t_{p v}$ | - | - | 4 | $\mu \mathrm{s}$ |
| Input data set-up | $\mathrm{t}_{\mathrm{ps}}$ | 0 | - | - | $\mu \mathrm{s}$ |
| Input data hold | $t_{\text {ph }}$ | 4 | - | - | $\mu \mathrm{s}$ |


| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt $\overline{\text { INT }}$ (pin 13) |  |  |  |  |  |
| Output current LOW $\text { at } \mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | ${ }^{1} \mathrm{OL}$ | 1,6 | - | - | mA |
| Output current HIGH at $V_{\mathrm{OH}}=\mathrm{V}_{\mathrm{DD}}$ | ${ }^{\mid 1} \mathrm{OH} \mid$ | - | - | 100 | nA |
| $\overline{I N T}$ timing; $\mathrm{C}_{\mathrm{L}} \leqslant 100 \mathrm{pF}$ (see Fig. 13) |  |  |  |  |  |
| Input data valid | $\mathrm{t}_{\mathrm{iv}}$ | - | - | 4 | $\mu \mathrm{S}$ |
| Reset delay | $\mathrm{tir}_{\text {r }}$ | - | - | 4 | $\mu \mathrm{S}$ |
| Select inputs A0, A1, A2 (pins 1 to 3) |  |  |  |  |  |
| Input voltage LOW | $V_{\text {IH }}$ | -0,5 V | - | $0,3 V_{\text {DD }}$ | V |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | $0,7 \mathrm{~V}_{\mathrm{DD}}$ | - | $V_{D D}+0,5 V$ | V |
| Input leakage current at $V_{1}=V_{D D}$ or $V_{S S}$ | $1 \mathrm{~L} \mid$ | - | - | 100 | nA |

## Note 1

The power-on reset circuit resets the $\mathrm{I}^{2} \mathrm{C}$ bus logic with $\mathrm{V}_{\mathrm{DD}}<\mathrm{V}_{\mathrm{REF}}$ and sets all ports to logic 1 (input mode with current source to $\mathrm{V}_{\mathrm{DD}}$ ).

Purchase of Philips $1^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specifications defined by Philips.


PCF8576

## UNIVERSAL LCD DRIVER FOR LOW MULTIPLEX RATES

## GENERAL DESCRIPTION

The PCF8576 is a peripheral device which interfaces to almost any liquid crystal display (LCD) having low multiplex rates. It generates the drive signals for any static or multiplexed LCD containing up to four backplanes and up to 40 segments and can easily be cascaded for larger LCD applications. The PCF8576 is compatible with most microprocessors and communicates via a two-line bidirectional bus $\left(1^{2} \mathrm{C}\right)$. Communication overheads are minimized by a display RAM with auto-incremented addressing, by hardware subaddressing and by display memory switching (static and duplex drive modes).

## Features

- Single-chip LCD controller/driver
- Selectable backplane drive configuration: static or 2/3/4 backplane multiplexing
- Selectable display bias configuration: static, $1 / 2$ or $1 / 3$
- Internal LCD bias generation with voltage-follower buffers
- 40 segment drives: up to twenty 8 -segment numeric characters; up to ten 15 -segment alphanumeric characters; or any graphics of up to 160 elements
- $40 \times 4$-bit RAM for display data storage
- Auto-incremented display data loading across device subaddress boundaries
- Display memory bank switching in static and duplex drive modes
- Versatile blinking modes
- LCD and logic supplies may be separated
- Wide power supply range: from 2 V for low-threshold LCDs and up to 9 V for guest-host LCDs and high-threshold(automobile) twisted nematic LCDs
- Low power consumption
- Power-saving mode for extremely low power consumption in battery-operated and telephone applications
- $1^{2} \mathrm{C}$ bus interface
- TTL/CMOS compatible
- Compatible with any 4-bit, 8-bit or 16 -bit microprocessors
- May be cascaded for large LCD applications (up to 2560 segments possible)
- Optimized pinning for single plane wiring in both single and multiple PCF8576 applications
- Space-saving 56 -lead plastic mini-pack (VSO-56)
- Very low external component count (at most one resistor, even in multiple device applications)
- Compatible with chip-on-glass technology
- Manufactured in silicon gate CMOS process


## PACKAGE OUTLINES

PCF8576T: 56-lead mini-pack; plastic (VSO-56; SOT-190).
PCF8576U: uncased chip in tray


Fig. 1 Block diagram.


Fig. 2 Pinning diagram.

## PINNING

| 1 | SDA | $1^{2} \mathrm{C}$ bus data input/output |
| :---: | :---: | :---: |
| 2 | SCL | $1^{2} \mathrm{C}$ bus clock input/output |
| 3 | SYMC | cascade synchronization input/output |
| 4 | CLK | external clock input/output |
| 5 | $V_{\text {DD }}$ | positive supply voltage |
| 6 | OSC | oscillator input |
| 7 8 9 | $\begin{aligned} & \text { A0 } \\ & \text { A1 } \\ & \text { A } \end{aligned}$ | $1^{2} \mathrm{C}$ bus subaddress inputs |
| 10 | SAO | $1^{2} \mathrm{C}$ bus slave address bit 0 input |
| 11 | $\mathrm{V}_{\text {SS }}$ | logic ground |
| 12 | $V_{\text {LCD }}$ | LCD supply voltage |
| $\begin{aligned} & 13 \\ & 14 \\ & 15 \\ & 16 \end{aligned}$ | BPO <br> BP2 <br> BP1 <br> BP3 | LCD backplane outputs |
| $\begin{aligned} & 17 \\ & \text { to } \\ & 56 \end{aligned}$ | $\begin{aligned} & \text { So } \\ & \text { to } \\ & \text { S39 } \end{aligned}$ | LCD segment outputs |

## FUNCTIONAL DESCRIPTION

The PCF8576 is a versatile peripheral device designed to interface any microprocessor to a wide variety of LCDs. It can directly drive any static or multiplexed LCD containing up to four backplanes and up to 40 segments. The display configurations possible with the PCF8576 depend on the number of active backplane outputs required; a selection of display configurations is given in Table 1.

Table 1 Selection of display configurations

| active back- <br> plane outputs | no. of <br> segments | 7-segment <br> numeric | 14 -segment <br> alphanumeric | dot matrix |
| :--- | :--- | :--- | :--- | :--- |
| 4 | 160 | 20 digits + <br> 20 indicator <br> symbols | 10 characters + <br> 20 indicator <br> symbols | 160 dots <br> $(4 \times 40)$ |
| 3 | 120 | 15 digits + <br> 15 indicator <br> symbols | 8 characters + <br> 8 indicator <br> symbols | 120 dots <br> $(3 \times 40)$ |
| 2 | 80 | 10 digits + <br> 10 indicator <br> symbols | 5 characters + <br> 10 indicator <br> symbols | 80 dots <br> $(2 \times 40)$ |
| 1 | 40 | 5 digits + <br> 5 indicator <br> symbols | 2 characters + <br> 12 indicator <br> symbols | 40 dots |

All of the display configurations given in Table 1 can be implemented in the typical system shown in Fig. 3. The host microprocessor maintains the 2 -line $I^{2} \mathrm{C}$ bus communication channel with the PCF8576. A resistor connected between OSC (pin 6) and $\mathrm{V}_{\text {SS }}$ (pin 11) controls the device clock frequency. The appropriate biasing voltages for the multiplexed LCD waveforms are generated internally. The only other connections required to complete the system are to the power supplies ( $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{SS}}$ and $\mathrm{V}_{\mathrm{LCD}}$ ) and to the LCD panel chosen for the application.


Fig. 3 Typical system configuration.

## Power-on reset

At power-on the PCF8576 resets to a defined starting condition as follows:

1. All backplane outputs are set to $V_{D D}$.
2. All segment outputs are set to $V_{D D}$.
3. The drive mode ' $1: 4$ multiplex with $1 / 3$ bias' is selected.
4. Blinking is switched off.
5. Input and output bank selectors are reset (as defined in Table 5).
6. The $I^{2} \mathrm{C}$ bus interface is initialized.
7. The data pointer and the subaddress counter are cleared.

Data transfers on the $I^{2} \mathrm{C}$ bus should be avoided for 1 ms following power-on to allow completion of the reset action.

## LCD bias generator

The full-scale LCD voltage $\left(\mathrm{V}_{\mathrm{op}}\right)$ is obtained from $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$. The LCD voltage may be temperature compensated externally through the $V_{\text {LCD }}$ supply to pin 12. Fractional LCD biasing voltages are obtained from an internal voltage divider of three series resistors connected between $V_{D D}$ and $V_{L C D}$. The centre resistor can be switched out of circuit to provide a $1 / 2$ bias voltage level for the $1: 2$ multiplex configuration.

## LCD voltage selector

The LCD voltage selector coordinates the multiplexing of the LCD according to the selected LCD drive configuration. The operation of the voltage selector is controlled by MODE SET commands from the command decoder. The biasing configurations that apply to the preferred modes of operation, together with the biasing characteristics as functions of $V_{o p}=V_{D D}-V_{L C D}$ and the resulting discrimination ratios (D), are given in Table 2.

Table 2 Preferred LCD drive modes: summary of characteristics

| LCD drive mode | LCD bias <br> configuration | $\frac{V_{\text {off(rms) }}}{V_{\text {op }}}$ | $\frac{V_{\text {on (rms) }}}{V_{\text {op }}}$ | $D=\frac{V_{\text {on }}(r m s)}{V_{\text {off }}(r m s)}$ |
| :--- | :--- | :--- | :--- | :--- |
| static (1 BP) | static (2 levels) | 0 | 1 | $\infty$ |
| $1: 2$ MUX (2 BP) | $1 / 2$ (3 levels) | $\sqrt{2 / 4=0,354}$ | $\sqrt{10 / 4=0,791}$ | $\sqrt{5}=2,236$ |
| $1: 2$ MUX (2 BP) | $1 / 3$ (4 levels) | $1 / 3=0,333$ | $\sqrt{5 / 3}=0,745$ | $\sqrt{5}=2,236$ |
| $1: 3$ MUX (3 BP) | $1 / 3$ (4 levels) | $1 / 3=0,333$ | $\sqrt{33 / 9}=0,638$ | $\sqrt{33 / 3}=1,915$ |
| $1: 4$ MUX (4 BP) | $1 / 3$ (4 levels) | $1 / 3=0,333$ | $\sqrt{3 / 3}=0,577$ | $\sqrt{3}=1,732$ |

## LCD voltage selector (continued)

A practical value for $V_{O p}$ is determined by equating $V_{O f f(r m s)}$ with a defined LCD threshold voltage ( $V_{\text {thLCD }}$ ), typically when the LCD exhibits approximately $10 \%$ contrast. In the static drive mode a suitable choice is $V_{\text {op }} \gtrsim 3 V_{\text {thLCD }}$.
Multiplex drive ratios of $1: 3$ and 1:4 with $1 / 2$ bias are possible but the discrimination and hence the contrast ratios are smaller $(\sqrt{3}=1,732$ for $1: 3$ multiplex or $\sqrt{21} / 3=1,528$ for $1: 4$ multiplex). The advantage of these modes is a reduction of the LCD full scale voltage $\mathrm{V}_{\mathrm{op}}$ as follows:

1 : 3 multiplex ( $1 / 2$ bias) : $V_{\text {op }}=\sqrt{6} V_{\text {off }}(r m s)=2,449 \mathrm{~V}_{\text {off }}(\mathrm{rms})$
$1: 4$ multiplex ( $1 / 2$ bias) : $\mathrm{V}_{\mathrm{op}}=4 \sqrt{3} / 3 \mathrm{~V}_{\mathrm{off}}(\mathrm{rms})=2,309 \mathrm{~V}_{\mathrm{off}}(\mathrm{rms})$
These compare with $V_{o p}=3 V_{\text {off }}(\mathrm{rms})$ when $1 / 3$ bias is used.

## LCD drive mode waveforms

The static LCD drive mode is used when a single backplane is provided in the LCD. Backplane and segment drive waveforms for this mode are shown in Fig. 4.

(a) WAVEFORMS AT DRIVER

$-V_{\text {op }}-$
(b) RESULTANT WAVEFORMS AT LCD SEGMENT

$$
7 Z 91465
$$

Fig. 4 Static drive mode waveforms: $\mathrm{V}_{\mathrm{Op}}=\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$.

When two backplanes are provided in the LCD the $1: 2$ multiplex drive mode applies. The PCF8576 allows use of $1 / 2$ or $1 / 3$ bias in this mode as shown in Figs 5 and 6.


Fig. 5 Waveforms for $1: 2$ multiplex drive mode with $1 / 2$ bias: $V_{o p}=V_{D D}-V_{L C D}$.

LCD drive mode waveforms (continued)


Fig. 6 Waveforms for $1: 2$ multiplex drive mode with $1 / 3$ bias: $V_{o p}=V_{D D}-V_{L C D}$.

The backplane and segment drive wavefront for the 1:3 multiplex drive mode (three LCD backplanes) and for the 1:4 multiplex drive mode (four LCD backplanes) are shown in Figs 7 and 8 respectively.


Fig. 7 Waveforms for $1: 3$ multiplex drive mode: $\mathrm{V}_{\mathrm{op}}=\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$.


Fig. 8 Waveforms for 1:4 multiplex drive mode: $V_{o p}=V_{D D}-V_{L C D}$.

## Oscillator

## Internal clock

The internal logic and the LCD drive signals of the PCF8576 are timed either by the built-in oscillator or from an external clock. When the internal oscillator is used, frequency control is performed by a single resistor connected between OSC (pin 6) and $\mathrm{V}_{\mathrm{SS}}(\mathrm{pin} 11)$ as shown in Fig. 9. In this case, the output from CLK (pin 4) provides the clock signal for cascaded PCF8576s in the system.


Fig. 9 Oscillator frequency
as a function of $\mathrm{R}_{\mathrm{osc}}$ :
${ }^{\mathrm{f}} \mathrm{CLK} \approx\left(3,4 \times 10^{7} / \mathrm{R}_{\text {osc }}\right) \mathrm{kHz} \cdot \Omega$.

## External clock

The condition for external clock is made by tying OSC (pin 6) to $V_{D D}$; CLK (pin 4) then becomes the external clock input.
The clock frequency ( f CLK) determines the LCD frame frequency and the maximum rate for data reception from the $I^{2} \mathrm{C}$ bus. To allow $I^{2} \mathrm{C}$ bus transmissions at their maximum data rate of 100 kHz , ${ }^{\mathrm{f}} \mathrm{CLK}$ should be chosen to be above 125 kHz .
A. clock signal must always be supplied to the device; removing the clock may freeze the LCD in a d.c. state.

## Timing

The timing of the PCF8576 organizes the internal data flow of the device. This includes the transfer of display data from the display RAM to the display segment outputs. In cascaded applications, the synchronization signal $\overline{\text { SYNC maintains the correct timing relationship between the PCF8576s in the }}$ system. The timing also generates the LCD frame frequency which it derives as an integer multiple of the clock frequency (Table 3). The frame frequency is set by the choice of value for $\mathrm{R}_{\mathrm{osc}}$ when internal clock is used, or by the frequency applied to pin 4 when external clock is used.

Table 3 LCD frame frequencies

| PCF8576 mode | recommended $R_{\text {OSC }}(k \Omega)$ | $f_{\text {frame }}$ | nominal $f_{\text {frame }}(\mathrm{Hz})$ |
| :--- | :---: | :--- | :---: |
| normal mode | 180 | ${ }^{f}$ CLK/2880 | 64 |
| power-saving mode | 1200 | ${ }^{\mathrm{f}} \mathrm{CLK} / 480$ | 64 |

## Timing (continued)

The ratio between the clock frequency and the LCD frame frequency depends on the mode in which the device is operating. In the normal mode, $R_{\text {osc }}=180 \mathrm{k} \Omega$ will result in the nominal frame frequency. In the power-saving mode the reduction ratio is six times smaller; this allows the clock frequency to be reduced by a factor of six and for the same frame frequency $R_{\text {osc }}$ will be $1,2 \mathrm{M} \Omega$. The reduced clock frequency and the increased value of $\mathrm{R}_{\text {Osc }}$ together contribute to a significant reduction in power dissipation. The lower clock frequency has the disadvantage of increasing the response time when large amounts of display data are transmitted on the $I^{2} \mathrm{C}$ bus. When a device is unable to 'digest' a display data byte before the next one arrives, it holds the SCL line LOW until the first display data byte is stored. This slows down the transmission rate of the $1^{2} \mathrm{C}$ bus but no data loss occurs.

## Display latch

The display latch holds the display data while the corresponding multiplex signals are generated. There is a one-to-one relationship between the data in the display latch, the LCD segment outputs and one column of the display RAM.

## Shift register

The shift register serves to transfer display information from the display RAM to the display latch while previous data are displayed.

## Segment outputs

The LCD drive section includes 40 segment outputs S0 to S39 (pins 17 to 56 ) which should be connected directly to the LCD. The segment output signals are generated in accordance with the multiplexed backplane signals and with the data resident in the display latch. When less than 40 segment outputs are required the unused segment outputs should be left open.

## Backplane outputs

The LCD drive section includes four backplane outputs BPO to BP3 which should be connected directly to the LCD. The backplane output signals are generated in accordance with the selected LCD drive mode. If less than four backplane outputs are required the unused outputs can be left open. In the 1:3 multiplex drive mode BP3 carries the same signal as BP1, therefore these two adjacent outputs can be tied together to give enhanced drive capabilities. In the 1:2 multiplex drive mode BP0 and BP2, BP1 and $B P 3$ respectively carry the same signals and may also be paired to increase the drive capabilities. In the static drive mode the same signal is carried by all four backplane outputs and they can be connected in parallel for very high drive requirements.

## Display RAM

The display RAM is a static $40 \times 4$-bit RAM which stores LCD data. A logic 1 in the RAM bit-map indicates the 'on' state of the corresponding LCD segment; similarly, a logic 0 indicates the 'off' state. There is a one-to-one correspondence between the RAM addresses and the segment outputs, and between the individual bits of a RAM word and the backplane outputs. The first RAM column corresponds to the 40 segments operated with respect to backplane BPO (Fig. 10). In multiplexed LCD applications the segment data of the second, third and fourth column of the display RAM are time-multiplexed with $B P 1, B P 2$ and $B P 3$ respectively.


Fig. 10 Display RAM bit-map showing direct relationship between display RAM addresses and segment outputs, and between bits in a RAM word and backplane outputs.

When display data are transmitted to the PCF8576 the display bytes received are stored in the display RAM according to the selected LCD drive mode. To illustrate the filling order, an example of a 7 -segment numeric display showing all drive modes is given in Fig. 11; the RAM filling organization depicted applies equally to other LCD types.
With reference to Fig. 11, in the static drive mode the eight transmitted data bits are placed in bit 0 of eight successive display RAM addresses. In the 1:2 multiplex drive mode the eight transmitted data bits are placed in bits 0 and 1 of four successive display RAM addresses. In the $1: 3$ multiplex drive mode these bits are placed in bits 0,1 and 2 of three successive addresses, with bit 2 of the third address left unchanged. This last bit may, if necessary, be controlled by an additional transfer to this address but care should be taken to avoid overriding adjacent data because full bytes are always transmitted. In the 1:4 multiplex drive mode the eight transmitted data bits are placed in bits $0,1,2$ and 3 of two successive display RAM addresses.

## Data pointer

The addressing mechanism for the display RAM is realized using the data pointer. This allows the loading of an individual display data byte, or a series of display data bytes, into any location of the display RAM. The sequence commences with the initialization of the data pointer by the LOAD DATA POINTER command. Following this, an arriving data byte is stored starting at the display RAM address indicated by the data pointer thereby observing the filling order shown in Fig. 11. The data pointer is automatically incremented according to the LCD configuration chosen. That is, after each byte is stored, the contents of the data pointer are incremented by eight (static drive mode), by four ( $1: 2$ multiplex drive mode), by three ( $1: 3$ multiplex drive mode) or by two ( $1: 4$ multiplex drive mode).

## Subaddress counter

The storage of display data is conditioned by the contents of the subaddress counter. Storage is allowed to take place only when the contents of the subaddress counter agree with the hardware subaddress applied to A0, A1 and A2 (pins 7, 8, and 9). The subaddress counter value is defined by the DEVICE SELECT command. If the contents of the subaddress counter and the hardware subaddress do not agree then data storage is inhibited but the data pointer is incremented as if data storage had taken place. The subaddress counter is also incremented when the data pointer overflows.


Fig. 11 Relationships between LCD layout, drive mode, display RAM filling order and display data transmitted over the $I^{2} \mathrm{C}$ bus ( $\mathrm{x}=$ data bit unchanged).

## Subaddress counter (continued)

The storage arrangements described lead to extremely efficient data loading in cascaded applications. When a series of display bytes are being sent to the display RAM, automatic wrap-over to the next PCF8576 occurs when the last RAM address is exceeded. Subaddressing across device boundaries is successful even if the change to the next device in the cascade occurs within a transmitted character (such as during the 14th display data byte transmitted in 1:3 multiplex mode).

## Output bank selector

This selects one of the four bits per display RAM address for transfer to the display latch. The actual bit chosen depends on the particular LCD drive mode in operation and on the instant in the multiplex sequence. In 1:4 multiplex, all RAM addresses of bit 0 are the first to be selected, these are followed by the contents of bit 1 , bit 2 and then bit 3 . Similarly in $1: 3$ multiplex, bits 0,1 and 2 are selected sequentially. In 1:2 multiplex, bits 0 then 1 are selected and, in the static mode, bit 0 is selected.

The PCF8576 includes a RAM bank switching feature in the static and 1:2 multiplex drive modes. In the static drive mode, the BANK SELECT command may request the contents of bit 2 to be selected for display instead of bit 0 contents. In the 1:2 drive mode, the contents of bits 2 and 3 may be selected instead of bits 0 and 1 . This gives the provision for preparing display information in an alternative bank and to be able to switch to it once it is assembled.

## Input bank selector

The input bank selector loads display data into the display RAM according to the selected LCD drive configuration. Display data can be loaded in bit 2 in static drive mode or in bits 2 and 3 in 1:2 drive mode by using the BANK SELECT command. The input bank selector functions independently of the output bank selector.

## Blinker

The display blinking capabilities of the PCF8576 are very versatile. The whole display can be blinked at frequencies selected by the BLINK command. The blinking frequencies are integer multiples of the clock frequency; the ratios between the clock and blinking frequencies depend on the mode in which the device is operating, as shown in Table 4.

An additional feature is for an arbitrary selection of LCD segments to be blinked. This applies to the static and 1:2 LCD drive modes and can be implemented without any communication overheads. By means of the output bank selector, the displayed RAM banks are exchanged with alternate RAM banks at the blinking frequency. This mode can also be specified by the BLINK command.
In the 1:3 and 1:4 multiplex modes, where no alternate RAM bank is available, groups of LCD segments can be blinked by selectively changing the display RAM data at fixed time intervals.

If the entire display is to be blinked at a frequency other than the nominal blinking frequency, this can be effectively performed by resetting and setting the display enable bit E at the required rate using the MODE SET command.

Blinker (continued)
Table 4 Blinking frequencies

| blinking mode | normal operating <br> mode ratio | power-saving <br> mode ratio | nominal blinking frequency <br> $f_{\text {blink }}(\mathrm{Hz})$ |
| :--- | :--- | :--- | :--- |
| off | - | - | blinking off |
| 2 Hz | $\mathrm{f}_{\mathrm{CLK}} / 92160$ | $\mathrm{f}_{\mathrm{CLK}} / 15360$ | 2 |
| 1 Hz | $\mathrm{f}_{\mathrm{CLK}} / 184320$ | $\mathrm{f}_{\mathrm{CLK}} / 30720$ | 1 |
| $0,5 \mathrm{~Hz}$ | ${ }^{\mathrm{f}} \mathrm{CLK} / 368640$ | ${ }^{\mathrm{f}} \mathrm{CLK} / 61440$ | 0,5 |

## CHARACTERISTICS OF THE I ${ }^{2} \mathrm{C}$ BUS

The I ${ }^{2} \mathrm{C}$ bus is for 2-way, 2 -line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 12 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 13 Definition of start and stop conditions.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is a "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 14 System configuration.

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 15 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Note

The general characteristics and detailed specification of the $I^{2} C$ bus are described in a separate data sheet (serial data buses) in handbook: ICs for digital systems in radio, audio and video equipment.

## PCF8576 $I^{2} \mathrm{C}$ bus controller

The PCF8576 acts as an $1^{2} \mathrm{C}$ slave receiver. It does not initiate $I^{2} \mathrm{C}$ bus transfers or transmit data to an $1^{2} \mathrm{C}$ master receiver. The only data output from the PCF8576 are the acknowledge signals of the selected devices. Device selection depends on the $I^{2} \mathrm{C}$ bus slave address, on the transferred command data and on the hardware subaddress.
In single device applications, the hardware subaddress inputs A0, A1 and A2 are normally tied to $V_{S S}$ which defines the hardware subaddress 0 . In multiple device applications A0, A1 and A2 are tied to $V_{S S}$ or $V_{D D}$ according to a binary coding scheme such that no two devices with a common $I^{2} C$ slave address have the same hardware subaddress.
In the power-saving mode it is possible that the PCF8576 is not able to keep up with the highest transmission rates when large amounts of display data are transmitted. If this situation occurs, the PCF8576 forces the SCL line LOW until its internal operations are completed. This is known as the 'clock synchronization feature' of the $1^{2} \mathrm{C}$ bus and serves to slow down fast transmitters. Data loss does not occur.

## input filters

To enhance noise immunity in electrically adverse environments, RC low-pass filters are provided on the SDA and SCL lines.

## ${ }^{2} \mathrm{C}$ bus protocol

Two ${ }^{2} \mathrm{C}$ bus slave addresses (0111000 and 0111001) are reserved for PCF8576. The least-significant bit of the slave address that a PCF8576 will respond to is defined by the level tied at its input SA0 (pin 10). Therefore, two types of PCF8576 can be distinguished on the same $1^{2} \mathrm{C}$ bus which allows:
(a) up to 16 PCF8576s on the same $I^{2} \mathrm{C}$ bus for very large LCD applications;
(b) the use of two types of LCD multiplex on the same $1^{2} \mathrm{C}$ bus.

The $1^{2} \mathrm{C}$ bus protocol is shown in Fig. 16. The sequence is initiated with a start condition (S) from the $1^{2} \mathrm{C}$ bus master which is followed by one of the two PCF8576 slave addresses available. All PCF8576s with the corresponding SAO level acknowledge in parallel the slave address but all PCF8576s with the alternative SAO level ignore the whole $I^{2} \mathrm{C}$ bus transfer. After acknowledgement, one or more command bytes $(\mathrm{m})$ follow which define the status of the addressed PCF8576s. The last command byte is tagged with a cleared most-significant bit, the continuation bit C . The command bytes are also acknowledged by all addressed PCF8576s on the bus.
After the last command byte, a series of display data bytes ( $n$ ) may follow. These display data bytes are stored in the display RAM at the address specified by the data pointer and the subaddress counter. Both data pointer and subaddress counter are automatically updated and the data are directed to the intended PCF8576 device. The acknowledgement after each byte is made only by the (A0, A1, A2) addressed PCF8576. After the last display byte, the $I^{2} \mathrm{C}$ bus master issues a stop condition (P).


Fig. $161^{2} \mathrm{C}$ bus protocol.

## Command decoder

The command decoder identifies command bytes that arrive on the $I^{2} \mathrm{C}$ bus. All available commands carry a continuation bit C in their most-significant bit position (Fig. 17). When this bit is set, it indicates that the next byte of the transfer to arrive will also represent a command. If the bit is reset, it indicates the last command byte of the transfer. Further bytes will be regarded as display data.


Fig. 17 General format of command byte.
The five commands available to the PCF8576 are defined in Table 5.

Command decoder (continued)
Table 5 Definition of PCF8576 commands



## Display controller

The display controller executes the commands identified by the command decoder. It contains the status registers of the PCF8576 and coordinates their effects. The controller is also responsible for loading display data into the display RAM as required by the filling order.

## Cascaded operation

In large display configurations, up to 16 PCF8576s can be distinguished on the same $I^{2} \mathrm{C}$ bus by using the 3 -bit hardware subaddress ( $A 0, A 1, A 2$ ) and the programmable $I^{2} \mathrm{C}$ slave address ( SAO ). It is also possible to cascade up to 16 PCF8576s. When cascaded, several PCF8576s are synchronized so that they can share the backplane signals from one of the devices in the cascade. Such an arrangement is costeffective in large LCD applications since the backplane outputs of only one device need to be throughplated to the backplane electrodes of the display. The other PCF8576s of the cascade contribute additional segment outputs but their backplane outputs are left open (Fig. 18).
The $\overline{\text { SYNC }}$ line is provided to maintain the correct synchronization between all cascaded PCF8576s. This synchronization is guaranteed after the power-on reset. The only time that $\overline{\text { SYNC }}$ is likely to be needed is if synchronization is accidently lost (e.g. by noise in adverse electrical environments; or by the definition of a multiplex mode when PCF8576s with differing SAO levels are cascaded). SYNC is organized as an input/output pin; the output section being realized as an open-drain driver with an internal pull-up resistor. A PCF8576 asserts the SYNC line at the onset of its last active backplane signal and monitors the SYNC line at all other times. Should synchronization in the cascade be lost, it will be restored by the first PCF8576 to assert SYNC. The timing relationships between the backplane waveforms and the $\overline{\mathrm{SYNC}}$ signal for the various drive modes of the PCF8576 are shown in Fig. 19.


Fig. 18 Cascaded PCF8576 configuration.


Fig. 19 Synchronization of the cascade for the various PCF8576 drive modes.

For single plane wiring of packaged PCF8576s and chip-on-glass cascading, see application information.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage range
LCD supply voltage range Input voltage range (SCL; SDA;

A0 to A2; OSC; CLK; $\overline{\text { SYNC; }}$ SAO)
Output voltage range ( S 0 to S 39 ;
BPO to BP3)
D.C. input current
D.C. output current
$\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{LCD}}$ current
Power dissipation per package
Power dissipation per output
Storage temperature range
$V_{D D}$
$V_{\text {LCD }}$
$V_{1}$
$\mathrm{v}_{\mathrm{O}}$
$\pm 1$
$\pm 10$
$\pm \mathrm{I}_{\mathrm{DD}}, \pm \mathrm{I}_{\mathrm{SS}}, \pm \mathrm{I}_{\mathrm{LCD}}$
$P_{\text {tot }}$
$\mathrm{P}_{\mathrm{O}}$
$\mathrm{T}_{\text {stg }}$

$$
\begin{array}{r}
-0,5 \text { to }+11 \mathrm{~V} \\
\mathrm{~V}_{\mathrm{DD}}-11 \text { to } \mathrm{V}_{\mathrm{DD}} \mathrm{~V}
\end{array}
$$

$$
\mathrm{V}_{\mathrm{SS}}-0,5 \text { to } \mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}
$$

$$
\mathrm{V}_{\mathrm{LCD}}--0,5 \text { to } \mathrm{V}_{\mathrm{DD}}+0,5 \mathrm{~V}
$$

$$
\max .
$$

20 mA max.
max.
50 mA
max. $\quad 400 \mathrm{~mW}$
max. $\quad 100 \mathrm{~mW}$
-65 to $+150{ }^{\circ} \mathrm{C}$

## D.C. CHARACTERISTICS

$V_{S S}=0 V_{;} V_{D D}=2$ to $9 V_{;} V_{L C D}=V_{D D}-2$ to $V_{D D}-9 \mathrm{~V}$;
$\mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$; unless otherwise specified

| parameter | symbol | min . | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Operating supply voltage | $V_{\text {DD }}$ | 2 | - | 9 | V |
| LCD supply voltage (note 1) | $V_{\text {LCD }}$ | $V_{D D}{ }^{-9}$ | - | $\mathrm{V}_{\mathrm{DD}}{ }^{-2}$ | V |
| Operating supply current (normal mode) at $\mathrm{f}_{\mathrm{CLK}}=200 \mathrm{kHz}$ (note 2) | ${ }^{\text {I D D }}$ | - | - | 180 | $\mu \mathrm{A}$ |
| Power-saving mode supply current at $\mathrm{V}_{\mathrm{DD}}=3,5 \mathrm{~V}$; $\mathrm{V}_{\mathrm{LCD}}=0 \mathrm{~V}$; ${ }^{\mathrm{f}} \mathrm{CLK}=35 \mathrm{kHz}$ (note 2) | ${ }_{\text {ILP }}$ | - | - | 60 | $\mu \mathrm{A}$ |
| LCD supply current (normal mode) at ${ }^{\mathrm{f}} \mathrm{CLK}=200 \mathrm{kHz}$ (note 2) | ${ }^{\text {I LCD }}$ | - | - | 120 | $\mu \mathrm{A}$ |
| Logic |  |  |  |  |  |
| Input voltage LOW | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}$ | - | 0,3 $V_{\text {DD }}$ | V |
| Input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 0,7 $V_{\text {DD }}$ | - | $\mathrm{V}_{\text {DD }}$ | V |
| Output voltage LOW at $\mathrm{I}_{\mathrm{O}}=0 \mathrm{~mA}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0,05 | V |
| Output voltage HIGH at $\mathrm{I}=0 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OH}}$ | $V_{D D^{-0,05}}$ | - | - | V |
| Output current LOW (CLK, $\overline{\mathrm{SYNC}}$ ) at $\mathrm{V}_{\mathrm{OL}}=1,0 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | IOL1 | 1 | - | - | mA |
| Output current HIGH (CLK) at $\mathrm{V}_{\mathrm{OH}}=4,0 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | ${ }^{\mathrm{O}} \mathrm{OH}$ | - | - | -1 | mA |
| Output current LOW (SDA; SCL) at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | ${ }^{\text {I OL2 }}$ | 3 | - | - | mA |
| Leakage current (SA0; A0 to A2; CLK; SCL ; SDA) at $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}}$ | $\pm{ }_{\text {l }}^{\text {L }}$ 1 | - | - | 1 | $\mu \mathrm{A}$ |


| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Leakage current (OSC) at $V_{1}=V_{D D}$ | $\pm$ L2 | - | - | 1 | $\mu \mathrm{A}$ |
| Pull-up resistor ( $\overline{\text { SYNC }}$ ) | RSYNC | 20 | 50 | 150 | k $\Omega$ |
| Power-on reset level (note 3) | $\mathrm{V}_{\text {REF }}$ | - | 1,0 | 1,6 | V |
| Tolerable spike width on bus | $\mathrm{t}_{\text {sw }}$ | - | - | 100 | ns |
| Input capacitance (note 4) | $\mathrm{C}_{1}$ | - | - | 7 | pF |
| LCD outputs |  |  |  |  |  |
| D.C. voltage component (BPO to BP3) at $\mathrm{C}_{\mathrm{BP}}=35 \mathrm{nF}$ | $\pm \mathrm{V}_{\mathrm{BP}}$ | - | 20 | - | mV |
| D.C. voltage component ( S 0 to S 39 ) at $\mathrm{C}_{\mathrm{S}}=5 \mathrm{nF}$ | $\pm \mathrm{V}_{\text {S }}$ | - | 20 | - | mV |
| Output impedance (BPO to BP3) at $V_{\text {LCD }}=V_{\text {DD }}-5 \mathrm{~V}$ (note 5) | $\mathrm{R}_{\mathrm{BP}}$ | - | - | 5 | k $\Omega$ |
| Output impedance ( SO to S 39 ) at $V_{\text {LCD }}=\mathrm{V}_{\mathrm{DD}}-5 \mathrm{~V}$ (note 5) | $\mathrm{R}_{S}$ | - | - | 7,0 | k $\Omega$ |

A.C. CHARACTERISTICS (note 6)
$V_{S S}=0 V_{;} V_{D D}=2$ to $9 \mathrm{~V} ; \mathrm{V}_{\mathrm{LCD}}=\mathrm{V}_{D D^{-}}-2$ to $\mathrm{V}_{\mathrm{DD}}-9 \mathrm{~V}$;
$T_{\text {amb }}=-40$ to $+85^{\circ} \mathrm{C}$; unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Oscillator frequency (normal mode) at $V_{D D}=5 \mathrm{~V} ; \mathrm{R}_{\mathrm{OSC}}=180 \mathrm{k} \Omega$ (note 7) | ${ }^{\text {f CLK }}$ | 125 | 185 | 288 | kHz |
| Oscillator frequency (power-saving mode) at $\mathrm{V}_{\mathrm{DD}}=3,5 \mathrm{~V} ; \mathrm{R}_{\mathrm{OSC}}=1,2 \mathrm{M} \Omega$ | ${ }^{\text {f CLKLP }}$ | 21 | 31 | 48 | kHz |
| CLK HIGH time | ${ }^{\text {t CLKH }}$ | 1 | - | - | $\mu \mathrm{s}$ |
| CLK LOW time | ${ }^{\text {t CLKL }}$ | 1 | - | - | $\mu \mathrm{s}$ |
| $\overline{\text { SYNC propagation delay }}$ | tPSYNC | - | - | 400 | ns |
| SYNC LOW time | ${ }^{\text {t SYNCL }}$ | 1 | - | - | $\mu \mathrm{S}$ |
| Driver delays with test loads at $V_{L C D}=V_{D D}-5 \mathrm{~V}$ | tPLCD | - | - | 30 | $\mu \mathrm{s}$ |

A.C. CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $1^{2} \mathrm{C}$ bus high-speed mode |  |  |  |  |  |
| Bus free time | $\mathrm{t}_{\text {BUF }}$ | 4,7 | - | - | $\mu \mathrm{s}$ |
| Start condition hold time | ${ }^{\text {t HD }}$; STA | 4 | - | - | $\mu \mathrm{s}$ |
| SCL. LOW time | ${ }^{\text {t LOW }}$ | 4,7 | - | - | $\mu \mathrm{s}$ |
| SCL HIGH time | $\mathrm{t}_{\mathrm{HIGH}}$ | 4 | -- | - | $\mu \mathrm{s}$ |
| Start condition set-up time (repeated start code only) | ${ }^{\text {t }}$ U ${ }^{\text {STA }}$ | 4,7 | - | - | $\mu \mathrm{s}$ |
| Data hold time | ${ }^{\text {thD }}$; DAT | 0 | - | - | $\mu \mathrm{s}$ |
| Data set-up time | ${ }^{\text {t }}$ SU: DAT | 250 | - | - | ns |
| Rise time | ${ }^{\text {tR }}$ | - | - | 1 | $\mu \mathrm{s}$ |
| Fall time | ${ }^{\text {t }}$ F | - | - | 300 | ns |
| Stop condition set-up time | ${ }^{\text {t }}$ SU; STO | 4,7 | - | -- | $\mu \mathrm{s}$ |
| $1^{2} \mathrm{C}$ bus low-speed mode |  |  |  |  |  |
| Bus free time | $\mathrm{t}_{\text {BUF }}$ | 105 | - | - | $\mu \mathrm{s}$ |
| Start condition hold time | thD; STA | 365 | - | - | $\mu \mathrm{s}$ |
| SCL. LOW time | t LOW | 105 | - | 155 | $\mu \mathrm{s}$ |
| SCL HIGH time | ${ }^{\text {thigh }}$ | 365 | - | 415 | $\mu \mathrm{s}$ |
| Start condition set-up time (repeated start code only) | tSU; STA | 105 | - | 155 | $\mu \mathrm{s}$ |
| Data hold time | ${ }^{\text {thD }}$; DAT | 0 | - | - | $\mu \mathrm{s}$ |
| Data set-up time | ${ }^{\text {t }}$ SU; DAT | 250 | - | - | ns |
| Rise time | ${ }^{\text {tR }}$ | - | - | 1 | $\mu \mathrm{s}$ |
| Fall time | ${ }^{\text {t }}$ F | - | - | 300 | ns |
| Stop condition set-up time | tSU; STO | 105 | - | 155 | $\mu \mathrm{s}$ |

## Notes to characteristics

1. $V_{L C D}<V_{D D}-3 V$ for $1 / 3$ bias.
2. Outputs open; inputs at $\mathrm{V}_{S S}$ or $\mathrm{V}_{\mathrm{DD}}$; external clock with $50 \%$ duty cycle; $I^{2} \mathrm{C}$ bus inactive.
3. Resets all logic when $\mathrm{V}_{\mathrm{DD}}<\mathrm{V}_{\mathrm{REF}}$.
4. Periodically sampled, not $100 \%$ tested.
5. Outputs measured one at a time.
6. All timing values referred to $\mathrm{V}_{I H}$ and $\mathrm{V}_{I L}$ levels with an input voltage swing of $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{DD}}$.
7. At ${ }^{\mathrm{f}} \mathrm{CLK}<125 \mathrm{kHz}, \mathrm{I}^{2} \mathrm{C}$ bus maximum transmission speed is derated.


Fig. 20 Test loads.


Fig. 21 Driver timing waveforms.


Fig. $22 I^{2} \mathrm{C}$ bus high-speed mode timing waveforms.


Fig. $23 I^{2} \mathrm{C}$ bus low-speed mode timing waveforms.


Fig. 24 Typical supply current characteristics.


Fig. 25 Typical characteristics of LCD outputs.

APPLICATION INFORMATION


Fig. 26 Single plane wiring of packaged PCF8576s.

## Chip-on-glass cascadability in single plane

In chip-on-glass technology, where driver devices are bonded directly onto the glass of the LCD, it is important that the devices may be cascaded without the crossing of conductors, but the paths of conductors can be continued on the glass under the chip. All of this is facilitated by the PCF8576 bonding pad layout (Fig. 27). Pads needing bus interconnection between all PCF8576s of the cascade are $V_{D D}, V_{S S}, C L K, S C L, S D A$ and $\overline{S Y N C}$. These lines may be led to the corresponding pads of the next PCF8576 through the wide opening between the $\mathrm{V}_{\text {LCD }}$ pad and the backplane output pads. The only bussed line that does not require a second opening to lead through to the next PCF8576 is $\mathrm{V}_{\mathrm{LCD}}$, being the cascade centre. The placing of $\mathrm{V}_{\text {LCD }}$ adjacent to $\mathrm{V}_{\mathrm{SS}}$ allows the two supplies to be tied together.
Fig. 28 shows the connection diagram for a cascaded PCF8576 application with single plane wiring. Note the use of the open space between the $V_{\text {LCD }}$ pad and the backplane output pads to route $V_{D D}$, $V_{S S}, C L K, S C L, S D A$ and $\overline{\text { SYNC. The external connections may be made to either end of the cascade, }}$ wherever most convenient for the connector.
When an external clocking source is to be used, OSC of all devices should be tied to $V_{D D}$. The pads OSC, A0, A1, A2 and SA0 have been placed between $\mathrm{V}_{\mathrm{SS}}$ and $\mathrm{V}_{\mathrm{DD}}$ to facilitate wiring of oscillator, hardware subaddress and slave address.

## APPLICATION INFORMATION (continued)



Fig. 27 PCF8576 bonding pad locations.

## Bonding pad locations

All $\mathrm{x} / \mathrm{y}$ coordinates are referenced to left-hand bottom corner (0/0, Fig. 27).
Dimensions in $\mu \mathrm{m}$

| pad | x | y |  | pad | x | $y$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S34 | 160 | $\stackrel{160}{4}$ | bottom | S33 | $160$ | 400 | 1 left |
| S35 | 380 |  |  | S32 |  | 640 |  |
| S36 | 580 |  |  | S31 |  | 860 |  |
| S37 | 780 |  |  | S30 |  | 1060 |  |
| S38 | 980 |  |  | S29 |  | 1260 |  |
| S39 | 1180 |  |  | S28 |  | 1460 |  |
| SDA | 1380 |  |  | S27 |  | 1660 |  |
| SCL | 1580 |  |  | S26 |  | 1860 |  |
| SYNC | 1780 |  |  | S25 |  | 2260 |  |
| CLK | 1980 |  |  | S24 |  | 2460 |  |
| $V_{\text {DD }}$ | 2180 |  |  | S23 |  | 2660 |  |
| OSC | 2400 |  |  | S22 |  | 2860 |  |
| A0 | 2640 |  |  | S21 |  | 3060 |  |
| A1 | 2910 | 160 | bottom | S20 |  | 3260 |  |
|  |  |  |  | S19 |  | 3480 |  |
| S17 | 160 | $3960$ | top | S18 | 160 | 3720 | left |
| S16 | 380 |  |  |  |  |  |  |
| S15 | 580 |  |  | A2 | 2910 | 360 | right |
| S14 | 780 |  |  | SAO | 4 | 560 | 1 |
| S13 | 980 |  |  | $\mathrm{V}_{\text {SS }}$ |  | 760 |  |
| S12 | 1180 |  |  | $V_{\text {LCD }}$ |  | 960 |  |
| S11 | 1380 |  |  | BPO |  | 2360 |  |
| S10 | 1580 |  |  | BP2 |  | 2560 |  |
| S9 | 1780 |  |  | BP1 |  | 2760 |  |
| S8 | 1980 |  |  | BP3 |  | 2960 |  |
| S7 | 2180 |  |  | So |  | 3160 |  |
| S6 | 2400 |  |  | S1 |  | 3360 |  |
| S5 | 2640 |  |  | S2 | - | 3560 | $\dagger$ |
| S4 | 2910 | 3960 | top | S3 | 2910 | 3760 | right |



Fig. 28 Chip-on-glass application; cascaded PCF8576s with single-plane wiring (viewed from back of chip).


Purchase of Philips' $I^{2} \mathrm{C}$ components conveys a license under the
Philips $I^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specifications defined by Philips.

PCF8577

## LCD DIRECT/DUPLEX DRIVER WITH I²C BUS INTERFACE

## GENERAL DESCRIPTION

The PCF8577 is a single chip, silicon gate CMOS circuit. It is designed to drive liquid crystal displays with up to 32 segments directly, or 64 segments in a duplex manner.
The two-line $I^{2} \mathrm{C}$ bus interface substantially reduces wiring overheads in remote display applications. Bus traffic is minimized in multiple IC applications by automatic address incrementing, hardware subaddressing and display memory switching (direct drive mode).
The PCF8577 and PCF8577A differ only in their slave address.

## Features

- Direct/duplex drive modes with up to 32/64 LCD-segment drive capability per device
- Operating supply voltage: 2,5 to 9 V
- Low power consumption
- $1^{2} \mathrm{C}$ bus interface
- Optimized pinning for single plane wiring
- Single-pin built-in oscillator
- Auto-incremented loading across device sub-address boundaries
- Display memory switching in direct drive mode
- May be used for $I^{2} \mathrm{C}$ bus output expander
- System expansion up to 256 segments ( 512 segments with PCF8577A)
- Power-on-reset sets all segments off (to blank)


Fig. 1 Block diagram.

## PACKAGE OUTLINES

PCF8577P, PCF8577AP: 40-lead DIL; plastic (SOT-129).
PCF8577T, PCF8577AT: 40-lead mini-pack; plastic (VSO-40; SOT-158A).


Fig. 2 Pinning diagram.

## PINNING

## Supply

| 35 | V DD | positive supply <br> negative supply |
| :--- | :--- | :--- |
| 38 | V SS $^{2}$ |  |
| ${ }^{2}$ C bus |  |  |
| 40 | SDA | $1^{2} \mathrm{C}$ bus data line |
| 39 | SCL | $1^{2} \mathrm{C}$ bus clock line |

Inputs
36 A1 hardware address line
37 AO/OSC hardware address line/oscillator pin

## Outputs

1-32 S1-S32
segment outputs
harware address line/cascade sync input/backplane output cascade sync input/backplane output

## FUNCTIONAL DESCRIPTION

Hardware sub-address A0, A1, A2
The hardware sub-address lines A0, A1, A2 are used to program the device sub-address for each PCF8577 on the bus. Lines A0 and A2 are shared with OSC and BP2 respectively to reduce pin-out requirements.
A0/OSC Line AO is defined as LOW (logic 0 ) when this pin is used for the local oscillator or when connected to $\mathrm{V}_{\text {SS }}$. Line A0 is defined as HIGH (logic 1) when connected to $\mathrm{V}_{\text {DD }}$.
A1 Line A1 must be defined as LOW (logic 0 ) or as HIGH (logic 1 ) by connection to $\mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\mathrm{DD}}$ respectively.
A2/BP2 In the direct drive mode the second backplane signal BP2 is not used and the A2/BP2 pin is exclusively the A2 input. Line A2 is defined as LOW (logic 0 ) when connected to $\mathrm{V}_{\mathrm{SS}}$ or, if this is not possible, by leaving it unconnected (internal pull-down). Line A2 is defined as HIGH (logic 1) when connected to VDD.
In the duplex drive mode the second backplane signal BP2 is required and the A2 signal is undefined. In this mode device selection is made exclusively from lines A0 and A1.

## Oscillator AO/OSC

The PCF8577 has a single-pin built-in oscillator which provides the modulation for the LCD segment driver outputs. One external resistor and one external capacitor are connected to the AO/OSC pin to form the oscillator. In an expanded system containing more than one PCF8577 the backplane signals are usually common to all devices and only one oscillator is needed. The devices which are not used for the oscillator are put into the expansion mode by connecting the AO/OSC pin to either $V_{\text {DD }}$ or $\mathrm{V}_{\text {SS }}$ depending on the required state for AO. In the expansion mode each PCF8577 is synchronized from the backplane signal(s).

## User-accessible registers

There are nine user-accesible 1-byte registers. The first is a control register which is used to control the loading of data into the segment byte registers and to select display options. The other eight are segment byte registers, split into two banks of storage, which store the segment data. The set of even numbered segment byte registers is called BANK A. Odd numbered segment byte registers are called BANK B.
There are two slave addresses, one for PCF8577, and one for PCF8577A (see Fig. 14). All addressed devices load the second byte into the control register and each device maintains an identical copy of the control byte in the control register at all times (see $\mathrm{I}^{2} \mathrm{C}$ bus protocol Fig. 15).
The control register is shown in more detail in Fig. 3. The least-significant bits select which device and which segment byte register are loaded next. This part of the register is therefore called the Segment Byte Vector (SBV).
The upper three bits of the SBV (V5 to V 3 ) are compared with the hardware sub-address input signals A2, A1 and A0. If they are the same then the device is enabled for loading, if not the device ignores incoming data but remains active.
The three least-significant bits of the SBV (V2 to V0) address one of the segment byte registers within the enabled chip for loading segment data.


Fig. 3 PCF8577 register organization.

## FUNCTIONAL DESCRIPTION (continued)

The control register also has two display control bits. These bits are named MODE and BANK. The MODE bit selects whether the display outputs are configured for direct or duplex drive displays. The BANK bit allows the user to display BANK A or BANK B.

## Auto-incremented loading

After each segment byte is loaded the SBV is incremented automatically, thus auto-incremented loading occurs if more than one segment byte is received in a data transfer.
Since the SBV addresses both device and segment registers, auto-incremented loading may proceed across device boundaries provided that the hardware sub-addresses are arranged contiguously.

## Direct drive mode

The PCF8577 is set to the direct drive mode by loading the MODE control bit with logic 0 . In this mode only four bytes are needed to store the data for the 32 segment drivers. Setting the BANK bit to logic 0 selects even bytes (BANK A); setting the BANK bit to logic 1 selects odd bytes (BANK B).
In the direct drive mode the SBV is auto-incremented by two after the loading of each segment byte register. This means that auto-incremented loading of BANK A or BANK B is possible. Either bank may be completely or partially loaded irrespective of which bank is being displayed. Direct drive output waveforms are shown in Fig. 4.


$$
\begin{aligned}
& V_{O N}=V_{D D}-V_{S S} \\
& V_{O F F}=0
\end{aligned}
$$

Fig. 4 Direct drive mode display output waveforms.

## Duplex mode

The PCF8577 is set to the duplex mode by loading the MODE bit with logic 1 . In this mode a second backplane signal (BP2) is needed and pin A2/BP2 is used for this; therefore A2 and its equivalent SBV bit V5 are undefined. The SBV auto-increments by one between loaded bytes.
All of the segment bytes are needed to store data for the 32 segment drivers and the BANK bit is ignored.
Duplex mode output waveforms are shown in Fig. 5.
DEVELOPMENT DATA


Fig. 5 Duplex mode display output waveforms.

## CHARACTERISTICS OF THE $I^{2} \mathrm{C}$ BUS

The $I^{2} \mathrm{C}$ bus is for 2-way, 2-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals.


Fig. 6 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the stop condition (P).


Fig. 7 Definition of start and stop conditions.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 8 System configuration.

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each byte is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse, set up and hold times must be taken into account. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 9 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Timing specifications

Within the $I^{2} \mathrm{C}$ bus specifications a high-speed mode and a low-speed mode are defined. The PCF8577 operates in both modes and the timing requirements are as follows:

## High-speed mode

Masters generate a bus clock with a maximum frequency of 100 kHz . Detailed timing is shown in Fig. 10.


Fig. 10 Timing of the high-speed mode.

## CHARACTERISTICS OF THE $\boldsymbol{I}^{2} \mathbf{C}$ BUS (continued)

Where:

| t BUF | $t \geqslant t_{\text {LOW }}$ min | The minimum time the bus must be free before a new transmission can start |
| :---: | :---: | :---: |
| ${ }^{\text {t }} \mathrm{HD} ;$ STA | $\mathrm{t} \geqslant \mathrm{t}_{\text {HIGHmin }}$ | Start condition hold time |
| ${ }^{\text {t }}$ LOWmin | $4,7 \mu \mathrm{~s}$ | Clock LOW period |
| ${ }^{\text {t HIGHmin }}$ | $4 \mu \mathrm{~s}$ | Clock HIGH period |
| ${ }^{\text {t }}$ SU; STA | $t \geqslant t_{\text {LOWmin }}$ | Start condition set-up time, only valid for repeated start code |
| ${ }^{\text {t HD }}$; DAT | $\mathrm{t} \geqslant 0 \mu \mathrm{~s}$ | Data hold time |
| ${ }^{\text {t }}$ SU; DAT | $t \geqslant 250 \mathrm{~ns}$ | Data set-up time |
| ${ }^{\text {t }}$ R | $\mathrm{t} \leqslant 1 \mu \mathrm{~s}$ | Rise time of both the SDA and SCL line |
| ${ }^{\text {t }}$ F | $t \leqslant 300 \mathrm{~ns}$ | Fall time of both the SDA and SCL line |
| ${ }^{\text {t }}$ SU; STO | $\mathrm{t} \geqslant \mathrm{t}_{\text {LOWmin }}$ | Stop condition set-up time |

## Note

All the timing values referred to $V_{I H}$ and $V_{I L}$ levels with a voltage swing of $V_{S S}$ to $V_{D D}$.


Fig. 11 Complete data transfer in the high-speed mode.

Where:
Clock t LOWmin
$4,7 \mu \mathrm{~s}$
${ }^{t}$ HIGHmin
$4 \mu \mathrm{~s}$

The dashed line is the acknowledgement of the receiver

Mark-to-space ratio
Max. number of bytes
Premature termination of transfer
Acknowledge clock bit

1:1 (LOW-to-HIGH)
unrestricted
allowed by generation of STOP condition
must be provided by the master

## Low-speed mode

Masters generate a bus clock with a maximum frequency of 2 kHz ; a minimum LOW period of $105 \mu \mathrm{~s}$ and a minimum HIGH period of $365 \mu \mathrm{~s}$. The mark-to-space ratio is $1: 3 \mathrm{LOW}$-to-HIGH. Detailed timing is shown in Fig. 12.


Fig. 12 Timing of the low-speed mode.
Where:
tBUF
tHD; STA
t LOW
${ }^{t}$ HIGH
${ }^{\text {t SU; STA }}$
${ }^{t}$ HD ; DAT
${ }^{t}$ SU; DAT
${ }^{t} R$
tF
${ }^{\text {t SU; STO }}$

$$
\begin{aligned}
& t \geqslant 105 \mu \mathrm{~s}(t \text { LOWmin }) \\
& t \geqslant 365 \mu \mathrm{~s}(t \text { HIGHmin }) \\
& 130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s} \\
& 390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s} \\
& 130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}^{*} \\
& \mathrm{t} \geqslant 0 \mu \mathrm{~s} \\
& \mathrm{t} \geqslant 250 \mathrm{~ns} \\
& \mathrm{t} \leqslant 1 \mu \mathrm{~s} \\
& \mathrm{t} \leqslant 300 \mathrm{~ns} \\
& 130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}
\end{aligned}
$$

## Note

All the timing values referred to $V_{\text {IH }}$ and $V_{\text {IL }}$ levels with a voltage swing of $V_{\text {SS }}$ to $V_{D D}$, for definitions see high-speed mode.

[^29]CHARACTERISTICS OF THE $\mathbf{I}^{2} \mathrm{C}$ BUS (continued)


Fig. 13 Complete data transfer in the low-speed mode.

Where:

Clock thowmin
${ }^{\text {thIGHmin }}$
Mark-to-space ratio
Start byte
Maximum number of bytes
Premature termination of transfer
Acknowledge clock bit
$130 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$
$390 \mu \mathrm{~s} \pm 25 \mu \mathrm{~s}$
1:3 (LOW-to-HIGH)
00000001
6
not allowed
must be provided by master

## Note

The general characteristics and detailed specification of the $\mathrm{I}^{2} \mathrm{C}$ bus are described in a separate data sheet (serial data buses) in handbook: ICs for digital systems in radio, audio and video equipment.

## ADDRESSING

Before any data is transmitted on the $\mathrm{I}^{2} \mathrm{C}$ bus, the device which should respond is addressed first. The addressing is always done with the first byte transmitted after the start procedure.

## Slave address

The slave address for PCF8577 and PCF8577A are shown in Fig. 14.


Fig. 14 PCF8577 and PCF8577A slave addresses.

## $1^{2} \mathrm{C}$ bus protocol

The PCF8577 $\mathrm{I}^{2} \mathrm{C}$ bus protocol is shown in Fig. 15.


Fig. $15 I^{2} \mathrm{C}$ bus protocol.
The PCF8577 is a slave receiver and has a fixed slave address (Fig. 14). All PCF8577 on the same bus acknowledge the slave address in parallel. The second byte is always the control byte and is loaded into the control register of each PCF8577 on the bus. Subsequent data bytes are loaded into the segment registers of the selected device. Any number of data bytes may be loaded in one transfer and in an expanded system rollover of the SBV from 111111 to 000000 is allowed. If a stop (P) condition is given after the control byte acknowledge the segment data remains unchanged. This allows the BANK bit to be toggled without changing the segment register contents. During loading of segment data only the selected PCF8577 gives an acknowledge. Loading is terminated by generating a stop (P) condition.

## DISPLAY MEMORY MAPPING

The mapping between the eight segment registers and the segment outputs S1 to S32 is shown in Tables 1 and 2.
Since only one register bit per segment is needed in the direct drive mode, the BANK bit allows swapping of display information. If BANK is set to logic 0 even bytes (BANK A) are displayed; if BANK is set to logic 1 odd bytes (BANK B) are displayed. BP1 is always used for the backplane output in the direct drive mode.

Table 1 Segment byte - segment driver mapping in the direct drive mode.

| MODE | BANK | V2 | V1 | Vo | $\begin{array}{\|l\|l\|} \hline \text { SEGMENT } \\ \hline \text { REGISTER } \\ \hline \end{array}$ | $\begin{gathered} \text { M S B } \\ 7 \end{gathered}$ | 6 | 5 | 4 | 3 | 2 | 1 | $\begin{gathered} \text { L S B } \\ 0 \end{gathered}$ | BACKPLANE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | BP1 |
| 0 | 1 | 0 | 0 | 1 | 1 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | BP1 |
| 0 | 0 | 0 | 1 | 0 | 2 | S16 | S15 | S14 | S13 | S12 | S11 | S10 | S9 | BP1 |
| 0 | 1 | 0 | 1 | 1 | 3 | S16 | S15 | S14 | S13 | S12 | S11 | S10 | S9 | BP1 |
| 0 | 0 | 1 | 0 | 0 | 4 | S24 | S23 | S22 | S21 | S20 | S19 | S18 | S17 | BP1 |
| 0 | 1 | 1 | 0 | 1 | 5 | S24 | S23 | S22 | S21 | S20 | S19 | S18 | S17. | BP1 |
| 0 | 0 | 1 | 1 | 0 | 6 | S32 | S31 | S30 | S29 | S28 | S27 | S26 | S25 | BP1 |
| 0 | 1 | 1 | 1 | 1 | 7 | S32 | S31 | S30 | S29 | S28 | S27 | S26 | S25 | BP1 |

Mapping example: bit 0 of register 7 controls the LCD segment S25 if BANK bit is a logic 1.

DISPLAY MEMORY MAPPING (continued)
Even bytes (BANK A) correspond to backplane 1 (BP1) and odd bytes (BANK B) correspond to backplane 2 (BP2).

Table 2 Segment byte - segment driver mapping in the duplex mode.

| MODE | BANK | V2 | V1 | V0 | $\begin{array}{\|l\|} \hline \text { SEGMENT BIT } \\ \hline \text { REGISTER } \end{array}$ | $\begin{gathered} \text { M S B } \\ 7 \end{gathered}$ | 6 | 5 | 4 | 3 | 2 | 1 | $\begin{gathered} \text { LS } B \\ 0 \end{gathered}$ | BACKPLANE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $x$ | 0 | 0 | 0 | 0 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | BP1 |
| 1 | x | 0 | 0 | 1 | 1 | S8 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | BP2 |
| 1 | x | 0 | 1 | 0 | 2 | S16 | S15 | S14 | S13 | S12 | S11 | S10 | S9 | BP1 |
| 1 | $x$ | 0 | 1 | 1 | 3 | S16 | S15 | S14 | S13 | S12 | S11 | S10 | S9 | BP2 |
| 1 | x | 1 | 0 | 0 | 4 | S24 | S23 | S22 | S21 | S20 | S19 | S18 | S17 | BP1 |
| 1 | $x$ | 1 | 0 | 1 | 5 | S24 | S23 | S22 | S21 | S20 | S19 | S18 | S17 | BP2 |
| 1 | $x$ | 1 | 1 | 0 | 6 | S32 | S31 | S30 | S29 | S28 | S27 | S26 | S25 | BP1 |
| 1 | x | 1 | 1 | 1 | 7 | S32 | S31 | S30 | S29 | S28 | S27 | S26 | S25 | BP2 |

$X=$ don't care.
Mapping example: bit 7 of register 5 controls the LCD segment S24/BP2.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)

Supply voltage range
Voltage on any pin
D.C. input current
D.C. output current
$\mathrm{V}_{\text {DD }}$ or $\mathrm{V}_{\text {SS }}$ current
Power dissipation per package
Power dissipation per output
Operating ambient temperature range
Storage temperature range
$V_{D D}$
$V_{I}$
$\pm I_{I}$
$\pm I_{O}$
$\pm I_{D D}, I_{S S}$
$P_{\text {tot }}$
$P$
$T_{\text {amb }}$
$T_{\text {stg }}$
$-0,5$ to 11
$V_{S S}-0,8$ to $V_{D D}+0,8$
max. 20 mA
$\max 25 \mathrm{~mA}$
max. 50 mA
max. 500* mW
max. 100 mW
-40 to $+85 \quad{ }^{\circ} \mathrm{C}$
-65 to $+150 \quad{ }^{\circ} \mathrm{C}$

[^30]
## CHARACTERISTICS

$V_{D D}=2,5$ to $9 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | symbol | min. | typ.* | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\text {DD }}$ | 2,5 | - | 9,0 | V |
| $\begin{aligned} & \text { Supply current } \\ & \begin{aligned} \text { fSCL } & =100 \mathrm{kHz} ; \text { no load } ; \text { ROSC }=1 \mathrm{MS} \\ \mathrm{fSCL} & =0 ; \text { no load } ; \text { ROSC }=1 \mathrm{M} \Omega ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \\ & T_{\mathrm{amb}}=25{ }^{\circ} \mathrm{C} \end{aligned} \end{aligned}$ |  |  |  |  |  |
|  | IDD | - | 80 | 250 | $\mu \mathrm{A}$ |
|  | ! DD | - | 35 | 70 | $\mu \mathrm{A}$ |
| Power-on-reset level** | $V_{\text {REF }}$ | - | 1,1 | 2,0 | v |
| Input SCL; input/output SDA input voltage LOW | $\mathrm{V}_{\text {IL }}$ | 0 | - | 0,8 | V |
| input voltage HIGH | $\mathrm{V}_{\text {IH }}$ | 2,0 | - | 9,0 | V |
| output current LOW at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | ${ }^{\text {IOL }}$ | 3,0 | - | - | mA |
| output leakage current HIGH at $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{DD}}$ | IOH | - | - | 250 | nA |
| tolerable spike width on bus | ${ }_{\text {t }}^{\text {sw }}$ | - | - | 100 | ns |
| input capacitance at $\mathrm{V}_{1}=\mathrm{V}_{\text {SS }}$ | $\mathrm{Cl}_{1}$ | - | - | 7 | pF |
| A1 input leakage current at $\mathrm{V}_{1}=\mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\mathrm{DD}}$ | 11 | - | - | 250 | $n \mathrm{~A}$ |
| $\mathrm{A} 2 / \mathrm{BP} 2$ input current at $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{DD}}$ | 11 | - | 2,0 | - | $\mu \mathrm{A}$ |
| A0/OSC input current at $\mathrm{V}_{1}=\mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\mathrm{DD}}$ | $\pm 1$ | - | 5,0 | - | $\mu \mathrm{A}$ |
| DC component of LCD driver | $\pm \mathrm{V}_{\text {BP }}$ | - | 20 | - | $m V$ |
| Segment loads | CSX | - | - | 5 | nf |
|  | $\mathrm{R}_{\mathrm{SX}}$ | 1 | - | - | $\mathrm{M} \Omega$ |
| Segment output current $\text { at } \mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | ${ }^{\text {IOL }}$ | 0,3 | - | - | mA |
| Segment output current <br> at $V_{O H}=V_{D D}-0,4 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | ${ }_{-} \mathrm{I} \mathrm{OH}$ | 0,3 | - | - | mA |
| Backplane load (direct drive) | $\mathrm{C}_{\text {BP }}$ | - | -- | 50 | nF |
|  | $\mathrm{R}_{\mathrm{BP}}$ | 100 | - | - | $k \Omega$ |
| Backplane loads (duplex drive) | $\mathrm{C}_{\text {BP }}$ | - | - | 35 | nF |
|  | R ${ }_{\text {BP }}$ | 100 | - | - | $k \Omega$ |
| Rise and fall times ( $V_{B P}-V_{S X}$ ) at maximum load | $\mathrm{tr}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | - | 200 | $\mu \mathrm{s}$ |
| Display frequency <br> at $\mathrm{C}_{\mathrm{OSC}}=680 \mathrm{pF} ; \mathrm{R}_{\mathrm{OSC}}=1 \mathrm{M} \Omega$ | ${ }^{\text {f }}$ CCD | 65 | 90 | 120 | Hz |

[^31]
(1) The series resistance of the display backplane must be greater than $1 \Omega$.

Fig. 16 Direct drive display; expansion to 256 segments using eight PCF8577.

(1) The series resistances of the display backplanes must be greater than $1 \mathrm{k} \Omega$.

Fig. 17 Duplex display; expansion to $2 \times 128$ segments using four PCF8577.

## APPLICATION INFORMATION (continued)



## Notes

1. MODE bit must always be set to 0 (direct drive)
2. BANK switching is permitted
3. BP1 must always be connected to $\mathrm{V}_{\mathrm{SS}}$ and AO/OSC must be connected to either $\mathrm{V}_{\text {DD }}$ or $\mathrm{V}_{\text {SS }}$ (no LCD modulation)

Fig. 18 Use of PCF8577 as 32 -bit output expander in $\mathrm{I}^{2} \mathrm{C}$ bus application.


Purchase of Philips' $\left.\right|^{2} \mathrm{C}$ components conveys a license under the Philips $I^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specifications defined by Philips.

# 256 x 8-BIT STATIC RAM WITH ALARM CLOCK/CALENDAR AND BCD-COUNTER 

## GENERAL DESCRIPTION

The PCF8583 is a low power 2048 -bit static CMOS RAM organized as 256 words by 8 -bits. Addresses and data are transferred serially via a two-line bidirectional bus ( $\left.1^{2} \mathrm{C}\right)$. The built-in word address register is incremented automatically after each written or read data byte. One address pin A0 is used for programming the hardware address, allowing the connection of two devices to the bus without additional hardware. The built-in $32,768 \mathrm{kHz}$ oscillator circuit and the first 8 bytes of the RAM are used for the clock/calendar and counter functions. The next 8 bytes may be programmed as alarm registers or used as free RAM space.

## Features

- $I^{2} \mathrm{C}$ bus interface operating supply voltage: $2,5 \mathrm{~V}$ to 6 V
- Clock operating supply voltage ( 0 to $70^{\circ} \mathrm{C}$ ): $1,0 \mathrm{~V}$ to 6 V
- Data retention voltage: $1,0 \mathrm{~V}$ to 6 V
- Low standby current: max. $15 \mu \mathrm{~A}$
- Clock function with four year calendar
- 24 or 12 hour format
- $32,768 \mathrm{kHz}$ or 50 Hz time base
- Serial input/output bus ( $\mathrm{I}^{2} \mathrm{C}$ )
- Automatic word address incrementing
- Programmable alarm, timer and interrupt function


Fig. 1 Block diagram.

## PACKAGE OUTLINES

PCF8583P: 8-lead DIL; plastic (SOT-97AE).
PCF8583T: 8-lead mini-pack; plastic (SO-8L; SOT-176).

PINNING

| 1 | OSCI | oscillator input, 50 Hz or event-pulse input |  |
| :---: | :---: | :---: | :---: |
| OSCO oscillator output |  |  |  |
| 3 AO address input |  |  |  |
| $4 \quad \mathrm{~V}_{\text {SS }} \quad$ negative supply |  |  |  |
| 56 | SDA | serial data line | $1^{2} \mathrm{C}$ bus |
|  | SCL | serial clock line | , bus |
| 7 | INT | open drain interr | t output (active low) |
| $V_{\text {DD }}$ positive supply |  |  |  |



Fig. 2 Pinning diagram.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
Supply voltage range (pin 8); note 1
Voltage range on any input
D.C. input current (any input)
D.C. output current (any output)

Supply current (pin 4 or pin 8)
Power dissipation per package
Power dissipation per output
Storage temperature range
Operating ambient temperature range

## Note

1. Inputs and outputs are protected against electrostatic discharges in normal handling. However, to be totally safe, it is advised to take handling precautions appropriate to handling MOS devices (see 'Handling MOS devices').

## FUNCTIONAL DESCRIPTION

The PCF8583 contains a 256 by 8－bit RAM with an 8－bit auto－increment address register，an on－chip $32,768 \mathrm{kHz}$ oscillator circuit，a frequency divider，a serial two－line bidirectional $\mathrm{I}^{2} \mathrm{C}$ bus interface and a power－on reset circuit．
The first 8 bytes of the RAM（memory addresses 00 to 07 ）are designed as addressable 8 －bit parallel registers．The first register（memory address 00 ）is used as a control／status register．The memory ad－ dresses 01 to 07 are used as counters for the clock function．The memory addresses 08 to 0 F are free RAM locations or may be programmed as alarm registers．

## Counter function modes

When the control／status register is set a $32,768 \mathrm{kHz}$ clock mode，a 50 Hz clock mode or an event－ counter mode can be selected．
In the clock modes the hundredths of a second，seconds，minutes，hours，date，month（four year calendar）and weekdays are stored in a BCD format．The timer register stores up to 99 days．The event－ counter mode is used to count pulses applied to the oscillator input（OSCO left open）．The event counter stores up to 6 digits of data．
When one of the counters is read（memory locations 01 to 07 ），the contents of all counters are strobed into capture latches at the beginning of a read cycle．Therefore faulty reading of the count during a carry condition is prevented．

## Alarm function modes

By setting the alarm enable bit of the control／status register the alarm control register（address 08）is activated．
By setting the alarm control register a dated alarm，a daily alarm，a weekday alarm or a timer alarm may be programmed．In the clock modes，the timer register（address 07）may be programmed to count hundredths of a second，seconds，minutes，hours or days．Days are counted when an alarm is not programmed．
Whenever an alarm event occurs the alarm flag of the control／status register is set．A timer alarm event will set the alarm flag and an overflow condition of the timer will set the timer flag．The open drain interrupt output is switched on（active LOW）when the alarm or timer flag is set（enabled）．

When a timer function without any alarm function is programmed the remaining alarm registers （addresses 09 to $0 F$ ）may be used as free RAM space．

## PCF8583

## Control/status register

The control/status register is defined as the memory location 00 with free access for reading and writing via the $1^{2} \mathrm{C}$ bus. All functions and options are controlled by the contents of the control/status register (see Fig. 3).
MSB LSB


Memory location 00
reset state: 00000000

Timer flag (50\% duty factor seconds flag if alarm enable bit is 0 )
Alarm flag (50\% duty factor minutes flag if alarm enable bit is 0 )

Alarm enable bit:
0 alarm disabled (memory locations 08 to 0F are free RAM space)
1 alarm active (memory location 08 is the alarm control register)

Mask flag:
0 read locations 05 to 06 unmasked
1 read date and month count directly
Function mode:
00 clock mode $32,768 \mathrm{kHz}$
01 clock mode 50 Hz
10 event-counter mode
11 test modes
Hold last count flag:
0 count
1 store and hold last count in capture latches

Stop counting flag:
0 count pulses
1 stop counting, reset divider

Fig. 3 Control/status register.

## Counter registers

In the different modes the counter registers are programmed and arranged as shown in Fig. 4. Counter cycles are listed in Table 1.

In the clock modes 24 h or 12 h format can be selected by setting the most significant bit of the hours counter register. The format of the hours counter is shown in Fig. 5.
The year and date are packed into memory location 05 (see Fig. 6). The weekdays and months are packed into memory location 06 (see Fig. 7). When reading these memory locations the year and weekdays are masked out when the mask flag of the control/status register is set. This allows the user to read the date and month count directly.

In the event-counter mode events are stored in BCD format. D5 is the most significant and D0 the least significant digit. The divider is by-passed.


Fig. 4 Register arrangement.

Counter registers (continued)
MSB LSB

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |$\quad$ Memory location 04 (hours counter) reset state: 00000000

Unit hours BCD
Ten hours (0 to 2 binary)
AM/PM flag:
0 AM
1 PM
Format:
024 h format, AM/PM flag remains unchanged
112 h format, AM/PM flag will be updated

Fig. 5 Format of the hours counter.


Fig. 6 Format of the year/date counter.


Fig. 7 Format of the weekdays/months counter.

Table 1 Cycle length of the time counters, clock modes

|  | unit | counting cycle | carry to the next unit | contents of the month counter |
| :---: | :---: | :---: | :---: | :---: |
|  | hundredths of a second <br> seconds <br> minutes <br> hours (24 h) <br> hours (12 h) <br> date <br> months <br> year <br> weekdays <br> timer/days | 00 to 99 <br> 00 to 59 <br> 00 to 59 <br> 00 to 23 <br> 12 AM, <br> 01 AM to <br> 11 AM, <br> 12 PM, <br> 01 PM to <br> 11 PM <br> 01 to 31 <br> 01 to 30 <br> 01 to 29 <br> 01 to 28 <br> 01 to 12 <br> 0 to 3 <br> 0 to 6 <br> 00 to 99 | $\begin{aligned} & 99 \text { to } 00 \\ & 59 \text { to } 00 \\ & 59 \text { to } 00 \\ & 23 \text { to } 00 \\ & \\ & \\ & 11 \text { PM to } 12 \text { AM } \\ & 31 \text { to } 01 \\ & 30 \text { to } 01 \\ & 29 \text { to } 01 \\ & 28 \text { to } 01 \\ & 12 \text { to } 01 \\ & 6 \text { to } 0 \\ & \text { no carry } \end{aligned}$ | $\begin{aligned} & 1,3,5,7,8,10,12 \\ & 4,6,9,11 \\ & 2, \text { year }=0 \\ & 2, \text { year }=1,2,3 \end{aligned}$ |

## Alarm control register

When the alarm enable bit of the control/status register is set the alarm control register (address 08) is activated. All alarm, timer and interrupt output functions are controlled by the contents of the alarm control register (see Figs 8 a and 8 b ).


Fig. 8a Alarm control register, clock modes.


Fig. 8b Alarm control register, event-counter mode.

## Alarm registers

All alarm registers are allocated with a constant address offset of hex 08 to the corresponding counter registers.
An alarm goes off when the contents of the alarm registers matches bit-by-bit the contents of the involved counter registers. The year and weekday bits are ignored in a dated alarm. A daily alarm ignores the month and date bits. When a weekday alarm is selected, the contents of the alarm weekday/month register will select the weekdays on which an alarm is activated (see Fig. 9).


Fig. 9 Selection of alarm weekdays.

## Interrupt output

The open-drain n-channel interrupt output is programmed by setting the alarm control register. It is switched on (active LOW) when the alarm flag or the timer flag is set. In the clock mode without alarm the output sequence is controlled by the timer flag. The OFF voltage of the interrupt output may exceed the supply voltage.

## Oscillator and divider

A $32,768 \mathrm{kHz}$ quartz crystal has to be connected to OSCI (pin 1) and OSCO (pin 2). A trimmer capacitor between OSCI and $\mathrm{V}_{\text {DD }}$ is used for tuning the oscillator. The oscillator frequency is scaled down to 128 Hz by the divider. A 100 Hz clock signal is derived from this signal.
In the 50 Hz clock mode or event-counter mode the oscillator is disabled and the oscillator input is switched to a high impedance state. This allows the user to feed the 50 Hz reference frequency or an external high speed event signal into the input OSCI.

## Initialization

When power-up occurs the $1^{2} \mathrm{C}$ bus interface, the control/status register and all clock counters are reset. The device starts time keeping in the $32,768 \mathrm{kHz}$ clock mode with the 24 h format on the first of January at 0.00.00: 00.

A second level-sensitive reset signal to the $I^{2} \mathrm{C}$ bus interface is generated as soon as the supply voltage drops below the interface reset level. This reset signal does not affect the control/status or clock counter registers.
It is recommended to set the stop counting flag of the control/status register before loading the actual time into the counters. Loading of illegal states will lead to a clock malfunction but will not latch-up the device.

## CHARACTERICS OF THE I ${ }^{2}$ C BUS

The $I^{2} \mathrm{C}$ bus is for bidirectional, two-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock puise as changes in the data line at this time will be interpreted as a control signal.


Fig. 10 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH, is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH, is defined as the stop condition (P).


Fig. 11 Definition of start and stop condition.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 12 System configuration.

## PCF8583

## Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is not limited. Each data byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master also generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledge has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 13 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Timing specifications

All the timing values are valid within the operating supply voltage and ambient temperature range and refer to $\mathrm{V}_{\text {IL }}$ and $\mathrm{V}_{\text {IH }}$ with an input voltage swing of $\mathrm{V}_{\text {SS }}$ to $\mathrm{V}_{\text {DD }}$.

| parameter | symbol | min . | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SCL clock frequency | ${ }^{\text {f }}$ SCL | - | - | 100 | kHz |
| Tolerable spike width on bus | ${ }^{\text {t }}$ S $W$ | - | - | 100 | ns |
| Bus free time | ${ }_{\text {t }}$ BUF | 4,0 | - | - | $\mu \mathrm{s}$ |
| Start condition set-up time | ${ }^{\text {t }}$ SU; STA | 4,0 | - | - | $\mu \mathrm{s}$ |
| Start condition hold time | ${ }^{\text {thD }}$; STA | 4,7 | - | - | $\mu \mathrm{s}$ |
| SCL LOW time | thow | 4,7 | - | - | $\mu \mathrm{s}$ |
| SCL HIGH time | ${ }^{\text {thigh }}$ | 4,0 | - | - | $\mu \mathrm{s}$ |
| SCL and SDA rise time | ${ }^{\text {t }}$ R | - | - | 1,0 | $\mu \mathrm{s}$ |
| SCL and SDA fall time | ${ }^{\text {t }}$ F | - | - | 0,3 | $\mu \mathrm{s}$ |
| Data set-up time | ${ }^{\text {t }}$ SU; DAT | 250 | - | - | ns |
| Data hold time | ${ }^{\text {thD }}$; DAT | 0 | - | - | ns |
| SCL LOW to data out valid | ${ }^{\text {t }} \mathrm{VD}$; DAT | - | - | 3,4 | $\mu \mathrm{s}$ |
| Stop condition set-up time | ${ }^{\text {t }}$ SU; STO | 4,0 | - | - | $\mu \mathrm{s}$ |

PROTOCOL

|  | START <br> CONDITION <br> (S) | BIT 7 <br> MSB <br> (A7) | BIT 6 | (A6) |
| :--- | :--- | :--- | :--- | :--- |


| BIT 0 | ACKNOW- | STOP |  |
| :--- | :--- | :--- | :--- |
| LSB | LEDGE | CONDITION |  |
| $(R / W)$ | (A) | $(P)$ |  |



Fig. $14 I^{2} \mathrm{C}$ bus timing diagram.

## $I^{2} \mathrm{C}$ bus protocol

Before any data is transmitted on the $I^{2} \mathrm{C}$ bus, the device which should respond is addressed first. The addressing is always done with the first byte transmitted after the start procedure. The $I^{2} \mathrm{C}$ bus configuration for the different PCF8583 READ and WRITE cycles is shown in Fig. 15.


Fig. 15a Master transmits to slave receiver (WRITE mode).


Fig. 15b Master reads after setting word address (WRITE word address; READ data).


Fig. 15c Master reads slave immediately after first byte (READ mode).

## CHARACTERISTICS

$V_{D D}=2,5$ to $6,0 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply <br> Supply voltage | $V_{\text {DD }}$ | 2,5 | - | 6 | V |
| Supply current at <br> $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{DD}}$ <br> operating at $\mathrm{f}_{\mathrm{SCL}}=100 \mathrm{kHz}$ <br> standby at ${ }^{\mathrm{f}} \mathrm{SCL}=0 \mathrm{kHz}$ <br> standby at $\mathrm{T}_{\mathrm{amb}}=-25$ to $+70^{\circ} \mathrm{C}$ <br> Power-on reset voltage level (note 1) |  |  |  |  |  |
|  | ${ }^{\text {I D D }}$ | - | - | 200 | $\mu \mathrm{A}$ |
|  | IDDO | - | - | 15 | $\mu \mathrm{A}$ |
|  | IDDO | - | - | 5 | $\mu \mathrm{A}$ |
|  | $V_{\text {POR }}$ | 1,5 | 1,9 | 2,3 | V |
| Inputs; input/output SDA |  |  |  |  |  |
| Input voltage LOW (note 2) | $V_{\text {IL }}$ | -0,8 | - | $0,3 \times V_{\text {DD }}$ | V |
| Input voltage HIGH (note 2) | $\mathrm{V}_{\text {IH }}$ | $0,7 \times V_{\text {DD }}$ | - | $V_{D D}+0,8$ | V |
| Output current LOW at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | ${ }^{1} \mathrm{OL}$ | 3 | - | - | V |
| Output leakage current HIGH at $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{DD}}$ | ${ }^{\mathrm{O}} \mathrm{OH}$ | - | - | 250 | nA |
| Input leakage current at $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ | $\pm 11$ | - | - | 250 | nA |
| Input capacitance (SCL, SDA) at $V_{1}=V_{S S}$ | $\mathrm{Cl}_{1}$ | - | - | 7 | pF |
| LOW $\mathrm{V}_{\text {DD }}$ data retention |  |  |  |  |  |
| Supply voltage for data retention | $V_{\text {DDR }}$ | 1 | - | 6 | V |
| Supply current at $\mathrm{V}_{\text {DDR }}=1 \mathrm{~V}$ | ${ }^{\prime}$ DDR | - | - | 5 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Supply current at } \mathrm{V}_{\mathrm{DDR}}=1 \mathrm{~V} ; \\ & T_{\text {amb }}=-25 \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ | IDDR | - | - | 2 | $\mu \mathrm{A}$ |
| Oscillator |  |  |  |  |  |
| Integrated oscillator capacitance | Cosc | - | 40 | - | pF |
| Oscillator stability for: $\begin{aligned} & \Delta \mathrm{V}_{\mathrm{DD}}=100 \mathrm{mV} \\ & \text { at } \mathrm{V}_{\mathrm{DD}}=1,5 \mathrm{~V} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ | f/fosc | - | $2 \times 10^{-6}$ | - | - |

## CHARACTERISTICS (continued)

| parameter | symbol | min. | typ. | max. | unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Quartz crystal parameters |  |  |  |  |  |
| Frequency $=32,768 \mathrm{kHz}$ |  |  |  |  |  |
| Series resistance | $\mathrm{R}_{\mathrm{S}}$ | - | - | 40 | $\mathrm{~K} \Omega$ |
| Parallel capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | 9 | - | pF |
| Trimmer capacitance | $\mathrm{C}_{\mathrm{T}}$ | 5 | - | 25 | pF |

## Notes to characteristics

1. The power-on reset circuit resets the $I^{2} C$ bus logic when $V_{D D}<V_{P O R}$.
2. When the voltages are a diode voltage above or below the supply voltage $V_{D D}$ or $V_{S S}$ an input current will flow; this current must not exceed $\pm 0,5 \mathrm{~mA}$.

## APPLICATION INFORMATION

The PCF8583 slave address has a fixed combination 1010 as group 1.


Fig. 16 PCF8583 address.


Fig. 17 PCF8583 application diagram.


Purchase of Philips' $I^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$-system provided the system conforms to the $I^{2} \mathrm{C}$ specifications defined by Philips.

## 8-BIT A/D AND D/A CONVERTER

## GENERAL DESCRIPTION

The PCF8591 is a single chip, single supply low power 8-bit CMOS data acquisition device with four analogue inputs, one analogue output and a serial $I^{2} \mathrm{C}$ bus interface. Three address pins A0, A1 and A2 are used for programming the hardware address, allowing the use of up to eight devices connected to the $I^{2} \mathrm{C}$ bus without additional hardware. Address, control and data to and from the device are transferred serially via the two-line bidirectional bus ( $\left.I^{2} \mathrm{C}\right)$.

The functions of the device include analogue input multiplexing, on-chip track and hold function, 8 -bit analogue-to-digital conversion and an 8 -bit digital-to-analogue conversion. The maximum conversion rate is given by the maximum speed of the $\mathrm{I}^{2} \mathrm{C}$ bus.

## FEATURES

- Single power supply
- Operating supply voltage $2,5 \mathrm{~V}$ to 6 V
- Low standby current
- Serial input/output via $\mathrm{I}^{2} \mathrm{C}$ bus
- Address by 3 hardware address pins
- Sampling rate given by $\mathrm{I}^{2} \mathrm{C}$ bus speed
- 4 analogue inputs programmable as single-ended or differential inputs
- Auto-incremented channel selection
- Analogue voltage range from $\mathrm{V}_{S S}$ to $\mathrm{V}_{\mathrm{DD}}$
- On-chip track and hold circuit
- 8 -bit successive approximation $A / D$ conversion
- Multiplying DAC with one analogue output


## APPLICATIONS

Closed loop control systems; low power converter for remote data acquisition; battery operated equipment; acquisition of analogue values in automotive, audio and TV applications.

## PACKAGE OUTLINES



Fig. 1 Block diagram.

## PINNING



Fig. 2 Pinning diagram.

1. AINO
2. AIN1
(A/D converter)
3. AIN3
4. AO
5. A1
6. A2
7. $\mathrm{V}_{\mathrm{SS}}$
8. SDA
9. SCL
10. OSC
11. EXT
12. AGND
13. VREF
14. AOUT
$16 \mathrm{~V}_{\mathrm{DD}}$
analogue inputs
hardware address
negative supply voltage
oscillator input/output
analogue ground
voltage reference input
positive supply voltage
$1^{2} \mathrm{C}$ bus data input/output
$1^{2} \mathrm{C}$ bus clock input/output
external/internal switch for oscillator input
analogue output ( $D / A$ converter)

## FUNCTIONAL DESCRIPTION

## Adressing

Each PCF8591 device in an $1^{2} \mathrm{C}$ bus system is activated by sending a valid address to the device. The address consists of a fixed part and a programmable part. The programmable part must be set according to the address pins A0, A1 and A2. The address always has to be sent as the first byte after the start condition in the $1^{2} \mathrm{C}$ bus protocol. The last bit of the address byte is the read/write-bit which sets the direction of the following data transfer (see Figs 3 and 10).


Fig. 3 Address byte.

## Control byte

The second byte sent to a PCF8591 device will be stored in its control register and is required to control the device function.
The upper nibble of the control register is used for enabling the analogue output, and for programming the analogue inputs as single-ended or differential inputs. The lower nibble selects one of the analogue input channels defined by the upper nibble (see Fig. 4). If the auto-increment flag is set the channel number is incremented automatically after each A/D conversion.
The selection of a non-existing input channel results in the highest available channel number being allocated. Therefore, if the auto-increment flag is set, the next selected channel will be always channel 0 . The most significant bits of both nibbles are reserved for future functions and have to be set to 0 . After a power-on reset condition all bits of the control register are reset to 0 . The D/A converter and the oscillator are disabled for power saving. The analogue output is switched to a high impedance state.


00 Four single ended inputs


01 Three differential inputs


10 Single ended and differential mixed


11 Two differential inputs


ANALOGUE OUTPUT ENABLE FLAG:
(analogue output active if 1)

Fig. 4 Control byte.

## D/A conversion

The third byte sent to a PCF8591 device is stored in the DAC data register and is converted to the corresponding analogue voltage using the on-chip D/A converter. This D/A converter consists of a resistor divider chain connected to the external reference voltage with 256 taps and selection switches. The tap-decoder switches one of these taps to the DAC output line (see Fig. 5).
The analogue output voltage is buffered by an auto-zeroed unity gain amplifier. This buffer amplifier may be switched on or off by setting the analogue output enable flag of the control register. In the active state the output voltage is held until a further data byte is sent.
The on-chip D/A converter is also used for successive approximation A/D conversion. In order to release the DAC for an A/D conversion cycle the unity gain amplifier is equipped with a track and hold circuit. This circuit holds the output voltage while executing the A/D conversion.
The output voltage supplied to the analogue output AOUT is given by the formula shown in Fig. 6. The waveforms of a D/A conversion sequence are shown in Fig. 7.


Fig. 5 DAC resistor divider chain.
MSB

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| DAC data <br> register |  |  |  |  |  |  |  |

7280963 register


Fig. 6 DAC data and d.c. conversion characteristics.


Fig. $7 \mathrm{D} / \mathrm{A}$ conversion sequence.

## A/D conversion

The $A / D$ converter makes use of the successive approximation conversion technique. The on-chip D/A converter and a high gain comparator are used temporarily during an A/D conversion cycle.
An A/D conversion cycle is always started after sending a valid read mode address to a PCF8591 device. The A/D conversion cycle is triggered at the trailing edge of the acknowledge clock pulse and is executed while transmitting the result of the previous conversion (see Fig. 8).

Once a conversion cycle is triggered an input voltage sample of the selected channel is stored on the chip and is converted to the corresponding 8-bit binary code. Samples picked up from differential inputs are converted to an 8 -bit two's complement code (see Fig. 9). The conversion result is stored in the ADC data register and awaits transmission. If the auto-increment flag is set the next channel is selected.
The first byte transmitted in a read cycle contains the conversion result code of the previous read cycle. After a power-on reset condition the first byte read is a hexadecimal 80 . The protocol of an $1^{2} \mathrm{C}$ bus read cycle is shown in Fig. 10.
The maximum A/D conversion rate is given by the actual speed of the $I^{2} \mathrm{C}$ bus.
 SDA


Fig. 8 A/D conversion sequence.


Fig. 9a $A / D$ conversion characteristics of single-ended inputs.


Fig. 9b A/D conversion characteristics of differential inputs.

## Reference voltage

For the $D / A$ and $A / D$ conversion either a stable external voltage reference or the supply voltage has to be applied to the resistor divider chain (pins $V_{\text {REF }}$ and AGND). The AGND pin has to be connected to the system analogue ground and may have a d.c. off-set with reference to $\mathrm{V}_{\mathrm{SS}}$.
A low frequency may be applied to the $V_{\text {REF }}$ and AGND pins. This allows the use of the D/A converter as a one-quadrant multiplier; see Application Information and Fig. 6.
The A/D converter may also be used as a one or two quadrant analogue divider. The analogue input voltage is divided by the reference voltage. The result is converted to a binary code. In this application the user has to keep the reference voltage stable during the conversion cycle.

## Oscillator

An on-chip oscillator generates the clock signal required for the A/D conversion cycle and for refreshing the auto-zeroed buffer amplifier. When using this oscillator the EXT pin has to be connected to $\mathrm{V}_{\text {SS }}$. At the OSC pin the oscillator frequency is available.
If the EXT pin is connected to VDD the oscillator output OSC is switched to a high impedance state allowing the user to feed an external clock signal to OSC.

## Bus protocol

After a start condition a valid hardware address has to be sent to a PCF8591 device. The read/write bit defines the direction of the following single or multiple byte data transfer. For the format and the timing of the start condition $(S)$, the stop condition $(P)$ and the acknowledge bit $(A)$ refer to the $1^{2} \mathrm{C}$ bus characteristics. In the write mode a data transfer is terminated by sending either a stop condition or the start condition of the next data transfer.


Fig. 10a Bus protocol for write mode, D/A conversion.


Fig. 10b Bus protocol for read mode, A/D conversion.

## CHARACTERICS OF THE $I^{2}$ C BUS

The $I^{2} \mathrm{C}$ bus is for bidirectional, two-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor. Data transfer may be initiated only when the bus is not busy.

## Bit transfer

One data bit is transfered during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as a control signal.


Fig. 11 Bit transfer.

## Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH, is defined as the start condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH, is defined as the stop condition (P).


Fig. 12 Definition of start and stop condition.

## System configuration

A device generating a message is a "transmitter", a device receiving a message is the "receiver". The device that controls the message is the "master" and the devices which are controlled by the master are the "slaves".


Fig. 13 System configuration.

## Acknowledge.

The number of data bytes transfered between the start and stop conditions from transmitter to receiver is not limited. Each data byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter whereas the master also generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.


Fig. 14 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$ bus.

## Timing specifications

All the timing values are valid within the operating supply voltage and ambient temperature range and refer to $V_{\text {IL }}$ and $V_{\text {IH }}$ with an input voltage swing of $V_{S S}$ to $V_{D D}$.

| parameter | symbol | min. | typ. | max. | unit |
| :--- | :--- | :---: | :---: | :---: | :--- |
| SCL clock frequency | fSCL | - | - | 100 | kHz |
| Tolerable spike width on bus | tSW | - | - | 100 | ns |
| Bus free time | tBUF | 4,0 | - | - | $\mu \mathrm{s}$ |
| Start condition set-up time | tSU; STA | 4,0 | - | - | $\mu \mathrm{s}$ |
| Start condition hold time | tHD; STA | 4,7 | - | - | $\mu \mathrm{s}$ |
| SCL LOW time | tLOW | 4,7 | - | - | $\mu \mathrm{s}$ |
| SCL HIGH time | tHIGH | 4,0 | - | - | $\mu \mathrm{s}$ |
| SCL and SDA rise time | tR | - | - | 1,0 | $\mu \mathrm{~s}$ |
| SCL and SDA fall time | tF | - | - | 0,3 | $\mu \mathrm{~s}$ |
| Data set-up time | tSU; DAT | 250 | - | - | ns |
| Data hold time | tHD; DAT | 0 | - | - | ns |
| SCL LOW to data out valid | tVD; DAT | - | - | 3,4 | $\mu \mathrm{~s}$ |
| Stop condition set-up time | tSU; STO | 4,0 | - | - | $\mu \mathrm{s}$ |

PROTOCOL

|  | START <br> CONDITION <br> (S) | BIT 7 <br> MSB <br> (A7) | BIT 6 |
| :--- | :--- | :--- | :--- |
| (A6) |  |  |  |


| BIT 0 | ACKNOW- | STOP |  |
| :--- | :--- | :--- | :--- |
| LSB <br> $(R / W)$ | LEDGE <br> (A) | CONDITION <br> $(P)$ |  |



Fig. $151^{2} \mathrm{C}$ bus timing diagram.

## RATINGS

Limiting values in accordance with the Absolute Maximum System (IEC 134)
$\left.\begin{array}{llrr}\text { Supply voltage range } & V_{D D} & -0,5 \text { to }+8,0 \mathrm{~V} \\ \text { Voltage on any pin } & V_{1} & & -0,5 \text { to } V_{D D}+0,5 \mathrm{~V}\end{array}\right)$

## Note:

Inputs and outputs are protected against electrostatic discharges in normal handling. However, to be totally safe, it is advised to take handling precautions appropriate to handling MOS devices (see 'Handling MOS devices').

## CHARACTERISTICS

$V_{D D}=2,5 \mathrm{~V}$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | conditions | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply |  |  |  |  |  |  |
| Supply voltage | operating | $V_{\text {DD }}$ | 2,5 | - | 6,0 | V |
| Supply current | standby |  |  |  |  |  |
|  | $V_{1}=V_{S S}$ or $V_{D D} ;$ no load | IDDO | - | 1 | 15 | $\mu \mathrm{A}$ |
| Supply current | operating; AOUT off; $\mathrm{fSCL}=100 \mathrm{kHz}$ | IDD1 | - | 125 | 250 | $\mu \mathrm{A}$ |
| Supply current | AOUT active; $\mathrm{fSCL}=100 \mathrm{kHz}$ | IDD2 | - | 0,45 | 1,0 | mA |
| Power-on reset level | note 1 | VPOR | 0,8 | - | 2,0 | V |
| Digital inputs/output | SCL, SDA, A0, A1, A2 |  |  |  |  |  |
| Input voltage | LOW | $V_{\text {IL }}$ | 0 | - | $0,3 \times V_{\text {DD }}$ | V |
| Input voltage | HIGH | $V_{\text {IH }}$ | $0,7 \times V_{\text {DD }}$ | - | VDD | V |
| Input current | leakage; $V_{1}=V_{S S} \text { to } V_{D D}$ | 11 | - | - | 250 | nA |
| Input capacitance |  | $\mathrm{Cl}_{1}$ | - | - | 5 | pF |
| SDA output current | reakage; <br> HIGH at $\mathrm{VOH}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{DD}}$ | IOH | - | - | 250 | nA |
| SDA output current | LOW at $\mathrm{V}_{\mathrm{OL}}=0,4 \mathrm{~V}$ | IOL | 3,0 | - | - | mA |


| parameter | conditions | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reference voltage inputs | VREF, AGND |  |  |  |  |  |
| Voltage range | reference | $V_{\text {REF }}$ | $\mathrm{V}_{\text {AGND }}$ | - | $V_{\text {DD }}$ | V |
| Voltage range | analogue ground | VAGND | VSS | - | $V_{\text {REF }}$ | V |
| Input current | leakage | \\| | - | - | 250 | nA |
| Input resistance | $V_{\text {REF }}$ to AGND | $\mathrm{R}_{\text {REF }}$ | - | 100 | - | $\mathrm{k} \Omega$ |
| Oscillator | OSC, EXT |  |  |  |  |  |
| Input current | leakage | 1 | - | - | 250 | nA |
| Oscillator frequency |  | fosc | 0,75 | - | 1,25 | MHz |

## D/A CHARACTERISTICS

$V_{D D}=5,0 \mathrm{~V} ; \mathrm{V}_{\text {SS }}=0 \mathrm{~V} ; \mathrm{V}_{\text {REF }}=5,0 \mathrm{~V} ; \mathrm{V}_{\text {AGND }}=0 \mathrm{~V} ; \mathrm{R}_{\text {load }}=10 \mathrm{k} \Omega ; \mathrm{C}_{\text {load }}=100 \mathrm{pF}$;
$\mathrm{T}_{\mathrm{amb}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | conditions | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Analogue output |  |  |  |  |  |  |
| Output voltage range | no resistive load | $\mathrm{V}_{\text {OA }}$ | $\mathrm{V}_{\text {SS }}$ | - | $V_{\text {DD }}$ | V |
| Output voltage range | $\mathrm{R}_{\text {load }}=10 \mathrm{k} \Omega$ | VOA | VSS | - | $0,9 x \vee D D$ | V |
| Output current | leakage; AOUT disabled | ILO | - | - | 250 | $n A$ |
| Accuracy |  |  |  |  |  |  |
| Offset error | $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$ | $\mathrm{OS}_{\mathrm{e}}$ | - | - | 50 | mV |
| Linearity error |  | Le | - | - | $\pm 1,5$ | LSB |
| Gain error | no resistive load | $\mathrm{G}_{\mathrm{e}}$ | - | - | 1 | \% |
| Settling time | to $1 / 2$ LSB full scale step | tDAC | - | - | 90 | $\mu \mathrm{s}$ |
| Conversion rate |  | $f_{\text {DAC }}$ | - | - | 11,1 | kHz |
| Supply noise rejection | $\begin{aligned} & \text { at } f=100 \mathrm{~Hz} \\ & V_{D D}=0,1 \mathrm{VPP} \end{aligned}$ | SNRR | - | 40 | - | dB |

## A/D CHARACTERISTICS

$V_{D D}=5,0 \mathrm{~V} ; \mathrm{V}_{\text {SS }}=0 \mathrm{~V} ; \mathrm{V}_{\text {REF }}=5,0 \mathrm{~V} ; \mathrm{V}_{\text {AGND }}=0 \mathrm{~V} ; \mathrm{R}_{\text {source }}=10 \mathrm{k} \Omega ; \mathrm{T}_{\text {amb }}=-40^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ unless otherwise specified

| parameter | conditions | symbol | min. | typ. | max. | unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Analogue inputs |  |  |  |  | VDD | V |
| Input voltage range | leakage | $V_{\text {IA }}$ | vSS | - |  |  |
| Input current |  | $1{ }_{\text {IA }}$ | - | - | 100 | nA |
| Input capacitance |  | $C_{\text {IA }}$ | - | 10 | - | pF |
| Input capacitance | differential | CID | - | 10 | - | pF |
| Single-ended voltage | measuring range | VIS | VAGND | - | $V_{\text {REF }}$ | V |
| Differential voltage | measuring range; |  |  |  |  |  |
|  | $V_{F S}=V_{\text {REF }}$ <br> $-V_{\text {AGND }}$ | VID | $\frac{-V_{F S}}{2}$ | - | $\frac{+V_{F S}}{2}$ | V |
| Accuracy | $\mathrm{Tamb}=25^{\circ} \mathrm{C}$ |  |  |  |  |  |
| Offset error |  | $\mathrm{OS}_{\mathrm{e}}$ | - | - | 20 | mV |
| Linearity error |  | Le | - | - | $\pm 1,5$ | LSB |
| Gain error |  | $\mathrm{G}_{\mathrm{e}}$ | - | - | 1 | \% |
| Gain error | small-signal; | GS | - | - | 5 | \% |
| Rejection ratio | common-mode | CMRR | - | 60 | - | dB |
| Supply noise rejection | at $\mathrm{f}=100 \mathrm{~Hz}$; |  |  |  |  |  |
|  | $V_{D D N}=0,1 \times V_{P P}$ | SNRR | - | 40 | - | dB |
| Conversion time |  | ${ }^{t} A D C$ | - | - | 90 | $\mu \mathrm{s}$ |
| Sampling/conversion rate |  | ${ }^{\text {f }}$ ADC | - | - | 11,1 | kHz |

## Note

1. The power on reset circuit resets the $I^{2} \mathrm{C}$ bus logic when $\mathrm{V}_{\mathrm{DD}}$ is less than $\mathrm{V}_{P O R}$.

(a) internal oscillator; $\mathrm{T}_{\mathrm{amb}}=+27^{\circ} \mathrm{C}$.

(b) external oscillator.

Fig. 16 Operating supply current against supply voltage (analogue output disabled).

(a) output impedance near negative power rail; $T_{a m b}=+27^{\circ} \mathrm{C}$.

(b) output impedance near positive power rail; $T_{\mathrm{amb}}=+27^{\circ} \mathrm{C}$.

Fig. 17 Output impedance of analogue output buffer (near power rails).
The $x$-axis represents the hex input-code equivalent of the output voltage.

## PCF8591

## APPLICATION INFORMATION

Inputs must be connected to $\mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\text {DD }}$ when not in use. Analogue inputs may also be connected to AGND or $V_{\text {REF }}$.

In order to prevent excessive ground and supply noise and to minimize cross-talk of the digital to analogue signal paths the user has to design the printed-circuit board layout very carefully. Supply lines common to a PCF8591 device and noisy digital circuits and ground loops should be avoided. Decoupling capacitors ( $>10 \mu \mathrm{~F}$ ) are recommended for power supply and reference voltage inputs.


Fig. 18 Application diagram.


ㅍus

Purchase of Philips' $1^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $\mathrm{I}^{2} \mathrm{C}$-system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specification defined by Philips.

## PACKAGE INFORMATION

Package outlines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1249

Soldering. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1277

## PACKAGE OUTLINES

For products: 2960, 2964B, 9401, 9403 and for products with prefixes: SCN, 8T, 8X1247
For products with prefixes: MAB, MAF, MEA, OM, PCD, PCF, SAA, TEA ..... 1255For products: 2960, 2964B, 9401, 9403 and for productswith prefixes: SCN, 8T, 8X
General information ..... 1249
F Hermetic cerdip ..... 1251
| Hermetic cerdil ..... 1252
N Plastic dual in-line ..... 1254

## GENERAL INFORMATION

## INTRODUCTION

The following information applies to all packages unless otherwise specified on individual package outline drawings.

## General

1. Dimensions shown are metric units (millimeters), except those in parentheses which are English units (inches).
2. Lead spacing shall be measured within this zone.
a. Shoulder and lead tip dimensions are to centerline of leads.
3. Tolerances non-cumulative
4. Thermal resistance values are determined by utilizing the linear temperature dependence of the forward voltage drop across the substrate diode in a digital device to monitor the junction temperature rise during known power application across VCC and ground. The values are based upon 120 mils square die for plastic packages and a 90 mils square die in the smallest available cavity for hermetic packages. All units were solder mounted to P.C. boards, with standard stand-off, for measurement

## Plastic Only

5. Lead material: Olin 194 (copper alloy) or equivalent, solder dipped
6. Body material: Plastic (epoxy)
7. Round hole in top corner denotes lead No. 1.
8. Body dimensions do not include molding flash.
9. SO packages-microminiature pack. ages:
a. Lead material: Olin 194 (copper alloy) or equivalent, solder dipped.
b. Body material: Plastic (epoxy).

## Hermetic Only

10. Lead material
a. ASTM alloy F. 15 (KOVAR) or equivalent gold plated, tin plated, or soider dipped.
b. ASTM alloy F-30 (Alloy 42) or equivalent tin plated. gold plated or solder dipped.
c. ASTM alloy F-15 (KOVAR) or equivalent gold plated.
11. Body Material
a. Eyelet, ASTM alloy F-15 or equivalent gold or tin plated, glass body.
b. Ceramic with glass seal at leads
c. BeO ceramic with glass seal at leads.
d. Ceramic with ASTM alloy $F \cdot 30$ or equiv. alent

Lid Material
a. Nickel or tin plated nickel, weld seal
b. Ceramic, glass seal.
c. ASTM alloy F- 15 or equivalent, gold plated. alloy seai.
a BeO Ceramic with glass seal
13. Signetics symbol, angle cut, or lead tab denotes Lead No. 1.
14. Recommended minimum offset before lead bend
15. Maximum glass climb . 010 inches.
16. Maximum glass climb or lid skew is . 010 inches.
17. Typical four places.
18. Dimension also applies to seating plane.

PLASTIC PACKAGES

| NO. OF LEADS | PACKAGE CODE | $\Theta_{j o} / \Theta_{j c}\left({ }^{\circ} \mathbf{C} / W\right)$ |
| :---: | :---: | :---: |
| Plastic Dual-In-Line |  | DESCRIPTION |
| 14 | NHA | $95 / 33$ |
| 16 | NJA | $73 / 33$ |
| 18 | NKA | $69 / 26$ |
| 20 | NLA | Cu Lead Frame |
| 24 | NNA | Cu Lead Frame |
| 28 | NQA | Cu Lead Frame |
|  |  | Cu Lead Frame |
| SO Packages | $56 / 23$ | Cu Lead Frame |
| 16 | DJ | Cu Lead Frame |
| 20 | DL | tbd |

GENERAL INFORMATION (continued)
hermetic packages

| NO. OF LEADS | PACKAGE CODE | $\theta_{j a} / \Theta_{j c}\left({ }^{\circ} \mathrm{C} / \mathrm{W}\right)$ | DESCRIPTION ${ }^{1}$ |
| :---: | :---: | :---: | :---: |
| Flat Packs |  |  |  |
| 10 | QF | 230155 | Flat Ceramic |
| 10 | WF | 240/50 | Flat Ceramic |
| 14 | QHA | 185/45 | Flat Ceramic Laminate |
| 14 | WH | 205/50 | Flat Ceramic |
| 16 | QJA | 170/45 | Flat Ceramic Laminate |
| 16 | RJA | 133/30 | Flat Ceramis, BeO |
| 16 | WJ | 200/50 | Flat Ceramic |
| 18 | RKA | 107/22 | Flat Ceramic, BeO |
| 24 | QNA | 155/44 | Flat Ceramic Laminate |
| 24 | RNA | 107/22 | Flat Ceamic, BeO |
| 24 | WN | 155/40 | Flat Ceramic |
| 28 | RQA | 107/22 | Flat Ceramic, BeO |
| 40 | RWA | 95/20 | Flat Ceramic, BeO |
| Cerdip Family |  |  |  |
| 8 | FE | 110/30 | Dual-In-Line Ceramic |
| 14 | FH | 110/30 | Dual-In-Line Ceramic |
| 16 | FJ | 77/30 | Dual-In-Line Ceramic |
| 18 | FK | 73/27 | Dual-In-Line Ceramic |
| 20 | FL | 72/25 | Dual-In-Line Ceramic |
| 22 | FM | 66/27 | Dual-In-Line Ceramic |
| 24 | FN | 63/26 | Dual-In-Line Ceramic |
| 28 | FQ | 57/27 | Dual-In-Line Ceramic |

NOTE

1. Dual-In-Line packages unless otherwise described

Memory Package Codes consist of two or three alphas as follows:

|  | N | K | A | Revision or other Signetics internal designator |
| :---: | :---: | :---: | :---: | :---: |
| Package Type |  |  |  |  |
| A = Plastic Leaded |  |  |  |  |
| D = Small Outline Plastic DIP |  |  |  | Number of Pins |
| $F=$ Cerdip |  |  |  | $J=16$ |
| $\mathrm{G}=$ Hermetic Leadless |  |  |  | $K=18$ |
| $N=$ Plastic DIP |  |  |  | $L=20$ |
| R = Ceramic Flat Pack |  |  |  | $\mathrm{M}=22$ |
| W = Cerpack Flat Pack |  |  |  | $\mathrm{N}=24$ $\mathrm{Q}=28$ |

## PACKAGE OUTLINES

## HERMETIC: Cerdip

FH 14


FM 22


FL 20


FN 24


FQ 28

constructions videss ar hon lle

## PACKAGE OUTLINES

HERMETIC: Cerdil
I 24


128


## HERMETIC: Cerdil (continued)

## 148



150


NOTE:

1. If solder dipped terminals used, terminal dimension tolerances may be increased by .001 .

## PLASTIC: Dual-in-line

NLA 20


NNA 24


N 22


NQA 28



N 14, N 48, N 50, N 64 For current information contact local sales offices.
For products with prefixes: MAB, MAF, MEA, OM, PCD,PCF, SAA, TEA
16-lead dual in line; plastic (SOT-38) ..... 1257
8 -lead dual in-line; plastic (SOT-97AE, DE, EE) ..... 1258
24-lead dual in-line; plastic (SOT-101A, B, F, G, L) ..... 1259
18-lead dual in-line; plastic (SOT-102HE, HG, KE, ME, PG) ..... 1260
28-lead dual in-line; plastic (SOT-117) ..... 1261
40-lead dual in-line; plastic (SOT-129) ..... 1262
28-lead dual in-line; ceramic (cerdip) (SOT-135A) ..... 1263
28-lead mini pack; plastic (SO-28; SOT-136A) ..... 1264
20-lead dual in-line; plastic (SOT-146) ..... 1265
8 -lead dual in-line; ceramic (cerdip) (SOT-151A) ..... 1266
40-lead mini-pack; plastic (VSO-40; SOT-158A) ..... 1267
16-lead mini-pack; plastic (SO-16L; SOT162A) ..... 1268
20-lead mini-pack; plastic (SO-20; SOT-163A) ..... 1269
8-lead mini-pack; plastic (SO-8L; SOT-176) ..... 1270
44-lead plastic leaded chip-carrier (PLCC); (SOT-187A) ..... 1271
68-lead plastic leaded chip-carrier (PLCC); (SOT-188A) ..... 1272
56-lead mini-pack; plastic (VSO-56; SOT-215) ..... 1273
40-lead dual in-line piggy back; plastic (SOT-215). ..... 1274
144-pin grid array (PGA) ..... 1275

## PACKAGE OUTLINES

## 16-LEAD DUAL IN-LINE; PLASTIC (SOT-38)


(2) Lead spacing tolerances apply from seating plane to the line indicated.

## Dimensions in mm



## 24-LEAD DUAL IN-LINE; PLASTIC (SOT-101A,B,F,G,L)


$\bigoplus$ Positional accuracy.
(M) Maximum Material Condition.
(1) Centre-lines of all leads are within $\pm 0,127 \mathrm{~mm}$ of the nominal position shown; in the worst case, the spacing between any two leads may deviate from nominal by $\pm 0,254 \mathrm{~mm}$.
(2) Lead spacing tolerances apply from seating plane to the line indicated.
(3) Index may be horizontal as shown, or vertical.

## Dimensions in mm

## 18-LEAD DUAL IN-LINE; PLASTIC (SOT-102HE, HG, KE, ME, PG)


side view
$\dagger$ Positional accuracy.
(IM) Maximum Material Condition.
(1) Centre-lines of all leads are within $\pm 0,127 \mathrm{~mm}$ of the nominal position shown; in the worst case, the spacing between any two leads may deviate from nominal by $\pm 0,254 \mathrm{~mm}$.
(2) Lead spacing tolerances apply from seating plane to the line indicated.

## Dimensioris in mm

## 28-LEAD DUAL IN-LINE; PLASTIC (SOT-117)





## Dimensions in mm

(3) Index may be horizontal as shown, or vertical.

28-LEAD DUAL IN-LINE; CERAMIC (CERDIP) (SOT-135A)


(1) Positional accuracy.
(M) Maximum Material Condition.
(1) Centre-lines of all leads are within $\pm 0,127 \mathrm{~mm}$ of the nominal position shown; in the worst case, the spacing between any two leads may deviate from nominal by $\pm 0,254 \mathrm{~mm}$.
(2) Lead spacing tolerances apply from seating plane to the line indicated.

## Dimensions in mm

## 28-LEAD MINI-PACK; PLASTIC (SO-28; SOT-136A)



Dimensions in mm
(1) Positional accuracy.
(IM) Maximum Material Condition.

## 20-LEAD DUAL IN-LINE; PLASTIC (SOT-146; 146C1)



side view
$\bigoplus$ Positional accuracy.
(M) Maximum Material Condition.
(1) Centre-lines of all leads are within $\pm 0,127 \mathrm{~mm}$ of the nominal position shown; in the worst case, the spacing between any two leads may deviate from nominal by $\pm 0,254 \mathrm{~mm}$.
(2) Lead spacing tolerances apply from seating plane to the line indicated.

## 8-LEAD DUAL IN-LINE; CERAMIC (CERDIP) (SOT-151A)



$\bigoplus$ Positional accuracy.
(M) Maximum Material Condition.
(1) Centre-lines of all leads are within $\pm 0,127 \mathrm{~mm}$ of the nominal position shown; in the worst case, the spacing between any two leads may deviate from nominal by $\pm 0,254 \mathrm{~mm}$.
(2) Lead spacing tolerances apply from seating plane to the line indicated.
Dimensions in mm

## PACKAGE OUTLINES

## 40-LEAD MINI-PACK; PLASTIC (VSO-40; SOT-158A)



## Dimensions in mm

$\bigoplus$ Positional accuracy.
(M) Maximum Material Condition.

## PACKAGE OUTLINES

## 16-LEAD MINI-PACK; PLASTIC (SO-16L; SOT-162A)



Dimensions in mm
$\bigoplus$ Positional accuracy.
(M) Maximum Material Condition.

## 20-LEAD MINI-PACK; PLASTIC (SO-20; SOT-163A)



Dimensions in mm
(1) Positional accuracy.
(M) Maximum Material Condition.

## 8-LEAD MINI-PACK; PLASTIC (SO-8L; SOT-176)




Dimensions in mm
$\bigoplus$ Positional accuracy.
(M) Maximum Material Condition.


44-LEAD PLASTIC LEADED CHIP-CARRIER (PLCC); SOT-187A



## PACKAGE OUTLINES

56-LEAD MINI-PACK; PLASTIC (VSO-56; SOT-190)


Dimensions in mm
© Positional accuracy.
(IM) Maximum Material Condition.

## 40-LEAD DUAL IN-LINE PIGGY BACK; PLASTIC (SOT-215)



## 144-PIN GRID ARRAY (PGA)



## Soldering

Plastic dual in-line (DIL) packages. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1279
Plastic mini-pack (SO) packages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1279
.

## SOLDERING

## Plastic dual in-line (DIL) packages

## 1. By hand

Apply the soldering iron below the seating plane (or not more than 2 mm above it).
If its temperature is below $300^{\circ} \mathrm{C}$ it must not be in contact for more than 10 seconds; if between $300^{\circ} \mathrm{C}$ and $400^{\circ} \mathrm{C}$, for not more than 5 seconds.

## 2. By dip or wave

The maximum permissible temperature of the solder is $260^{\circ} \mathrm{C}$; this temperature must not be in contact with the joint for more than 5 seconds. The total contact time of successive solder waves must not exceed 5 seconds.
The device may be mounted up to the seating plane, but the temperature of the plastic body must not exceed the specified storage maximum. If the printed-circuit board has been pre-heated, forced cooling may be necessary immediately after soldering to keep the temperature within the permissible limit.

## 3. Repairing soldered joints

The same precautions and limits apply as in (1) above.

## Plastic mini-pack (SO) packages

1. By hand-held soldering iron or pulse-heated solder tool

Apply the heating tool to the flat part of the lead only. Contact time must be limited to 10 seconds at up to $300^{\circ} \mathrm{C}$. When using proper tools, all leads can be soldered in one operation within 2 to 5 seconds at between 270 and $320^{\circ} \mathrm{C}$. (Pulse-heated soldering is not recommended for SO packages).
For pulse-heated solder tool (resistance) soldering of VSO packages, solder is applied to substrate by dipping or by an extra thick tin/lead plating before package placement.

## 2. By wave

Maximum permissible solder temperature is $260^{\circ} \mathrm{C}$, and maximum duration of package immersion in solder bath is 10 seconds, if allowed to cool to less than $150^{\circ} \mathrm{C}$ within 6 seconds. Typical dwell time is 4 seconds at $250^{\circ} \mathrm{C}$.
A modified wave soldering technique is recommended, using two solder waves (dual-wave); a first turbulent wave with high upward pressure is followed by a smooth, laminar wave. A mildly activated flux will eliminate the need for removal of corrosive residues in most applications.

## 3. By solder paste reflow

Reflow soldering requires the solder paste (a suspension of fine solder particles, flux and binding agent) to be applied to the substrate by screen printing or pressure-syringe dispensing before device placement.
Several techniques exist for reflowing, for example, thermal conduction by heated belt, infrared, and vapour-phase reflow. Dwell times vary between 8 and 60 seconds according to method. Typical reflow temperatures range from 215 to $250{ }^{\circ} \mathrm{C}$.
Pre-heating is necessary to dry paste and evaporate binding agent, and to reduce thermal shock on entry to reflow zone.

## 4. Repairing soldered joints

The same precautions and limits apply as in (1) above.

# Electronic components and materials for professional, industrial and consumer uses from the world-wide Philips Group of Companies 

Argentina: PHILIPS ARGENTINA S.A., Div. Elcoma, Vedia 3892, 1430 BUENOS AIRES, Tel. (01) $541-7141$ to 7747.
Australia: PHILIPS INDUSTRIES LTD., Elcoma Division, 11 Waltham Street, ARTARMON, N.S.W. 2064, Tel. (02) 4393322.
Austria: ÖSTERREICHISCHE PHILIPS INDUSTRIE G.m.b.H., UB Bauelemente, Triester Str. 64, A-1101 WIEN, Tel. (0222) 6291 11-0.
Belgium: N.V. PHILIPS \& MBLE ASSOCIATED, 80 Rue Des Deux Gares, B-1070 BRUXELLES, Tel. (02) 525-61-11.
Brazil: CONSTANTA-IBRAPE; (Active Devices): Av. Brigadeiro Faria Lima, 1735-SAO PAULO-SP, Tel. (011) 211-2600,
(Passive Devices \& Materials): Av. Francisco Monteiro, 702 - RIBEIRAO PIRES-SP, Tel. (011) 459-8211.
Canada: PHILIPS ELECTRONICS LTD., Elcoma Division, 601 Milner Ave., SCARBOROUGH, Ontario, M1B 1M8, Tel. (416) 292-5161.
Chile: PHILIPS CHILENA S.A., Av. Santa Maria 0760, SANTIAGO, Tel. (02) 773816.
Colombia: IND. PHILIPS DE COLOMBIA S.A., c/o IPRELENSO LTD., Cra. 21, No. 56-17, BOGOTA, D.E., Tel. (01) 2497624.
Denmark: MINIWATT A/S, Strandlodsvej 2, P.O. Box 1919, DK 2300 COPENHAGEN S, Tel. (01) 541133.
Finland: OY PHILIPS AB, Elcoma Division, Kaivokatu 8, SF-00100 HELSINKI 10, Tel. (90) 17271.
France: RTC-COMPELEC, 130 Avenue Ledru Rollin, F-75540 PARIS 11, Tel. (01) 43388000.
Germany (Fed. Republic): VALVO, UB Bauelemente der Philips G.m.b.H., Valvo Haus, Burchardstrasse 19, D-2 HAMBURG 1, Tel. (040) 3296-0.
Greece: PHILIPS HELLENIQUE S.A., Elcoma Division, No. 15, 25 th March Street, GR 17778 TAVROS, Tel. (01) 4894339/4894 911.
Hong Kong: PHILIPS HONG KONG LTD., Elcoma Div., 15/F Philips Ind. Bldg., 24-28 Kung Yip St., KWAI CHUNG, Tel. (0)-245121.
India: PEICO ELECTRONICS \& ELECTRICALS LTD., Elcoma Dept., Band Box Building,
Indonesia: P.T. PHILIPS-RALIN ELECTRONICS, Elcoma Div., Setiabudi II Building, 6th FI., Jalan H.R. Rasuna Said (P.O. Box 223/KBY) Kuningan, JAKARTA 12910, Tel. (021) 517995.
Ireland: PHILIPS ELECTRICAL (IRELAND) LTD., Elcoma Division, Newstead, Clonskeagh, DUBLIN 14, Tel. (01) 693355.
Italy: PHILIPS S.p.A., Div. Componenti Elcoma, Piazza IV Novembre 3, I-20124 MILANO, Tel. (02) 6752.1.
Japan: NIHON PHILIPS CORP., Shuwa Shinagawa Bldg., 26-33 Takanawa 3-chome, Minato-ku, TOKYO (108), Tel. (03) 448-5611. (IC Products) SIGNETICS JAPAN LTD., 8-7 Sanbancho Chiyoda-ku, TOKYO 102, Tel. (03) 230-1521.
Korea (Republic of): PHILIPS ELECTRONICS (KOREA) LTD., Elcoma Div., Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. (02) 794-5011.
Malaysia: PHILIPS MALAYSIA SDN BHD, Elcoma Div., 345 Jalan Gelugor, 11700 PULAU PINANG, Tel. (04) 870044.
Mexico: ELECTRONICA, S.A de C.V., Carr. México-Toluca km. 62.5, TOLUCA, Edo. de México 50140, Tel. Toluca 91 (721) 613-00.
Netherlands: PHILIPS NEDERLAND, Marktgroep Elonco, Postbus 90050, 5600 PB EINDHOVEN, Tel. (040) 783749.
New Zealand: PHILIPS NEW ZEALAND LTD., Elcoma Division, 110 Mt . Eden Road, C.P.O. Box 1041, AUCKLAND, Tel. (09) 605-914.
Norway: NORSK A/S PHILIPS, Electronica Dept., Sandstuveien 70, OSLO 6, Tel. (02) 680200.
Pakistan: PHILIPS ELECTRICAL CO. OF PAKISTAN LTDं., Philips Markaz, M.A. Jinnah Rd., KARACHI-3, Tel. (021) 725772.
Peru: CADESA, Av. Alfonso Ugarte 1268, LIMA 5, Tel. (014) 326070.
Philippines: PHILIPS INDUSTRIAL DEV. INC., 2246 Pasong Tamo, P.O. Box 911, Makati Comm. Centre, MAKATI-RIZAL 3116, Tel. (02) 868951 to 59.
Portugal: PHILIPS PORTUGUESA S.A.R.L., Av. Eng. Duarte Pacheco 6, 1009 LiSBOA Codex, Tel. (019) 683121.
Singapore: PHILIPS PROJECT DEV. (Singapore) PTE LTD., Elcoma Div., Lorong 1, Toa Payoh, SINGAPORE 1231, Tel. 3502000.
South Africa: S.A. PHILIPS (Pty) LTD., EDAC Div., 3rd Floor Rainer House, Upper Railway Rd. \& Ove St., New Doornfontein, JOHANNESBURG 2001, Tel. (011) 402-4600/07.
Spain: MINIWATT S.A., Balmes 22, BARCELONA 7, Tel. (03) 3016312.
Sweden: PHILIPS KOMPONENTER A.B., Lidingövägen 50, S-11584 STOCKHOLM 27, Tel. (08) 7821000.
Switzerland: PHILIPS A.G., Elcoma Dept., Allmendstrasse 140-142, CH-8027 ZÜRICH, Tel. (01) 4882211.
Taiwan: PHILIPS TAIWAN LTD., 150 Tun Hua North Road, P.O. Box 22978 , TAIPEI, Taiwan, Tel. (02) 7120500.
Thailand: PHILIPS ELECTRICAL CO. OF THAILAND LTD., 283 Silom Road, P.O. Box 961, BANGKOK, Tel. (02) 233-6330-9.
Turkey: TÜRK PHILIPS TICARETA.S., Elcoma Department, Inönü Cad., No. 78-80, 80090 Ayazpasa ISTANBUL, Tel. (01) 1435910.
United Kingdom: MULLARD LTD., Mullard House, Torrington Place, LONDON WC1E 7HD, Tel. (01) 5806633.
United States: (Active Devices \& Materials) AMPEREX SALES CORP., Providence Pike, SLATERSVILLE, R.I. 02876, Tel. (401) 762-9000. (Passive \& Electromech. Dev.) MEPCO/CENTRALAB, INC., 2001 West Blue Heron BIvd, RIVIERA BEACH, Florida 33404, Tel. (305) 881-3200.
(IC Products) SIGNETICS CORPORATION, 811 East Arques Avenue, SUNNYVALE, CA 94088-3409, Tel. (408) 991-2000.
Uruguay: LUZILECTRON S.A., Avda Uruguay 1287, P.O. Box 907, MONTEVIDEO, Tel. (02) 985395.
Venezuela: IND. VENEZOLANAS PHILIPS S.A., c/o MAGNETICA S.A., Calle 6, Ed. Las Tres Jotas, App. Post. 78117, CARACAS, Tel. (02) 2393931.
For all other countries apply to: Philips Electronic Components and Materials Division, International Business Relations, P.O. Box 218 ,
5600 MD EINDHOVEN, The Netherlands, Telex 35000 phtcnl


[^0]:    * 

    User manual 1986
    "Single-chip 8-bit Microcontrollers"
    Available on request

[^1]:    * Registers are both byte and bit addressable.

[^2]:    ** MOV A,ACC is not a valid instruction.

[^3]:    * Preliminary value.

[^4]:    ** MOV A, ACC is not a valid instruction.

[^5]:    * Preliminary value. Table showing ICC as function of frequency will be available at a later date.

[^6]:    ** MOV A,ACC is not permitted.

[^7]:    * Interfacing the PCB83C552 to devices with float times up to 75 ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.

[^8]:    ** MOV A,ACC is not permitted.

[^9]:    * Preliminary value for 85C51 only. Current for piggy-back EPROM must be added.

[^10]:    * Interfacing the PCB85C51 to devices with float times up to 75 ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.

[^11]:    * Preliminary values.

[^12]:    * Because of the inverted interrupt input $\mathrm{CE} / \overline{\mathrm{TO}}$ the conditional jump JTO is also inverted.

[^13]:    * The interrupt signal must be continually active until the vector address 05 H is present on the address bus.

[^14]:    Notes on following page.

[^15]:    NOTES:

    1. If not empty
    2. If not full

    X Don't Care

[^16]:    1. If all programming can be done in less than 1 second, $\mathrm{V}_{\mathrm{CC}}$ may remain at 7.75 V for the entire programming cycle.
[^17]:    CAUTION
    To prevent possible damage to the crystal. never apply an external oscillator signal to X1 or X2 input with crystal Y2 connected to the circuit.

[^18]:    *CP/M is a trademark of Digital Research Corp.
    ${ }^{*}$ ISIS is a trademark of Intel Corporation.

[^19]:    *In CODE $1 D_{2-0} 011$ the Check-Bit Latch is forced transparent, the Data Latch operates normaliy.

[^20]:    ** Device not tested in GENERATE mode

[^21]:    * fill in a mnemonic of the ACU-initialization field.
    ** fill in a mnemonic of the RFILE field.

[^22]:    ${ }^{1}$ A data package for this terminal is available upon request from Signetics.

[^23]:    ${ }^{1}$ A data package for the design, including details of operation, schematic, and program listing, is available upon request by writing to: Signetics Corporation Microprocessor Applications Dept.
    Mail Station 2576
    P.O. Box 3409

    Sunnyvale, CA 94088-3409
    February 1985

[^24]:    ${ }^{1}$ Rows are mumbered consecutively starting with row 0 . Thus, row 23 is the twenty-fourth row of characters.

[^25]:    * Equivalent to discharging a $250 \mu \mathrm{~F}$ capacitor through a $1 \mathrm{k} \Omega$ series resistor.

[^26]:    * Only valid for repeated start code.

[^27]:    * Only valid for repeated start code.

[^28]:    * Only valid for repeated start code.

[^29]:    * Only valid for repeated start code.

[^30]:    * Derate $7,7 \mathrm{~mW} / \mathrm{K}$ when $\mathrm{T}_{\mathrm{amb}}>60^{\circ} \mathrm{C}$.

[^31]:    * $V_{D D}=5 \mathrm{~V}$; $\mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$.
    ** The power-on-reset circuit resets the $I^{2} \mathrm{C}$ bus logic with $\mathrm{V}_{\mathrm{DD}}<\mathrm{V}_{\text {REF }}$.

