

THOMSON MOSTEK 1987

DATA BOOK \\ \section*{MICROPROCESSORS \\ \section*{MICROPROCESSORS and PERIPHERALS} and PERIPHERALS}


## CONTENTS

GENERAL INFORMATION
Contents ..... i
Alphanumerical index ..... iii
CHAPTER 1-6800 MICROPROCESSORS
6800 Microprocessors Selection Guide ..... 1-1
EF6802•EF6808 Microprocessor with Clock and Optional RAM ..... 1-3
EF6801•EF6803 Microcomputer/Microprocessor (MCU/MPU) ..... 1-27
EF6801U4•EF6803U4 Microcomputer/Microprocessor (MCU/MPU) ..... 1-67
EF6809 8-Bit Microprocessor Unit (MPU) ..... 1-111
EF6809E 8-Bit Microprocessor Unit (MPU) ..... 1-151
CHAPTER 2-6800 PERIPHERALS
6800 Peripherals Selection Guide ..... 2-1
EF6821 Peripheral Interface Adapter (PIA) ..... 2-3
EF6840 Programmable Timer Module (PTM) ..... 2-15
EF6850 Asynchronous Communications Interface Adapter (ACIA) ..... 2-31
EF6854 Advanced Data-Link Controller (ADLC) ..... 2-41
CHAPTER 3-68000 MICROPROCESSORS
68000 Microprocessors Selection Guide ..... 3-1
TS68000 16/32-Bit Microprocessor ..... 3-3
TS68008 8/32-Bit Microprocessor with 8-Bit Data Bus ..... 3-95
MK68200 FAMILY 16-Bit Single-Chip Microcomputers ..... 3-191
MK68HC200 FAMILY 16-Bit Single-Chip Microcomputers ..... 3-265
CHAPTER 4-68000 PERIPHERALS
68000 Peripherals Selection Guide ..... 4-1
MK68230 Parallel Interface/Timer ..... 4-3
MK68451 Memory Management Unit ..... 4-13
MK68564 Serial Input/Output Controller ..... 4-17
MK68901 Multi-Function Peripheral ..... 4-29
TS68HC901 HCMOS Multi-Function Peripheral ..... 4-59
CHAPTER 5 - MICROCOMPUTER PERIPHERALS
Microcomputer Peripherals Selection Guide ..... 5-1
MK3801 Serial Timer Interrupt Controller ..... 5-3
MK3835-MK3831 CMOS Microcomputer Clock/RAM ..... 5-19

## CONTENTS

Page
CHAPTER 6-CRT CONTROLLER
CRT Controllers Selection Guide ..... 6-1
EF9345 Single Chip Semi-Graphic Display Processor ..... 6-3
EF9367 Graphic Display Processor (GDP) ..... 6-49
EF9369 Single Chip Color Palette ..... 6-81
TS68483 Advanced Graphic and Alphanumeric Controller ..... 6-97
TS68494 Palette and Serial Port Controller ..... 6-143
CHAPTER 7 - DIGITAL SIGNAL PROCESSING ICs
Digital Signal Processing ICs Selection Guide ..... 7-1
TS68930•TS68931 Programmable Signal Processor ..... 7-3
TS68950 Modem Transmit Analog Interface ..... 7-55
TS68951 Modem Receive Analog Interface ..... 7-69
TS68952 Modem Transmit/Receive Clock Generator ..... 7-93
CHAPTER 8 - DATA COMMUNICATIONS ICs
MK68590 Local Area Network Controller for Ethernet ..... 8-1
MK68591/2 Serial Interface Adapter ..... 8-17
CHAPTER 9 - SURFACE MOUNTED DEVICES
LCC Selection Guide ..... 9-1
PLCC Selection Guide ..... 9-2

| Part number | Page | Part number | Page | Part number | Page |
| :--- | :--- | :--- | :--- | :--- | :--- |
| EF6802 | $1-3$ | MK3831 | $5-19$ | TS68008 | $3-95$ |
| EF6803 | $1-27$ | MK3835 | $5-19$ | MK68230 | $4-3$ |
| EF6803U4 | $1-67$ | MK68201 | $3-191$ | TS68483 | $6-97$ |
| EF6809 | $1-111$ | MK68211 | $3-191$ | TS68494 | $6-143$ |
| EF6809E | $1-151$ | MK68451 | $4-13$ | TS68930 | $7-3$ |
| EF6821 | $2-3$ | MK68564 | $4-17$ | TS68931 | $7-3$ |
| EF6840 | $2-15$ | MK68901 | $4-29$ | TS68950 | $7-55$ |
| EF6850 | $2-31$ | MK68E201 | $3-191$ | TS68951 | $7-69$ |
| EF6854 | $2-41$ | MK68E211 | $3-191$ | TS68952 | $7-93$ |
| EF9345 | $6-3$ | MK68HC201 | $3-265$ | TS68HC901 | $4-59$ |
| EF9367 | $6-49$ | MK68HC211 | $3-265$ |  |  |
| EF9369 | $6-81$ | MK68HCE221 | $3-265$ |  |  |
| MK3801 | $5-3$ | TS68000 | $3-3$ |  |  |

## THOMSON - MOSTEK TECHNICAL SUPPORT, PRODUCT MARKETING

## FOR INTEGRATED CIRCUITS:

(Corporate Headquarters)
1310 Electronics
Carrollton, TX 75006
214/466-6000
TWX 910-860-5437

FOR DISCRETE DEVICES AND R \& MICROWAVE TRANSISTORS:
16 Commerce Drive
Montgomeryville, PA 18936-1002
215/362-8500
FAX 215/362-1293

FOR PASSIVE COMPONENTS:
6203 Variel Avenue, Unit A P.O. Box 4051 Woodland Hills, CA 91367 818/887-1010
FAX 818/702-0725

FOR SPECIAL PRODUCTS:
301 Route 17 North
Rutherford, NJ 07070
201/438-2300
FAX 201/438-1774

## U.S. AND CANADIAN SALES OFFICES:

## WESTERN AREA:

Thomson Components - Mostek Corporation 2540 Mission College Blvd.
Suite 104
Santa Clara, CA 95054
408/970-8585
FAX 408-970-8737
Thomson Components - Mostek Corporation
18004 Skypark Circle
Suite 140
Irvine, CA 92714
714/250-0455
FAX 714/261-1505
Thomson Components - Mostek Corporation
6203 Variel Ave.
Unit A, P.O. Box 4051
Woodland Hills, CA 91367
818/887-1010
FAX 818/702-0725
Thomson Components - Mostek Corporation 1107 North East 45th St.
Suite 411
Seattle, WA 98105
206/632-0245
FAX 206/633-5413
Thomson Components - Mostek Corporation
601 South Bowen St.
Longmont, CO 80501
303/449-9000
FAX 303/651-7976
Thomson Components - Mostek Corporation
7950 East Redfield Rd.
Suite 160
Scottsdale, AZ 85260
602/998-1580
FAX 602/483-2303
Thomson Components - Mostek Corporation
7155 SW Varns' St.
Tigard, OR 97223-8057
503/620-5517
FAX 503/639-3591

FOR ALL OTHER COUNTRIES
Thomson Semiconducteurs
43, Avenue de L'Europe
78140 Vélizy-Villacoublay/France
Tél: (1) 394697 19/Télex: 204780 F
or contact Corporate Headquarters

## CENTRAL AREA:

Thomson Components - Mostek Corporation 1310 Electronics
MS1137
Carroilton, TX 75006
214/466-8844
TWX 910-860-5437
Thomson Components - Mostek Corporation
6100 Green Valley Drive
Suite 130
Bloomington, MN 55438
612/831-2322
FAX 612/831-8195
Thomson Components - Mostek Corporation
1827 Walden Office Square
\#430
Schaumburg, IL 60173
312/397-6550
FAX 312/397-4066
Thomson Components - Mostek Corporation 3215 Steck Ave.
Suite 202
Austin, TX 78758
512/451-4061
TWX 910-874-2007
Thomson Components - Mostek Corporation 26677 W. 12 Mile Rd.
Suite \#141
Southfieid, MI 48034
313/354-5840
FAX 313/354-3370

CANADA
Thomson CSF Canada
Semiconductor Division
1000 Sherbrooke West
Suite 2340
Montreal, Quebec H3A 3G4
514/288-4148
FAX 514/288-8987
Thomson Components - Mostek Corporation
44 Rosebud Ave.
Brampton, Ontario L6X 2W5
416/454-5252
FAX 416/454-4328

## EASTERN AREA:

Thomson Components - Mostek Corporation 83 Cambridge Street
Suite 2A
Burlington, MA 01802
617/273-3310
FAX 617/272-2467
Thomson Components - Mostek Corporation
The Pavilions at Greentree
Route \#73, Suite 101
Marlton, NJ 08053
609/596-9200
FAX 609/424-7437
Thomson Components - Mostek Corporation
4414 Evangel Cr. HC
Huntsville, AL 35816
205/830-9036
FAX 205/830-9038
Thomson Components - Mostek Corporation 387 Hooker Avenue
Office No. 2
Poughkeepsie, NY 12603
914/454-8813
FAX 914/454-1320
Thomson Components - Mostek Corporation
5890 Sawmill Rd.
Suite 204
Dublin, Ohio 43017
614/761-0676
FAX 614/761-2305
Thomson Components - Mostek Corporation
6045 Atlantic Blvd.
Suite 104
Norcross, GA 30071
404/662-1588
FAX 404/662-1561

## U.S. AND CANADIAN REPRESENTATIVES

CONNECTICUT
Scientific Components*
1185 S. Main St.
Cheshire, CT 06410
(203) 272-2963

FAX (203) 271-3048

## FLORIDA

Lawrence Associates*
5021 N. Dixie Hwy.
Boca Raton, FL 33431
(305) 368-7373

Sales Engineering Concepts, Inc. 926 Great Pond Dr.
Suite 2002
Altamonte Springs, FL 32714
(305) 682-4800

FAX (305) 682-6491
Sales Engineering Concepts, Inc.* 1000 S. Federal Hwy.
Suite 204
Deerfield Beach, FL 33441
(305) 426-4601

TWX 510-600-7/40

## ILLINOIS

Eagle Technical Sales, Inc.
1805 B. Hicks Rd.
Rolling Meadows, IL 60008
(312) 991-0700

## INDIANA

M/S Sales Associates, Inc.*
7319 W. Jefferson Blvd.
Ft. Wayne, IN 46804
(219) 436-3023

FAX (219) 436-3026
M/S Sales Associates, Inc.
1425 E. 86th St.
Indianapolis, IN 46240
(317) 257-8916

## OWA

Rep Associates*
980 Arica Ave.
Marion, IA 52302
(319) 373-0152

## KANSAS

Rush \& West Associates
107 N. Chester Street
Olathe, KS 66061
(913) 764-2700

TWX 910-380-8110

## MARYLAND

Tri-Mark Inc.
1410 Crain Hwy. NW
Glen Burnie, MD 21061
(301) 761-6000

FAX (301) 761-6006

## MASSACHUSETTS

A/D Nova Sales, Inc."
83 Cambridge St.
Suite 2D
Burlington, MA 01803
(617) 270-9600

FAX (617) 272-2467
Conti-Younger Assoc.*
12 Blanchard Rd.
Burlington, MA 01803
(617) 273-1583

FAX (617) 270-0301

## MICHIGAN

Electronic Sources, Inc.*
8014 W. Grand River
Suite 6
Brighton, MI 48116
(313) 227-3598

FAX (313) 227-5655
Centech, Inc.* 10312 E. 63rd Terrace
Raytown, MI 64133
(816) 358-8100

## MINNESOTA

Horizon*
8053 East Bloomington Freeway
Bloomington, MN 55420
(612) 884-6515

FAX (612) 888-3073

## MISSOURI

Rush \& West Associates*
2170 Mason Rd.
St. Louis, MO 63131
(314) 965-3322

TWX 910-752-653
TELEX 752653
NEW JERSEY
Tritek Sales, Inc.*
21 E. Euclid Ave.
Haddonfield, NJ 08033
(609) 429-1551

TWX 215-627-0149 (Philadelphia Line) TWX 710-896-0881

NE Components*
189-191 Godwin Ave.
Wyckoff, NJ 07481
(201) 848-1100

NEW YORK
Empire Technical Assoc.*
33 West State St.
Suite 211B
Binghamton, NY 13901
(607) 772-0651

Empire Technical Assoc
1551 E. Genesse St.
Skaneateles, NY 13152
(315) 685-5703

GT Sales*
34 Grand Blva.
Brentwood, NY 11717
(516) 231-0270

FAX (516) 273-1247

OHIO
Five Star Electronics* 6200 S.O.M. Center Road
Suite B 21
Solon, OH 44139
(216) 349-1611

Tom Mulligan Co.*
166 N.W. Professional Plaza
Columbus, OH 43220
(614) 457-2242

## PENNSYLVANIA

M. Lader Company*

456 Germantown Pike
Lafayette Hill, PA 19444
(215) 825-3177

## WISCONSIN

Heartland Technical Marketing*
3846 Wisconsin Ave.
Milwaukee, WI 53208
(414) 931-0606

## CANADA

Solution Electronic Sales*
100A 3380 Maquinna Dr
Vancouver, B.C. V5S 4C9
(604) 438-0679

[^0]
## U.S. AND CANADIAN DISTRIBUTORS

## ALABAMA

Marshall Industries 3313 S. Memorial Pkwy. Huntsville, AL 35801 (205) 881-9235

Quality Components, S.E. 4900 University Square \#207 Huntsville, AL 35817 (205) 830-1881

Pioneer Technologies Group 4825 University Square
Huntsville, AL 35805
(205) 837-9300

Schweber Electronics
4930-A Corporate Drive
Huntsville, AL 35805
(205) 895-0480

## ARIZONA

Kierulff Electronics 4134 E. Wood Street Phoenix, AZ 85040 (602) 437-0750

Marshall Industries 835 West 22nd St.
Tempe, AZ 85282
(602) 968-6181

Schweber Electronics
11049 North 23rd Drive
Suite 100
Phoenix, AZ 85029
(602) 997-4874

## ARKANSAS

See Oklahoma

## CALIFORNIA

Integrated Electronics Corp. 7000 Franklin Blvd., Suite 625 Sacramento, CA 95823
(916) 424-5297

Integrated Electronics Corp 2170 Paragon Drive
San Jose, CA 95131
(408) 435-1000

ITAL Sales
15405 Proctor Avenue
City of Industry, CA 91745
(818) 968-8515

Kierulff Electronics
9800 Variel Avenue
Chatsworth, CA 91311
(818) 407-2500

Kierulff Electronics
5650 Jillson St.
Los Angeles, CA 90040
(213) 725-0325

Kierulff Electronics 8797 Balboa Avenue San Diego, CA 92123 (619) 278-2112

Kierulff Electronics 1180 Murphy Avenue San Jose, CA 95131 (408) 971-2600

Kierulff Electronics 14101 Franklin Avenue Tustin, CA 92680 (714) 731-5711

Marshall Industries
One Morgan
Irvine, CA 92715
(714) 458-5395

Marshall Industries
9710 DeSoto Avenue
Chatsworth, CA 91311
(818) 407-0101

Marshall Industries
3039 Kilgore Ave., \#140
Rancho Cordova, CA 95670
(916) 635-9700

Marshall Industries 10105 Carroll Canyon Rd.
San Diego, CA 92131
(619) 578-9600

Marshall Industries
336 Los Coches St.
Milpitas, CA 95035
(408) 943-4600

Schweber Electronics
21139 Victory Blvd.
Conoga Park, CA 91303
(818) 999-4702

Schweber Electronics 1225 West 190th Street Suite 360
Gardena, CA 90248
(213) 327-8409

Schweber Electronics
17822 Gillette Avenue
Irvine, CA 92714
(714) 863-0264

FAX (714) 863-0200 (X500)
Schweber Electronics
1771 Tribute Rd. Suite B
Sacramento, CA 95815
(916) 929-9732

FAX (916) 929-5608
Schweber Electronics 6750 Nancy Ridge Drive
San Diego, CA 92121
(619) 450-0454

TWX 910-335-1155
Schweber Electronics
90 E. Tasman Drive
San Jose, CA 95131 (408) 946-7171

Zeus Components
1130 Hawk Circle
Anaheim, CA 92807
(714) 632-6880

TWX 910-591-1696
FAX (714) 630-8770
Zeus Components
1580 Old Oakland Road
Suite C205/C206
San Jose, CA 95131
(408) 998-5121

TWX 408-628-96083
FAX (408) 998-0285

## COLORADO

Integrated Electronics Corp. 5750 N. Logan Street
Denver, CO 80216
(303) 292-6121

Kierulff Electronics
7060 South Tuscon Way
Englewood, CO 80112
(303) 790-4444

Marshall Industries
7000 North Broadway
Denver, CO 80221
(303) 427-1818

Schweber Electronics
8955 E. Nicholas, Bldg. 2
Englewood, CO 80221
(303) 799-0258

## CONNECTICUT

Greene-Shaw
1475 Whalley Avenue
New Haven, CT 06525
(203) 397-0710

TWX 92-2498
Marshall Industries
20 Sterling Drive
Barnes Industrial Park, N
P.O. Box 200

Wallingford, CT 06492-0200
(203) 265-3822

Pioneer-Standard
112 Main Street
Norwalk, CT 06851
(203) 853-1515

TWX 710-468-3373
FAX (203) 838-9901
Schweber Electronics
Commercial Industrial Park
Finance Drive
Danbury, CT 06810
(203) 748-7080

TWX 710-456-9405
DELAWARE
See New Jersey
Pennsylvania

## FLORIDA

All American Semiconductor 16251 N.W. 54th Avenue
Miami, FL 33014
(305) 621-8282

800-327-6237
Marshall Industries
4205 34th St., S.W.
Orlando, FL 32811
(305) 841-1878
(305) 841-1878

Pioneer Technologies Group
337 S. North Lake, \#1000
Altamonte Springs, FL 32701
(305) 834-9090

TWX 810-853-0284
Pioneer Technologies Group
674 S. Military Trail
Deerfield Beach, FL 33441
(305) 428-8877

TWX 510-955-9653

Schweber Electronics
215 North Lake Blvd.
Altamonte Springs, FL 32701
(305) 331-7555

TWX 510-954-0304
Schweber Electronics
3665 Park Central Blvd. N.
Pompano Beach, FL 33064
(305) 977-7511

TWX 510-954-0304
Zeus Components
1750 West Broadway
Suite 114
Oviedo, FL 32765
(305) 365-3000

TWX 910-380-7430
FAX (305) 365-2356

## GEORGIA

Dixie Electronics
1234 Gordon Park Road
Augusta, GA 30901
(404) 722-2055

Pioneer Technologies Group
3100 F. Northwoods Place
Norcross, GA 30071
(404) 448-1711

TWX 810-766-4515
Quality Components
6145 N. Belt Parkway \#B
Norcross, GA 30071
(404) 449-9508

TWX 510-601-5297
629-32421
Schweber Electronics
303 Research Drive
Suite 210
Norcross, GA 30092
(404) 449-9170

TWX 810-766-1592

## ILLINOIS

Advent Electronics
7110-16 N. Lyndon St.
Rosemont, IL 60018
(312) 297-6200

Kierulff Electronics
1140 W. Thorndale Ave.
Itasca, IL 60143
(312) 250-0500

Marshall Industries
1261 Wiley Road
\#F
Schaumburg, IL 60195
(312) 490-0155

Pioneer-Standard
1551 Carmen Drive
Elk Grove Village, IL 60007
(312) 437-9680

Schweber Electronics
904 Cambridge Drive
Elk Grove Village, IL 60007
(312) 364-3750

TWX 910-222-3453

## U.S. AND CANADIAN DISTRIBUTORS

## INDIANA

Advent Electronics
8446 Moller Road Indianapolis, IN 46268
(317) 872-4910

TWX 810-341-3228
Marshall Industries 6990 Corporate Dr. Indianapolis, IN 46278 (317) 297-0483

Pioneer-Standard
6408 Castleplace Drive
Indianapolis, IN 46250
(317) 849-7300

TWX 810-260-1794
IOWA
Advent Electronics 682 58th Avenue, Ct. SW Cedar Rapids, IA 52404
(319) 363-022

TWX 910-525-1337
Schweber Electronics 5270 North Park Place, NE Cedar Rapids, IA 52402 (319) 373-1417

## KANSAS

Marshall Industries
8321 Melrose Dr.
Lenexa, KS 66214
(913) 492-3121

Schweber Electronics 10300 West 103rd Street Suite 200
Overland Park, KS 66214
(913) 492-2922

KENTUCKY
See Indiana
LOUISIANA
See Texas
MAINE
See Massachusetts

## MARYLAND

Marshall Industries 8445 Helgerman Court. Gaithersburg, MD 20877 (301) 840-9450

Pioneer Technologies Group
9100 Gaither Road Gaithersburg, MD 20877
(301) 921-0660

TWX 710-828-0545
Schweber Electronics
9330 Gaither Road Gaithersburg, MD 20877
(301) 840-5900

TWX 710-828-9749
Zeus Components
8930-A Route 108
Columbia, MD 21045
(301) 997-1118

TWX 910-380-3554
FAX (301) 964-9784
MASSACHUSETTS
Greene-Shaw 70 Bridge Street Newton, MA 02195
(617) 969-8900

TWX 922498

Kierulff Electronics
13 Fortune Drive
Billerica, MA 01821
(617) 667-8331

Lionex Corporation
36 Jonspin Road Wilmington, MA 01887
(617) 657-5170

FAX (617) 657-6008
Marshall Industries
One Wilshire Road
Burlington, MA 01803
(617) 272-8200

Pioneer-Standard
44 Hartwell Ave.
Lexington, MA 02173
Schweber Electronics
25 Wiggins Avenue
Bedford, MA 01730
(617) 275-5100

TWX 710-326-0268
Zeus Components
429 Marrett Road
Lexington, MA 02173
(617) 863-8800

TWX 710-326-7604
FAX (617) 863-8807

## MICHIGAN

Advent Electronics
24713 Crestview Ct
Farmington Hills, MI 48018 (313) 477-1650

Pioneer-Standard
4505 Broadmoor Avenue SE
Grand Rapids, MI 49508
(616) 698-1800

TWX 510-600-8456
Pioneer-Standard
13485 Stamford
Livonia, MI 48150
(313) 525-1800

TWX 810-242-3271
Schweber Electronics
12060 Hubbard Ave. CN3306
Livonia, MI 48150
(313) 525-8100

TWX 810-242-2983
minnesota
Kierulff Electronics
7667 Cahill Road
Edina, MN 55435
(612) 941-7500

Marshall Industries
3800 Annapolis Lane
Plymouth, MN 55441
(612) 559-2211

Pioneer Standard
10203 Bren Road East
Minnetonka, MN 55343
(612) $935-5444$

TWX 910-576-2738
Schweber Electronics
7424 W. 78th Street
Edina, MN 55435
(612) $941-5280$

TWX 910-576-3167
MISSISSIPPI
See Texas

## MISSOURI

Kierulff Electronics
11804 Borman Drive
St. Louis, MO 63146
(314) 997-4956

TWX 910-762-0721
Schweber Electronics
502 Earth City Expressway
Suite 203
Earth City, MO 63045
(314) 739-0526

TWX 43-4065
MONTANA
See California
NEBRASKA
See lowa
NEW HAMPSHIRE
Schweber Electronics
Bedford Farms Bldg. \#2
Manchester, NH 03102
(603) 625-2250

TWX 710-220-7572
FAX (603) 625-5710

## NEW JERSEY

Kierulff Electronics
37 Kulick Road
Fairfield, NJ 07006
(201) 575-6750

Marshall industries
101 Fairfield Rd.
Fairfield, NJ 07006
(201) 882-0320

Pioneer-Standard
45 Route 46
Pine Brook, NJ 07058
(201) 575-3510

TWX 710-734-4382
Schweber Electronics
18 Madison Road
Fairfield, NJ 07006
(201) 227-7880

TWX 710-734-4305
Solid State
46 Farrand Street
Bloomfield, NJ 07003
(201) 429-8700

TWX 710-994-4780
FAX (201) 429-8683

## NEW YORK

Add Electronics
7 Adler Drive
E. Syracuse, NY 13057
(315) 437-0300

Add Electronics
7375 Pittsford-Victor Rd.
Victor, NY 14564
Marshall Industries
129 Brown St.
Johnson City, NY 13790
Marshall Industries
1280 Scottsville Rd.
Rochester, NY 14624
Nu-Horizons Electronics 6000 New Horizons Blvd.
N. Amityville, NY 11701
(516) 226-6000

Pioneer-Standard
840 Fairport Park
Fairport, NY 14450
(716) 381-7070

TWX 510-253-7001
FAX (716) 381-5955
Pioneer-Standard
1806 Vestal Pkwy. East
Vestal, NY 13850
(607) 748-8211

TWX 510-252-0893
Pioneer-Standard
Crossways Park West
Woodbury, NY 11797
(516) 921-8700

TWX 510-221-2184
FAX (516) 921-2143
Schweber Electronics
3 Townline Circle
Rochester, NY 14623
(716) 424-2222

TWX 710-541-0601
Schweber Electronics
Jericho Turnpike
Westbury, NY 11590
(516) $334-7474$

TWX 510-220-1365
Zeus Components
100 Midland Avenue
Port Chester, NY 10573
(914) 937-7400

TWX 710-567-1248
FAX (914) 937-2553
NORTH CAROLINA
Dixie Electronics
2220 S. Tryon Street
Charlotte, NC 28234
(704) $377-4348$

Dixie Electronics
1021 R. Burke St
Winston-Salem, NC 27102
(919) 724-5961

Hammond Electronics
2923 Pacific Avenue
Greensboro, NC 27406
(919) 275-6391

TWX 628-94645
Pioneer Technologies Group 9801 A Southern Pine Blvd.
Charlotte, NC 28210
(704) 527-8188

TWX 810-621-0366
Quality Components, S.E
2940-15 Trawick Road
Raleigh, NC 27604
(919) 876-7767

Schweber Electronics
5285 North Blvd.
Raleigh, NC 27604
(919) 876-0000

TWX 510-928-0531
NORTH DAKOTA
See Minnesota
OHIO
Kierulft Electronics
476 Windsor Park Drive
Dayton, OH 45459
(513) 439-0045

## U.S. AND CANADIAN DISTRIBUTORS

OHIO (cont.)
Marshall Industries
6212 Executive Bivd.
Dayton, OH 45424
(513) 236-8088

Marshall Industries
59058 Harper Road
Solon, OH 44139
(216) 248-1788

Pioneer-Standard
4800 East 131st Street
Cleveland, OH 44105
(216) 587-3600

TWX 810-421-0011
Pioneer-Standard 4433 Interpoint Blvd.
Dayton, OH 45424
(513) 236-9900

TWX 810-459-1622
Schweber Electronics 23880 Commerce Park Rd.
Beachwood, OH 44122
(216) 464-2970

TWX 810-427-9441
Schweber Electronics
7865 Paragon Road
Suite 210
Dayton, OH 45459
(513) 439-1800

Zeus (Televox)
2593 Lance Drive
Dayton, OH 45409
(513) 294-4499

TWX 75-9251
FAX (513) 294-6620

## OKLAHOMA

Quality Components 9934 East 21st South Tulsa, OK 74129 (918) 664-8812 TWX 910-860-5459 629-28599

Schweber Electronics 4815 South Sheridan Fountain Plaza, Suite 109
Tulsa, OK 74145
(918) 622-8000

## OREGON

Almac Electronics Corp.
1885 N.W. 169th Place
Beaverton, OR 98006
(503) 629-8090

FAX (503) 645-0611
TWX 910-467-8743
Kierulff Electronics
14273 N.W. Science Park Drive
Portland, OR 97229
(503) 641-9150

Marshall Industries
8333 S.W. Cirrus Dr.
Beaverton, OR 97005
(503) 644-5050

## PENNSYLVANIA

Almo Electronics, Inc. 9815 Roosevelt Blvd. Philadelphia, PA 19114
(215) 698-4063

TLX 476-1218
FAX (215) 969-6768

Pioneer-Standard
259 Kappa Drive
Pittsburgh, PA 15238
(412) 782-2300

TWX 710-795-3122
Pioneer Technologies Group
261 Gibraltar Road
Horsham, PA 19044
(215) 674-4000

TWX 510-665-6778
Schweber Electronics
900 Business Center Dr.
Horsham, PA 19044
(215) 441-0600

TWX 510-665-6540
Schweber Electronics
1000 R.I.D.C. Plaza
Suite 203
Pittsburgh, PA 15238
(412) 782-1600

TWX 810-427-9441
RHODE ISLAND
See Massachusetts
New York
SOUTH CAROLINA
Dixie Electronics
1900 Barnwell Street
Columbia, SC 29202
(803) 779-5332

TLX 810-666-2620
FAX (803) 765-9276
Dixie Electronics
4909 Pelham Rd.
Greenville, SC 29606
(803) 297-1435

Dixie Electronics
\#6 Pepperhill Square
7525 Brandywine Road
N. Charleston, SC 29410
(803) 552-2671

SOUTH DAKOTA
See Minnesota
TENNESSEE
Dixie Electronics
Box 8215 Suncrest Drive
Gray, TN 37615
(615) 477-3838

Dixie Electronics 6408 Clinton Highway
Knoxville, TN 27912
(615) 938-4131

TEXAS
Kierulff Electronics
3007 Longhorn Blvd.
Austin, TX 78759
Kierulff Electronics
9610 Skillman Ave.
Dallas, TX 75243
(214) $343-2400$

Marshall Industries 2045 Chenault St. Carrollton, TX 75006
(214) 233-5200

FAX (214) $770-0675$

Pioneer-Standard
13710 Omega Road
Dallas, TX 75234
(214) 386-7300

TWX 910-860-5563
Pioneer-Standard
9901 Burnet Road
Austin, TX 78758
(512) 835-4000

TWX 910-874-1323
Pioneer-Standard
5853 Point West Drive
Houston, TX 77036
(713) 988-5555

TWX 910-881-1606
Quality Components
4257 Kellway Circle
Addison, TX 75001
(214) 733-4300

TWX 910-860-5459
Quality Components
1005 Industrial Blvd.
Sugarland, TX 77478
(713) 240-2255

TWX 62927026
Quality Components
2120 M. Braker Lane
Austin, TX 78758
(512) 835-0220

TWX 324930
Schweber Electronics
4202 Beltway Drive
Dallas, TX 75234
(214) 661-5010

TWX 910-860-5493
Schweber Electronics
6300 La Calma Drive
Suite 240
Austin, TX 78752
(512) 458-8253

TWX 910-874-2045
Schweber Electronics
10625 Richmond, Suite 100
Houston, TX 77042
(713) 784-3600

TWX 910-881-4836
Zeus Components
1800 North Glenville
Suite 120
Richardson, TX 75081
(214) 783-7010

TWX 910-867-9422
FAX (214) 234-4385
UTAH
Integrated Electronics Corp.
101 N. 700 West
N. Salt Lake City, UT 84054
(801) 298-1869

Kierulff Electronics
1846 Parkway Blvd.
Salt Lake City, UT 84119
(801) 973-6913

Marshall Industries
3501 South Main St.
Salt Lake City, UT 84115
(801) 261-0901

VIRGINIA
See Maryland

## WASHINGTON

Almac Electronics Corp.
14360 S.E. Eastgate Way
Bellevue, WA 98007
(206) 643-9992

TWX 910-444-2067
FAX (206) 746-7425
Almac Electronics Corp.
East 10905 Montgomery
Spokane, WA 99206
(509) 924-9500

TWX 510-773-1855
FAX (509) 928-6096
Kierulff Electronics
19450 68th Ave.
South Kent, WA 98032
(206) 575-4420

Marshall Industries
14102 N.E. 21st St.
Bellevue, WA 98007
(206) 747-9100

WASHINGTON D.C.
See Maryland

## WEST VIRGINIA

See Ohio
Pennsylvania
Maryland

## WISCONSIN

Kierulff Electronics
2238-E West Bluemound Road
Waukesha, WI 53186
(414) 784-8160

Marshall Industries
235 North Executive Dr.
\#305
Brookfield, WI 53005
(414) 797-8400

Schweber Electronics
3050 South Calhoun Rd.
New Berlin, WI 53151
(414) 784-9020

## WYOMING

See Oregon Washington

## CANADA

R.A.E. Industrial

3455 Gardner Court
Burnaby, B.C.
(604) 291-8866

TWX 610-929-3065
R.A.E. Industrial 11680 170th Street Edmonton, Alberta
T5S 1.17
(403) 451-4001

TWX 037-2653
Zentronics
8 Tilbury Court
Brampton, Ontario
L6T 3 T4
(416) 451-9600

TWX 06-97678
FAX (416) 451-8320

VERMONT
See New York

## U.S. AND CANADIAN DISTRIBUTORS

## CANADA (cont.)

Zentronics
3300-14 Ave., NE Bay \#1
Calgary, Alberta
T2A 6 J4
(403) 272-1021

## Zentronics

155 Colonnade, S. \#17/18
Nepean, Ontario
K2E 7K1
(613) 226-8840

TWX 06-97698

## Zentronics

11400 Bridgeport Rd. \#108
Richmond, B.C.
V6X 1 T2
(604) 273-5575

TWX 04-355844

## Zentronics

817 McCaffrey Street
St. Laurent, Quebec
H4T 1N3
(514) 737-9700

TWX 05-824826
Zentronics
564 Weber Street, N. \#10
Waterloo, Ontario
N21 5C6
(519) 884-5700

TWX 06-97678

Zentronics
590 Berry Street
Winnipeg, Manitoba
R3H OS1
(204) 775-8661

TWX 06-97678

Future Electronics
3220 5th Avenue, N.E.
Calgary, Alberta
T2A 5N1
(403) 235-5325

Future Electronics
82 St. Regis Crescent N.
Downsview, Ontario
M3J 1 Z3
(416) 638-4771

TWX 610-491-1470
FAX (416) 638-2936

Future Electronics
5312 Calgary Trail South
Edmonton, Alberta
T6H 4J8
(403) 438-2858

Future Electronics
Hymus Blvd.
Pointe Claire
Montreal, Quebec
H9R 5C7
(514) 694-7710

TWX 610-421-3251 or 610-421-3500
FAX (514) 695-3707 or (514) 694-0062

Future Electronics
Baxter Center
1050 Baxter Road
Ottawa, Ontario
K2C 3P2
(613) 820-8313

TWX 610-563-1697
FAX (613) 820-3271

Future Electronics 1695 Boundary Road Vancouver, B.C.
B5K 4X7
(604) 294-1166

TLX 04354744
FAX (604) 294-1206
Future Electronics
444 Sharon Bay
Winnipeg, Manitoba
R2G OH7
(604) 294-1166 (Vancouver)

## CHAPTER 1-6800 MICROPROCESSORS

6800 MICROPROCESSORS SELECTION GUIDE

| Part number | Description | Technology | Alt source | CLK freq. (MHz) | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { EF6802 } \\ & \text { EF68A02 } \\ & \text { EF68B02 } \end{aligned}$ | 8-bit MPU - 128 bytes of RAM - On-chip oscillator Expandable up to 64 Kbytes - 72 instructions 7 addressing modes - 6800 compatible | NMOS | MC6802 <br> MC68A02 <br> MC68B02 | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 1-3 |
| $\begin{aligned} & \text { EF6803 } \\ & \text { EF6803-1 } \\ & \text { EF68A03 } \\ & \text { EF68B03 } \end{aligned}$ | 8 -bit MPU - 128 bytes of RAM Multiplexed address and data bus -16-bit address bus - $8 \times 8$ multiply - Serial communication interface - 16 -bit timer 6800 compatible | HMOS | MC6803 <br> MC6803-1 <br> MC68A03 <br> MC68B03 | $\begin{gathered} \hline 1 \\ 1.25 \\ 1.5 \\ 2 \end{gathered}$ | 1-27 |
| $\begin{aligned} & \hline \text { EF6803U4 } \\ & \text { EF6803U4-1 } \\ & \text { EF68A03U4 } \end{aligned}$ | 8 -bit MPU - 192 bytes of RAM Multiplexed address and data bus 16 -bit address bus - $8 \times 8$ multiply - Serial communication interface - 16-bits enhanced timer - 6800 compatible | HMOS | MC6803U4 MC6803U4-1 MC68A03U4 | $\begin{gathered} 1 \\ 1.25 \\ 1.5 \end{gathered}$ | 1-67 |
| $\begin{aligned} & \text { EF6809 } \\ & \text { EF68A09 } \\ & \text { EF68B09 } \end{aligned}$ | High performance 8-bit MPU with on-chip clock - 64 Kbytes addressing space - Internal 16-bit structure - 59 instruction types 10 addressing modes - 6800 compatible | HMOS | MC6809 MC68A09 MC68B09 | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 1-111 |
| $\begin{aligned} & \text { EF6809E } \\ & \text { EF68A09E } \\ & \text { EF68B09E } \end{aligned}$ | External clock version of EF6809 | HMOS | MC6809E MC68A09E MC68B09E | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 1-151 |

The EF6802 is a monolithic 8 -bit microprocessor that contains all the registers and accumulators of the present EF6800 plus an internal clock oscillator and driver on the same chip. In addition, the EF6802 has 128 bytes of on-board RAM located at hex addresses $\$ 0000$ to $\$ 007 \mathrm{~F}$. The first 32 by tes of RAM, at hex addresses $\$ 0000$ to $\$ 001 \mathrm{~F}$, may be retained in a low power mode by utilizing $\mathrm{V}_{\mathrm{CC}}$ standby ; thus, facilitating memory retention during a power-down situation.
The EF6802 is completely software compatible with the EF6800 as well as the entire EF6800 family of parts. Hence, the EF6802 is expandable to 64 K words.
The EF6808 is identical to the EF6802 without on-board RAM.

- On-Chip Clock Circuit
- $128 \times 8$ Bit On-Chip RAM
- 32 Bytes of RAM are Retainable
- Software-Compatible with the EF6800
- Expandable to 64 K Words
- Standard TTL-Compatible inputs and Outputs
- 8-Bit Word Size
- 16-Bit Memory Addressing
- Interrupt Capability
- Three available versions : EF6802/08 ( 1.0 MHz ), EF68A02/08 ( 1.5 MHz ), EF68B02/08 ( 2.0 MHz ).


## MOS

(N-CHANNEL, SILICON-GATE, dEPLETION LOADI
MICROPROCESSOR WITH CLOCK AND OPTIONAL RAM



MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range |  |  |  |
| EF6802, EF680A02, EF680B02 |  | 0 to +70 |  |
| EF6802, EF68A02, EF68B02: V suffix | $\mathrm{T}_{\mathrm{A}}$ | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| EF6802, EF68A02: M suffix |  | -55 to +125 |  |
| EF6808, EF68A08, EF68B08 |  | to +70 |  |
| Storage Temperature Range | $\mathrm{T}_{\text {Stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This input contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this highimpedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voitage level (e.g., either $V_{S S}$ or $\mathrm{V}_{\mathrm{CC}}$ ).

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Average Thermal Resistance (Junction to Ambient) |  |  |  |
| Plastic | $\theta_{\text {JA }}$ | 100 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic |  | 50 |  |
| PLCC |  | 100 |  |

## POWER CONSIDERATIONS

The average chip-junction temperature, $T_{J}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T_{J}=T_{A}+\left(P_{D} \bullet \theta_{J A}\right) \tag{1}
\end{equation*}
$$

Where:
$T_{A}=$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta_{J A}=$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
$P_{D}=$ PINT + PPORT
$P_{\text {INT }}=$ ICC $\times V_{C C}$, Watts - Chip Internal Power
PPORT $=$ Port Power Dissipation, Watts - User Determined

For most applications PPORT $<$ PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.
An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K+\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \cdot\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A^{\bullet} \cdot P_{D} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P D$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of $\mathrm{T}_{\mathrm{A}}$.

DC ELECTRICAL CHARACTERISTICS $\operatorname{IV} \mathrm{CC}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0, \mathrm{~T}_{A}=0$ to $70^{\circ} \mathrm{C}$, unless otherwise noted)

| Characteristic |  | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\text { Logic, } \frac{\text { EXTAL }}{\text { RESET }}$ | $V_{1 H}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+2.0 \\ & \mathrm{v}_{\mathrm{SS}}+4.0 \end{aligned}$ | - | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\checkmark$ |
| Input Low Voltage | Logic, EXTAL, $\overline{\text { RESET }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | - | $\mathrm{V}_{\text {SS }}+0.8$ | V |
| Input Leakage Current ( $\mathrm{V}_{\text {in }}=0$ to $5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=$ max) | Logic | I in | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Output High Voltage } \\ & \text { (ILoad }=-205 \mu \mathrm{~A}, V_{C C}=\mathrm{min} \text { ) } \\ & \text { (ILoad }=-145 \mu \mathrm{~A}, V_{C C}=\mathrm{min} \text { ) } \\ & \text { (ILoad }=-100 \mu \mathrm{~A}, V_{C C}=\mathrm{min} \text { ) } \end{aligned}$ | $\begin{array}{r} \text { DO-D7 } \\ \text { A0.A15, } \mathrm{R} / \overline{\mathrm{W}}, \mathrm{VMA}, \mathrm{E} \\ \mathrm{BA} \end{array}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \prime S S+2.4 \\ & V_{S S}+2.4 \\ & v_{S S}+2.4 \\ & \hline \end{aligned}$ | - | - | V |
| Output Low Voltage (Load $=1.6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{min}$ ) |  | $\mathrm{V}_{\mathrm{OL}}$ | - | - | VSS +0.4 | V |
| Internal Power Dissipation (Measured at ${ }^{\top} \mathrm{A}=0^{\circ} \mathrm{C}$ ) |  | PINT | - | 0.750 | 1.0 | W |
| $V_{\text {CC }}$ Standby | Power Down Power Up | $\begin{gathered} v_{S B B} \\ v_{S B} \\ \hline \end{gathered}$ | $\begin{array}{r} 4.0 \\ 4.75 \\ \hline \end{array}$ | - | $\begin{aligned} & 5.25 \\ & 5.25 \end{aligned}$ | V |
| Standby Current |  | ISBB | - | - | 80 | mA |
| Capacitance$\left(V_{\text {In }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | $\begin{array}{r} \text { DO-D7 } \\ \text { Logic Inputs. EXTAL } \end{array}$ | $\mathrm{C}_{\text {in }}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{array}{r} 10 \\ 6.5 \\ \hline \end{array}$ | $\begin{gathered} 12.5 \\ 10 \\ \hline \end{gathered}$ | pF |
|  |  | $\mathrm{C}_{\text {out }}$ | - | - | 12 | pF |

- In power-down mode, maximum power dissipation is less than 42 mW .
\#Capacitances are perıodically sampled rather than $100 \%$ tested

CONTROL TIMING $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Characteristics | Symbol | $\begin{aligned} & \text { EF6802 } \\ & \text { EF6808 } \end{aligned}$ |  | EF68A02 <br> EF68A08 |  | $\begin{aligned} & \text { EF68B02 } \\ & \text { EF68B08 } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $\dagger_{0}$ | 0.1 | 1.0 | 0.1 | 1.5 | 0.1 | 2.0 | MHz |
| Crystal Frequency | ${ }^{\text {f }}$ (TAL | 1.0 | 4.0 | 1.0 | 6.0 | 1.0 | 8.0 | MHz |
| External Oscillator Frequency | $4 \times{ }^{\prime}{ }_{0}$ | 0.4 | 4.0 | 0.4 | 6.0 | 0.4 | 80 | MHz |
| Crystal Oscillator Start Up Time | $\mathrm{tr}_{\mathrm{c}}$ | 100 | - | 100 | - | 100 | - | ms |
| Processor Controis (HALT, MR, RE, $\overline{\text { RESET, }} \overline{\text { IRQ }} \overline{\text { NMI) }}$ |  |  |  |  |  |  |  |  |
| Processor Control Setup Time | tPCS | 200 | - | 140 | - | 110 | - | ns |
| Processor Control Rise and Fall Time (Does Not Apply to $\overline{\text { RESET }}$ ) | ${ }^{1} \mathrm{PCR}$. <br> tpCf | - | 100 | - | 100 | - | 100 | ns |

## BUS TIMING CHARACTERISTICS

| Ident. <br> Number | Characteristic | Symbol | $\begin{aligned} & \text { EF6802 } \\ & \text { EF6808 } \end{aligned}$ |  | EF68A02EF68A08 |  | EF68B02EF68B08 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }^{\text {t }} \mathrm{Cyc}$ | 1.0 | 10 | 0.667 | 10 | 0.5 | 10 | $\mu \mathrm{S}$ |
| 2 | Pulse Width. E Low | PWEL | 450 | 5000 | 280 | 5000 | 210 | 5000 | ns |
| 3 | Pulse Width, E High | PWEH | 450 | 9500 | 280 | 9700 | 220 | 9700 | ns |
| 4 | Clock Rise and Fall Time | tr. If | - | 25 | -- | 25 | - | 25 | ns |
| 9 | Address Hold Time* | ${ }^{1} \mathrm{AH}$ | 20 | - | 20 | - | 20 | - | ns |
| 12 | Non-Muxed Address Valid Time to E (See Note 5) | $\begin{aligned} & \text { t } \mathrm{AV} 1 \\ & \text { t } \mathrm{AV} 2 \\ & \hline \end{aligned}$ | $160$ | $270$ | $100$ | - | 50 | - | ns |
| 17 | Read Data Setup Time | tDSR | 100 | - | 70 | -- | 60 | - | ns |
| 18 | Read Data Hold Tıme | IDHR | 10 | - | 10 | - | 10 | - | ns |
| 19 | Write Data Delay Time | IODW | --' | 225 | - | 170 | - | 160 | ns |
| 21 | Write Data Hold Time* | IDHW | 30 | - | 20 | -- | 20 | . | ns |
| 29 | Usable Access Time (See Note 4) | ${ }^{1} \mathrm{ACC}$ | 535 | - | 335 |  | 235 | - | ns |

* Address and data hold times are periodically tested rather than 100\% tested.

FIGURE 2 - BUS TIMING


NOTES:

1. Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}} \geq 2.4 \mathrm{~V}$, unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.0 V , unless otherwise noted.
3. All electricals shown for the EF. 6802 apply to the EF6808, unless otherwise noted.
4. Usable access time is computed by: $12+3+4-17$.
5. If programs are not executed from on-board RAM, TAV1 applies. If programs are to be stored and executed from on-bnard RAM, TAV2 applies. For normal data storage in the on-board RAM, this extended delay does not apply. Programs cannot be executed from on-board RAM when using $A$ and $B$ parts (EF68A02, EF68A08, EF68B02, EF68B08). On-board'RAM can be used for data storage with all parts.
6. All electrical and control characteristics are referenced from: $T_{L}=0^{\circ} \mathrm{C}$ minimum and $T_{H}=70^{\circ} \mathrm{C}$ maximum.

FIGURE 3 - BUS TIMING TEST LOAD
$C=130 \mathrm{pF}$ for DO-D7, E
$=90 \mathrm{pF}$ for $\mathrm{AO}-\mathrm{A} 15, \mathrm{R} / \overline{\mathrm{W}}$, and VMA
$=30 \mathrm{pF}$ for BA
$R=11.7 \mathrm{k} \Omega$ for D0.D7, E
$=16.5 \mathrm{k} \Omega$ for $\mathrm{A} 0 . \mathrm{A} 15, \mathrm{R} / \overline{\mathrm{W}}$, and VMA
$=24 \mathrm{k} \Omega$ for $B A$


FIGURE 4 - TYPICAL DATA BUS OUTPUT DELAY versus CAPACITIVE LOADING


FIGURE 5 - TYPICAL READ/WRITE, VMA AND ADDRESS OUTPUT DELAY versus CAPACITIVE LOADING


FIGURE 6 - EXPANDED BLOCK DIAGRAM


## MPU REGISTERS

A general block diagram of the EF6802 is shown in Figure 6. As shown, the number and configuration of the registers are the same as for the EF6800. The $128 \times 8$-bit RAM* has been added to the basic MPU. The first 32 bytes can be retained during power-up and power-down conditions via the RE signal.

The EF6808 is identical to the EF6802 except for on-board RAM. Since the EF6808 does not have on-board RAM pin 36 must be tied to ground allowing the processor to utilize up to 64 K bytes of external memory.
The MPU has three 16 -bit registers and three 8 -bit registers available for use by the programmer (Figure 7).

## PROGRAM COUNTER

The program counter is a two byte (16-bit) register that points to the current program address.

## STACK POINTER

The stack pointer is a two byte register that contains the address of the next available location in an external push-down/pop-up stack. This stack is normally a random access read/write memory that may have any location (address) that is convenient. In those applications that require storage
of information in the stack when power is lost, the stack must be non-volatile.

## INDEX REGISTER

The index register is a two byte register that is used to store data or a 16 -bit memory address for the indexed mode of memory addressing.

## ACCUMULATORS

The MPU contains two 8 -bit accumulators that are used to hold operands and results from an arithmetic logic unit (ALU).

## CONDITION CODE REGISTER

The condition code register indicates the results of an Arithmetic Logic Unit operation: Negative (N), Zero (Z), Overflow (V), Carry from bit 7 (C), and Half Carry from bit 3 (H). These bits of the Condition Code Register are used as testable conditions for the conditional branch instructions. Bit 4 is the interrupt mask bit (I). The unused bits of the Condition Code Register (b6 and b7) are ones.

Figure 8 shows the order of saving the microprocessor status within the stack.

[^1]FIGURE 7 - PROGRAMMING MODEL OF THE MICROPROCESSING UNIT


```
    SP = Stack Pointer
```

    SP = Stack Pointer
    CC = Condition Codes (Also called the Processor Status Byte)
    CC = Condition Codes (Also called the Processor Status Byte)
    ACCB = Accumulator B
ACCB = Accumulator B
ACCA = Accumulator A
ACCA = Accumulator A
IXH=Index Register., Higher Order 8 Bits
IXH=Index Register., Higher Order 8 Bits
IXL = Index Register, Lower Order 8 Bits
IXL = Index Register, Lower Order 8 Bits
PCH = Program Counter, Higher Order 8 Bits
PCH = Program Counter, Higher Order 8 Bits
PCL = Prograrn Counter, Lower Order }8\mathrm{ Bits

```
    PCL = Prograrn Counter, Lower Order }8\mathrm{ Bits
```



## MPU SIGNAL DESCRIPTION

Proper operation of the MPU requires that certain control and timing signals be provided to accomplish specific functions and that other signal lines be monitored to determine the state of the processor. These control and timing signals are similar to those of the EF6800 except that TSC, DBE, $\phi 1, \phi 2$ input, and two unused pins have been eliminated, and the following signal and timing lines have been added:

RAM Enable (RE)
Crystal Connections EXTAL and XTAL
Memory Ready (MR)
$V_{C C} S$ tandby
Enable $\phi 2$ Output (E)
The following is a summary of the MPU signals:

## ADDRESS BUS (A0-A15)

Sixteen pins are used for the address bus. The outputs are capable of driving one standard TTL load and 90 pF . These lines do not have three-state capability.

## DATA BUS (DO-D7)

Eight pins are used for the data bus. It is bidirectional, transferring data to and from the memory and peripheral devices. It also has three-state output buffers capable of driving one standard TTL load and 130 pF .
Data bus will be in the output mode when the internal RAM is accessed and RE will be high. This prohibits external data entering the MPU. It should be noted that the internal RAM is fully decoded from $\$ 0000$ to $\$ 007 F$. External RAM at $\$ 0000$ to $\$ 007 \mathrm{~F}$ must be disabled when internal RAM is accessed.

## HALT

When this input is in the low state, all activity in the machine will be halted. This input is level sensitive. In the HALT mode, the machine will stop at the end of an instruc-
tion, bus available will be at a high state, valid memory address will be at a low state. The address bus will display the address of the next instruction.
To ensure single instruction operation, transition of the HALT line must occur tpCS before the falling edge of $E$ and the HALT line must go high for one clock cycle.
HALT should be tied high if not used. This is good engineering design practice in general and necessary to ensure proper operation of the part.

## READ/WRITE (R/W)

This TTL-compatible output signals the peripherals and memory devices whether the MPU is in a read (high) or write (low) state. The normal standby state of this signal is read (high). When the processor is halted, it will be in the read state. This output is capable of driving one standard TTL load and 90 pF .

## VALID MEMORY ADDRESS (VMA)

This output indicates to peripheral devices that there is a valid address on the address bus. In normal operation, this signal should be utilized for enabling peripheral interfaces such as the PIA and ACIA. This signal is not three-state. One standard TTL load and 90 pF may be directly driven by this active high signal.

BUS AVAILABLE (BA) - The bus available signal will normally be in the low state; when activated, it will go to the high state indicating that the microprocessor has stopped and that the address bus is available (but not in a three-state condition). This will occur if the HALT line is in the low state or the processor is in the WAIT state as a result of the execution of a WAIT instruction. At such time, all three-state output drivers will go to their off-state and other outputs to their normally inactive level. The processor is removed from the

WAIT state by the occurrence of a maskable (mask bit $\mathrm{I}=0$ ) or nonmaskable interrupt. This output is capable of driving one standard TTL load and 30 pF .

## interrupt request (ikQ)

A low level on this input requests that an interrupt sequence be generated within the machine. The processor will wait until it completes the current instruction that is being excuted before it recognizes the request. At that time, if the interrupt mask bit in the condition code register is not set, the machine will begin an interrupt sequence. The index register, program counter, accumulators, and condition code register are stored away on the stack. Next the MPU will respond to the interrupt request by setting the interrupt mask bit high so that no further interrupts may occur. At the end of the cycle, a 16 -bit vectoring address which is located in memory locations \$FFF8 and \$FFF9 is loaded which causes the MPU to branch to an interrupt routine in memory.
The HALT line must be in the high state for interrupts to be serviced. Interrupts will be latched internally while HALT is low.
A nominal $3 \mathrm{k} \Omega$ pullup resistor to V CC should be used for wire-OR and optimum control of interrupts. $\overline{\mathrm{IRQ}}$ may be tied directly to $V_{C C}$ if not used.

## RESET

This input is used to reset and start the MPU from a power-down condition, resulting from a power failure or an initial start-up of the processor. When this line is low, the MPU is inactive and the information in the registers will be lost. If a high level is detected on the input, this will signal the MPU to begin the restart sequence. This will start execu-
tion of a routine to initialize the processor from its reset condition. All the higher order address lines will be forced high. For the restart, the last two (\$FFFE, \$FFFF) locations in memory will be used to load the program that is addressed by the program counter. During the restart routine, the interrupt mask bit is set and must be reset before the MPU can be interrupted by $\overline{R Q}$. Power-up and reset timing and powerdown sequences are shown in Figures 9 and 10, respectively.
RESET, when brought low, must be held low at least three clock cycles. This allows adequate time to respond internally to the reset. This is independent of the $\mathrm{t}_{\mathrm{rc}}$ power-up reset that is required.
When RESET is released it must go through the low-tohigh threshold without bouncing, oscillating, or otherwise causing an erroneous reset (less than three clock cycles). This may cause improper MPU operation until the next valid reset.

## NON-MASKABLE INTERRUPT (NMI)

A low-going edge on this input requests that a nonmaskable interrupt sequence be generated within the processor. As with the interrupt request signal, the processor will complete the current instruction that is being executed before it recognizes the $\overline{\mathrm{NM}}$ signal. The interrupt mask bit in the condition code register has no effect on $\overline{\mathrm{NM}}$.

The index register, program counter, accumulators, and condition code registers are stored away on the stack. At the end of the cycle, a 16 -bit vectoring address which is located in memory locations \$FFFC and \$FFFD is loaded causing the MPU to branch to an interrupt service routine in memory.
A nominal $3 \mathrm{k} \Omega$ pullup resistor to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts. NMI may be tied

FIGURE 9 - POWER-UP AND RESET TIMING


NOTE: If option 1 is chosen, $\overline{\operatorname{RESET}}$ and RE pins can be tied together.
directly to $V_{C C}$ if not used
FIGURE 10 - POWER-DOWN SEQUENCE
Inputs $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupt lines that are sampled when E is high and will start the interrupt routine on a low $E$ following the completion of an instruction.

Figure 11 is a flowchart describing the major decision paths and interrupt vectors of the microprocessor. Table 1 gives the memory map for interrupt vectors.

TABLE 1 - MEMORY MAP FOR INTERRUPT VECTORS

| Vector |  | Description |
| :---: | :---: | :---: |
| MS | LS |  |
| SFFFE | SFFFF | Restart |
| SFFFC | SFFFD | Non-Maskable Interrupt |
| SFFFA | SFFFB | Software Interrupt |
| \$FFF8 | \$FFF9 | Interrupt Request |



FIGURE 11 - MPU FLOWCHART


FIGURE 12 - CRYSTAL SPECIFICATIONS


| $\mathrm{Y1}$ | $\mathrm{C}_{\text {in }}$ | C $_{\text {out }}$ |
| :---: | :---: | :---: |
| 3.58 MHz | 27 pF | 27 pF |
| .4 MHz | 27 pF | 27 pF |
| 6 MHz | 20 pF | 20 pF |
| 8 MHz | 18 pF | 18 pF |

-     -         -             -                 -                     -                         -                             -                                 -                                     -                                         -                                             -                                                 -                                                     -                                                         - 



Nominal Crystal Parameters*

|  | 3.58 MHz | 4.0 MHz | 6.0 MHz | 8.0 MHz |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R}_{\mathrm{S}}$ | $60 \Omega$ | $50 \mathrm{\Omega}$ | $30-50 \Omega$ | $20-40 \Omega$ |
| CO | 3.5 pF | 6.5 pF | $4-6 \mathrm{pF}$ | $4-6 \mathrm{pF}$ |
| C 1 | 0.015 pF | 0.025 pF | $0.01-0.02 \mathrm{pF}$ | $0.01-0.02 \mathrm{pF}$ |
| Q | $>40 \mathrm{~K}$ | $>30 \mathrm{~K}$ | $>20 \mathrm{~K}$ | $>20 \mathrm{~K}$ |

- These are representative AT-cut parallel resonance crystal parameters only. Crystals of other types of cuts may also be used.

Figure 13 - SUGGESTED PC BOARD LAYOUT
Example of Board Design Using the Crystal Oscillator



FIGURE 15 - MR NEGATIVE SETUP TIME REQUIREMENT


The E clock will be stretched at end of E high of the cycle during which MR negative meets the tpCS setup time. The tpCS setup time is referenced to the fall of $E$. If the tPCS setup time is not met, E will be stretched at the end of the next $E$-high $1 / 2$ cycle. E will be stretched in integral multiples of $1 / 2$ cycles.

## Resuming E Clocking



MR


The E clock will resume normal operation at the end of the $1 / 2$ cycle during which MR assertion meets the tPCS setup time. The tpCS setup time is referenced to transitions of $E$ were it not stretched. If tPCS setup time is not met, $E$ will fall at the second possible transition time after MR is asserted. There is no direct means of determining when the tpCS references occur, unless the synchronizing circuit of Figure 14 is used.

## RAM ENABLE (RE - EF6802 ONLY)

A TTL-compatible RAM enable input controls the on-chip RAM of the EF6802. When placed in the high state, the onchip memory is enabled to respond to the MPU controls. In the low state, RAM is disabled. This pin may also be utilized to disable reading and writing the on-chip RAM during a power-down situation. RAM Enable must be low three cycles before $\mathrm{V}_{\mathrm{CC}}$ goes below 4.75 V during power-down. RAM enable must be tied low on theEF6808. RE should be tied to the correct high or low state if not used.

## EXTAL AND XTAL

These inputs are used for the internal oscillator that may be crystal controlled. These connections are for a parallel resonant fundamental crystal (see Figure 12). (AT-cut.) A divide-by-four circuit has been added so a 4 MHz crystal may be used in lieu of a 1 MHz crystal for a more cost-effective system. An example of the crystal circuit layout is shown in Figure 13. Pin 39 may be driven externally by a TTL input signal four times the required E clock frequency. Pin 38 is to be grounded.
An RC network is not directly usable as a frequency source on pins 38 and 39 . An RC network type TTL or CMOS oscillator will work well as long as the TTL or CMOS output drives the on-chip oscillator.

LC networks are not recommended to be used in place of the crystal.
If an external clock is used, it may not be halted for more than tPW $\phi$ L. The EF6802 and EF6808 are dynamic parts except for the internal RAM, and require the external clock to retain information.

## MEMORY READY (MR)

MR is a TTL-compatible input signal controlling the stretching of $E$. Use of MR requires synchronization with the $4 \times f_{0}$ signal, as shown in Figure 14. When MR is high, E will be in normal operation. When MR is low, E will be stretched integral numbers of half periods, thus allowing interface to slow memories. Memory Ready timing is shown in Figure 15.
MR should be tied high (connected directly to $\mathrm{V}_{\mathrm{CC}}$ ) if not used. This is necessary to ensure proper operation of the part. A maximum stretch is $\mathrm{t}_{\mathrm{cyc}}$.

## ENABLE (E)

This pin supplies the clock for the MPU and the rest of the system. This is a single-phase, TTL-compatible clock. This clock may be conditioned by a memory read signal. This is equivalent to $\phi 2$ on the EF6800. This output is capable of driving one standard TTL load and 130 pF .

## VCC STANDBY (EF6802 ONLY)

This pin supplies the dc voltage to the first 32 bytes of RAM as well as the RAM Enable (RE) control logic. Thus, retention of data in this portion of the RAM on a power-up, power-down, or standby condition is guaranteed. Maximum current drain at $\mathrm{V}_{\mathrm{SB}}$ maximum is ISBB.

## MPU INSTRUCTION SET

The instruction set has 72 different instructions. Included are binary and decimal arithmetic, logical, shift, rotate, load, store, conditional or unconditional branch, interrupt and stack manipulation instructions (Tables 2 through 6). The instruction set is the same as that for the EF6800.

## MPU ADDRESSING MODES

There are seven address modes that can be used by a programmer, with the addressing mode a function of both the type of instruction and the coding within the instruction. A summary of the addressing modes for a particular instruction can be found in Table 7 along with the associated instruction execution time that is given in machine cycles. With a bus frequency of 1 MHz , these times would be microseconds.

## ACCUMULATOR (ACCX) ADDRESSING

In accumulator only addressing, either accumulator $A$ or accumulator $B$ is specified. These are one-byte instructions.

## IMMEDIATE ADDRESSING

In immediate addressing, the operand is contained in the second byte of the instruction except LDS and LDX which have the operand in the second and third bytes of the instruction. The MPU addresses this location when it fetches the immediate instruction for execution. These are two- or three-byte instructions.

## DIRECT ADDRESSING

In direct addressing, the address of the operand is contained in the second byte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes in the machine, i.e., locations zero through 255. Enhanced execution times are achieved by storing data in these locations. In most configurations, it should be a random-access memory. These are two-byte instructions.

## EXTENDED ADDRESSING

In extended addressing, the address contained in the second byte of the instruction is used as the higher eight bits of the address of the operand. The third byte of the instruction is used as the lower eight bits of the address for the operand. This is an absolute address in memory. These are three-byte instructions.

## INDEXED ADDRESSING

In indexed addressing, the address contained in the second byte of the instruction is added to the index register's lowest eight bits in the MPU. The carry is then added to the higher order eight bits of the index register. This result is then used to address memory. The modified address is held in a temporary address register so there is no change to the index register. These are two-byte instructions.

## IMPLIED ADDRESSING

In the implied addressing mode, the instruction gives the address (i.e., stack pointer, index register, etc.). These are one-byte instructions.

RELATIVE ADDRESSING
In relative addressing, the address contained in the second
byte of the instruction is added to the program counter's lowest eight bits plus two. The carry or borrow is then added to the high eight bits. This allows the user to address data within a range of -125 to +129 bytes of the present instruction. These are two-byte instructions.

TABLE 2 - MICROPROCESSOR INSTRUCTION SET - ALPHABETIC SEQUENCE

| ABA | Add Accumulators | CLR | Clear | PUL | Pull Data |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADC | Add with Carry | CLV | Clear Overflow | ROL | Rotate Left |
| ADD | Add | CMP | Compare | ROR | Rotate Right |
| AND | Logical And | COM | Complement | RTI | Return from Interrupt |
| ASL | Arithmetic Shift Left | CPX | Compare Index Register | RTS | Return from Subroutine |
| ASR | Arithmetic Shift Right | DAA | Decimal Adjust | SBA | Subtract Accumulators |
| BCC | Branch if Carry Clear | DEC | Decrement | SBC | Subtract with Carry |
| BCS | Branch if Carry Set | DES | Decrement Stack Pointer | SEC | Set Carry |
| BEQ | Branch if Equal to Zero | DEX | Decrement Index Register | SEI | Set Interrupt Mask |
| BGE | Branch if Greater or Equal Zero | EOR | Exclusive OR | SEV | Set Overtiow |
| BHI | Branch if Higher | INC | Increment | STA | Store Accumulator |
| BIT | Bit Test | INS | Increment Stack Pointer | STS | Store Stack Register |
| BLE | Branch if Less or Equal | INX | Increment Index Register | SUB | Store Index Regist |
| BLS | Branch if Lower or Same |  | Jump | SWI | Software Interrupt |
| BLT | Branch if Less than Zero | JMP | Jump to Subroutine |  | Soltware Interrupt |
| BMI | Branch if Minus | JSA | Jump to Subroutine | TAB | Transfer Accumulators |
| BNE | Branch it Not Equal to Zero | LDA | Load Accumulator | TAP | Transfer Accumulators to Condition Code Reg. |
| BPL | Branch if Plus | LDS | Load Stack Pointer | TBA | Transfer Accumulators |
| BRA | Branch Always | LDX | Load Index Register | TPA | Transfer Condition Code Reg. to Accumulator |
| BSR | Branch to Subroutine | LSR | Logical Shift Right | TST | Test |
| BVC | Branch if Overflow Clear | NEG |  | TSX | Transfer Stack Pointer to Index Register |
| BVS | Branch if Overflow Set | $\begin{aligned} & \text { NEG } \\ & \text { NOP } \end{aligned}$ | No Operation | TXS | Transfer Index Register to Stack Pointer |
| CBA CLC CLI | Compare Accumulators Clear Carry Clear Interrupt Mask | $\begin{aligned} & \text { ORA } \\ & \text { PSH } \end{aligned}$ | Inclusive OR Accumulator Push Data | WAI | Wait for Interrupt |



| OP | Operation Code (Hexadecimal). | + | Boolean tnclusive OR. |
| :---: | :---: | :---: | :---: |
| - | Number of MPU Cycles: | $\stackrel{+}{ }$ | Boolean Exclusive OR, |
| $=$ | Number of Program Bytes. | m | Complement of M . |
| + | Arithmetic Plus. | $\rightarrow$ | Transter into: |
| - | Arithmetic Minus. | 0 | Bit $=$ Zero, |
| - | Boolean AND. | 00 | Byte $=$ Zero. |
| Msp | Contents of memory location pointed to be Stack Pointer. |  |  |

Note - Accumulator addressing mode instructions are included in the column for IMPLIED addressing

## CONDITION CODE SYMBOLS:

[^2]| POINTER OPERATIONS | MNEMONIC | IMMED |  |  | DIRECT |  |  | INDEX |  |  | EXTND |  |  | IMPLIED |  |  | BOOLEAN/ARITHMETIC OPERATION | COND. CODE REG |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 32 |  |  |  | 21 | 0 |  |  |  |  |
|  |  | OP | $\sim$ | \# |  |  |  | OP | $\sim$ | \# |  |  |  | OP | - | \# |  | OP | - | \# | OP | ~ | \# | H | 1 | $N$ | 2 v | c |
| Compare Index Reg | CPX | 8C | 3 | 3 | 9C | 4 | 2 | AC | 6 | 2 | EC | 5 | 3 |  |  |  | $\mathrm{X}_{H}-M \cdot \mathrm{X}_{L}-(M+1)$ | $\bullet$ | - | (1) | 18 | - |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 4 | 1 | $x-1-x$ | - | - | - 1 | $\bullet$ | - |
| Decrement Stack Potr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 4 | 1 | SP-1-SP | - | $\bullet$ | - | - $\bullet$ | - |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 4 | 1 | $x+1 \rightarrow x$ | $\bullet$ | - | - | $\bullet$ | - |
| Increment Siack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 4 | 1 | SP $+1 \rightarrow$ SP | $\bullet$ | - | - - | $\bullet$ | - |
| Load Index feg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 6 | 2 | FE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{X}_{\mathrm{H},}(\mathrm{M}+\mathrm{H}) \rightarrow \mathrm{X}_{\mathrm{L}}$ | - | - | (9) | 1 R | - |
| Load Stack Pntt | LOS | 8E | 3 | 3 | 9E | 4 | 2 | AE | 6 | 2 | BE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{SP}_{\mathrm{H}_{1}}(\mathrm{M}+1) \rightarrow$ SP |  | - | (9) | : R | $\bullet$ |
| Store Index Reg | StX |  |  |  | DF | 5 | 2 | EF | 7 | 2 | FF | 6 | 3 |  |  |  | $X_{H} \rightarrow M . X_{L} \rightarrow(M+1)$ | $\bullet$ | - | (9) | : R | - |
| Store Stack Pntr | STS |  |  |  | 9 F | 5 | 2 | AF | 7 | 2 | BF | 6 | 3 |  |  |  | $S P_{H} \rightarrow M . S P_{L} \rightarrow(M+1)$ | - | - | (9) : | : R | - |
| Indx Reg - Stack Pntr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 4 | 1 | $x-1-S P$ | - | - | - | - | $\bullet$ |
| Stack Pntt-Indx Reg | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 4 | 1 | SP $+1 \rightarrow x$ | - | - | - | - | - |

TABLE 5 - JUMP AND BRANCH INSTRUCTIONS

| OPERATIONS | MNEMONIC | RELATIVE |  |  | Index |  |  | EXTND |  |  | IMPLIED |  |  | BRANCH TEST |  | COND. CODE REG. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |
|  |  | OP | $\sim$ | \# |  |  |  | OP | $\sim$ | \# |  |  |  | OP | $\sim$ | \# | OP | - | \# | H | 1 | N | 2 | $v$ | C |
| Branch Always | BRA | 20 | 4 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | None | $\bullet$ | - | - | $\bullet$ | - | $\bullet$ |
| Branch If Carry Clear | BCC | 24 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{C}=0$ | - | - | - | - | - | - |
| Branch if Carry Set | BCS | 25 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{C}=1$ | - | - | - | - | $\cdots$ | $\bullet$ |
| Branch If $=$ Zero | BEO | 27 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $z=1$ | - | - | - | - | - | - |
| Branch If $\geqslant$ Zero | bGE | 2C | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $N \oplus \sim=0$ | - | - | - | - | - | - |
| Branch if $>$ Zero | BGT | 2 E | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | - | - | - | - | - | - |
| Branch if Higher | BHI | 22 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{C}+\mathrm{Z}=0$ | - | - | - | - | - | - |
| Branch If $\leqslant$ Zero | BLE | 2 F | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{Z}+(\mathrm{N} \oplus(\mathrm{V})=1$ | - | - | - | - | - | - |
| Branch if Lower Or Same | BLS | 23 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $C+Z=1$ | - | - | - | $\bullet$ | - | - |
| Branch if < Zero | BLT | 20 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $N \oplus \sim=1$ | - | - | - | - | - | - |
| Branch If Minus | BMI | 28 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $N=1$ | - | - | - | - | - | - |
| Branch If Not Equal Zero | BNE | 26 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{z}=0$ | - | - | - | - | - | - |
| Branch it Overflow Clear | BVC | 28 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{V}=0$ | - | - | - |  | - | - |
| Branch it Overflow Set | BVS | 29 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $v=1$ | - | - | - | - | - | $\bullet$ |
| Branch if Plus | BPL | 2A | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | - | - | - | - | - | $\bullet$ |
| Branch To Subroutine | BSR | 80 | 8 | 2 |  |  |  |  |  |  |  |  |  |  |  | - | - | - | - | - | - |
| Jump | JMP |  |  |  | 6 E | 4 | 2 | 7E | 3 | 3 |  |  |  |  | See Special Operations | - | - | - | - | - | - |
| Jump To Subroutine | JSR |  |  |  | AD | 8 | 2 | BD | 9 | 3 |  |  |  |  | (Figure 16) | - |  | - | - | $\bullet$ | - |
| No Operation | NOP |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 |  | Advances Prog. Cntr. Onlv | - | - | - 1 | $\bullet$ | $\bullet$ | $\bullet$ |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  | 3B | 10 | 1 |  |  |  |  |  |  |  |  |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  |  | $\bullet$ |  |  |  | - | $\bullet$ |
| Software interrupt | SWI |  |  |  |  |  |  |  |  |  | 3 F | 12 | 1 | , | See Special Uperations | - | $\bullet$ | - | - | - | - |
| Wait for Interrupt | WAI |  |  |  |  |  |  |  |  |  | 3 E | 9 | 1 |  | (Figure 16) | - | (11) | - | - | - | - |

## SPECIAL OPERATIONS

## JSR, JUMP TO SUBROUTINE:



BSR, BRANCH TO SUBROUTINE:


$$
\begin{aligned}
& n+2 \text { Formed From }[n+2)_{H} \text { and }[n+2)_{L}
\end{aligned}
$$

JMP, JUMP:


RTS, RETURN FROM SUBROUTINE:


RTI, RETURN FROM INTERRUPT:


| SP | Stack |
| :---: | :---: |
| SP |  |
| SP + 1 | Condition Code |
| SP +2 | Acmitr B |
| SP +3 | Acmitr A |
| SP +4 | Index Register ( $\mathrm{X}_{\mathrm{H}}$ ) |
| SP + 5 | Index Register ( $\mathrm{X}_{\mathrm{L}}$ ) |
| $S P+6$ | PCH |
| $\rightarrow \mathrm{SP}+7$ | $P C_{L}$ |



TABLE 6 - CONDITION CODE REGISTER MANIPULATION INSTRUCTIONS
COND. CODE REG

| OPERATIONS | MNEMONIC |  |  |  | BOOLEAN OPERATION |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | - | \# |  | H | 1 | N | 2 | v | C |
| Clear Carry | CLC | OC | 2 | 1 | $0 \rightarrow$ C | - | - | - | - | - | R |
| Clear Interrupt Mask | CLI | OE | 2 | 1 | $0 \rightarrow 1$ | - | R | - | - | - | - |
| Clear Overfiow | CLV | OA | 2 | 1 | $0 \rightarrow V$ | - | - | - | - | R | - |
| Set Carry | SEC | OD | 2 | 1 | $1 \rightarrow$ C | - | - | - | - | - | S |
| Set Interrupt Mask | SEI | OF | 2 | 1 | $1 \rightarrow 1$ | - | S | - | - | - | - |
| Set Overflow | SEV | 08 | 2 | 1 | $1 \rightarrow V$ | - | - | - | - | S | - |
| Acmltr A $\rightarrow$ CCR | TAP | 06 | 2 | 1 | $A \rightarrow C C R$ |  |  |  |  |  | - |
| CCR $\rightarrow$ Acmltr $A$ | TPA | 07 | 2 | 1 | $C C R \rightarrow A$ | - | - | - | $1 \cdot$ | - | - |

CONDITION CODE REGISTER NOTES: (Bit set it test is true and cleared otherwise)

| (Bit V) | Test: Result $=10000000$ ? |
| :--- | :--- |
| (Bit C) | Test: Result $\neq 00000000$ ? |
| (Bit C) | Test: Decimal value of most significant $B C D$ Character greater than nine? |
|  | (Not cleared if previously set.) |
| (Bit V) | Test: Operand $=10000000$ prior to execution? |
| (Bit V) Test: Operand $=01111111$ prior to execution? |  |
| (Bit V) Test: Set equal to result of $N \oplus C$ after shift has occurred. |  |

(Bit V) Test: Operand $=01111111$ prior to execution?
(Bit V) Test: Set equal to result of $N \oplus C$ after shitt has occurred.

| 7 | (Bit N) | Test: Sign bit of most significant (MS) byte $=1$ ? |
| :--- | :--- | :--- |
| 8 | (Bit V) | Test: 2's complement overflow from subtraction of MS bytes? |
| 9 | (Bit N) | Test: Result less than zero? (Bit $15=1$ ) |
| 10 | (All) | Load Condition Code Register from Stack. (See Special 0perations) |
| 11 | (Bit I) | Set when interrupt occurs. If previously set, a Non Maskable <br> Interrupt is required to exit the wait state. |
| 12 | (All) | Set according to the contents of Accumulator A. |



| INC |  |  |
| :---: | :---: | :---: |
| INS |  |  |
| INX |  | - |
| JMP |  |  |
| JSR |  |  |
| LDA | x |  |
| LDS |  |  |
| LDX |  | - |
| LSR |  | 2 |
| NEG |  | 2 |
| NOP |  |  |
| ORA | x | - |
| PSH |  | - |
| PUL |  | - |
| ROL |  | 2 |
| ROR |  | 2 |
| RTI |  | - |
| RTS |  | - |
| SBA |  | - |
| SBC | - | - |
| SEC |  | - |
| SEI |  | - |
| SEV |  | - |
| STA | x | - |
| STS |  | - |
| STX |  | $\bullet$ |
| SUB | x | - |
| SWI |  | - |
| TAB |  | - |
| TAP |  | - |
| TBA |  | - |
| TPA |  | $\bullet$ |
| TST |  | 2 |
| TSX |  | $\bullet$ |
| TSX |  | - |
| WAI |  | - |

(Dual Operand)

NOTE: Interrupt time is 12 cycles from the end of the instruction being executed, except following a WAI instruction. Then it is 4 cycles.

Table 8 provides a detailed description of the information present on the address bus, data bus, valid memory address line (VMA), and the read/write line (R/W) during each cycle for each instruction.

This information is useful in comparing actual with expected results during debug of both software and hardware
as the control program is executed. The information is categorized in groups according to addressing modes and number of cycles per instruction. In general, instructions with the same addressing mode and number of cycles execute in the same manner; exceptions are indicated in the table.)

TABLE 8 - OPERATIONS SUMMARY

| Address Mode and Instructions | Cycles | Cycle $\#$ | VMA Line | Address Bus | $\underset{\text { Line }}{R / \bar{W}}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMMEDIATE |  |  |  |  |  |  |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $1$ | Op Code Address <br> Op Code Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code Operand Data |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { LDX } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | $1$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address + 2 | $1$ | Op Code <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |

DIRECT

| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | 1 | Op Code Address <br> Op Code Address +1 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand <br> Operand Data |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { LDX } \end{aligned}$ | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Address of Operand <br> Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Destination Address <br> Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Destination Address <br> Irrelevant Data (Note 1) <br> Data from Accumulator |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | 1 1 0 1 1 | Op Code Address <br> Op Code Address + 1 <br> Address of Operand <br> Address of Operand <br> Address of Operand + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Address of Operand <br> Irrelevant Data (Note 1) <br> Register Data (High Order Byte) <br> Règister Data (Low Order Byte) |

INDEXED

| JMP |  | 1 | 1 | Op Code Address | 1 | Op Code |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | 4 | 2 | 1 | Op Code Address + 1 | 1 | Offset |
|  |  | 3 | 0 | Index Register | 1 | Irrelevant Data (Note 1) |
|  |  | 4 | 0 | Index Register Plus Offset (w/o Carry) | 1 | Irrelevant Data (Note 1) |
| ADC EOR |  | 1 | 1 | Op Code Address | 1 | Op Code |
| ADD LDA |  | 2 | 1 | Op Code Address + 1 | 1 | Offset |
| AND ORA | 5 | 3 | 0 | Index Register | 1 | Irrelevant Data (Note 1) |
| BIT SBC |  | 4 | 0 | Index Register Plus Offset (w/o Carry) | 1 | Irrelevant Data (Note 1) |
| CMP SUB |  | 5 | 1 | Index Register Plus Offset | 1 | Operand Data |
| CPX |  | 1 | 1 | Op Code Address | 1 | Op Code |
| LDS |  | 2 | 1 | Op Code Address + 1 | 1 | Offset |
|  |  | 3 | 0 | Index Register | 1 | Irrelevant Data (Note 1) |
|  |  | 4 | 0 | Index Register Plus Offset (w/o Carry) | 1 | Irrelevant Data (Note 1) |
|  |  | 5 | 1 | Index Register Plus Offset | 1 | Operand Data (High Order Byte) |
|  |  | 6 | 1 | Index Register Plus Offset + 1 | 1 | Operand Data (Low Order Byte) |

TABLE 8 - OPERATIONS SUMMARY (CONTINUED)

| Address Mode and Instructions | Cycles | Cycle <br> 4 | VMA Line | Address Bus | $\begin{aligned} & R / \bar{W} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INDE XED (Continued) |  |  |  |  |  |  |
| STA | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Index Register <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Offset <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Operand Data |
| ASL LSR <br> ASR NEG <br> CLR ROL <br> COM ROR <br> DEC TST <br> INC  | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | 1 <br> 1 <br> 0 <br> 0 <br> 1 <br> 0 <br> $1 / 0$ <br> (Note <br> 3 ) <br> 1 | Op Code Address <br> Op Code Address +1 <br> Index Register <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Offset <br> Index Register Plus Offset <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Current Operand Data <br> Irrelevant Data (Note 1) <br> New Operand Data (Note 3) |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \end{aligned}$ | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Index Register <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Offset <br> Index Register Plus Offset <br> Index Register Pluts Offset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| JSR | 8 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Index Register <br> Stack Pointer <br> Stack Pointer -- 1 <br> Stack Pointer - 2 <br> Index Register <br> Index Register Plus Offset (w/o Carry) | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) |

EXTENDED

| JMP | 3 | 1 2 3 | $1$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 | 1 1 1 | Op Code <br> Jump Address (High Order Byte) <br> Jump Address (Lpw Order Byte) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | 1 2 3 4 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address +2 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { LDX } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 <br> Address of Operand <br> Address of Operand + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| $\begin{aligned} & \text { STA A } \\ & \text { STA B } \end{aligned}$ | 5 | 1 2 3 4 5 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address +2 <br> Operand Destination Address <br> Operand Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Destination Address (High Order Byte) <br> Destination Address (Low Order Byte) <br> Irrelevant Data (Note 1) <br> Data from Accumulator |
| ASL LSR ASR NEG CLR ROL COM ROR DEC TST INC | 6 | 1 2 3 4 5 6 | $\begin{gathered} \hline 1 \\ 1 \\ 1 \\ 1 \\ 0 \\ 1 / 0 \\ \text { (Note } \\ 3 \text { ) } \\ \hline \end{gathered}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address +2 <br> Address of Operand <br> Address of Operand <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Current Operand Data <br> Irrelevant Data (Note 1) <br> New Operand Data (Note 3) |

TABLE 8 - OPERATIONS SUMMARY (CONTINUED)

| Address Mode <br> and Instructions | Cycles | Cycle <br> \# | VMA <br> Line | Address Bus | R/W <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |




TABLE 8 - OPERATIONS SUMMARY (CONCLUDED)

| Address Mode <br> and Instructions | Cycles | Cycle <br> $z$ | VMA <br> Line | Address Bus | $R / \bar{W}$ <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| INHERENT (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WAI | 9 | 1 | 1 | Op Code Address | 1 | Op Code |
|  |  | 2 | 1 | Op Code Address + 1 | 1 | Op Code of Next Instruction |
|  |  | 3 | 1 | Stack Pointer | 0 | Return Address (Low Order Byte) |
|  |  | 4 | 1 | Stack Pointer - 1 | 0 | Return Address (High Order Byte) |
|  |  | 5 | 1 | Stack Pointer - 2 | 0 | Index Register (Low Order Byte) |
|  |  | 6 | 1 | Stack Pointer - 3 | 0 | Index Register (High Order Byte) |
|  |  | 7 | 1 | Stack Pointer - 4 | 0 | Contents of Accumulator A |
|  |  | 8 | 1 | Stack Pointer - 5 | 0 | Contents of Accumulator B |
|  |  | 9 | 1 | Stack Pointer - 6 | 1 | Contents of Cond. Code Register |
| RTI | 10 | 1 | 1 | Op Code Address | 1 | Op Code |
|  |  | 2 | 1 | Op Code Address + 1 | 1 | Irrelevant Data (Note 2) |
|  |  | 3 | 0 | Stack Pointer | 1 | Irrelevant Data (Note 1) |
|  |  | 4 | 1 | Stack Pointer + 1 | 1 | Contents of Cond. Code Register from Stack |
|  |  | 5 | 1 | Stack Pointer +2 | 1 | Contents of Accumulator B from Stack |
|  |  | 6 | 1 | Stack Pointer +3 | 1 | Contents of Accumulator A from Stack |
|  |  | 7 | 1 | Stack Pointer +4 | 1 | Index Register from Stack (High Order Byte) |
|  |  | 8 | 1 | Stack Pointer + 5 | 1 | Index Register from Stack (Low Order Byte) |
|  |  | 9 | 1 | Stack Pointer +6 | 1 | Next Instruction Address from Stack (High Order Byte) |
|  |  | 10 | 1 | Stack Pointer +7 | 1 | Next Instruction Address from Stack (Low Order Byte) |
| SWI | 12 | 1 | 1 | Op Code Address | 1 | Op Code |
|  |  | 2 | 1. | Op Code Address + 1 | 1 | Irrelevant Data (Note 1) |
|  |  | 3 | 1 | Stack Pointer | 0 | Return Address (Low Order Byte) |
|  |  | 4 | 1 | Stack Pointer - 1 | 0 | Return Address (High Order Byte) |
|  |  | 5 | 1 | Stack Pointer - 2 | 0 | Index Register (Low Order Byte) |
|  |  | 6 | 1 | Stack Pointer - 3 | 0 | Index Register (High Order Byte) |
|  |  | 7 | 1 | Stack Pointer - 4 | 0 | Contents of Accumulator A |
|  |  | 8 | 1 | Stack Pointer - 5 | 0 | Contents of Accumulator B |
|  |  | 9 | 1 | Stack Pointer - 6 | 0 | Contents of Cond. Code Register |
|  |  | 10 | 0 | Stack Pointer - 7 | 1 | Irrelevant Data (Note 1) |
|  |  | 11 | 1 | Vector Address FFFA (Hex) | 1 | Address of Subroutine (High Order Byte) |
|  |  | 12 | 1 | Vector Address FFFB (Hex) | 1 | Address of Subroutine (Low Order Byte) |



[^3]
## PHYSICAL DIMENSIONS



PSUFFIX PLASTIC PACKAGE


## ORDERING INFORMATION

| EF68A02 $\left\|C_{\mid} \mathbf{M}_{\mid} \mathbf{B / B}\right\|$ |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| The table below horizontally shows all available suffix combinations for package, operating temperature and screening level. Other possibilities on request. |  |  |  |  |  |  |  |  |  |  |  |  |
| DEVICE | PACKAGE |  |  |  |  | OPER. TEMP |  |  | SCREENING LEVEL |  |  |  |
|  | C | J | P | E | FN | L* | V | M | Std | D | G/B | B/B |
| EF6802/08 (1.0 MHz) | $\bullet$ |  | - |  | $\bullet$ | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  | $\bullet$ |  |  |  | $\bullet$ |  | $\bullet$ |  |  |  |
|  |  |  |  | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  | $\bullet$ | $\bullet$ |
| Ef68A02/A08 (1.5 MHz) | $\bullet$ |  | - |  |  | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  | $\bullet$ |  |  |  | $\bullet$ |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  |  | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  | $\bullet$ | $\bullet$ |
| Ef68B02/B08 ( 2.0 MHz ) | $\bullet$ |  | $\bullet$ |  |  | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  |  |  |  |  | $\bullet$ |  | $\bullet$ |  | $\bullet$ |  |
| Examples : EF6802C, EF6802CV, EF6802EM, EF6802EM G/B |  |  |  |  |  |  |  |  |  |  |  |  |
| Package : C : Ceramic DIL, J : Cerdip DIL, P : Plastic DIL, E: LCCC, FN : PLCC. <br> Oper. temp. : L* : $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}$ : $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{M}:-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$, * : may be omitted. Screening level : Std : (no-end suffix), D : NFC 96883 level D, G/B : NFC 96883 level G, B/B : NFC 96883 level B and MIL-STD-883C level B. |  |  |  |  |  |  |  |  |  |  |  |  |

CB-521


FN SUFFIX
PLCC 44


CB-708


## ESUFFIX

 LCCC 44


#### Abstract

The EF6801 is an 8-bit single-chip microcomputer unit (MCU) which significantly enhances the capabilities of the 6800 family of parts. It includes an upgraded 6800 microprocessor unit (MPU) with upward-source and object-code compatibility. Execution times of key instructions have been improved and several new instructions have been added including an unsigned multiply. The MCU can function as a monolithic microcomputer or can be expanded to a 64 K byte address space. It is TTL compatible and requires one +5 -volt power supply. On-chip resources include 2048 bytes of ROM 128 bytes of RAM, a Serial Communications Interface (SCI), parallel I/O, and a three function Programmable Timer. The EF6803 can be considered as an EF6801 operating in Modes 2 or 3. EF6801 MCU Family features include :


- Enhanced EF6800 Instruction Set
- $8 \times 8$ Multiply Instruction
- Serial Communications Interface (SCI)
- Upward Source and Object Code Compatibility with the 6800
- 16-Bit Three-Function Programmable Timer
- Single-Chip or Expanded Operation to 64K Byte Address Space
- Bus Compatibility with the 6800 Family
- 2048 Bytes of ROM (EF6801)
- 128 Bytes of RAM
- 64 Bytes of RAM Retainable During Powerdown
- 29 Parallel I/O and Two Handshake Control Lines
- Internal Clock Generator with Divide-by-Four Output.
- Complete Development System Support on DEVICE ${ }^{\circledR}$.
- $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Temperature range
- $-40^{\circ} \mathrm{C}$ to $+105^{\circ} \mathrm{C}$ Temperature range


## HMOS

(HIGH-DENSITY N-CHANNEL, SILICON-GATEI

## MICROCOMPUTER/ MICROPROCESSOR




(1) No functioning ROM in EF6803

## POWER CONSIDERATIONS

The average chip-junction temperature, $\mathrm{T}_{\mathrm{J}}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{aligned}
& T_{J}=T_{A}+\left(P_{D} \bullet \theta_{J A}\right) \\
& \text { Where: }
\end{aligned}
$$

```
TA =Ambient Temperature, }\mp@subsup{}{}{\circ}\textrm{C
0JA =Package Thermal Resistance, Junction-to-Ambient, }\mp@subsup{}{}{\circ}\textrm{C}/\textrm{W
PD=PINT + PPORT
PINT =|ICC }\times\mp@subsup{V}{CC}{C}\mathrm{ , Watts - Chip Internal Power
PPORT=Port Power Dissipation, Watts - User Determined
```

For most applications PPORT < PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K+\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D}\left(T A+273^{\circ} \mathrm{C}\right)+\theta J A \cdot P^{\circ} D^{2} \tag{3}
\end{equation*}
$$

Where K is a constant pertaining to the particular part. K can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P D$ and $T J$ can be obtained by solving equations (1) and (2) iteratively for any value of $\mathrm{T}_{\mathrm{A}}$.

MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{C C}$ | -0.3 to + 7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Ranqe <br> EF6801/03, EF6801/03-1, EF68A01/03 <br> EF68801/03, EF6801/03-1 : V suffix <br> EF6801/03, EF6801/03-1 : A suffix | ${ }^{\top}$ A | $\begin{gathered} T_{L} \text { to } T_{H} \\ 0 \text { to } 70 \\ -40 \text { to } 85 \\ -40 \text { to } 105 \\ \hline \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avord application of any voltage higher than maximum rated voltages to this high-impedance circuit. For proper operation it is recommended that $V_{\text {in }}$ and $V_{\text {out }}$ be constrained to the range $V_{S S} \leq\left(V_{\text {in }}\right.$ or $\left.V_{\text {out }}\right) \leq V_{C C}$. Input protection is enhanced by connecting unused inputs to either $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{S S}$

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Rating |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Plastic | $\theta \mathrm{JA}$ | 50 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| PLCC |  | 100 |  |

CONTROL TIMING $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=0$ to $\left.70^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | EF6801 |  | EF6801-1 |  | EF68A01 |  | EF68B01 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $\mathrm{f}_{0}$ | 0.5 | 1.0 | 0.5 | 1.25 | 0.5 | 1.5 | 0.5 | 2.0 | 4 MHz |
| Crystal Frequency | ${ }^{\text {f XTAL }}$ | 2.0 | 4.0 | 2.0 | 5.0 | 2.0 | 6.0 | 2.0 | 8.0 | MHz |
| External Oscillator Frequency | ${ }^{4 f_{0}}$ | 2.0 | 4.0 | 2.0 | 5.0 | 2.0 | 6.0 | 2.0 | 8.0 | MHz |
| Crystal Oscillator Start Up Time | tric | - | 100 | - | 100 | - | 100 | - | 100 | ms |
| Processor Control Setup Time | tpCS | 200 | - | 170 | - | 140 | - | 110 | - | ns |

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Characteristic | Symbol | $\begin{gathered} \mathrm{EF} 6801 / 03 \\ 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{gathered}$ |  | $\begin{gathered} \text { EF6801/03 } \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{gathered}$ |  | $\begin{array}{\|c\|} \hline \text { EF6801/03 } \\ -40^{\circ} \mathrm{C} \text { to }+105^{\circ} \mathrm{C} \\ \hline \end{array}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Input High Voltage $\begin{array}{r}\overline{\text { RESET }} \\ \text { Other Inputs }\end{array}$ | $V_{\text {IH }}$ | $\begin{array}{\|l\|} \hline \mathrm{V}_{\mathrm{SS}}+4.0 \\ \mathrm{~V}_{\mathrm{SS}}+2.0 \end{array}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{CC}} \end{aligned}$ | $\begin{array}{\|c\|} \hline \mathrm{VSS}_{\mathrm{SS}}+4.0 \\ \mathrm{~V}_{\mathrm{SS}}+2.2 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+4.0 \\ & \mathrm{~V}_{\mathrm{SS}}+2.2 \end{aligned}$ | $V_{C C}$ <br> $V_{C C}$ | V |
| Input Low Voltage All Inputs | VIL | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+0.8$ | $\mathrm{VSS}-0.3$ | $\mathrm{V}_{\mathrm{SS}}+0.8$ | $\mathrm{V}^{\text {SS }-0.3}$ | $\mathrm{V}_{\mathrm{SS}}+0.8$ | V |
| Input Load Current Port 4 <br> $\left(\mathrm{~V}_{\text {in }}=0\right.$ to 2.4 V$)$ SCl | 1 in | \|l| | $\begin{aligned} & 0.5 \\ & 0.8 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 0.8 \\ & 1.0 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 0.8 \\ & 1.0 \\ & \hline \end{aligned}$ | mA |
| Input Leakage Current <br> $\left(V_{\text {in }}=0\right.$ to 5.25 V$)$ <br> $\overline{\mathrm{NMI}}, \overline{\mathrm{RQ}}, \overline{\mathrm{RESET}}$ | 1 in | - | 2.5 | - | 5.0 | - | 5.0 | $\mu \mathrm{A}$ |
| Hi-Z (Off State) input Current $\left(\mathrm{V}_{\text {in }}=0.5\right.$ to 2.4 V$) \quad$ Ports 1,2 , and 3 | \|TSI | - | 10 | - | 20 | - | 20 | $\mu \mathrm{A}$ |
| Output High Voltage  <br> ("Load $=-65 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ )* E, Port 4, SC1, SC2 <br> ("Load $=-100 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ ) Other Outputs | V OH | $\left\lvert\, \begin{aligned} & \mathrm{V} S \mathrm{~S}+2.4 \\ & \mathrm{~V}_{\mathrm{SS}}+2.4 \end{aligned}\right.$ | - | $\begin{array}{\|} \mathrm{V}_{\mathrm{SS}}+2.4 \\ \mathrm{v}_{\mathrm{SS}}+2.4 \end{array}$ | - | $\left\lvert\, \begin{array}{\|r\|}  \\ \mathrm{VSS}+2.4 \\ \mathrm{VSS}_{\mathrm{SS}}+2.4 \end{array}\right.$ | . - | V |
| Output Low Voltage. <br> ( ${ }_{\text {Load }}=2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ ) <br> All Outputs | $\mathrm{V}_{\mathrm{OL}}$ | - | $\mathrm{NSS}+0.5$ | - | $\mathrm{NSS}+0.6$ | 6 | $\mathrm{V}_{\mathrm{SS}}+0.6$ | V |
| Darlington Drive Current ( $\mathrm{V}_{\mathrm{O}}=1.5 \mathrm{~V}$ ) Port 1 | ${ }^{1} \mathrm{OH}$ | 1.0 | 4.0 | 1.0 | 5.0 | 1.0 | 5.0 | mA |
| Internal Power Dissipation <br> (Measured at $T_{A}=T_{L}$ in Steady-State Operation) | PINT | - | 1200 | - | 1500 | - | 1500 | mW |
| Input Capacitance Port 3, Port 4, SCl <br> $\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}_{\mathrm{O}}=1.0 \mathrm{MHz}\right)$ Other Inputs | $\mathrm{Cin}_{\text {in }}$ | - | $\begin{gathered} 12.5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{gathered} 12.5 \\ 10 \\ \hline \end{gathered}$ | - | $\begin{gathered} 12.5 \\ 10 \\ \hline \end{gathered}$ | pF |
| $V_{\text {CC Standby }}$ (r $\begin{array}{r}\text { Powerdown } \\ \text { Powerup }\end{array}$ | $\begin{aligned} & \hline \mathrm{v}_{\mathrm{SBB}} \\ & \mathrm{v}_{\mathrm{SB}} \end{aligned}$ | $\begin{gathered} 4.0 \\ 4.75 \\ \hline \end{gathered}$ | $\begin{aligned} & 5.25 \\ & 5.25 \end{aligned}$ | $\begin{gathered} 4.0 \\ 4.75 \\ \hline \end{gathered}$ | $\begin{aligned} & 5.25 \\ & 5.25 \\ & \hline \end{aligned}$ | $\begin{gathered} 4.0 \\ 4.75 \end{gathered}$ | $\begin{aligned} & 5.25 \\ & 5.25 \\ & \hline \end{aligned}$ | $\checkmark$ |
| Standby Current Powerdown | ISBB | - | 6.0 | - | 8.0 | - | 8.0 | mA |

*Negotiable to $-100 \mu \mathrm{~A}$ (for further information contact the factory)

PERIPHERAL PORT TIMING (Refer to Figures 2.5)

| Characteristics | Symbol | EF6801 |  | $\begin{aligned} & \text { EF6801-1 } \\ & \text { EF6803-1 } \end{aligned}$ |  | EF68A01 <br> EF68A03 |  | EF68B01 EF68B03 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| Peripheral Data Setup Time | tPDSU | 200 | - | 200 | - | 150 | - | 100 | - | ns |
| Peripheral Data Hold Time | tPDH | 200 | - | 200 | - | 150 | - | 100 | - | ns |
| Delay Time, Enable Positive Transition to $\overline{\mathrm{OS} 3}$ Negative Transition | tosD1 | - | 350 | - | 350 | - | 300 | - | 250 | ns |
| Delay Time, Enable Positive Transition to $\overline{\mathrm{OS} 3}$ Positive Transition | tosD2 | - | 350 | - | 350 | - | 300 | - | 250 | ns |
| Delay Time, Enable Negative Transition to Peripheral Data Valid | tPWD | - | 350 | - | 350 | - | 300 | - | 250 | ns |
| Delay Time, Enable Negative Transition to Peripheral CMOS Data Valid | ${ }^{\text {t }}$ CMOS | - | 2.0 | - | 2.0 | - | 2.0 | - | 2.0 | $\mu \mathrm{S}$ |
| Input Strobe Pulse Width | tpWIS | 200 | - | 200 | - | 150 | - | 100 | - | ns |
| Input Data Hold Time | ${ }_{\text {ti }} \mathrm{H}$ | 50 | - | 50 | - | 40 | - | 30 | - | ns |
| Input Data Setup Time | IIS | 20 | - | 20 | - | 20 | - | 20 | - | ns |

FIGURE 2 - DATA SETUP AND HOLD TIMES (MPU READ)

-Port 3 Non-Latched Operation (LATCH ENABLE $=0$ )

FIGURE 3 - DATA SETUP AND HOLD TIMES (MPU WRITE)


NOTES:
110 k Pultup resistor required for Port 2 to reach 0.7 VCC
2 Not applicable to P21
3 Port 4 cannot be pulled above VCC

FIGURE 4 - PORT 3 OUTPUT STROBE TIMING (EF6801 SINGLE-CHIP MODE)


Access matches Output Strobe Select (OSS = O, a read: OSS = 1, a write)

FIGURE 5 - PORT 3 LATCH TIMING (EF6801 SINGLE-CHIP MODE)


NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted.

BUS TIMING (See Notes 1 and 2)

| Ident. <br> Number | Characteristics | Symbol | EF6801 <br> EF6803 |  | EF6801.1 <br> EF6803-1 |  | $\begin{aligned} & \text { EF68A01 } \\ & \text { EF68A03 } \end{aligned}$ |  | EF68B01 <br> EF68B03 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }^{\text {t }} \mathrm{cyc}$ | 1.0 | 2.0 | 0.8 | 2.0 | 0.667 | 2.0 | 0.5 | 2.0 | $\mu \mathrm{s}$ |
| 2 | Pulse Width, E Low | PWEL | 430 | 1000 | 360 | 1000 | 300 | 1000 | 210 | 1000 | ns |
| 3 | Pulse Width, E High | PWEH | 450 | 1000 | 360 | 1000 | 300 | 1000 | 220 | 1000 | ns |
| 4 | Clock Rise and Fall Time | $t_{r}, t_{\text {f }}$ | - | 25 | - | 25 | - | 25 | - | 20 | ns |
| 9 | Address Hold Time | ${ }^{\text {taH }}$ | 20 | - | 20 | - | 20 | - | 10 | - | ns |
| 12 | Non-Muxed Address Valid Time to E* | ${ }^{\text {taV }}$ | 200 | - | 150 | - | 115 | - | 70 | - | ns |
| 17 | Read Data Setup Time | tDSR | 80 | - | 70 | - | 60 | - | 40 | - | ns |
| 18 | Read Data Hold Time | TDHR | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| 19 | Write Data Delay Time | toDW | - | 225 | - | 200 | - | 170 | - | 120 | ns |
| 21 | Write Data Hold Time | IDHW | 20 | - | 20 | - | 20 | - | 10 | - | ns |
| 22 | Muxed Address Valid Time to E Rise* | t AVM | 200 | - | 150 | - | 115 | - | 80 | - | ns |
| 24 | Muxed Address Valid Time to AS Fall* | ${ }^{\text {t } A S L}$ | 60 | - | 50 | - | 40 | - | 20 | - | ns |
| 25 | Muxed Address Hold Time | ${ }^{\text {t }}$ AHL | 20 | - | 20 | - | 20 | - | 10 | - | ns |
| 26 | Delay Time, E to AS Rise* | ${ }^{\text {t }}$ ASD | $90^{\circ}{ }^{\circ}$ | - | $70^{\circ}$ | - | $60^{\circ}$ | - | 45** | - | ns |
| 27 | Pulse Width, AS High* | PWASH | 220 | - | 170 | - | 140 | - | 110 | - | ns |
| 28 | Delay Time, AS to E Rise* | ${ }^{\text {t }}$ ASED | 90 | - | 70 | - | 60 | - | 45 | - | ns |
| 29 | Usable Access Time* | ${ }^{\text {t }}$ ( ${ }^{\text {ch }}$ | 595 | - | 465 | - | 380 | - | 270 | - | ns |

- At specified cycle time.
* t ASD parameters listed assume external TTL clock drive with $50 \% \pm 5 \%$ duty cycle. Devices driven by an external TTL clock with $50 \%$ $\pm 1 \%$ duty cycle or which use a crystal have the following taSD specifications : 100 ns min. ( 1.0 MHz devices), 80 ns min . ( 1.25 MHz devices), $65 \mathrm{~ns} \min$. (1.5 MHz devices), $50 \mathrm{~ns} \min$. ( 2.0 MHz devices).

FIGURE 6 - BUS TIMING



## INTRODUCTION

The EF6801 is an 8-bit monolithic microcomputer which can be configured to function in a wide variety of applications. The facility which provides this extraordinary flexibility is its ability to be hardware programmed into eight different operating modes. The operating mode controls the configuration of 18 of the 40 MCU pins, available on-chip resources, memory map, location (internal or external) of interrupt vectors, and type of external bus. The configuration of the remaining 22 pins is not dependent on the operating mode.
Twenty-nine pins are organized as three 8 -bit ports and one 5-bit port. Each port consists of at least a Data Register and a write-only Data Direction Register. The Data Direction Register is used to define whether corresponding bits in the Data Register are configured as an input (clear) or output (set).

The term "port," by itself, refers to all of the hardware associated with the port. When the port is used as a "data port" or " $1 / 0$ port," it is controlled by the port Data Direction Register and the programmer has direct access to the port pins using the port Data Register. Port pins are labled as $\mathrm{P}_{\mathrm{ij}}$ where i identifies one of four ports and j indicates the particular bit.

The Microprocessor Unit (MPU) is an enhanced EF6800 MPU with additional capabilities and greater throughput. It is upward source and object code compatible with the EF6800. The programming model is depicted in Figure 9 , where Accumulator $D$ is a concatenation of Accumulators $A$ and B. A list of new operations added to the 6800 instruction set are shown in Table 1.

The EF6803 can be considered an EF6801 that operates in Modes 2 and 3 only.

FIGURE 9 - PROGRAMMING MODEL


## OPERATING MODES

The EF6801 provides eight different operating modes (Modes 0 through 7), the EF6803 provides two operating modes (Modes 2 and 3). The operating modes are hardware selectable and determine the device memory map, the configuration of Port 3, Port 4, SC1, SC2, and the physical location of the interrupt vectors.

## FUNDAMENTAL MODES

The eight operating modes can be grouped into three fundamental modes which refer to the type of bus it supports: Single Chip, Expanded Non-Multiplexed, and Expanded Multiplexed. Single chip modes include 4 and 7, Expanded

Non-Multiplexed is Mode 5 and the remaining five are Expanded Multiplexed modes. Table 2 summarizes the characteristics of the operating modes.

## EF6801 Single-Chip Modes $(4,7)$

In the Single-Chip Mode, the four MCU ports are configured as parallel input/output data ports, as shown in Figure 10. The MCU functions as a monolithic microcomputer in these two modes without external address or data buses. A maximum of $291 / O$ lines and two Port 3 control lines are provided. Peripherals or another MCU can be interfaced to Port 3 in a loosely coupled dual processor configuration, as shown in Figure 11.

TABLE 1 - NEW INSTRUCTIONS

| Instruction | Description |
| :---: | :--- |
| ABX | Unsigned addition of Accumulator B to Index Register |
| ADDD | Adds (without carry) the double accumulator to memory and leaves the sum in the double accumulator |
| ASLD or LSLD | Shifts the double accumulator left (towards MSB) one bit; the LSB is cleared and the MSB is shifted into the C-bit |
| BHS | Branch if Higher or Same; unsigned conditional branch (same as BCC) |
| BLO | Branch if Lower; Unsigned conditional branch (same as BCS) |
| BRN | Branch Never |
| JSR | Additional addressing mode: direct |
| LDD | Loads double accumulator from memory |
| LSL | Shifts memory or accumulator left (towards MSB) one bit; the LSB is cleared and the MSB is shifted into the C-bit (same as |
| LSRD | Shifts the double accumulator right (towards LSB) one bit; the MSB is cleared and the LSB is shifted into the C-bit |
| MUL | Unsigned multiply; multiplies the two accumulators and leaves the product in the double accumulator |
| PSHX | Pushes the Index Register to stack |
| PULX | Pulls the Index Register from stack |
| STD | Stores the double accumulator to memory |
| SUBD | Subtracts memory from the double accumulator and leaves the difference in the double accumulator |
| CPX | Internal processing modified to permit its use with any conditional branch instruction |

In Single-Chip Test Mode (4), the RAM responds to \$XX80 through \$XXFF and the ROM is removed from the internal address map. A test program must first be loaded into the RAM using modes $0,1,2$, or 6 . If the MCU is Reset and then programmed into Mode 4, execution will begin at \$XXFE:XXFF. Mode 5 can be irreversibly entered from Mode 4 without asserting RESET by setting bit 5 of the Port 2 Data Register. This mode is used primarily to test Ports 3 and 4 in the Single-Chip and Non-Multiplexed Modes.

## EF6801 Expanded Non-Multiplexed Mode (5)

A modest amount of external memory space is provided in the Expanded Non-Multiplexed Mode while significant onchip resources are retained. Port 3 functions as an 8 -bit
bidirectional data bus and Port 4 is configured initially as an input data port. Any combination of the eight leastsignificant address lines may be obtained by writing to the Port 4 Data Direction Register. Stated alternatively, any combination of AO to A7 may be provided while retaining the remainder as input data lines. Internal pullup resistors pull the Port 4 lines high until the port is configured.

Figure 12 . illustrates a typical system configuration in the Expainded Non-Multiplexed Mode. The MCU interfaces directly with 6800 family parts and can access 256 bytes of external address space at $\$ 100$ through $\$ 1 F F$. IOS provides an address decode of external memory ( $\$ 100-\$ 1 F F$ ) and can be used as a memory page select or chip select line.

TABLE 2 - SUMMARY OF EF6801/03 OPERATING MODES

| Common to all Modes: |
| :--- |
| Reserved Register Area |
| Port 1 |
| Port 2 |
| Programmable Timer |
| Serial Communications Interface |
| Single Chip Mode 7 |
| 128 bytes of RAM; 2048 bytes of ROM |
| Port 3 is a parallel I/O port with two control lines |
| Port 4 is a parallel I/O port |
| SC1 is Input Strobe 3 (IIS3) |
| SC2 is Dutput Strobe 3 (OS3) |

(0s3)
Expanded Non-Multiplexed Mode 5
128 bytes of RAM; 2048 bytes of ROM
256 bytes of external memory space
Port 3 is an 8 -bit data bus
Port 4 is an input port/address bus
SC1 is Input/Output Select (IOS)
SC2 is Read/Write (R/ $\bar{W}$ )
Expanded Multiplexed Modes 1, 2, 3, $6^{*}$
Four memory space options ( 64 K address space):
(1) No internal RAM or ROM (Mode 3)
(2) Internal RAM, no ROM (Mode 2)
(3) Internal RAM and ROM (Mode 1)
(4) Internal RAM, ROM with partial address bus (Mode 6)

Port 3 is a multiplexed address/data bus
Port 4 is an address bus (inputs/address in Mode 6)
SC1 is Address Strobe (AS)
SC2 is Read/Write ( $\mathrm{R} / \overline{\mathrm{W}}$ )

## Test Modes 0 and 4

Expanded Multiplexed Test Mode 0
May be used to test RAM and ROM
Single Chip and Non-Multiplexed Test Mode 4
(1) May be changed to Mode 5 without going through Reset
(2) May be used to test Ports 3 and 4 as I/O ports
*The EF6803 operates only in modes 2 and 3


FIGURE 12 - EXPANDED NON-MULTIPLEXED CONFIGURATION


## Expanded-Multiplexed Modes (0, 1, 2, 3, 6)

A 64 K byte memory space is provided in the expanded multiplexed modes. In each of the expanded multiplexed modes Port 3 functions as a time multiplexed address/data bus with address valid on the negative edge of Address Strobe (AS), and data valid while E is high. In Modes 0 to 3, Port 4 provides address lines A8 to A15. In Mode 6, however, Port 4 initially is configured at $\overline{\text { RESET }}$ as an input data port. The port 4 Data Direction Register can then be changed to provide any combination of address lines, A8 to A15. Stated alternatively, any subset of A8 to A15 can be provided while retaining the remaining port 4 lines as input data lines. Internal pullup resistors pull the Port 4 lines high until software configures the port.

In Mode 0, the Reset vector is external for the first two E -cycles after the positive edge of $\overline{\mathrm{RESET}}$, and internal thereafter. In addition, the internal and external data buses are connected so there must be no memory map overlap in order to avoid potential bus conflicts. Mode 0 is used primarily to verify the ROM pattern and monitor the internal data bus with the automated test equipment.

Only the EF6801 can operate in each of the expanded multiplexed modes. The EF6803 operates only in Modes 2 and 3.

Figure 13 depicts a typical configuration for the Expanded-

Multiplexed Modes. Address Strobe can be used to control a transparent D-type latch to capture addresses A0-A7, as shown in Figure 14. This allows Port 3 to function as a Data Bus when $E$ is high.

## PROGRAMMING THE MODE

The operating mode is determined at $\overline{\operatorname{RESET}}$ by the levels asserted on P22, P21, and P20. These levels are latched into $\mathrm{PC} 2, \mathrm{PC} 1$, and PCO of the program control register on the positive edge of $\overline{\text { RESET. The operating mode may be read }}$ from the Port 2 Data Register as shown below, and programming levels and timing must be met as shown in Figure 15. A brief outline of the operating modes is shown in Table 3.

PORT 2 DATA REGISTER

\$0003

Circuitry to provide the programming levels is dependent primarily on the normal system usage of the three pins. If configured as outputs, the circuit shown in Figure 16 may be used; otherwise, three-state buffers can be used to provide isolation while programming the mode.

TABLE 3 - MODE SELECTION SUMMARY

| Mode* | $\begin{aligned} & \text { P22 } \\ & \text { PC2 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { P21 } \\ & \text { PC1 } \end{aligned}$ | $\begin{aligned} & \text { P2O } \\ & \text { PCO } \end{aligned}$ | ROM | RAM | Interrupt Vectors | Bus Mode | Operating Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | H | H | H | 1 | 1 | 1 | 1 | Single Chip |
| 6 | H | H | L | 1 | 1 | 1 | $\operatorname{MUX}(5,6)$ | Multiplexed/Partial Decode |
| 5 | H | L | H | 1 | 1 | 1 | NMUX ${ }^{(5,6)}$ | Non-Multiplexed/Partial Decode |
| 4 | H | L | L | $1^{(2)}$ | $11)$ | 1 | 1 | Single Chip Test |
| 3 | L | H | H | E | E | E | MUX ${ }^{(4)}$ | Multiplexed/ No RAM or ROM |
| 2 | L | H | L | E | 1 | E | MUX ${ }^{(4)}$ | Multiplexed/RAM |
| 1 | L | L | H | 1 | 1 | E | $M \cup X^{(4)}$ | Multiplexed/RAM \& ROM |
| 0 | L | L | L | 1 | I | H3) | MUX ${ }^{(4)}$ | Multiplexed Test |

Legend:
1-Internal
E-External
MUX - Multiplexed
NMUX - Non-Multiplexed
L - Logic " O "
$H-$ Logic "1"

Notes:
(1) Internal RAM is addressed at $\$ \times \times 80$
(2) Internal ROM is disabled
(3) $\overline{\mathrm{RESET}}$ vector is external for 2 cycles after $\overline{\mathrm{RESET}}$ goes high
(4) Addresses associated with Ports 3 and 4 are considered external in Modes 0 , 1, 2, and 3
(5) Addresses associated with Port 3 are considered external in Modes 5 and 6
(6) Port 4 default is user data input; address output is optional by writing to Port 4 Data Direction Register

[^4]FIGURE 13 - EXPANDED MULTIPLEXED CONFIGURATION


NOTE: To avoid data bus (Port 3) contention in the expanded multiplexed modes, memory devices should be enabled only during E high time.



MODE PROGRAMMING (Refer to Figure 15)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Mode Programming Input Voltage Low* | $V_{\text {MPL }}$ | - | 1.8 | V |
| Mode Programming Input Voltage High | $\mathrm{V}_{\text {MPH }}$ | 4.0 | - | V |
| Mode Programming Diode Differential (If Diodes are Used) | VMPDD | 0.6 | - | V |
| RESET Low Pulse Width | PWRSTL | 3.0 | - | E-Cycles |
| Mode Programming Setup Time | tMPS | 2.0 | - | E-Cycles |
| Mode Programming Hold Time RESET Rise Time $\geq 1 \mu \mathrm{~S}$ $\overline{\text { RESET Rise Time }<1 \mu \mathrm{~S}}$ | ${ }^{\text {t MPH }}$ | 0 100 | - | ns |

*For $T_{A}=-40^{\circ} \mathrm{C}$ to $+105^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{MPL}}=1.7 \mathrm{~V}$.

FIGURE 16 - TYPICAL MODE PROGRAMMING CIRCUIT


## MEMORY MAPS

The 6801 Family can provide up to 64 K byte address space depending on the operating mode. A memory map for each operating mode is shown in Figure 17.

The first 32 locations of each map are reserved for the internal register area, as shown in Table 4, with exceptions as indicated.

FIGURE 17 - EF6801/03 MEMORY MAPS (Sheet 1 of 3)


FIGURE 17 - EF6801/03 MEMORY MAPS (Sheet 2 of 3)


FIGURE 17 - EF6801/03 MEMORY MAPS (Sheet 3 of 3)

| Non-Multiplexed/Partial Decode <br> NOTES: <br> 1) Excludes the following addresses which may not be used externally: $\$ 04, \$ 06$, and $\$ 0 \mathrm{~F}$ (no $\overline{\mathrm{OS}}$ ). <br> 2) This mode may be entered without going through $\overline{\text { RESET }}$ by using mode 4 and subsequently writing a one into the PCO bit of the port 2 data register. <br> 3) Address lines $A 0$ to $A 7$ will not contain addresses until the data direction register for port 4 has been written with ones in the appropriate bits. These address lines will assert ones until made outputs by writing the data direction register. | NOTES: <br> 1) Excludes the following addresses which may be used externally: \$04, \$06, and \$0F. <br> 2) Address lines A8-A15 will not contain addresses until the data direction register for port 4 has been written with ones in the appropriate bits. These address lines will assert ones until made outputs by writing the data direction register. |  |
| :---: | :---: | :---: |

## EF6801/03 INTERRUPTS

The 6801 Family supports two types of interrupt requests: maskable and non-maskable. A Non-Maskable Interrupt ( $\overline{N M}$ ) is always recognized and acted upon at the completion of the current instruction. Maskable interrupts are controlled by the Condition Code Register I-bit and by individual enable bits. The 1 -bit controls 'all maskable interrupts. Of the maskable interrupts, there are two types: $\overline{\mathrm{RQ1}}$ and TRQ2. The Programmable Timer and Serial Communications interface use an internal IRO2 interrupt line, as shown in Figure 1. External devices (and IS3) use TRQ1. An IRQ1 interrupt is serviced before IRQ2 if both are pending.

All IRQ2 interrupts use hardware prioritized vectors. The single SCI interrupt and three timer interrupts are serviced in a prioritized order and each is vectored to a separate location. All interrupt vector locations are shown in Table 5.

The Interrupt flowchart is depicted in Figure 18 and is common to every interrupt excluding reset. During interrupt servicing the Program Counter, Index Register, A Accumulator, B Accumulator, and Condition Code Register are pushed to the stack. The l-bit is set to inhibit maskable interrupts and a vector is fetched corresponding to the current highest priority interrupt. The vector is transferred to the Program Counter and instruction execution is resumed. Interrupt and RESET timing are illustrated in Figures 19 and 20.

## FUNCTIONAL PIN DESCRIPTIONS

## $V_{C C}$ AND VSS

$V_{C C}$ and VSS provide power to a large portion of the MCU. The power supply should provide +5 volts ( $\pm 5 \%$ ) to $V_{C C}$, and VSS should be tied to ground. Total power dissipation (including $V_{C C}$ Standby), will not exceed PD milliwatts.

## VCC STANDBY

$V_{C C}$ Standby provides power to the standby portion (\$80 through \$BF) of the RAM and the STBY PWR and RAME bits of the RAM Control Register. Voltage requirements depend on whether the device is in a powerup or powerdown state. In the powerup state, the power supply should provide +5 volts ( $\pm 5 \%$ ) and must reach $V_{\text {SB }}$ volts before $\overline{\text { RESET }}$ reaches 4.0 volts. During powerdown, VCC Standby must remain above $V_{S B B}(\mathrm{~min})$ to sustain the standby RAM and STBY PWR bit. While in powerdown operation, the standby current will not exceed ISBB.
It is typical to power both $V_{C C}$ and $V_{C C}$ Standby from the same source during normal operation. A diode must be used
between them to prevent supplying power to VCC during powerdown operation. VCC Standby should be tied to ground in Mode 3.

TABLE 4 - INTERNAL REGISTER AREA

| Register | Address |
| :---: | :---: |
| Port 1 Data Direction Register ${ }^{\text {.. }}$ <br> Port 2 Data Direction Register … <br> Port 1 Data Register <br> Port 2 Data Register | $\begin{aligned} & \infty 0 \\ & 01 \\ & 02 \\ & 03 \\ & \hline \end{aligned}$ |
| Port 3 Data Direction Register ${ }^{\text {. }}$. <br> Port 4 Data Direction Register ${ }^{\text {... }}$ <br> Port 3 Data Register <br> Port 4 Data Register | 04* 05** 06* 07** |
| Timer Control and Status Register <br> Counter (High Byte) <br> Counter (Low Byte) <br> Output Compare Register (High Byte) | 08 09 $0 A$ $O B$ |
| Output Compare Register (Low Byte) Input Capture Register (High Byte) Input Capture Register (Low Byte) Port 3 Control and Status Register | $\begin{aligned} & O C \\ & O D \\ & O E \\ & O E \\ & O F^{*} \end{aligned}$ |
| Rate and Mode Control Register <br> Transmit/Receive Control and Status Register <br> Receive Data Register <br> Transmit Data Register | $\begin{aligned} & 10 \\ & 11 \\ & 12 \\ & 13 \end{aligned}$ |
| RAM Control Register Reserved | $\begin{gathered} 14 \\ 15.1 \mathrm{~F} \end{gathered}$ |

*External addresses in Modes 0, 1, 2, 3, 5, 6; cannot be accessed in Mode 5 (No IOS)

- External addresses in Modes 0, 1, 2, 3
$\cdots 1=$ Output, $0=$ Input

TABLE 5 - MCU INTERRUPT VECTOR LOCATIONS

| MSB | LSB | Interrupt |
| :--- | :---: | :---: |
| FFFE | FFFF | $\overline{\text { RESET }}$ |
| FFFC | FFFD | $\overline{\text { NMI }}$ |
| FFFA | FFFB | Software Interrupt (SWI) |
| FFF8 | FFF9 | $\overline{\text { IRQ1 (or } \overline{\text { IS3 }} \text { ) }}$ |
| FFF6 | FFF7 | ICF (Input Capture)* |
| FFF4 | FFF5 | OCF (Output Compare)* |
| FFF2 | FFF3 | TOF (Timer Overflow)* |
| FFFO | FFF1 | SCI (RDRF + ORFE + TDRE)* |

- IRQ2 Interrupt


FIGURE 19 - INTERRUPT SEQUENCE


FIGURE 20 - RESET TIMING


## XTAL1 AND EXTAL2

These two input pins interface either a crystal or TTL compatible clock to the MCU internal clock generator. Divide-byfour circuitry is included which allows use of the inexpensive 3.58 MHz or 4.4336 MHz Color Burst TV crystals. A 20 pF capacitor should be tied from each crystal pin to ground to ensure reliable startup and operation. Alternatively, EXTAL2 may be driven by an external TTL compatible clock at $4 f_{o}$ with a duty cycle of $50 \%( \pm 5 \%)$ with XTAL1 connected to ground.

The internal oscillator is designed to interface with an ATcut quartz crystal resonator operated in parallel resonance mode in the frequency range specified for fXTAL. The crystal should be mounted as close as possible to the input pins to minimize output distortion and startup stabilization time. The MCU is compatible with most commercially available crystals. Nominal crystal parameters are shown in Figure 21.

## $\overline{\text { RESET }}$

This input is used to reset the internal state of the device and provide an orderly startup procedure. During powerup, $\overline{R E S E T}$ must be held below 0.8 volts: (1) at least tRC after $V_{C C}$ reaches 4.75 volts in order to provide sufficient time for the clock generator to stabilize, and (2) until $V_{C C}$ Standby reaches 4.75 volts. RESET must be held low at least three E -cycles if asserted during powerup operation.

## E (ENABLE)

This is an output clock used primarily for bus synchronization. It is TTL compatible and is the slightly skewed divide-by-four result of the device input clock frequency. It will drive one Schottky TTL load and 90 pF , and all data given in cycles is referenced to this clock unless otherwise noted.

## $\overline{N M I}(N O N-M A S K A B L E ~ I N T E R R U P T) ~$

$A n \cdot \overline{N M I}$ negative edge requests an $M C U$ interrupt sequence, but the current instruction will be completed before it responds to the request. The MCU will then begin an interrupt sequence. Finally, a vector is fetched from \$FFFC and \$FFFD, transferred to the Program Counter and instruction execution is resumed. $\overline{\mathrm{NMI}}$ typically requires a $3.3 \mathrm{k} \mathrm{\Omega}$ (nominal) resistor to $V_{C C}$. There is no internal $\overline{N M T}$ pullup resistor. $\overline{\mathrm{NMI}}$ must be held low for at least one E-cycle to be recognized under all conditions.

## |RQ1 (MASKABLE INTERRUPT REQUEST 1)

$\overline{\mathrm{IRQ1}}$ is a level-sensitive input which can be used to request an interrupt sequence. The MPU will complete the current instruction before it responds to the request. If the interrupt mask bit (1-bit) in the Condition Code Register is clear, the MCU will begin an interrupt sequence. A vector is fetched from \$FFF8 and \$FFF9, transferred to the Program Counter, and instruction execution is resumed.
IRQ1 typically requires an external $3.3 \mathrm{k} \Omega$ (nominal) resistor to $\mathrm{V}_{\mathrm{CC}}$ for wire-OR applications. $\overline{\mathrm{RQ1}}$ has no internal pullup resistor.

## SC1 AND SC2 (STROBE CONTROL 1 AND 2)

The function of SC1 and SC2 depends on the operating mode. SC1 is configured as an output in all modes except single chip mode, whereas SC2 is always an output. SC1 and SC2 can drive one Schottky load and 90 pF .

## SC1 and SC2 In Single-Chip Mode

In Single-Chip Mode, SC1 and SC2 are configured as an input and output, respectively, and both function as Port 3 control lines. SC1 functions as $\overline{\mathrm{S} 3}$ and can be used to indicate that Port 3 input data is ready or output data has been accepted. Three options associated with $\overline{153}$ are controlled by Port 3 Control and Status Register and are discussed in the Port 3 description. If unused, $\overline{153}$ can remain unconnected.

SC 2 is configured as $\overline{\mathrm{OS} 3}$ and can be used to strobe output data or acknowledge input data. It is controlled by Output Strobe Select (OSS) in the Port 3 Control and Status Register. The strobe is generated by a read (OSS $=0$ ) or write (OSS $=1$ ) to the Port 3 Data Register. $\overline{O S 3}$ timing is shown in Figure 4.

## SC1 And SC2 In Expanded Non-Multiplexed Mode

In the Expanded Non-Multiplexed Mode, both SC1 and SC2 are configured as outputs. SC1 functions as Input/Output Select ( $\overline{\mathrm{IOS}}$ ) and is asserted only when $\$ 0100$ through $\$ 01 \mathrm{FF}$ is sensed on the internal address bus.

SC2 is configured as Read/Write and is used to control the direction of data bus transfers. An MPU read is enabled when Read/Write and E are high.

## SC1 And SC2 In Expanded Multiplexed Mode

In the Expanded Multiplexed Modes, both SC1 and SC2 are configured as outputs. SC1 functions as Address Strobe and can be used to demultiplex the eight least significant addresses and the data bus. A latch controlled by Address Strobe captures address on the negative edge, as shown in Figure 14.

SC2 is configured as Read/Write and is used to control the direction of data bus transfers. An MPU read is enabled when Read/Write and $E$ are high.

## P10-P17 (PORT 1)

Port 1 is a mode independent 8-bit I/O port with each line an input or output as defined by the Port 1 Data Direction Register. The TTL compatible three-state output buffers can drive one Schottky TTL load and 30 pF , Darlington transistors, or CMOS devices using external pullup resistors. It is configured as a data input port by $\overline{\mathrm{RESET}}$. Unused lines can remain unconnected.

## P20-P24 (PORT 2)

Port 2 is a mode-independent, 5 -bit, multipurpose $1 / O$ port. The voltage levels present on P20, P21, and P22 on the rising edge of $\overline{R E S E T}$ determine the operating mode of the MCU. The entire port is then configured as a data input port. The Port 2 lines can be selectively configured as data output lines by setting the appropriate bits in the Port 2 Data Direction Register. The Port 2 Data Register is used to move data through the port. However, if P21 is configured as an output, it will be tied to the timer Output Compare function and cannot be used to provide output from the Port 2 Data Register.

Port 2 can also be used to provide an interface for the Serial Communications Interface and the timer Input Edge function. These configurations are described in the Programmable Timer and Serial Communications Interface (SCI) section.

The Port 2 three-state, TTL-compatible output buffers are capable of driving one Schottky TTL load and 30 pF , or CMOS devices using external pullup resistors.

PORT 2 DATA REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $P C 2$ | $P C 1$ | $P C 0$ | $P 24$ | $P 23$ | $P 22$ | $P 21$ | $P 20$ |

## (a) Nominal Recommended Crystal Parameters

|  | Nominal Crystal Parameters* |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 3.58 MHz | 4.00 MHz | 5.0 MHz | 6.0 MHz | 8.0 MHz |
| RS | $60 \Omega$ | $50 \Omega$ | $30-50 \Omega$ | $30-50 \Omega$ | $20-40 \Omega$ |
| $\mathrm{C}_{0}$ | 3.5 pF | 6.5 pF | $4-6 \mathrm{pF}$ | $4-6 \mathrm{pF}$ | $4-6 \mathrm{pF}$ |
| $\mathrm{C}_{1}$ | 0.015 pF | 0.025 pF | $0.01-0.02 \mathrm{pF}$ | $0.01-0.02 \mathrm{pF}$ | $0.01-0.02 \mathrm{pF}$ |
| Q | $>40 \mathrm{~K}$ | $>30 \mathrm{~K}$ | $>20 \mathrm{~K}$ | $>20 \mathrm{~K}$ | $>20 \mathrm{~K}$ |

- NOTE: These are representative AT-cut crystal parameters only. Crystals of other types of cut may also be used.

$C_{L}=20 \mathrm{pF}$ (typical)


Equivalent Circuit
(b) Oscillator Stabilization Time ( $\mathbf{t}_{\mathrm{RC}}$ )


## P30-P37 (PORT 3)

Port 3 can be configured as an I/O port, a bidirectional 8 -bit data bus, or a multiplexed address/data bus depending on the operating mode. The TTL compatible three-state output buffers can drive one Schottky TTL load and 90 pF . Unused lines can remain unconnected.

## Port 3 In Single-Chip Mode

Port 3 is an 8 -bit I/O port in the Single-Chip Mode, with each line configured by the Port 3 Data Direction Register. There are also two lines, $\overline{\mathrm{S} 3}$ and $\overline{\mathrm{OS} 3}$, which can be used to control Port 3 data transfers.
Three Port 3 options are controlled by the Port 3 Control and Status Register and are available only in Single-Chip Mode: (1) Port 3 input data can be latched using $\overline{153}$ as a control signal, (2) OS3 can be generated by either an MPU read or write to the Port 3 Data Register, and (3) an $\overline{\mathrm{RQ1}}$ interrupt can be enabled by an IS3 negative edge. Port 3 latch timing is shown in Figure 5.

| PORT 3 CONTROL AND STATUS REGISTER |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| $\left\|\begin{array}{c} \text { IS3 } \\ \text { Flag } \end{array}\right\|$ | IS3 <br> IRQ1 <br> Enable | X | OSS | Latch Enable | X | X | X |  |

Bit 0-2
Bit 3

Bit 4

Bit 5
Bit 6

Bit 7
Bit 5

Not used.
LATCH ENABLE. This bit controls the input latch for Port 3 . If set, input data is latched by an IS3 negative edge. The latch is transparent after a read of the Port 3 Data Register. LATCH ENALBLE is cleared during reset.
OSS (Output Strobe Select). This bit determines whether $\overline{0 S 3}$ will be generated by a read or write of the Port 3 Data Register. When clear, the strobe is generated by a read; when set, it is generated by a write. OSS is cleared during reset.
Not used.
IS3 IRQ1 ENABLE. When set, an $\overline{\text { RQ1 }}$ interrupt will be enabled whenever IS3 FLAG is set; when clear, the interrupt is inhibited. This bit is cleared during reset.
IS3 FLAG. This read-only status bit is set by an $\overline{\mathrm{S3}}$ negative edge. It is cleared by a read of the Port 3 Control and Status Register (with IS3 FLAG set) followed by a read or write to the Port 3 Data Register or during reset.

## Port 3 In Expanded Non-Multiplexed Mode

Port 3 is configured as a bidirectional data bus (D7-D0) in the Expanded Non-Multiplexed Mode. The direction of data transfers is controlled by Read/Write (SC2). Data is clocked by E (Enable).

## Port 3 In Expanded Multiplexed Mode

Port 3 is contigured as a time multiplexed address (AO-A7) and data bus (D7-D0) in the Expanded Multiplexed Modes, where Address Strobe (AS) can be used to demultiplex the two buses. Port 3 is held in a high impedance state between valid address and data to prevent bus conflicts.

## P40-P47 (PORT 4)

Port 4 is configured as an 8 -bit $1 / 0$ port, as address outputs, or as data inputs depending on the operating mode. Port 4 can drive one Schottky TTL load and 90 pF and is the only port with internal pullup resistors. Unused lines can remain unconnected.

## Port 4 In Single-Chip Mode

In Single-Chip Mode, Port 4 functions as an 8-bit $1 / \mathrm{O}$ port with each line configured by the Port 4 Data Direction Register. Internal pullup resistors allow the port to directly interface with CMOS at 5 volt levels. External pullup resistors to more than 5 volts, however, cannot be used.

## Port 4 In Expanded Non-Multiplexed Mode

Port 4 is configured from reset as an 8 -bit input port, where the Port 4 Data Direction Register can be written to provide any or all of eight address lines, A0 to A7. Internal pullup resistors pull the lines high until the Port 4 Data Direction Register is configured.

## Port 4 In Expanded Multiplexed Mode

In all Expanded Multiplexed modes except Mode 6, Port 4 functions as half of the address bus and provides A8 to A15. In Mode 6, the port is configured from reset as an 8 -bit parallel input port, where the Port 4 Data Direction Register can be written to provide any or all of upper address lines A8 to A15. Internal pullup resistors pull the lines high until the Port 4 Data Direction Register is configured, where bit 0 controls A8.

## RESIDENT MEMORY

The EF6801 provides 2048 bytes of on-board ROM and 128 bytes of on-board RAM.
One half of the RAM is powered through the $V_{C C}$ standby pin and is maintainable during $V_{C C}$ powerdown. This standby portion of the RAM consists of 64 bytes located from $\$ 80$ through \$BF.

Power must be supplied to $\mathrm{V}_{\mathrm{CC}}$ standby if the internal RAM is to be used regardless of whether standby power operation is anticipated.

The RAM is controlled by the RAM Control Register.

## RAM CONTROL REGISTER (\$14)

The RAM Control Register includes two bits which can be used to control RAM accesses and determine the adequacy of the standby power source during powerdown operation. It is intended that RAME be cleared and STBY PWR be set as part of a powerdown procedure.

RAM CONTROL REGISTER


Bit 0-5
Bit 6 RAME

Not used.
RAM Enable. This read/write bit can be used to remove the entire RAM from the internal memory map. RAME is set (enabled) during reset provided standby power is available on the positive edge of $\overline{\text { RESET. If RAME is clear, }}$ any access to a RAM address is external. If RAME is set and not in mode 3, the RAM is included in the internal map.
Standby Power. This bit is a read/write status bit which, when once set, remains set as long as $V_{C C}$ standby remains above $\mathrm{V}_{\text {SBB }}$ (minimum). As long as this bit is set following a period of standby operation, the standby power supply has adequately preserved the data in the standby RAM. If this bit is cleared during a period of standby operation, it indicates that $V_{C C}$ standby had fallen to a level sufficiently below $\mathrm{V}_{\text {SBB }}$ (minimum) to suspect that data in the standby RAM is not valid. This bit can be set only by software and is not affected during reset.

## PROGRAMMABLE TIMER

The programmable timer can be used to perform input waveform measurements while independently generating an output waveform. Pulse widths can vary from several microseconds to many seconds. A block diagram of the timer is shown in Figure 22.

## COUNTER (\$09:0A)

The key timer element is a 16 -bit free-running counter which is incremented by E (enable). It is cleared during reset and is read-only with one exception: a write to the counter ( $\$ 09$ ) will preset it to $\$ F F F 8$. This feature, intended for testing, can disturb serial operations because the counter provides the SCl internal bit rate clock. TOF is set whenever the counter contains all ones.

## OUTPUT COMPARE REGISTER ( $\$ 0 \mathrm{~B}: 0 \mathrm{C}$ )

The output compare register is a 16 -bit read/write register used to control an output waveform or provide an arbitrary timeout flag. It is compared with the free-running counter on each E cycle. When a match occurs, OCF is set and OLVL is clocked to an output level register. If port 2, bit 1 , is configured as an output, OLVL will appear at P21 and the output compare register and OLVL can then be changed for the next

FIGURE 22 - BLOCK DIAGRAM OF PROGRAMMABLE TIMER

and OLVL is clocked to an output level register. If Port 2, bit 1 , is configured as an output, OLVL will appear at P21 and the Output Compare Register and OLVL can then be changed for the next compare. The function is inhibited for one cycle after a write to its high byte ( $\$ 0 \mathrm{~B}$ ) to ensure a valid compare. The Output Compare Register is set to \$FFFF at $\overline{\text { RESET. }}$

## INPUT CAPTURE REGISTER (\$OD:0E)

The Input Capture Register is a 16 -bit read-only register used to store the free-running counter when a "proper" input transition occurs as defined by IEDG. Port 2, bit 0 should be configured as an input, but the edge detect circuit always senses P20 even when configured as an output. An input capture can occur independently of ICF: the register always contains the most current value. Counter transfer is inhibited, however, between accesses of a double byte MPU read. The input pulse width must be at least two E-cycles to ensure an input capture under all conditions.

## TIMER CONTROL AND STATUS REGISTER (\$08)

The Timer Control and Status Register (TCSR) is an 8 -bit register of which all bits are readable, while only bits 0-4 can be written. The three most significant bits provide the timer status and indicate if:

- a proper level transition has been detected,
- a match has occured between the free-running counter and the output compare register, and
- the free-running counter has overflowed.

Each of the three events can generate an $\overline{\mathrm{RQ2}}$ interrupt and is controlled by an individual enable bit in the TCSR.

## TIMER CONTROL AND STATUS REGISTER (TCSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICF | OCF | TOF | EICI | EOCI | ETOI | IEDG | OLVL | $\$ 0008$ |

Bit 0 OLVL Output level. OLVL is clocked to the output level register by a successful output compare and will appear at P21 if Bit 1 of the Port 2 Data Direction Register is set. It is cleared during reset.
Bit 1 EIDG Input Edge. IEDG is cleared during reset and controls which level transition will trigger a counter transfer to the Input Capture Register:
IEDG $=0$ Transfer on a negative-edge IEDG = 1 Transfer on a positive-edge.

Bit 2 ETOI

Bit 3 EOCl
Enable Timer Overflow Interrupt. When set, an IRQ2 interrupt is enabled for a timer overflow; when clear, the interrupt is inhibited. It is cleared during reset.
Enable Output Compare Interrupt. When set, an IRQ2 interrupt is enabled for an output compare; when clear, the interrupt is inhibited. It is cleared during reset.

Bit 4 EICl Enable Input Capture Interrupt. When set, an IRQ2 interrupt is enabled for an input capture; when clear, the interrupt is inhibited. It is cleared during reset.
Bit 5 TOF
Timer Overflow Flag. TOF is set when the counter contains all 1 's. It is cleared by reading the TCSR (with TOF set) then reading the counter high byte ( $\$ 09$ ), or during reset.
Bit 6 OCF
Output Compare Flag. OCF is set when the Output Compare Register matches the free-running counter. It is cleared by reading the TCSR . with OCF set) and then writing to the Output Compare Register (\$OB or $\$ 0 \mathrm{C}$ ), or during reset.
Bit 7 ICF
Input Capture Flag. ICF is set to indicate a proper level transition; it is cleared by reading the TCSR (with ICF set) and then the Input Capture Register High Byte (\$0D), or during reset.

## SERIAL COMMUNICATIONS INTERFACE (SCI)

A full-duplex asynchronous Serial Communications Interface (SCI) is provided with two data formats and a variety of rates. The SCl transmitter and receiver are functionally independent, but use the same data format and bit rate. Serial data formats include standard mark/space (NRZ) and Biphase and both provide one start bit, eight data bits, and one stop bit. "Baud" and "bit rate" are used synonymously in the following description.

## WAKE-UP FEATURE

In a typical serial loop multi-processor configuration, the software protocol will usually identify the addressee(s) at the beginning of the message. In order to permit uninterested MPU's to ignore the remainder of the message, a wake-up feature is included whereby all further SCI receiver flag (and interrupt) processing can be inhibited until its data line goes idle. An SCl receiver is re-enabled by an idle string of ten consecutive 1's or during reset. Software must provide for the required idle string between consecutive messages and prevent it within messages.

## PROGRAMMABLE OPTIONS

The following features of the SCI are programmable:

- format: standard mark/space (NRZ) or Bi-phase
- clock: external or internal bit rate clock
- Baud: one of 4 per E-clock frequency, or external clock ( $\times 8$ desired baud)
- wake-up feature: enabled or disabled
- interrupt requests: enabled individually for transmitter and receiver
- clock output: internal bit rate clock enabled or disabled to P22


## SERIAL COMMUNICATIONS REGISTERS

The Serial Communications Interface includes four addressable registers as depicted in Figure 23: It is controlled by the Rate and Mode Control Register and the Transmit/Receive Control and Status Register. Data is transmitted and received utilizing a write-only Transmit Register and a read-only Receive Register. The shift registers are not accessible to software.

## Rate and Mode Control Register (RMCR) (\$10)

The Rate and Mode Control Register controls the SCl bit rate, format, clock source, and under certain conditions, the configuration of P22. The register consists of four write-only bits which are cleared during reset. The two least significant bits control the bit rate of the internal clock and the remaining two bits control the format and clock source.

RATE AND MODE CONTROL REGISTER (RMCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | CC 1 | CCO | SS 1 | SSO |

SS1:SSO Speed Select. These two bits select the Baud rate when using. the internal clock. Four rates may be selected which are a function of the MCU input frequency. Table 6 lists bit time and rates for three selected MCU frequencies.
CC1:CCO Clock Control and Format Select. These two bits control the format and select the serial clock source. If CC 1 is set, the DDR value for P 22 is forced to the complement of CCO and cannot be altered until CC1 is cleared. If CC1 is cleared after having been set, its DDR value is unchanged. Table 7 defines the formats, clock source, and use of P22.
If both CC1 and CCO are set, an external TTL compatible clock must be connected to P22 at eight times ( 8 X ) the desired bit rate, but not greater than E , with a duty cycle of $50 \%( \pm 10 \%)$. If CC1:CC0 $=10$, the internal bit rate clock is provided at P22 regardless of the values for TE or RE.
NOTE: The source of SCI internal bit rate clock is the timer free running counter. An MPU write to the counter can disturb serial operations.

FIGURE 23 - SCI REGISTERS


## Transmit/Receive Control And Status Register (TRCSR) (\$11)

The Transmit/Receive Control and Status Register controls the transmitter, receiver, wake-up feature, and two individual interrupts and monitors the status of serial operations. All eight bits are readable while bits 0 to 4 are also writable. The register is initialized to $\$ 20$ by $\overline{R E S E T}$.

## TRANSMIT/RECEIVE CONTROL AND STATUS REGISTER (TRCSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDRF | ORFE | TDRE | RIE | RE | TIE | TE | WU |

Bit 0 WU "Wake-up" on Idle Line. When set, WU enables the wake-up function; it is cleared by ten consecutive 1's or during reset. WU will not set if the line is idle.
Bit 1 TE Transmit Enable. When set, P24 DDR bit is set, cannot be changed, and will remain set if TE is subsequently cleared. When TE is changed from clear to set, the transmitter is connected to P24 and a preamble of nine consecutive 1's is transmitted. TE is cleared during reset.
Bit 2 TIE Transmit Interrupt Enable. When set, an $\overline{\mathrm{RQ} 2}$ interrupt is enabled when TDRE is set; when clear, the interrupt is inhibited. TE is cleared during reset.
Bit 3 RE

Bit 4 RIE

Transmit Data Register Empty. TDRE is set when the Transmit Data Register is transferred to the output serial shift register or during reset. It is cleared by reading the TRCSR (with TDRE set) and then writing to the Transmit Data Register. Additional data will be transmitted only if TDRE has been cleared.
Overrun Framing Error. If set, ORFE indicates either an overrun or framing error. An overrun is a new byte ready to transfer to the Receiver Data Register with RDRF still set. A receiver framing error has occurred when the byte boundaries of the bit stream are not synchronized to the bit counter. An overrun can be distinguished from a framing error by the state of RDRF: if RDRF is set, then an overrun has occurred; otherwise a framing error has been detected. Data is not transferred to the Receive Data Register in an overrun condition. Unframed data causing a framing error is transferred to the Receive Data Register. However, subsequent data transfer is blocked until the framing error flag is cleared. ORFE is cleared by reading the TRCSR (with ORFE set) then the Receive Data Register, or during reset. Receive Data Register Full. RDRF is set when the input serial shift register is transferred to the Receive Data Register. It is cleared by reading the TRCSR (with RDRF set), and then the Receive Data Register, or during reset.

TABLE 6 - SCI BIT TIMES AND RATES

| SS1:SS0 |  | $\xrightarrow{4} \mathrm{O} \rightarrow$ | 2.4576 MHz | 4.0 Mhz | 4.9152 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | E | 614.4 kHz | 1.0 MHz | 1.2288 MHz |
| 0 | 0 | + 16 | $26 \mu \mathrm{~s} / 38,400$ Baud | $16 \mu \mathrm{~s} / 62,500$ Baud | $13.0 \mu \mathrm{~s} / 76,800$ Baud |
| 0 | 1 | + 128 | $208 \mu \mathrm{~s} / 4,800$ baud | $128 \mu \mathrm{~s} / 7812.5$ Baud | $104.2 \mu \mathrm{~S} / 9,600$ Baud |
| 1 | 0 | + 1024 | $1.67 \mathrm{~ms} / 600$ Baud\$ | $1.024 \mathrm{~ms} / 976.6$ Baud | $833.3 \mu \mathrm{~s} / 1,200$ Baud |
| 1 | 1 | + 4096 | $6.67 \mathrm{~ms} / 150$ Baud | $4.096 \mathrm{~ms} / 244.1$ Baud | $3.33 \mathrm{~ms} / 300$ Baud |
| 'External (P22) |  |  | $13.0 \mu \mathrm{~s} / 76,800$ Baud | $8.0 \mu \mathrm{~s} / 125,000$ Baud | $6.5 \mu \mathrm{~s} / 153,600$ Baud |

[^5]TABLE 7 - SCI FORMAT AND CLOCK SOURCE CONTROL

| CC1:CC0 | Format | Clock <br> Source | Port 2 <br> Bit 2 |
| :---: | :---: | :---: | :---: |
| 00 | Bi-Phase | Internal | Not Used |
| 01 | NRZ | Internal | Not Used |
| 10 | NRZ | Internal | Output |
| 11 | NRZ | External | Input |

## SERIAL OPERATIONS

The SCl is initialized by writing control bytes first to the Rate and Mode Control Register and then to the Transmit/Receive Control and Status Register. When TE is set, the output of the transmit serial shift register is connected to P24 and serial output is initiated by transmitting a 9 -bit preamble of 1 's.

At this point one of two situations exist: 1 ) if the Transmit Data Register is empty (TDRE $=1$ ), a continuous string of 1 's will be sent indicating an idle line, or 2 ) if a byte has been written to the Transmit-Data Register (TDRE $=0$ ), it will be transferred to the output serial shift register (synchronized with the bit rate clock), TDRE will be set, and transmission will begin.

The start bit ( 0 ), eight data bits (beginning with bit 0 ) and a stop bit (1), will be transmitted. If TDRE is still set when the next byte transfer should occur, 1's will be sent until more data is provided. In Bi-phase format, the output toggles at the start of each bit and at half-bit time when a " 1 " is sent. Receive operation is controlled by RE which configures P23 as an input and enables the receiver. SCl data formats are illustrated in Figure 24.

## INSTRUCTION SET

The EF6801/03 is upward source and object code: compatible with the EF6800. Execution times of key instructions have been reduced and several new instructions have been added, including a hardware multiply. A list of new operations added to the EF6800 instruction set is shown in Table 1.

In addition, two new special opcodes, $4 E$ and 5 E , are provided for test purposes. These opcodes force the Program Counter to increment like a 16 -bit counter, causing address lines used in the expanded modes to increment until the device is reset. These opcodes have no mnemonics.

The coding of the first (or only) byte corresponding to an
executable instruction is sufficient to identify the instruction and the addressing mode. The hexadecimal equivalents of the binary codes, which result from the translation of the 82 instructions in all valid modes of addressing, are shown in Table 8. There are 220 valid machine codes, 34 unassigned codes, and 2 codes reserved for test purposes.

## PROGRAMMING MODEL

A programming model for the EF6801/03 is shown in Figure 10. Accumulator A can be concatenated with accumulator $B$ and jointly referred to as accumulator $D$ where $A$ is the most significant byte. Any operation which modifies the double accumulator will also modify accumulator A and/or B. Other registers are defined as follows:

Program Counter - The program counter is a 16 -bit register which always points to the next instruction.

Stack Pointer - The stack pointer is a 16 -bit register which contains the address of the next available location in a pushdown/pullup (LIFO) queue. The stack resides in random access memory at a location defined by the programmer.

Index Register - The Index Register is a 16-bit register which can be used to store data or provide an address for the indexed mode of addressing.

Accumulators - The MPU contains two 8-bit accumulators, $A$ and $B$, which are used to store operands and results from the arithmetic logic unit (ALU). They can also be concatenated and referred to as the D (double) accumulator.

Condition Code Registers - The condition code register indicates the results of an instruction and includes the following five condition bits: Negative ( N ), Zero ( $Z$ ), Overflow (V), Carry/Borrow from MSB (C), and Half Carry from bit $3(\mathrm{H})$. These bits are testable by the conditional branch instructions. Bit 4 is the interrupt mask (1-bit) and inhibits all maskable interrupts when set. The two unused bits, $B 6$ and B7, are read as ones.

FIGURE 24 - SCI DATA FORMATS


## ADDRESSING MODES

Six addressing modes can be used to reference memory A summary of addressing modes for all.instructions is presented in Tables 9, 10, 11, and 12, where execution times are provided in E-cycles. Instruction execution times are summarized in Table 13. With an input frequency of 4 MHz , E-cycles are equivalent to microseconds. A cycle-by-cycle description of bus activity for each instruction is provided in Table 14 and a description of selected instructions is shown in Figure 25.

Immediate Addressing - The operand or "immediate byte(s)" is contained in the following byte(s) of the instruction where the number of bytes matches the size of the register. These are two or three byte instructions.

Direct Addressing - The least significant byte of the operand address is contained in the second byte of the instruction and the most significant byte is assumed to be $\$ 00$. Direct addressing allows the user to access \$00 through \$FF using two byte instructions and execution time is reduced by eliminating the additional memory access. In most applica-
tions, the 256 -byte area is reserved for frequently referenced data.

Extended Addressing - The second and third bytes of the instruction contain the absolute address of the operand. These are three byte instrutions.
Indexed Addressing - The unsigned offset contained in the second byte of the instruction is added with carry to the Index Register and used to reference memory without changing the Index Register. These are two byte instructions.
Inherent Addressing - The operand(s) are registers and no memory reference is required. These are single byte instructions.

Relative Addressing - Relative addressing is used only for branch instructions. If the branch condition is true, the Program Counter is overwritten with the sum of a signed single byte displacement in the second byte of the instruction and the current Program Counter. This provides a branch range of -126 to 129 bytes from the first byte of the instruction. These are two byte instructions.

TABLE 8 - CPU INSTRUCTION MAP

| OP | MNEM | MODE | $\sim$ | . | OP | MNEM | MODE | $\sim$ | $\cdots$ | OP | MNEM | MODE | $\sim$ | \# | OP | MNEM | MODE | $\sim$ | \# | OP | MNEM | MODE | $\sim$ | $\cdots$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | - |  |  |  | 34 | OES | INHER | 3 | 1 | 68 | ASL | INOXD | 6 | 2 | 9 C | CPX |  | 5 | 2 | D0 | SUBB | DIR | 3 | 2 |
| 01 | NOP | INHER | 2 | 1 | 35 | TXS |  | 3 | 1 | 69 | ROL | - | 6 | 2 | 90 | JSA | , | 5 | 2 | D1 | CMPB | , | 3 | 2 |
| 02 | - |  |  |  | 36 | PSHA |  | 3 | 1 | 6A | DEC |  | 6 | 2 | 9E | LOS | $\dagger$ | 4 | 2 | 02 | SBCB |  | 3 | 2 |
| 03 | - |  |  |  | 37 | PSHB |  | 3 | 1 | 6 B | - |  |  |  | 9 F | STS | DlR | 4 | 2 | D3 | ADOD |  | 5 | 2 |
| 04 | LSRD |  | 3 | 1 | 38 | Pulx |  | 5 | 1 | 6C | INC |  | 6 | 2 | 40 | SUBA | INDXD | 4 | 2 | D4 | ANDB |  | 3 | 2 |
| Ob | ASLD |  | 3 | 1 | 39 | RTS |  | 5 | , | 6 D | TST |  | 6 | 2 | A 1 | CMPA |  | 4 | 2 | D5 | BITB |  | 3 | 2 |
| 06 | TAP |  | 2 | 1 | 3 A | ABX |  | 3 | 1 | 6 E | JMP |  | 3 | 2 | A2 | SBCA |  | 4 | 2 | D6 | LDAB |  | 3 | 2 |
| 07 | TPA |  | 2 | 1 | 38 | RTI |  | 10 | 1 | 6F | CLR | INDXD | 6 | 2 | A3 | SUBD |  | 6 | 2 | 07 | STAB |  | 3 | 2 |
| 08 | InX |  | 3 | 1 | 3 C | PSHX |  | 4 | 1 | 70 | NEG | EXIND | 6 | 3 | A4 | ANDA |  | 4 | 2 | D8 | EORB |  | 3 | 2 |
| 09 | DEX |  | 3 | 1 | 30 | MUL |  | 10 | 1 | 71 | - |  |  |  | A5 | BITA |  | 4 | 2 | D9 | ADCB |  | 3 | 2 |
| OA | CLV |  | 2 | 1 | 3 E | WAI |  | 9 | 1 | 72 | - |  |  |  | A6 | LDAA |  | 4 | 2 | DA | ORAB |  | 3 | 2 |
| OB | SEV |  | 2 | 1 | 3F | SWI |  | 12 | 1 | 73 | COM |  | 6 | 3 | A7 | STAA |  | 4 | 2 | DB | ADDB |  | 3 | 2 |
| OC | CLC |  | 2 | 1 | 40 | NEGA |  | 2 | 1 | 74 | LSR |  | 6 | 3 | A8 | EORA |  | 4 | 2 | OC | LDO |  | 4 | 2 |
| 00 | SEC |  | 2 | 1 | 41 | . |  |  |  | 75 | - |  |  |  | A9 | ADCA |  | 4 | 2 | OD | STD |  | 4 | 2 |
| OE | CLI |  | 2 | 1 | 42 | - |  |  |  | 76 | ROR |  | 6 | 3 | AA | ORAA |  | 4 | 2 | DE | LDX |  | 4 | 2 |
| Of | SEI |  | 2 | 1 | 43 | COMA |  | 2 | 1 | 77 | ASR |  | 6 | 3 | $A B$ | ADDA |  | 4 | 2 | OF | STX | DIR | 4 | 2 |
| 10 | SBA |  | 2 | 1 | 44 | LSRA |  | 2 | 1 | 78 | ASL |  | 6 | 3 | $A C$ | CPX |  | 6 | 2 | EO | SUB | INOXD | 4 | 2 |
| 11 | CBA |  | 2 | 1 | 45 | LSRA |  |  |  | 79 | ROL |  | 6 | 3 | $A D$ | JSR |  | 6 | 2 | E1 | CMPB | , | 4 | 2 |
| 12 | - |  |  |  | 46 | RORA |  | 2 | 1 | 7 A | DEC |  | 6 | 3 | $A E$ | LDS |  | 5 | 2 | E2 | SBCB |  | 4 | 2 |
| 13 | - |  |  |  | 47 | ASRA |  | 2 | 1 | 78 | . |  |  |  | AF | STS | INDXD | 5 | 2 | E 3 | ADD |  | 6 | 2 |
| 14 | - |  |  |  | 48 | ASLA |  | 2 | 1 | 7 C | INC |  | 6 | 3 | B0 | SUBA | EXIND | 4 | 3 | E4 | ANDB |  | 4 | 2 |
| 15 | $\cdots$ |  |  |  | 49 | ROLA |  | 2 | 1 | 70 | TST |  | 6 | 3 | 81 | CMPA | - | 4 | 3 | E5 | BITB |  | 4 | 2 |
| 16 | TAB |  | 2 | 1 | 4 A | DEECA |  | 2 | 1 | 7 E | JMP |  | 3 | 3 | 82 | SBCA |  | 4 | 3 | E6 | LDAB |  | 4 | 2 |
| 17 | tBa |  | 2 | 1 | 48 | - |  |  |  | 75 | CLP | EXTND | 6 | 3 | B3 | SUBD |  | 6 | 3 | E 7 | STAB |  | 4 | 2 |
| 18 | - |  |  |  | 4 C | INCA |  | 2 | 1 | 80 | SUBA | IMMED | 2 | 2 | B4 | ANDA |  | 4 | 3 | EB | EORB |  | 4 | 2 |
| 19 | DAA | INHER | 2 | 1 | 40 | ISTA |  | 2 | 1 | 81 | CMPA |  | 2 | 2 | B5 | BITA |  | 4 | 3 | E9 | ADCB |  | 4 | 2 |
| 1 A | - |  |  |  | 4E | T |  |  |  | 82 | SBCA |  | 2 | 2 | B6 | LDAA |  | 4 | 3 | EA | ORAB |  | 4 | 2 |
| 1 B | ABA | INHER | 2 | 1 | 4F | CLPA |  | 2 | 1 | 83 | SUBD |  | 4 | 3 | B7 | STAA |  | 4 | 3 | EB | ADDB |  | 4 | 2 |
| 1 C | $\cdot$ |  |  |  | 50 | NEGB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 | B8 | EORA |  | 4 | 3 | EC | LDO |  | 5 | 2 |
| 10 | - |  |  |  | 51 | - |  |  |  | 85 | BITA |  | 2 | 2 | 89 | ADCA |  | 4 | 3 | ED | STD |  | 5 | 2 |
| IE | - |  |  |  | 52 | - |  |  |  | 86 | LDAA |  | 2 | 2 | BA | ORAA |  | 4 | 3 | EE | LDX | 1 | 5 | 2 |
| 1F | - |  |  |  | 53 | COMB |  | 2 | 1 | 87 | - |  |  |  | BB | ADDA |  | 4 | 3 | EF | STX | INDXD | 5 | 2 |
| 20 | Bra | REL | 3 | 2 | 54 | LSRB |  | 2 | 1 | 88 | EORA |  | 2 | 2 | BC | CPX |  | 6 | 3 | F0 | SUBB | EXIND | 4 | 3 |
| 21 | BRN | 4 | 3 | 2 | 55 | - |  |  |  | 89 | ADCA |  | 2 | 2 | 80 | JSR |  | 6 | 3 | F1 | CMPB | A | 4 | 3 |
| 22 | BHI |  | 3 | 2 | 56 | RORE |  | 2 | 1 | 8A | ORAA |  | 2 | 2 | BE | LDS |  | 5 | 3 | F 2 | SBCB |  | 4 | 3 |
| 23 | BLS |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 88 | ADDA |  | 2 | 2 | BF | STS | EXTND | 5 | 3 | F 3 | ADOD |  | 6 | 3 |
| 24 | BCC |  | 3 | 2 | 58 | ASLB |  | 2 | 1 | 8 C | CPX | IMMED | 4 | 3 | CO | SUBB | IMMED | 2 | 2 | F4 | ANDE |  | 4 | 3 |
| 25 | BCS |  | 3 | 2 | 59 | ROLS |  | 2 | 1 | 80 | BSR | AEL | 6 | 2 | Cl | CMPB |  | 2 | 2 | -5 | Bits |  | 4 | 3 |
| 26 | BNE |  | 3 | 2 | 5A | DECB |  | 2 | 1 | 8 E | LDS | IMMED | 3 | 3 | C2 | SBCB |  | 2 | 2 | F6 | LDAB |  | 4 | 3 |
| 27 | BEO |  | 3 | 2 | 58 | . |  |  |  | BF |  |  |  |  | C3 | ADOD |  | 4 | 3 | F7 | STAB |  | 4 | 3 |
| 28 | BvC |  | 3 | 2 | 5 C | INCB |  | 2 | 1 | 90 | SUBA | OIR | 3 | 2 | C4 | ANDB |  | 2 | 2 | F8 | EORE |  | 4 | 3 |
| 29 | Bvs |  | 3 | 2 | 50 | TSTB |  | 2 | 1 | 91 | CMPA | 4 | 3 | 2 | C5 | Bitb |  | 2 | 2 | F9 | ADCB |  | - | 3 |
| 2A | BPL |  | 3 | 2 | 5 E | 1 | 7 |  |  | 92 | SBCA |  | 3 | 2 | C6 | LDAB |  | 2 | 2 | FA | ORAB |  | 4 | 3 |
| 2B | BMI |  | 3 | 2 | 5F | CLRB | INHER | 2 | 1 | 93 | SUBD |  | 5 | 2 | C 7 |  |  |  |  | fB | ADOB |  | 4 | 3 |
| 2 C | 8GE |  | 3 | 2 | 60 | NEG | INDXD | 6 | 2 | 34 | ANDA |  | 3 | 2 | C8 | EORB |  | 2 | 2 | FC | LDO |  | 5 | 3 |
| 20 | BLT |  | 3 | 2 | 61 | - | A |  |  | 95 | BITA |  | 3 | 2 | C9 | ADCB |  | 2 | 2 | FD | STD | 1 | 5 | 3 |
| 2E | BGT | 1 | 3 | 2 | 62 | - |  |  |  | 96 | ldam |  | 3 | 2 | CA | ORAB |  | 2 | 2 | fE | LDX |  | 5 | 3 |
| 2 F | BLE | REL | 3 | 2 | 63 | COM |  | 6 | 2 | 97 | STAA |  | 3 | 2 | CB | ADOB |  | 2 | 2 | FF | Six | EXTND | 5 | 3 |
| 30 | TSX | INHER | 3 | 1 | 64 | LSR |  | 6 | 2 | 98 | EORA |  |  | 2 | CC | LDO | 1 | 3 | 3 |  |  |  |  |  |
| 31 | ins | - | 3 | 1 | 65 | - |  |  |  | 99 | ADCA |  | 3 | 2 | CO |  |  |  |  |  |  |  |  |  |
| 32 | PULA |  | 4 | 1 | 66 | ROR |  | 6 | 2 | 94 | ORAA | $\downarrow$ | 3 | 2 | CO | LDX | IMMED | 3 | 3 |  | dofined | OP CODE |  |  |
| 33 | PULB | 1 | 4 | 1 | 67 | ASR | INDXO | 6 | 2 | 98 | ADDA |  | 3 | 2 | CF | - |  |  |  |  |  |  |  |  |

NOTES:

1. Addressing Modes

$$
\begin{array}{lll}
\text { INHER = Inherent } & \text { INDXD = Indexed } & \text { IMMED }=\text { Immediate } \\
R E L=\text { Relative } & \text { EXTND }=\text { Extended } & \text { DIR }=\text { Direct }
\end{array}
$$

2. Unassigned opcodes are indicated by "'"" and should not be executed.
3. Codes marked by " $T$ " force the PC to function as a 16 -bit counter.

TABLE 9 - INDEX REGISTER AND STACK MANIPULATION INSTRUCTIONS

| Pointer Operations | Mnemonic | Immed |  |  | Direct |  |  | Index |  |  | Extnd |  |  | Inherent |  |  | Boolean/ <br> Arithmetic Operation | Condition Codes |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | OP |  | \# |  |  |  | OP |  | \# |  |  |  |  | $\sim$ |  |  |  | OP $\sim$ | \# | OP | ~ |  | H | 1 | N | Z | V | C |
| Compare Index Reg | CPX | 8C | 4 | 3 | 9C | 5 | 2 | AC | 6 | 2 | BC | 6 | 3 |  |  |  | $X-M: M+1$ | $\bullet$ | $\bullet$ | 1 |  |  | 1 |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 3 | 1 | $x-1-x$ | $\bullet$ | - | $\bullet$ |  | - | $\bullet$ |
| Decrement Stack Pntr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 3 | 1 | SP-1-SP | $\bullet$ | - | - | - | - | $\bigcirc$ |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 3 | 1 | $x+1 \rightarrow x$ | $\bigcirc$ | $\bullet$ | $\bullet$ | 1 | - | $\bullet$ |
| Increment Stack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 3 | 1 | $1 S P+1-S P$ | $\bullet$ | - | $\bullet$ | - | - | $\bullet$ |
| Load Index Reg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 |  |  |  | $M-X_{H}(M+1)-X_{L}$ | $\bullet$ | $\bullet$ |  |  | R | $\bigcirc$ |
| Load Stack Pntr | LDS | 8E | 3 | 3 | 9 E | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 |  |  |  | $M-S P_{H},(M+1)-S P_{L}$ | $\bullet$ | - |  |  | R | $\bullet$ |
| Store Index Reg | STX |  |  |  | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 |  |  |  | $X_{H} \rightarrow M, X_{L}-(M+1)$ | - | $\bullet$ |  |  | R | $\bigcirc$ |
| Store Stack Pntr | STS |  |  |  | 9 F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 |  |  |  | $S P_{H} \rightarrow M, S P_{L}-(M+1)$ | $\bullet$ | $\bullet$ |  |  | R | $\bullet$ |
| Index Reg - Stack Pntr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 3 | 1 | $X-1-S P$ | $\bullet$ | - | - | $\bigcirc$ | $\bullet$ | - |
| Stack Pntr $\rightarrow$ Index Reg | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 3 | 1 | $S P+1 \rightarrow x$ | $\bullet$ | - | $\bigcirc$ | - | 0 | - |
| Add | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3 A | 3 | 1 | $B+X \rightarrow X$ | $\bullet$ | - | $\bullet$ | - | $\bullet$ | - |
| Push Data | PSHX |  |  |  |  |  |  |  |  |  |  |  |  | 3C | 4 | 1 | $\begin{aligned} & X_{L}-\text { MSP }, S P-1 \rightarrow S P \\ & X_{H}-M S P, S P-1-S P \end{aligned}$ | $\bullet$ | - | - | - | - | - |
| Pull Data | PULX |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 5 | 1 | $\begin{aligned} & S P+1-S P, M_{S P}-X_{H} \\ & S P+1-S P, M_{S P}-X_{L} \end{aligned}$ | - | $\bullet$ | - | - | - | - |

TABLE 10 - ACCUMULATOR AND MEMORY INSTRUCTIONS

| Accumulator and Memory Operations | MNE | Immed |  |  | Direct |  |  | Index |  |  | Extend |  |  | Inher |  |  | Boolean Expression | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Op | - | \# | Op | $\sim$ | \# | Op | $\sim$ | \# | Op | $\sim$ | \# | Op | $\sim$ | \# |  |  | H | I | N | 2 | V | ${ }^{\text {c }}$ |
| Add Acmitrs | ABA |  |  |  |  |  |  |  |  |  |  |  |  | 18 | 2 | 1 | $A+B=A$ |  |  | $\bigcirc$ |  |  |  |  |
| Add B to X | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3A | 3 | 1 | $00: B+X-X$ |  | $\bullet$ | $\bullet$ | $\bigcirc$ | $\bigcirc$ | $\bullet$ | $\bullet$ |
| Add with Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | B9 | 4 | 3 |  |  |  | $A+M+C-A$ |  |  | $\bigcirc$ | 1 |  |  |  |
|  | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 |  |  |  | $B+M+C-B$ |  |  | $\bigcirc$ |  |  |  |  |
| Add | ADDA | 8B | 2 | 2 | 98 | 3 | 2 | AB | 4 | 2 | BB | 4 | 3 |  |  |  | $A+M-A$ |  |  | $\bigcirc$ | ! |  |  |  |
|  | ADDB | CB | 2 | 2 | DB | 3 | 2 | EB | 4 | 2 | FB | 4 | 3 |  |  |  | $B+M-A$ |  |  | $\bigcirc$ |  |  |  |  |
| Add Double | ADDD | C3 | 4 | 3 | D3 | 5 | 2 | E3 | 6 | 2 | F3 | 6 | 3 |  |  |  | $D+M: M+1 \rightarrow 0$ |  | $\bigcirc$ | $\bigcirc$ |  |  |  |  |
| And | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A4 | 4 | 2 | B4 | 4 | 3 |  |  |  | $A \cdot M-A$ |  | $\bigcirc$ | $\bigcirc$ |  |  | R | $\bigcirc$ |
|  | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 |  |  |  | $B \cdot M-B$ |  | - | $\bigcirc$ |  |  | R | $\bigcirc$ |
| Shift Left, Arithmetic | ASL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  | $\text { Q }- \text { पim } \prod_{0}<0$ |  | $\bigcirc$ | $\bigcirc$ | - |  |  |  |
|  | ASLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 2 | 1 |  |  | $\bigcirc$ | $\bigcirc$ | - |  |  |  |
|  | ASLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 2 | 1 |  |  | $\bigcirc$ | $\bigcirc$ | 7 |  | 7 | 7 |

TABLE 10 - ACCUMULATOR AND MEMORY INSTRUCTIONS (CONTINUED)

| Accumulator and Memory Operations | MNE | 1 mmed |  |  | Direct |  |  | Index |  |  | Extend |  |  | Inher |  |  | Boolean Expression | Condition Codes |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Op | $\sim$ | * | Op | $\sim$ | \# | Op | - | \# | Op | - | \# | Op | ~ | \# |  | H | 1 | N | 2 | V | C |
| Shift Left Dbl | ASLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 3 | 1 |  | $\bigcirc$ | $\bigcirc$ | 1 | 1 | 1 | 1 |
| Shift Right. Arithmetic | ASR |  |  |  |  |  |  | 67 | 6 | 2 | 77 | 6 | 3 |  |  |  | $\rightarrow \overbrace{b 7} \rightarrow \prod_{\infty} \rightarrow-a$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | ASRA |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 2 | 1 |  | $\bullet$ | - | 1 | 1 | 1 | 1 |
|  | ASRB |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 2 | 1 |  | 0 | - | 1 | 1 | 1 | 1 |
| Bit Test | BITA | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | B5 | 4 | 3 |  |  |  | A.M | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
|  | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 |  |  |  | B. M | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
| Compare Acmitrs | CBA |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 2 | 1 | A - B | $\bullet$ | - | 1 | 1 | 1 | 1 |
| Clear | CLR |  |  |  |  |  |  | 6 F | 6 | 2 | 7 F | 6 | 3 |  |  |  | O0-M | $\bullet$ | - | R | S | R | R |
|  | CLRA |  |  |  |  |  |  |  |  |  |  |  |  | 4F | 2 | 1 | O0-A | $\bullet$ | - | R | 5 | R | R |
|  | CLRB |  |  |  |  |  |  |  |  |  |  |  |  | 5F. | 2 | 1 | 00-B | $\bullet$ | - | R | S | R | R |
| Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | B1 | 4 | 3 |  |  |  | A - M | $\bullet$ | $\bullet$ | 1 |  | 1 |  |
|  | CMPB | C1 | 2 | 2 | D1 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 |  |  |  | B.M | $\bullet$ | $\bigcirc$ |  |  | 1 |  |
| 1's Complement | COM |  |  |  |  |  |  | 63 | 6 | 2 | 73 | 6 | 3 |  |  |  | $M-M$ | - | - |  |  | R | S |
|  | COMA |  |  |  |  |  |  |  |  |  |  |  |  | 43 | 2 | 1 | $\vec{A}-A$ | $\bullet$ | $\bigcirc$ |  |  | R | S |
|  | COMB |  |  |  |  |  |  |  |  |  |  |  |  | 53 | 2 | 1 | B-8 | $\bullet$ | - |  |  | R | S |
| Decimal Adj, A | DAA |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 | Adj binary sum to $8 C D$ | - | $\bullet$ |  |  |  | 1 |
| Decrement | DEC |  |  |  |  |  |  | 6A | 6 | 2 | 7 A | 6 | 3 |  |  |  | $M-1-M$ | - | $\bullet$ |  |  |  | $\bullet$ |
|  | DECA |  |  |  |  |  |  |  |  |  |  |  |  | 4A | 2 | 1 | A-1-A | $\bullet$ | $\bigcirc$ |  | 1 |  | $\bullet$ |
|  | DECB |  |  |  |  |  |  |  |  |  |  |  |  | 5A | 2 | 1 | $B-1 \rightarrow B$ | $\bullet$ | $\bullet$ |  | 1 | 1 | $\bullet$ |
| Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | B8 | 4 | 3 |  |  |  | $A \oplus M-A$ | $\bullet$ | $\bullet$ |  | 1 | R | $\bullet$ |
|  | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 |  |  |  | $\mathrm{B} \oplus \mathrm{M}-\mathrm{B}$ | - | $\bullet$ |  | 1 | A | $\bigcirc$ |
| Increment | INC |  |  |  |  |  |  | 6C | 6 | 2 | 7 C | 6 | 3 |  |  |  | $M+1-M$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | $\bigcirc$ |
|  | INCA |  |  |  |  |  |  |  |  |  |  |  |  | 4C | 2 | 1 | $A+1-A$ | $\bullet$ | $\bullet$ |  |  |  | $\bullet$ |
|  | INCB |  |  |  |  |  |  |  |  |  |  |  |  | 5 C | 2 | 1 | $B+1-B$ | - | - | 1 |  |  | $\bullet$ |
| Load Acmitrs | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | B6 | 4 | 3 |  |  |  | $M-A$ | - | $\bullet$ |  |  | R | $\bullet$ |
|  | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 |  |  |  | M -B | $\bullet$ | $\bullet$ |  |  | A | $\bigcirc$ |
| Load Double | LDD | CC | 3 | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 |  |  |  | $\mathrm{M}: \mathrm{M}+1-\mathrm{D}$ | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bigcirc$ |
| Logical Shift, Left | LSL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  | $\text { Q }<\text { שָ }$ | $\bullet$ | $\bullet$ | 1 | 1 | T |  |
|  | LSLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 2 | 1 |  | $\bullet$ | $\bullet$ |  |  | 1 |  |
|  | LSLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 2 | 1 |  | - | $\bullet$ |  | 1 | 1 |  |
|  | LSLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 3 | 1 |  | $\bullet$ | $\bigcirc$ | , | , |  |  |
| Shift Right, Logical | LSR |  |  |  |  |  |  | 64 | 6 | 2 | 74 | 6 | 3 |  |  |  | $0 \rightarrow \overrightarrow{\square 7} \overrightarrow{D I D}_{50} \rightarrow \square$ | $\bullet$ | - | R |  |  |  |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 2 | 1 |  | $\bullet$ | $\bigcirc$ | R |  |  | 1 |
|  | LSRB |  |  |  |  |  |  |  |  |  |  |  |  | 54 | 2 | 1 |  | $\bullet$ | - | R |  |  | 1 |
|  | LSRD |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 3 | 1 |  | $\bullet$ | - | R | 1 |  | - |
| Multiply | MUL |  |  |  |  |  |  |  |  |  |  |  |  | 3D | 10 | 1 | $A \times B=D$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |  |
| 2's Complement (Negate) | NEG |  |  |  |  |  |  | 60 | 6 | 2 | 70 | 6 | 3 |  |  |  | $00-M-M$ | - | $\bullet$ | 1 | 1 | 1 |  |
|  | NEGA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 2 | 1 | O0-A - A | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | NEGB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 | $00-B-B$ | $\bullet$ | $\bigcirc$ | 1 | 1 | 1 |  |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 | $P C+1-P C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bigcirc$ | $\bullet$ | $\bigcirc$ |
| Inclusive OR | ORAA | 8A | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 |  |  |  | $A+M \rightarrow A$ | $\bullet$ | - |  | 1 | R | 0 |
|  | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 |  |  |  | $B+M-B$ | $\bullet$ | $\bullet$ | 1 | 1 | R | 0 |
| Push Data | PSHA |  |  |  |  |  |  |  |  |  |  |  |  | 36 | 3 | 1 | A $\rightarrow$ Stack | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 0 |
|  | PSHB |  |  |  |  |  |  |  |  |  |  |  |  | 37 | 3 | 1 | B - Stack | $\bullet$ | $\bullet$ | $\bullet$ | $\bigcirc$ | $\bigcirc$ | $\bullet$ |
| Pull Data | PULA |  |  |  |  |  |  |  |  |  |  |  |  | 32 | 4 | 1 | Stack - A | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | PULB |  |  |  |  |  |  |  |  |  |  |  |  | 33 | 4 | 1 | Stack - B | $\bullet$ | $\bigcirc$ | $\bullet$ | $\bullet$ | - | - |
| Rotate Left | ROL |  |  |  |  |  |  | 69 | 6 | 2 | 79 | 6 | 3 |  |  |  | $0<\prod_{67}$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | ROLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 2 | 1 |  | - | $\bullet$ | 1 | 1 | 1 | 1 |
|  | ROLB |  |  |  |  |  |  |  |  |  |  |  |  | 59 | 2 | 1 |  | - | - | 1 | 1 | 4 | , |
| Rotate Right | ROR |  |  |  |  |  |  | 66 | 6 | 2 | 76 | 6 | 3 |  |  |  |  | - | $\bullet$ | 1 |  |  |  |
|  | RORA |  |  |  |  |  |  |  |  |  |  |  |  | 46 | 2 | 1 |  | $\bullet$ | $\bigcirc$ | 1 | 1 | ! | 1 |
|  | RORB |  |  |  |  |  |  |  |  |  |  |  |  | 56 | 2 | 1 |  | $\bullet$ | $\bigcirc$ | 1 | 1 | , |  |
| Subtract Acmitr | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 2 | 1 | $A-B \rightarrow A$ | - | - | 1 | 1 |  |  |
| Subtract with Carry | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | B2 | 4 | 3 |  |  |  | $A \cdot M-C-A$ | - | $\bullet$ |  |  |  | T |
|  | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C-B$ | $\bullet$ | $\bullet$ |  | 1 | 1 | 1 |
| Store Acmltrs | STAA |  |  |  | 97 | 3 | 2 | A7 | 4 | 2 | B7 | 4 | 3 |  |  |  | $A-M$ | $\bigcirc$ | $\bullet$ |  |  | R | $\bullet$ |
|  | STAB |  |  |  | D7 | 3 | 2 | E7 | 4 | 2 | F7 | 4 | 3 |  |  |  | $B-M$ | - | $\bullet$ | 1 | 1 | R | $\bullet$ |
|  | STD |  |  |  | DD | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 |  |  |  | $D-M: M+1$ | - | $\bullet$ | 1 | 1 | R | $\bigcirc$ |
| Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | BO | 4 | 3 |  |  |  | $A . M-A$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 |  |
|  | SUBB | CO | 2 | 2 | DO | 3 | 2 | EO | 4 | 2 | FO | 4 | 3 |  |  |  | $B-M-B$ | - | $\bullet$ | 1 | 1 | 1 | 1 |
| Subtract Double | SUBD | 83 | 4 | 3 | 93 | 5 | 2 | A3 | 6 | 2 | B3 | 6 | 3 |  |  |  | $D \cdot M: M+1-D$ | $\bullet$ | $\bullet$ | 1 | + | 1 | 1 |
| Transfer Acmitr | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 2 | 1 | $A-B$ | $\bigcirc$ | $\bigcirc$ | 1 |  | R | $\bigcirc$ |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 2 | 1 | $B-A$ | $\bigcirc$ | $\bigcirc$ | 1 |  | R | $\bigcirc$ |
| Test, Zero or Minus | TST |  |  |  |  |  |  | 6D | 6 | 2 | 70 | 6 | 3 |  |  |  | M - 00 | 0 | $\bigcirc$ |  |  | R | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 4D | 2 | 1 | A - 00 | $\bigcirc$ | $\bigcirc$ |  |  | R | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 | B.00 | $\bullet$ | $\bullet$ |  | 1 | R | R |

The Condition Code Register notes are listed after Table 12.

TABLE 11 - JUMP AND BRANCH INSTRUCTIONS

| Operations | Mnemonic | . Direct |  |  | Relative |  |  | Index |  |  | Extnd |  |  | Inherent |  |  | Branch Test | Cond. Code Reg. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | OP | $\sim$ | \# |  |  |  | OP | $\sim$ | \# |  |  |  | OP | ~ | \# |  | OP | $\sim$ | \# | OP | $\sim$ | 開 | H | 1 | N | 2 | V | C |
| Branch Always | BRA |  |  |  | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  | None | $\bigcirc$ | - | $\bigcirc$ | - | - | $\bigcirc$ |
| Branch Never | BRN |  |  |  | 21 | 3 | 2 |  |  |  |  |  |  |  |  |  | None | $\bigcirc$ | - | $\bigcirc$ | - | $\bigcirc$ | $\bigcirc$ |
| Branch If Carry Clear | BCC |  |  |  | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=0$ | $\bigcirc$ | - | - | - | - | - |
| Branch If Carry Set | BCS |  |  |  | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=1$ | $\bigcirc$ | - | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| Branch If = Zero | BEQ |  |  |  | 27 | 3 | 2 |  |  |  |  |  |  |  |  |  | $z=1$ | $\bigcirc$ | - | - | - | - | $\bigcirc$ |
| Branch If $\geq$ Zero | BGE |  |  |  | 2 C | 3 | 2 |  |  |  |  |  |  |  |  |  | $N \oplus V=0$ | $\bigcirc$ | $\bigcirc$ | - | - | $\bigcirc$ | $\bigcirc$ |
| Branch If $>$ Zero | BGT |  |  |  | 2 E | 3 | 2 |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | $\bigcirc$ | - | - | - | - | $\bigcirc$ |
| Branch If Higher | BHI |  |  |  | 22 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C+Z=0$ | $\bigcirc$ | $\bigcirc$ | - | - | $\bigcirc$ | $\bigcirc$ |
| Branch If Higher or Same | BHS |  |  |  | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=0$ | - | - | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ |
| Branch If $\leq$ Zero | BLE |  |  |  | 2F | 3 | 2 |  |  |  |  |  |  |  |  |  | $Z+(\mathrm{N} \oplus \mathrm{V})=1$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| Branch If Carry Set | BLO |  |  |  | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=1$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| Branch If Lower Or Same | BLS |  |  |  | 23 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C+Z=1$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | 0 |
| Branch If < Zero | BLT |  |  |  | 2D | 3 | 2 |  |  |  |  |  |  |  |  |  | $N \oplus \cdot=1$ | - | - | - | - | - | $\bigcirc$ |
| Branch If Minus | BMI |  |  |  | 2 B | 3 | 2 |  |  |  |  |  |  |  |  |  | $N=1$ | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| Branch If Not Equal Zero | BNE |  |  |  | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  | $Z=0$ | $\bigcirc$ | - | 0 | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| Branch If Overflow Clear | BVC |  |  |  | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  | $V=0$ | $\bigcirc$ | 0 | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ |
| Branch If Overflow Set | BVS |  |  |  | 29 | 3 | 2 |  |  |  |  |  |  |  |  |  | $V=1$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ |
| Branch If Plus | BPL |  |  |  | 2A | 3 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | $\bigcirc$ | - | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ |
| Branch To Subroutine | BSR |  |  |  | 8D | 6 | 2 |  |  |  |  |  |  |  |  |  | See Special | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| Jump | JMP |  |  |  |  |  |  | 6 E | 3 | 2 | $7 E$ | 3 | 3 |  |  |  | Operations - | - | - | - | - | - | $\bigcirc$ |
| Jump To Subroutine | JSR | 9D | 5 | 2 |  |  |  | AD | 6 | 2 | BD | 6 | 3 |  |  |  | Figure 26 | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 |  | - | - | - | - | - | $\bigcirc$ |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  |  |  |  | 381 | 10 | 1 |  |  |  | 1 | 1 | 1 | 1 |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 | See Special | $\bigcirc$ | - | $\bigcirc$ | - | $\bigcirc$ | $\bigcirc$ |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  |  |  |  | 3F 1 | 12 | 1 | Operations Figure 26 | - | S | - | $\bigcirc$ | - | $\bigcirc$ |
| Wait For Interrupt | WAI |  |  |  |  |  |  |  |  |  |  |  |  | 3E | 9 | 1 |  | - | - | - | - | - | $\bigcirc$ |

TABLE 12 - CONDITION CODE REGISTER MANIPULATION INSTRUCTIONS

| Operations | Inherent |  |  |  | Boolean Operation | Cond. Code Reg. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | 1 <br> 1 | 3 | $\begin{array}{\|l\|} \hline 2 \\ \hline 2 \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 1 \\ \hline v \\ \hline \end{array}$ | O |
|  | Mnemonic | OP | - | \# |  |  |  |  |  |  | [ |
| Clear Carry | CLC | OC | 2 | 1 |  | $0-\mathrm{C}$ | $\bigcirc$ | - | $\bigcirc$ | $\bullet$ | $\bigcirc$ | R |
| Clear Interrupt Mask | CLI | OE | 2 | 1 | $0-1$ | - | R | - | - | $\bigcirc$ | $\bigcirc$ |
| Clear Overflow | CLV | OA | 2 | 1 | $0-\mathrm{V}$ | - | - | - | - | R | $\bigcirc$ |
| Set Carry | SEC | OD | 2 | 1 | $1-\mathrm{C}$ | - | - | $\bullet$ | - | $\bullet$ | S |
| Set Interrupt Mask | SEI | OF | 2 | 1 | 1-1 | $\bullet$ | S | - | - | $\bullet$ | $\bigcirc$ |
| Set Overflow | SEV | OB | 2 | 1 | $1-\mathrm{V}$ | - | - | $\bullet$ | - | S | $\bullet$ |
| Accumulator A - CCR | TAP | 06 | 2 | 1 | A - CCR | 1 | 1 | 1 | 1 | 1 | 1 |
| CCR - Accumulator $A$ | TPA | 07 | 2 | 1 | CCR - A | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

## LEGEND

## OPOperation Code (Hexadecimal)

~ Number of MPU Cycles
Msp Contents of memory location pointed to by Stack Pointer
\# Number of Program Bytes

+ Arithmetic Plus
- Arithmetic Minus
- Boolean AND

X Arithmetic Multiply

+ Boolean Inclusive OR
$\oplus$ Boolean Exclusive OR
$\boldsymbol{M}$ Complement of M
- Transfer Into

0 Bit = Zero
00 Byte $=$ Zero

## CONDITION CODE SYMBOLS

H Half-carry from bit 3
I Interrupt mask
$N$ Negative (sign bit)
Z Zero (byte)
$\checkmark$ Overflow, 2's complement
C Carry/Borrow from MSB
R Reset Always
S Set Always
A Affected

- Not Affected

TABLE 13 - INSTRUCTION EXECUTION TIMES IN E-CYCLES

|  | ADDRESSING MODE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & 8 \\ & 9 \\ & 8 \\ & 8 \\ & 5 \end{aligned}$ | \% | $\begin{aligned} & 8 \\ & 6 \\ & \mathbf{8} \\ & \mathbf{8} \\ & \mathbf{x} \end{aligned}$ | E X ¢ E | $$ | - |
| ABA | - | - | - | - | 2 | - |
| ABX | - | - | - | - | 3 | - |
| ADC | 2 | 3 | 4 | 4 | - | - |
| ADD | 2 | 3 | 4 | 4 | - | - |
| ADDD | 4 | 5 | 6 | 6 | - | - |
| AND | 2 | 3 | 4 | 4 | - | - |
| ASL | $\bigcirc$ | $\bigcirc$ | 6 | 6 | 2 | - |
| ASLD |  | $\bigcirc$ | - | $\bigcirc$ | 3 | - |
| ASR | - | - | 6 | 6 | 2 | - |
| BCC | - | - | - | - | - | 3 |
| BCS | - | - | - | - | - | 3 |
| BEQ |  | - | - | - | - | 3 |
| BGE |  | - | - | - | - | 3 |
| BGT | - | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | 3 |
| BHI |  |  |  | $\bigcirc$ |  | 3 |
| BHS | - | - | - | - | - | 3 |
| BIT | 2 | 3 | 4 | 4 | - | - |
| BLE | - | - | - | - | - | 3 |
| BLO | - | - | - | - | - | 3 |
| BLS | - | - | - | - | - | 3 |
| BLT | - | $\bigcirc$ | $\bigcirc$ | - | - | 3 |
| BMI | - | - | - | - |  | 3 |
| BNE | - | - | - | - | - | 3 |
| BPL | - | - | - | - | - | 3 |
| BRA | - | - | - | - | - | 3 |
| BRN | - | - | - | - | - | 3 |
| BSR | - | - | - | - | - | 6 |
| BVC | - | $\bigcirc$ | - | $\bigcirc$ | - | 3 |
| BVS | - | - | - | - | - | 3 |
| CBA | - | - | - | - | 2 | - |
| CLC | - | - | - | - | 2 | - |
| CLI | - | - | - | - | 2 | - |
| CLR | - | - | 6 | 6 | 2 | - |
| CLV | - | - | - | - | 2 | - |
| CMP | 2 | 3 | 4 | 4 | $\bigcirc$ | O |
| COM | $\bigcirc$ | - | 6 | 6 | 2 | - |
| CPX | 4 | 5 | 6 | 6 | - | - |
| DAA | - | - | - | - | 2 | - |
| DEC | - | - | 6 | 6 | 2 | - |
| DES | - | - | - | - | 3 | - |
| DEX | - | - | - | - | 3 | - |
| EOR | 2 |  | $4$ | 4 | - |  |
| INC | - | - | 6 | 6 | - | - |
| INS | - | - | - | $\bigcirc$ | 3 | $\bigcirc$ |


|  | ADDRESSING MODE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\%$ <br> 8 <br> 8 | 8 8 8 \% W | 8 8 8 8 | ¢ | 3 3 8 |
| INX | - | - | - | - | 3 | - |
| JMP | - | - | 3 | 3 | - | - |
| JSR | - | 5 | 6 | 6 | - | - |
| LDA | 2 | 3 | 4 | 4 | - |  |
| LDD | 3 | 4 | 5 | 5 | - | - |
| LDS | 3 | 4 | 5 | 5 | - | - |
| LDX | 3 | 4 | 5 | 5 | - | $\bigcirc$ |
| LSL |  |  | 6 | 6 | 2 |  |
| LSLD | - | - | - | - | 3 |  |
| LSR | - | - | 6 | 6 | 2 | - |
| LSRD | - | - | - | - | 3 | - |
| MUL | - | - | - | - | 10 |  |
| NEG |  | - | 6 | 6 | 2 | - |
| NOP | - | - | - | $\bigcirc$ | 2 | - |
| ORA | 2 | 3 | 4 | 4 | - |  |
| PSH |  | - | - | - | 3 | - |
| PSHX |  | - | - | - | 4 |  |
| PUL |  | - | - | - | 4 | - |
| PULX |  | - | - | - | 5 | - |
| ROL |  | - | 6 | 6 | 2 |  |
| ROR | $\bigcirc$ | - | 6 | 6 | 2 |  |
| RTI |  | - | - | $\bigcirc$ | 10 |  |
| RTS |  | - | - | - | 5 |  |
| SBA |  | - | - | - | 2 | - |
| SBC | 2 | 3 | 4 | 4 | - | - |
| SEC | - | - | - | - | 2 | - |
| SEI |  | - | - | - | 2 |  |
| SEV | $\bigcirc$ | $\bigcirc$ | - | - | 2 |  |
| STA | $\bigcirc$ | 3 | 4 | 4 | - |  |
| STD | - | 4 | 5 | 5 | - | - |
| STS | - | 4 | 5 | 5 | - |  |
| STX | - | 4 | 5 | 5 | - |  |
| SUB | 2 | 3 | 4 | 4 | - | - |
| SUBD | 4 | 5 | 6 | 6 | - | - |
| SWI | $\bigcirc$ | - | $\bigcirc$ | $\bigcirc$ | 12 |  |
| TAB | - | - | $\bigcirc$ | - | 2 | - |
| TAP | - | - | - | - | 2 | - |
| TBA | - | - | $\bigcirc$ | - | 2 |  |
| TPA | - | - | - | - | 2 |  |
| TST | - | - | 6 | 6 | 2 | - |
| TSX | - | - | - | - | 3 | - |
| TXS | - | - | - | - | 3 | - |
| WAI | - | - | - | - | 9 | - |

## SUMMARY OF CYCLE-BY-CYCLE OPERATION

Table 14 provides a detailed description of the information present on the address bus, data bus, and the read/write $(R / \bar{W})$ line during each cycle of each instruction.
The information is useful in comparing actual with expected results during debug of both software and hardware as the program is executed. The information is categorized in groups according to addressing mode and number of cycles
per instruction: In general, instructions with the same addressing mode and number of cycles execute in the same manner. Exceptions are indicated in the table.
Note that during MPU reads of internal locations, the resultant value will not appear on the external data bus except in mode 0 . "High order" byte refers to the mostsignificant byte of a 16 -bit value.

TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 1 of 5)

| Address Mode and <br> Instructions | Cycles | Cycle <br> $\#$ | Address Bus | R/ $\bar{W}$ <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |

IMMEDIATE

| ADC | EOR | 2 | 1 | Opcode Address | 1 | Opcode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | LDA |  | 2 | Opcode Address + 1 | 1 | Operand Data |
| AND | ORA |  |  |  |  |  |
| BIT | SBC |  |  |  |  |  |
| CMP | SUB |  |  |  |  |  |
| LDS |  | 3 | 1 | Opcode Address | 1 | Opcode |
| LDX |  |  | 2 | Opcode Address + 1 | 1 | Operand Data (High Order Byte) |
| LDD |  |  | 3 | Opcode Address + 2 | 1 | Operand Data (Low Order Byte) |
| CPX |  | 4 | 1 | Opcode Address | 1 | Upcode |
| SUBD |  |  | 2 | Opcode Address + 1 | 1 | Operand Data (High Order Byte) |
| ADDD |  |  | 3 | Opcode Address + 2 | 1 | Operand Data (Low Order Byte) |
|  |  |  | 4 | Address Bus FFFF | 1 | Low Byte of Restart Vector |

DIRECT

| ADC | EOR | 3 | 1 | Opcode Address | 1 | Opcode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | LDA |  | 2 | Opcode Address + 1 | 1 | Address of Operand |
| AND | ORA |  | 3 | Address of Operand | 1 | Operand Data |
| BIT | SBC ${ }^{\text {- }}$ |  |  |  |  |  |
| CMP | SUB |  |  |  |  |  |
| STA |  | 3 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Destination Address |
|  |  |  | 3 | Destination Address | 0 | Data from Accumulator |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \end{aligned}$ |  | 4 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Address of Operand |
|  |  |  | 3 | Address of Operand | 1 | Operand Data (High Order Byte) |
|  |  |  | 4 | Operand Address + 1 | 1 | Operand Data (Low Order Byte) |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \\ & \text { STD } \end{aligned}$ |  | 4 |  | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Address of Operand |
|  |  |  | 3 | Address of Operand | 0 | Register Data (High Order Byte) |
|  |  |  | 4 | Address of Operand +1 | 0 | Register Data (Low Order Byte) |
| $\begin{aligned} & \text { CPX } \\ & \text { SUBD } \\ & \text { ADDD } \end{aligned}$ |  | 5 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Address of Operand |
|  |  |  | 3 | Operand Address | 1 | Operand Data (High Order Byte) |
|  |  |  | 4 | Operand Address + 1 | 1 | Operand Data (Low Order Byte) |
|  |  |  | 5 | Address Bus FFFF | 1 | Low Byte of Restart Vector |
| JSR |  | 5 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Irrelevant Data |
|  |  |  | 3 | Subroutine Address | 1 | First Subroutine Opcode |
|  |  |  | 4 | Stack Pointer | 0 | Return Address (Low Order Byte) |
|  |  |  | 5 | Stack Pointer - 1 | 0 | Return Address (High Order Byte) |

TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 2 of 5)

| Address Mode and Instructions | Cycles | Cycle | 'Address Bus | $\begin{aligned} & \text { R/W } \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EXTENDED |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Jump Address (High Order Bytes) <br> Jump Address (Low Order Byte) |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode Address of Operand Address of Operand (Low Orde: Brite) Operand Data``` |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Destination Address (High Order Byte) Destination Address (Low Order Byte) Data from Accumulator |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \\ & \text { STD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| ASL LSR <br> ASR NEG <br> CLR ROL <br> COM ROR <br> DEC TST* <br> INC  | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand <br> Address Bus FFFF <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Current Operand Data <br> Low Byte of Restart Vector <br> New Operand Data |
|  | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> Operand Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Address (High Order Byte) <br> Operand Address (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) <br> Low Byte of Restait Vector |
| JSR | 6 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Subroutine Starting Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Address of Subroutine (High Order Byte) <br> Address of Subroutine (Low Order Byte) <br> Opcode of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

[^6]TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 3 of 5)

| Address Mode and Instructions | Cycles | Cycle | Address Bus | $\begin{aligned} & R / \bar{W} \\ & \text { Line } \\ & \hline \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INDEXED |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Offset <br> Low Byte of Restart Vector Operand Data |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode Offset Low Byte of Restart Vector Operand Data |
| $\begin{array}{\|l\|} \hline \text { LDS } \\ \text { LDX } \\ \text { LDD } \end{array}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Index Register Plus Offset + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| $\begin{aligned} & \hline \text { STS } \\ & \text { STX } \\ & \text { STD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Index Register Plus Offset + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| ASL LSR <br> ASR NEG <br> CLR ROL <br> COM ROR <br> DEC TST* <br> INC  <br> CPX  | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Address Bus FFFF <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Current Operand Data <br> Low Byte of Restart Vector <br> New Operand Data |
| CPX <br> SUBD <br> ADDD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register + Offset <br> Index Register + Offset + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector Operand Data (High Order Byte) Operand Data (Low Order Byte) Low Byte of Restart Vector |
| JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register + Offset <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> First Subroutine Opcode <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

[^7]TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 4 of 5)

| Address Mode and Instructions |  |  | Cycles | Cycle " | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INHERENT |  |  |  |  |  |  |  |
| $\begin{array}{\|l} \hline \mathrm{ABA} \\ \mathrm{ASL} \\ \mathrm{ASR} \\ \mathrm{CBA} \\ \mathrm{CLC} \\ \mathrm{CLI} \\ \mathrm{CLR} \\ \mathrm{CLV} \\ \mathrm{COM} \end{array}$ | DAA <br> DEC <br> INC <br> LSR <br> NEG <br> NOP <br> ROL <br> ROR <br> SBA | $\begin{aligned} & \text { SEC } \\ & \text { SEI } \\ & \text { SEV } \\ & \text { TAB } \\ & \text { TAP } \\ & \text { TBA } \\ & \text { TPA } \\ & \text { TST } \end{aligned}$ | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 | $1$ | Opcode <br> Opcode of Next instruction |
| ABX |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data Low Byte of Restart Vector |
| $\begin{aligned} & \text { ASLD } \\ & \text { LSRD } \end{aligned}$ |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data Low Byte of Restart Vector |
| $\begin{aligned} & \text { DES } \\ & \text { INS } \end{aligned}$ |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Previous Stack Pointer Contents | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction Irrelevant Data |
| $\begin{array}{\|l\|} \hline \operatorname{INX} \\ \mathrm{DEX} \end{array}$ |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction Low Byte of Restart Vector |
| $\begin{aligned} & \text { PSHA } \\ & \text { PSHB } \end{aligned}$ |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Opcode of Next Instruction <br> Accumulator Data |
| TSX |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction Irrelevant Data |
| TXS |  |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction <br> Low Byte of Restart Vector |
| PULA PULB |  |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction <br> Irrelevant Data <br> Operand Data from Stack |
| PSHX |  |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Opcode <br> Irrelevant Data <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) |
| PULX |  |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Irrelevant Data <br> Irrelevant Data <br> Index Register (High Order Byte) <br> Index Register (Low Order Byte) |
| RTS |  |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Irrelevant Data <br> Irrelevant Data <br> Address of Next Instruction (High Order Byte) <br> Address of Next Instruction (Low Order Byte) |
| WAI |  |  | 9 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \\ & 9 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer-2 <br> Stack Pointeı-3 <br> Stack Pointer-4 <br> Stack Pointer - 5 <br> Stack Pointer-6 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Opcode of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) <br> Contents of Accumulator $A$ <br> Contents of Accumulator B <br> Contents of Condition Code Register |

TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 5 of 5)

| Address Mode and <br> Instructions | Cycles | Cycle <br> $\#$ | Address Bus | / $\bar{W}$ <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |

INHERENT

| MUL | 10 | $\begin{gathered} \hline 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ \hline \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Address Bus FFFF <br> Address Bus FFFF <br> Address Bus FFFF <br> Address Bus FFFF <br> Address Bus FFFF <br> Address Bus FFFF <br> Address Bus FFFF | 1 1 1 1 1 1 1 1 1 1 | Opcode <br> Irrelevant Data <br> Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RTI | 10 | $\begin{gathered} \hline 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer +2 <br> Stack Pointer +3 <br> Stack Pointer +4 <br> Stack Pointer +5 <br> Stack Pointer +6 <br> Stack Pointer +7 | 1 1 1 1 1 1 1 1 1 1 1 | Opcode <br> Irrelevant Data <br> Irrelevant Data <br> Contents of Condition Code Register from Stack <br> Contents of Accumulator B from Stack <br> Contents of Accumulator A from Stack <br> Index Register from Stack (High Order Byte) <br> Index Register from Stack (Low Order Byte) <br> Next Instruction Address from Stack (High Order Byte) <br> Next Instruction Address from Stack (Low Order Byte) |
| SWI | 12 | $\begin{gathered} \hline 1 \\ 2 \\ 3 \\ 4 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \\ 12 \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Stack Pointer - 3 <br> Stack Pointer-4 <br> Stack Pointer - 5 <br> Stack Pointer-6 <br> Stack Pointer - 7 <br> Vector Address FFFA (Hex) <br> Vector Address FFFB (Hex) | 1 1 0 0 0 0 0 0 0 1 1 1 | Opcode <br> Irrelevant Data <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) <br> Contents of Accumulator A <br> Contents of Accumulator B <br> Contents of Condition Code Register <br> Irrelevant Data <br> Address of Subroutine (High Order Byte) <br> Address of Subroutine (Low Order Byte) |

RELATIVE


## FIGURE 25 - SPECIAL OPERATIONS



Legend: Address of next instruction in Main Program to be execited upon return from subroutine
RTN $\mathrm{N}_{\mathrm{H}}=$ Most significant byte of Return Address
RTN $\mathrm{H}_{\mathrm{L}}=$ Least significant byte of Return Address
$\rightarrow=$ Stack Pointer After Execution
$K=8$-bit Unsigned Value


P SUFFIX PLASTIC PACKAGE

ALSO AVAILABLE
C SUFFIX
CERAMIC PACKAGE

CB-521


FN SUFFIX
PLCC 44


## ORDERING INFORMATION

The information required when ordering a custom MCU is listed below. The ROM program may be transmitted to THOMSON SEMICONDUCTEURS on EPROM(s) or an EFDOS/MDOS* disk file.

To initiate a ROM pattern for the MCU, it is necessary to first contact your local THOMSON SEMICONDUCTEURS representative or distributor.

## EPROMs

Two 2708 or one 2716 type EPROMs, programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. The EPROM must be clearly marked to indicate which EPROM corresponds to which address space. The recommended marking procedure is illustrated below:

$X X X=$ Customer $1 D$
After the EPROM(s) are marked, they should be placed in conductive IC carriers and securely packed. Do not use styrofoam.

## VERIFICATION MEDIA

All original pattern media (EPROMs or floppy disk) are filed for contractual purposes and are not returned. A computer listing of the ROM code will be generated and returned along with a listing verification form. The listing should be thoroughly checked and the verification form completed, signed, and returned to THOMSON SEMICONDUCTEURS. The signed verification form constitutes the
contractual agreement for creation of the customer mask. If desired, THOMSON SEMICONDUCTEURS will program on blank EPROM from the data file used to create the custom mask and aid in the verification process.

## ROM VERIFICATION UNITS (RVUs)

Ten MCUs contaınıng the customer's ROM pattern will be sent for program verification. These units will have been made using the custom mask but are for the purpose of ROM verification only. For expediency they are usually unmarked, packaged in ceramic, and tested only at room temperature and 5 volts. These RVUs are included in the mask charge and are not production parts. The RVUs are thus not guaranteed by THOMSON SEMICONDUCTEURS. Quality Assurance, and should be discarded after verification is completed

## FLEXIBLE DISKS

The disk media submitted must be single-sided, EFDOS/ MDOS* compatible floppies.
The customer must write the binary file name and company name on the disk with a felt-tip-pen. The minimum EFDOS/MDOS* system files, as well as the absolute binary object file (Filename .LO type of file) from the 6801 cross assembler, must be on the disk. An object file made from a memory dump using the ROLLOUT command is also acceptable. Consider submitting a source listing as well as the following files: filename .LX (DEVICE/EXORciser loadable format) and filename .SA (ASCII Source Code). These files will of course be kept confidential and are used 1) to speed up the process in-house if any problems arise, and 2) to speed up the user-to-factory interface if the user finds any software errors and needs assistance quickly from THOMSON SEMICONDUCTEURS factory representatives.

EFDOS is THOMSON SEMICONDUCTEURS' Disk Operating System available on development systems such as DEVICE,..
MDOS* is MOTOROLA's Disk Operating System available on development systems such as EXORciser,...
*Requires prior factory approval.

Whenever ordering a custom MCU is required, please contact your local THOMSON SEMICONDUCTEURS representative or THOMSON SEMICONDUCTEURS distributor and/or complete and send the attached 'MCU customer ordering sheet" to your local THOMSON SEMICONDUCTEURS representative.

ORDERING INFORMATION


EXORciser is a registered trade mark of MOTOROLA Inc.


## ADVANCE INFORMATION

The EF6801U4 is an 8-bit single-chip microcomputer unit (MCU) which enhances the capabilities of the EF6801 and significantly enhances the capabilities of the EF6800 Family of parts. It includes an EF6801 microprocessor unit (MPU) with direct object-code compatibility and upward object-code compatibility with the EF6800. Execution times of key instructions have been improved over the EF6800 and the new instructions found on the EF6801 are included. The MCU can function as a monolithic microcomputer or can be expanded to a 64 K byte address space. It is TTL compatible and requi res one +5 -volt power supply. On-chip resources include 4096 bytes of ROM, 192 bytes of RAM, a serial communications interface (SCI), parallel $1 / O$, and a 16 -bit six-function programmable timer. The EF6803U4 can be considered as an EF6801U4 operating in modes 2 or 3 ; i.e., those that do not use internal ROM.

- Enhanced EF6800 Instruction Set
- Upward Source and Object Code Compatibility with the EF6800 and EF6801
- Bus Compatibility with the EF6800 Family
- $8 \times 8$ Multiply Instruction
- Single-Chip or Expanded Operation to 64K Byte Address Space
- Internal Clock Generator with Divide-by-Four Output
- Serial Communications Interface (SCI)
- 16-Bit Six-Function Programmable Timer
- Three Output Compare Functions
- Two Input Capture Functions
- Counter Alternate Address
- 4096 Bytes of ROM (EF6801U4)
- 192 Bytes of RAM
- 32 Bytes of RAM Retainable During Power Down
- 29 Parallel I/O and I wo Handshake Control Lines
- $\overline{\mathrm{NMI}}$ Inhibited Until Stack Load
- Complete Development System Support on DEVICE ${ }^{\circledR}$.
- $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ Temperature Range


## HMOS

HIGH-DENSITY N-CHANNEL, SILICON-GATE

## MICROCOMPUTER/ MICROPROCESSOR





NOTE : No functioning ROM in EF6803U4.

MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{H}}$ to $\mathrm{T}_{\mathrm{L}}$ | ${ }^{\circ} \mathrm{C}$ |
| EF6801/03U4, EF6801/03U4-1. |  | 0 to 70 <br> EF68A01/03U4 |  |
| EF6801/03U4, EF6801/03U4-1 : V suffix |  |  |  |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Rating |
| :---: | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Plastic | $\theta J A$ | 50 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| PLCC |  | 100 |  |

This device contains circuitry to protect the in. puts against damage due to high static voltages or electric fields; however, it is advised that nor mal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high-impedance circuit. For proper opera tion it is recommended that $V_{\text {in }}$ and $V_{\text {out }}$ be con strained to the range $V_{S S} \leq\left(V_{\text {in }}\right.$ or $\left.V_{\text {out }}\right) \leq V_{C C}$ input protection is enhanced by connecting unused inputs to elther $V_{D D}$ or $V_{S S}$

## POWER CONSIDERATIONS

The average chip-junction temperature, $\mathrm{T}_{\mathrm{J}}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{aligned}
& T_{J}=T_{A}+\left(P_{D} \bullet \theta J A\right) \\
& \text { Where: }
\end{aligned}
$$

$$
\begin{aligned}
& \mathrm{T}_{\mathrm{A}} \equiv \text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
& \theta J A \equiv \text { Package Thermal Resistance, Junction-to-Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
& \mathrm{PD}_{\mathrm{D}} \equiv \text { PINT }+ \text { PPORT } \\
& \text { PINT } \equiv \mathrm{I} C C \times \mathrm{V}_{C C} \text {, Watts - Chip Internal Power } \\
& \text { PPORT } \equiv \text { Port Power Dissipation, Watts - User Determined }
\end{aligned}
$$

For most applications PPORT $<$ PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K \div\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \bullet P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known TA. Using this value of $K$ the values of $P D$ and $T J$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

CONTROL TIMING $\left(V_{C C}=5.0 \mathrm{~V}_{ \pm} 5 \%, \mathrm{~V}_{S S}=0, \mathrm{~T}_{\mathrm{A}}=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | $\begin{aligned} & \text { EF6801U4 } \\ & \text { EF6803U4 } \end{aligned}$ |  | $\begin{aligned} & \text { EF6801U4-1 } \\ & \text { EF6803U4-1 } \end{aligned}$ |  | EF68A01U4 EF68A03U4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $\mathrm{f}_{0}$ | 0.5 | 1.0 | 0.5 | 1.25 | 0.5 | 1.5 | MHz |
| Crystal Frequency | ${ }^{\text {f }}$ XTAL | 2.0 | 4.0 | 2.0 | 5.0 | 2.0 | 6.0 | MHz |
| External Oscillator Frequency | $4 \mathrm{f}_{0}$ | 2.0 | 4.0 | 2.0 | 5.0 | 2.0 | 6.0 | MHz |
| Crystal Oscillator Startup Time | $\mathrm{t}_{\mathrm{rc}}$ | - | 100 | - | 100 | - | 100 | ms |
| Processor Control Setup Time | tPCS | 200 | - | 170 | - | 140 | - | ns |

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$ unless otherwise noted)

| Characteristic | Symbol | $\begin{array}{c\|} \text { EF6801/03U4-A01/03U4 } \\ 0^{\circ} \text { to }+70^{\circ} \mathrm{C} \\ \hline \end{array}$ |  | EF6801U4/6803U4 $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Input High Voltage $\begin{array}{r}\text { RESET } \\ \text { Other Inputs* }\end{array}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{SS}}+4.0 \\ & \mathrm{v}_{\mathrm{SS}}+2.0 \end{aligned}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{v}_{\mathrm{SS}}+4.0 \\ & \mathrm{v}_{\mathrm{SS}}+2.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | V |
| Input Low Voltage All Inputs* | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{v}_{\text {SS }}+0.8$ | $\mathrm{v}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+0.8$ | V |
| Input Load Current ( $\mathrm{V}_{\text {in }}=0$ to 2.4 V$)$ Port 4 <br>  SCl | lin | - | $\begin{aligned} & 0.5 \\ & 0.8 \end{aligned}$ | - | $\begin{aligned} & 0.8 \\ & 1.0 \end{aligned}$ | mA |
| Input Leakage Current $\left(\mathrm{V}_{\mathrm{in}}=0 \text { to } 5.5 \mathrm{~V}\right)$ | $\mathrm{l}_{\text {in }}$ | - | 2.5 | - | 5.0 | $\mu \mathrm{A}$ |
| $\mathrm{Hi}-\mathrm{Z}$ (Off-State) Input Current <br> $\left(\mathrm{V}_{\text {in }}=0.5\right.$ to 2.4 V$)$ Port 1, Port 2, Port 3 | ITSI | - | 10 | - | 20 | $\mu \mathrm{A}$ |
| Output High Voltage  <br> (ILoad $=-65 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=$ Min) Port 4, SC1, SC2 <br> (ILoad $=-100 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=$ Min) Other Outputs | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & v_{S S}+2.4 \\ & v_{S S}+2.4 \end{aligned}$ | - | $\begin{array}{r} \mathrm{v}_{\mathrm{SS}}+2.4 \\ \mathrm{v}_{\mathrm{SS}}+2.4 \end{array}$ | - | V |
| Output Low Voltage  <br> (load $=2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=$ Min) All Outputs | VoL | - | $\mathrm{V}_{\text {SS }}+0.5$ | - | $\mathrm{V}_{\text {SS }}+0.6$ | V |
| Darlington Drive Current <br> $\left(\mathrm{V}_{\mathrm{O}}=1.5 \mathrm{~V}\right)$ Port 1 | ${ }^{1} \mathrm{OH}$ | 1.0 | 4.0 | 1.0 | 5.0 | mA |
| Internal Power Dissipation (Measured at $T_{A}=T_{L}$ in Steady-State Operation)*** | PINT | - | 1200 | - | 1500 | mW |
| Input Capacitance  <br> $\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}\right.$, Port 3, Port 4, SC1 <br> $\mathrm{f}_{\mathrm{O}}=1.0 \mathrm{MHz}$ ) Other Inputs | $\mathrm{C}_{\text {in }}$ | - | $\begin{aligned} & 12.5 \\ & 10.0 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 12.5 \\ & 10.0 \\ & \hline \end{aligned}$ | pF |
| $\mathrm{V}_{\text {CC }}$ Standby $\quad \begin{array}{r}\text { Powerdown } \\ \text { Powerup }\end{array}$ | $\begin{aligned} & \hline \mathrm{v}_{\mathrm{SBB}} \\ & \mathrm{v}_{\mathrm{SB}} \\ & \hline \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 4.75 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 5.25 \\ & 5.25 \\ & \hline \end{aligned}$ | $\begin{array}{r} 4.0 \\ 4.75 \\ \hline \end{array}$ | $\begin{array}{r} \hline 5.25 \\ 5.25 \\ \hline \end{array}$ | V |
| Standby Current Powerdown | ISBB | - | 3.0 | - | 3.5 | mA |

* Except mode programming levels; see Figure 16.
*     * Negotiable to $-100 \mu \mathrm{~A}$ (for further information contact the factory).
*     *         * For the EF6801U4/EF6803U4 $T_{L}=0^{\circ} \mathrm{C}$ and for the EF6801U4/EF6803U4: V suffix $T_{L}=-40^{\circ} \mathrm{C}$

PERIPHERAL PORT TIMING (Refer to Figures 1-4)

| Characteristic | Symbol | $\begin{aligned} & \text { EF6801/03U4 } \\ & \text { EF6801/03U4-1 } \end{aligned}$ |  |  | EF68A01/03U4 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |
| Peripheral Data Setup Time | tPDSU | 200 | - | - | $150{ }^{\prime}$ | - | - | ns |
| Peripheral Data Hold Time | ${ }^{1} \mathrm{PDH}$ | 200 | - | - | 150 | - | - | ns |
| Delay Time, Enable Positive Transition to $\overline{053}$ Negative Transition | tosol | -- | - | 350 | - | - | 300 | ns |
| Delay Time, Enable Positive Transition to OS3 Positive Transition | tosD2 | - | - | 350 | - | - | 300 | ns |
| Delay Time, Enable Negative Transition to Peripheral Data Valid Port 1 <br> Port 2, 3, 4 | tPWD | - | - | $\begin{aligned} & 350 \\ & 350 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & 300 \\ & 300 \\ & \hline \end{aligned}$ | ns |
| Delay Time, Enable Negative Transition to Peripheral CMOS Data Valid | ${ }^{\text {t }}$ CMOS | - | - | 2.0 | - | - | 2.0 | $\mu \mathrm{S}$ |
| input Strobe Pulse Width | tPWIS | 200 | - | - | 150 | - | - | ns |
| input Data Hold Time | ${ }_{1} \mathrm{H}$ | 50 | - | - | 40 | - | - | ns |
| Input Data Setup Time | 1 S | 20 | - | - | 20 | - | - | ns |

FIGURE 1 - DATA SETUP AND HOLD TIMES (MPU READ)

*Port 3 non-latched operation (Latch enable $=0$ )

FIGURE 2 - DATA SETUP AND HOLD TIMES (MPU WRITE)


NOTES

1. 10 k pullup resistor required for port 2 to reach 07 V CC
2. Not applicable to P21
3. Port 4 cannot be pulled above $\mathrm{V}_{\mathrm{CC}}$

FIGURE 3 - PORT 3 OUTPUT STROBE TIMING (EF6801U4 SINGLE-CHIP MODE)


FIGURE 4 - PORT 3 LATCH TIMING (EF6801U4 SINGLE-CHIP MODE)


* Access matches output strobe select (OSS $=0$, a read; $O S S=1$, a write)

NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted.


FIGURE 6 - TIMING TEST LOAD PORTS 1, 2, 3, AND 4


$$
\begin{aligned}
C & =90 \mathrm{pF} \text { for P30-P37, P40-P47, E, SC1, SC2 } \\
& =30 \mathrm{pF} \text { for P10-P17, P20-P24 } \\
R & =37 \mathrm{k} \Omega \text { for P40-P47, SC1, SC2 } \\
& =24 \mathrm{k} \Omega \text { for P10-P17, P20-P24. } \\
& =24 \mathrm{k} \Omega \text { for P30-P37, E }
\end{aligned}
$$

BUS TIMING (See Notes 1 and 2, and Figure 7)

| Ident. <br> Number | Characteristics | Symbol | $\begin{aligned} & \text { EF6801U4 } \\ & \text { EF6803 U4 } \end{aligned}$ |  | $\begin{array}{\|l\|} \hline \text { EF6801U4-1 } \\ \text { EF6803U4-1 } \\ \hline \end{array}$ |  | $\begin{aligned} & \text { EF68A01U4 } \\ & \text { EF68A03U4 } \\ & \hline \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }^{\text {cheyc }}$ | 1.0 | 2.0 | 0.8 | 2.0 | 0.66 | 2.0 | $\mu \mathrm{s}$ |
| 2 | Pulse Width, E Low | PWEL | 430 | 1000 | 360 | 1000 | 300 | 1000 | ns |
| 3 | Pulse Width, E High | PWEH | 450 | 1000 | 360 | 1000 | 300 | 1000 | ns |
| 4 | Clock Rise and Fall Time | $\mathrm{tr}_{\mathrm{r}}, \mathrm{tf}_{\mathrm{f}}$ | - | 25 | - | 25 | - | 25 | ns |
| 9 | Address Hold Time | ${ }^{\text {t }}$ A ${ }^{\text {a }}$ | 20 | - | 20 | - | 20 | - | ns |
| 12 | Non-Muxed Address Valid Time to E* | ${ }_{\text {t }}$ AV | 200 | - | 150 | - | 115 | - | ns |
| 17 | Read Data Setup Time | tDSR | 80 | - | 70 | - | 60 | - | ns |
| 18 | Read Data Hold Time | ${ }^{\text {t }}$ DHR | 10 | - | 10 | - | 10 | - | ns |
| 19 | Write Data Delay Time | tDDW | - | 225 | - | 200 | - | 160 | ns |
| 21 | Write Data Hold Time | tDHW | 20 | - | 20 | - | 20 | - | ns |
| 22 | Muxed Address Valid Time to E Rise* | tavm | 160 | - | 120 | - | 100 | - | ns |
| 24 | Muxed Address Valid Time to AS Fall* | ${ }^{\text {t }} \mathrm{ASL}$ | 40 | - | 30 | - | 30 | - | ns |
| 25 | Muxed Address Hold Time | ${ }^{\text {t }}$ AHL | 20 | - | 20 | - | 20 | - | ns |
| 26 | Delay Time, E to AS Rise* | ${ }^{\text {t }}$ ASD | 200 | - | 170 | - | 130 | - | ns |
| 27 | Pulse Width, AS High* | PWASH | 100 | - | 80 | - | 60 | - | ns |
| 28 | Delay Time, AS to E Rise* | ${ }^{\text {t }}$ ASED | 90 | - | 70 | - | 60 | - | ns |
| 29 | Usable Access Time* (See Note 3) | ${ }^{\text {t }}$ ACC | 555 | - | 435 | - | 385 | - | ns |

*At specified cycle time.
FIGURE 7 - BUS TIMING


NOTES:

1. Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}} \geq 2.4 \mathrm{~V}$, unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.0 V , unless otherwise specified.
3. Usable access time is computed by $22+3-17+4$.
4. Memory devices should be enabled only during $E$ high to avoid port 3 bus contention.
5. Item 26 is different from the EF6801 but it is upward compatible.

## INTRODUCTION

The EF6801U4 is an 8-bit monolithic microcomputer which can be configured to function in a wide variety of applications. The facility which provides this extraordinary flexibility is its ability to be hardware programmed into eight different operating modes. The operating mode controls the configuration of 18 of the 40 MCU pins, available on-chip resources, memory map, location (internal or external) of interrupt vectors, and type of external bus. The configuration of the remaining 22 pins is not dependent on the operating mode.
Twenty-nine pins are organized as three 8 -bit ports and one 5 -bit port. Each port consists of at least a data register and a write-only data direction register. The data direction register is used to define whether corresponding bits in the data register are configured as an input (clear) or output (set).

The term "port" by itself refers to all of the hardware associated with the port. When the port is used as a "data port" or "1/O port," it is controlled by the port data direction register and the programmer has direct access to the port pins using the port data register. Port pins are labeled as Pij where $i$ identifies one of four ports and $j$ indicates the particular bit.

The microprocessor unit (MPU) is an enhanced EF6800 MPU with additional capabilities and greater throughput. It is upward source and object code compatible with the EF6800 and the EF6801. The programming model is depicted in Figure 8 where accumulator D is a concatenation of accumulators $A$ and $B$. A list of new operations added to the EF6800 instruction set are shown in Table 1.

The EF6803U4 can be considered an EF6801U4 that operates in modes 2 and 3 only.

FIGURE 8 - PROGRAMMING MODEL


TABLE 1 - NEW INSTRUCTIONS

| Instruction | Description |
| :---: | :--- |
| ABX | Unsigned addition of accumulator B to index register |
| ADDD | Adds iwithout carry) the double accumulator to memory and leaves the sum in the double accumulator |
| ASLD or LSLD | Shifts the double accumulator left (towards MSB) one bit, the LSB is cleared, and the MSB is shifted into the C bit |
| BHS | Branch if higher or same, unsigned conditional branch (same as BCC) |
| BLO | Branch if lower, unsigned conditional branch (same as BCS) |
| BRN | Branch never |
| JSR | Additional addressing mode direct |
| LDD | Loads double accumulator from memory |
| LSL | Shifts memory or accumulator left (towards MSB) one bit, the LSB is cleared, and the MSB is shifted into the C bit |
| (same as ASL) |  |
| LSRD | Shifts the double accumulator right (towards LSB) one bit, the MSB is cleared, and the LSB is shifted into the C bit |
| MUL | Unsigned multiply, multiplies the two accumulators and leaves the product in the double accumulator |
| PSHX | Pushes the index register to stack |
| PULX | Pulls the index register from stack |
| STD | Stores the double accumulator to memory |
| SUBD | Subtracts memory from the double accumulator and leaves the difference in the double accumulator |
| CPX | Internal processing modified to permit its use with any conditional branch instruction |

## OPERATING MODES

The EF6801U4 provides seven different operating modes (modes 0 through 3 and 5 through 7) and the EF6803U4 provides two operating modes (modes 2 and 3 ). The operating modes are hardware selectable and determine the device memory map, the configuration of port 3, port 4, SC1, SC2, and the physical location of the interrupt vectors.

## FUNDAMENTAL MODES

The seven operating modes ( $0-3,5-7$ ) can be grouped into three fundamental modes which refer to the type of bus it supports: single chip, expanded non-multiplexed, and ex-
panded multiplexed. Single chip is mode 7, expanded nonmultiplexed is mode 5 , and the remaining 5 are expanded multiplexed modes. Table 2 summarizes the characteristics of the operating modes.

EF6801U4 SINGLE-CHIP MODE (7) -- In the single-chip mode, the four MCU ports are configured as parallel input/output data ports, as shown in Figure 9. The MCU functions as a monolithic microcomputer in this mode without external address or data buses. A maximum of 29 //O lines and two port 3 control lines are provided. Peripherals or another MCU can be interfaced to port 3 in a loosely coupled dual-processor configuration, as shown in Figure 10.

## TABLE 2 - SUMMARY OF EF6801U4/EF6803U4 OPERATING MODES

```
Single-Chip (Mode 7)
    192 bytes of RAM, 4096 bytes of ROM
    Port 3 is a parallel I/O port with two control lines
    Port 4 is a parallel I/O port
Expanded Non-Multiplexed (Mode 5)
    192 bytes of RAM, 4096 bytes of ROM
    256 bytes of external memory space
    Port 3 is an 8-bit data bus
    Port 4 is an input port/address bus
Expanded Multiplexed (Modes 0, 1, 2, 3, 6*
    Four memory space options (total 64K address space)
        (1) Internal RAM and ROM with partial address bus (mode 1)
        (2) Internal RAM, no ROM (mode 2)
        (3) Extended addressing of internal I/O and RAM
        4) Internal RAM and ROM with partial address bus (mode 6)
    Port 3 is multiplexed address/data bus
    Port 4 is address bus (inputs/address in mode 6)
    Test mode (mode 0):
        May be used to test internal RAM and ROM
        May be used to test ports }3\mathrm{ and 4 as I/O ports by writing into mode }
    Only modes 5, 6, and 7 can be irreversibly entered from mode 0
Resources Common to All Modes
    Reserved register area
    Port }1\mathrm{ input/output operation
    Port 2 input/output operation
    Timer operation
    Serial communications interface operation
```

*The EF6803U4 operates only in modes 2 and 3.


FIGURE 10 - SINGLE-CHIP DUAL PROCESSOR CONFIGURATION


## EF6801U4 EXPANDED NON-MULTIPLEXED MODE (5)

- A modest amount of external memory space is provided in the expanded non-multiplexed mode while significant onchip resources are retained. Port 3 functions as an 8-bit bidirectional data bus and port 4 is configured initially as an input data port. Any combination of the eight least significant address lines may be obtained by writing to the port 4 data direction register. Stated alternatively, any combination of A0 to A7 may be provided while retaining the remainder as input data lines. Internal pullup resistors pull the port 4 lines high until the port is configured.

Figure 11 illustrates a typical system configuration in the expanded non-multiplexed mode. The MCU interfaces directly with EF6800 family parts and can access 256 bytes of external address space at $\$ 100$ through $\$ 1 \mathrm{FF}$. IOS provides an address decode of external memory (\$100-\$1FF) and can be used as a memory-page select or chip-select ti ne.

EXPANDED MULTIPLEXED MODES $(0,1,2,3,6)-A$ 64 K byte memory space is provided in the expanded multiplexed modes. In each of the expanded multiplexed modes, port 3 functions as a time multiplexed address/data bus with address valid on the negative edge of address strobe (AS) and data valid while $E$ is high. In modes 0,2 , and 3 , port 4 provides address lines A8 to A15. In modes 1 and 6, however, port 4 initially is configured at reset as an input data port. The port 4 data direction register can then be changed to provide any combination of address lines A8 to A15. Stated alternatively, any subset of A8 to A15 can be provided while retaining the remaining port 4 lines as input data lines. Internal pullup resistors pull the port 4 lines high until software configures the port. In mode 1, the internal pullup resistors will hold the upper address lines high producing a value of $\$ F F X X$ for a reset vector. A simple method of getting the desired address lines configured as outputs is to have an external EPROM not fully decoded so it appears at
two address locations (ו.e.. $\$ F X X X$ and $\$ B X X X$ ). Then, when the reset vector appears as \$FFFE, the EPROM will be accessed and can point to an address in the top $\$ 100$ bytes of the internal or external ROM/EPROM that will configure port 4 as desired.

In mode 0, the reset and interrupt vectors are located at \$BFFO-\$BFFF. In addition, the internal and external data buses are connected, so there must be no memory map overlap in order to avord potential bus conflicts. By writing the PC0-PC2 bits in the port 2 data register, modes 5,6 , and 7 can be irreversibly entered from mode 0 . Mode 0 is used
primarily to verify the ROM pattern and monitor the internal data bus with the automated test equipment.

Only the EF6801U4 can operate in each of the expanded multiplexed modes. The EF6803U4 operates only in modes 2 and 3 .

Figure 12 depicts a typical configuration for the expanded multiplexed modes. Address strobe can be used to control a transparent D-type latch to capture addresses A0-A7, as shown in Figure 13. This allows port 3 to function as a data bus when $E$ is high.

FIGURE 11 - EXPANDED NON-MULTIPLEXED CONFIGURATION


FIGURE 12 - EXPANDED MULTIPLEXED CONFIGURATION


NOTE To avoid data bus (port 3) contention in the expanded multiplexed modes, memory devices should be enabled only during E high time


## PROGRAMMING THE MODE

The operating mode is determined at $\overline{\text { RESET }}$ by the levels asserted on P22, P21, and P20. These levels are latched into $\mathrm{PC} 2, \mathrm{PC} 1$, and PC0 of the program control register on the positive edge of $\overline{\mathrm{RESET}}$. The operating mode may be read from the port 2 data register, as shown below, and programming levels and timing must be met as shown in Figure 14. A brief outline of the operating modes is shown in Table 3.

PORT 2 DATA REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PC 2 | $\mathrm{PC1}$ | PCO | P 24 | P 23 | P 22 | P 21 | P 20 |

Circuitry to provide the programming levels is dependent primarily on the normal system usage of the three pins. If configured as outputs, the circuit shown in Figure 15 may be used; otherwise, three-state buffers can be used to provide isolation while programming the mode.

## MEMORY MAPS

The EF6801U4/EF6803U4 can provide up to 64 K byte address space depending on the operating mode. A memory map for each operating mode is shown in Figure 16. The first 32 locations of each map are reserved for the internal register area, as shown in Table 4, with exceptions as indicated.


MODE PROGRAMMING (Refer to Figure 14)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Mode Programming Input Voltage Low | $V_{\text {MPL }}$ | - | 1.8 | V |
| Mode Programming Input Voltage High | $\mathrm{V}_{\text {MPH }}$ | 4.0 | - | V |
| Mode Programming Diode Differential (if Diodes are Used) | $V_{\text {MPDD }}$ | 0.6 | - | V |
| RESET Low Pulse Width | PW ${ }_{\text {RSTL }}$ | 3.0 | - | E Cycles |
| Mode Programming Setup Time | ${ }_{\text {t MPS }}$ | 2.0 | - | E Cycles |
| Mode Programming Hold Time RESET Rise Time $\geq 1 \mu \mathrm{~s}$ $\overline{\text { RESET Rise Time }<1 \mu \mathrm{~s}}$ | ${ }^{\text {t MPH }}$ | $\begin{gathered} 0 \\ 100 \end{gathered}$ | - | ns |

table 3 - MOde selection summary
$\left.\begin{array}{|c|c|c|c|c|c|c|c|c|}\hline \text { Mode* } & \text { P22 } & \text { P21 } & \text { P20 } & \text { PC1 } & \text { PC0 } & \text { ROM } & \text { RAM } & \begin{array}{c}\text { Interrupt } \\ \text { Vectors }\end{array} \\ \hline 7 & \text { H } & \text { H } & \text { H } & \text { l } & \text { I } & \text { Bus } \\ \text { Mode }\end{array}\right]$

## LEGEND

I - Internal
E - External
MUX - Multiplexed
NMUX - Non-Multiplexed
L - Logic " 0 "
$H-\operatorname{Logic}$ " 1 "
NOTES:

1. Addresses associated with ports 3 and 4 are considered external in modes $0,1,2$, and 3
2. Addresses associated with port 3 are considered external in modes 5 and 6 .
3. Port 4 default is user data input; address output is optional by writing to port 4 data direction register
4. Mode 4 is a non-user mode and should not be used as an operating mode.
5. Mode 3 has the internal RAM and internal registers relocated at \$D000-\$DOFF

* The EF6803U4 operates only in modes 2 and 3.

FIGURE 15 - TYPICAL MODE PROGRAMMING CIRCUIT


FIGURE 16 - EF6801U4/EF6803U4 MEMORY MAPS (Sheet 1 of 4)


NOTES:

1) Excludes the following addresses which may be used externally: $\$ 04, \$ 05, \$ 06, \$ 07$, and \$OF.
2) The interrupt vectors are at $\$ B F F 0-\$ B F F F$.
3) There must be no overlapping of internal and external memory spaces to avoid driving the data bus with more than one device.
4) This mode is the only mode which may be used to examine the entire ROM using an external $\overline{\operatorname{RESET}}$ vector.
5) Modes 5-7 can be irreversibly entered from mode 0 by writing to the PCO-PC2 bits of the port 2 data register.


FIGURE 16 - EF6801U4/EF6803U4 MEMORY MAPS (Sheet 3 of 4)


FIGURE 16 - EF6801U4/EF6803U4 MEMORY MAPS (Sheet 4 of 4)


TABLE 4 - INTERNAL REGISTER AREA

| Register | Address |  |
| :---: | :---: | :---: |
|  | Other <br> Modes | Mode 3 |
| Port 1 Data Direction Regrster * ** | 0000 | D000 |
| Port 2 Data Drection Register * ** | 0001 | D001 |
| Port 1 Data Register | 0002 | D002 |
| Port 2 Data Register | 0003 | D003 |
| Port 3 Data Direction Register * ** | 0004* | D004* |
| Port 4 Data Direction Register*** | 0005* * | D005** |
| Port 3 Data Register | 0006* | D006* |
| Port 4 Data Register | 0007** | D007** |
| Timer Control and Status Register | 0008 | D008 |
| Counter (High Byte) | 0009 | D009 |
| Counter (Low Byte) | 000A | D00A |
| Output Compare Register (High Byte) | 000B | D00B |
| Output Compare Register (Low Byte) | 000C | D00C |
| Input Capture Register (High Byte) | 000D | DOOD |
| Input Capture Register (Low Byte) | O00E | DOOE |
| Port 3 Control and Status Register | 000F* | D00F* |
| Rate and Mode Control Register | 0010 | D010 |
| Transmit/Receive Control and Status Register | 0011 | D011 |
| Receive Data Register | 0012 | D012 |
| Transmit Data Register | 0013 | D013 |
| RAM Control Register | 0014 | D014 |
| Counter Alternate Address (High Byte) | 0015 | D015 |
| Counter Alternate Address (Low Byte) | 0016 | D016 |
| Timer Control Register 1 | 0017 | D017 |
| Timer Control Register 2 | 0018 | D018 |
| Timer Status Register | 0019 | D019 |
| Output Compare Register 2 (High Byte) | 001A | D01A |
| Output Compare Register 2 (Low Byte) | 001B | D01B |
| Output Compare Register 3 (High Byte) | 001C | D01C |
| Output Compare Register 3 (Low Byte) | 001 D | D01D |
| Input Capture Register 2 (High Byte) | 001 E | D01E |
| Input Capture Register 2 (Low Byte) | 001F | D01F |

* External addresses in modes $0,1,2,3,5$, and 6 cannot be accessed in mode 5 (no IOS).
*     * External Addresses in Modes 0, 2, and 3.
$* * * 1=$ Output, $0=$ Input


## EF6801U4/EF6803U4 INTERRUPTS

The EF6801 Family supports two types of interrupt requests: maskable and non-maskable. A non-maskable interrupt ( $\overline{\mathrm{NM}}$ ) is always recognized and acted upon at the com. pletion of the current instruction. Maskable interrupts are controlled by the condition code register I bit and by in dividual enable bits. The I bit controls all maskable inter rupts. Of the maskable interrupts, there are two types: $\overline{\text { RQ1 }}$ and $\overline{\mathrm{RQ} 2}$. The programmable timer and serial communica. tions interface use an internal $\overline{\mathbb{R Q 2}}$ interrupt line, as shown in the block diagram. External devices and IS3 use $\overline{\mathrm{RQ} 1}$. An $\overline{\mathrm{RQ1}}$ interrupt is serviced before $\overline{\mathrm{RQ2}}$ if both are pending

## NOTE

After reset, an $\overline{\mathrm{NMI}}$ will not be serviced until the first program load of the stack pointer. Any $\overline{\mathrm{NMI}}$ generated before this load will be remembered by the processor and serviced subsequent to the stack pointer load

All $\overline{\mathrm{RQQ2}}$ interrupts use hardware prioritized vectors. The single SCl interrupt and three timer interrupts are serviced in a prioritized order and each is vectored to a separate location. All interrupt vector locations are shown in Table 5. In mode 0 , reset and interrupt vectors are defined as $\$ B F F 0$. \$BFFF.

The interrupt flowchart is depicted in Figure 17 and is common to every interrupt excluding reset. During interrupt servicing, the program counter, index register, A accumulator, B accumulator, and condition code register are pushed to the stack. The I bit is set to inhibit maskable interrupts and a vector is fetched corresponding to the current highest priority interrupt. The vector is transferred to the program counter and instruction execution is resumed. Interrupt and $\overline{\text { RESET }}$ timing are illustrated in Figures 18 and 19.

TABLE 5 - MCU INTERRUPT VECTOR LOCATIONS

| Mode 0 |  | Modes 1-3, 5-7 |  | Interrupt * * |
| :---: | :---: | :---: | :---: | :---: |
| MSB | LSB | MSB | LSB |  |
| BFFE | BFFF | FFFE | FFFF | $\overline{\text { RESET }}$ |
| BFFC | BFFD | FFFC | FFFD | Non-Maskable Interrupt * * |
| BFFA | BFFB | FFFA | FFFB | Software Interrupt |
| BFF8 | BFF9 | FFF8 | FFF9 | Maskable Interrupt Request 1 |
| BFF6 | BFF7 | FFF6 | FFF7 | Input Capture Flag* |
| BFF4 | BFF5 | FFF4 | FFF5 | Output Compare Flag* |
| BFF2 | BFF3 | FFF2 | FFF3 | Timer Overflow Flag* |
| BFFO | BFF1 | FFFO | FFF1 | Serial Communications Interface* |
| * $\overline{\mathrm{RQ} 2}$ interrupt <br> * $\overline{\text { NMI }}$ must be armed (by accessng stack pointer) before an <br> $\overline{\mathrm{NMI}}$ is executed. <br> * Mode 4 interrupt vectors are undefined. |  |  |  |  |
|  |  |  |  |  |  |

FIGURE 17 - INTERRUPT FLOWCHART



FIGURE 19 －－$\overline{\text { RESET TIMING }}$


Internal R $\bar{W}$

ぞローソ
Internal
Data Bus

$\triangle J 1 J$ not Valid

## FUNCTIONAL PIN DESCRIPTIONS

## VCC AND VSS

$\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$ provide power to a large portion of the MCU. The power supply should provide +5 volts $( \pm 5 \%)$ to $V_{C C}$ and $V_{S S}$ should be tied to ground. Total power dissipation (including $V_{C C}$ standby) will not exceed $P_{D}$ milliwatts.

## $V_{C C}$ STANDBY

$V_{\text {CC }}$ standby provides power to the standby portion $1 \$ 40$ through $\$ 5 F$ in all modes except mode 3 which is \$D040 through \$D05F) of the RAM and the STBY PWR and RAME bits of the RAM control register. Voltage requirements depend on whether the device is in a power-up or power-down state. In the power-up state, the power supply should provide +5 volts ( $\pm 5 \%$ ) and must reach $V_{S B}$ volts before $\overline{R E S E T}$ reaches 4.0 volts. During power down, $V_{C C}$ standby must remain above $V_{S B B}$ (minimum) to sustain the standby RAM and STBY PWR bit. While in power-down operation, the standby current will not exceed ISBB.

It is typical to power both $V_{C C}$ and $V_{C C}$ standby from the same source during normal operation. A diode must be used between them to prevent supplying power to $\mathrm{V}_{\mathrm{CC}}$ during power-down operation.

## XTAL1 AND EXTAL 2

These two input pins interface either a crystal or TTLcompatible clock to the MCU internal clock generator. Divide-by-four circuitry is included which allows use of the inexpensive 3.58 MHz or 4.4336 MHz color burst TV crystals. A 20 pF capacitor should be tied from each crystal pin to ground to ensure reliable startup and operation. Alternatively, EXTAL2 may be driven by an external TTL-compatible clock at $4 f_{0}$ with a duty cycle of $50 \%( \pm 5 \%)$ with XTAL1 connected ground.

The internal oscillator is designed to interface with an ATcut quartz crystal resonator operated in parallel resonance mode in the frequency range specified for fXTAL. The crystal should be mounted as close as possible to the input pins to minimize output distortion and startup stabilization time. The MCU is compatible with most commercially available crystals. Nominal crystal parameters are shown in Figure 20.

## RESET

This input is used to reset the internal state of the device and provide an orderly startup procedure. During power up, $\overline{R E S E T}$ must be held below 0.8 volt : (1) at least tRC after $V_{C C}$ reaches 4.75 volts in order to provide sufficient time for the clock generator to stabilize, and (2) until $V_{C C}$ standby reaches 4.75 volts. $\overline{R E S E T}$ must be held low at least three $E$ cycles if asserted during power-up operation.

## E (ENABLE)

This is an output clock used primarily for bus synchronization. It is TTL compatible and is the slightly skewed divide-by-four result of the device input clock frequency. It will drive one Schottky TTL load and 90 pF , and all data given in cycles is referenced to this clock unless otherwise noted.

## $\overline{\text { NMI }}$ (NON-MASKABLE INTERRUPT)

$\mathrm{An} \overline{\mathrm{NMI}}$ negative edge requests an MCU interrupt sequence, but the current instruction will be completed before
it responds to the request. The MCU will then begin an interrupt sequence. Finally, a vector is fetched from \$FFFC and \$FFFD (\$BFFC and \$BFFD in mode 0), transferred to the program counter, and instruction execution is resumed. $\overline{\mathrm{NMI}}$ typically requires a $3.3 \mathrm{k} \mathrm{\Omega}$ (nominal) resistor to $\mathrm{V}_{\mathrm{CC}}$. There is no internal $\overline{\mathrm{NMI}}$ pullup resistor. $\overline{\mathrm{NMI}}$ must be held low for at least one E cycle to be recognized under all conditions.

## NOTE

After reset, an $\overline{\mathrm{NMI}}$ will not be serviced until the first program load of the stack pointer. Any $\overline{\mathrm{NMI}}$ generated before this load will remain pending by the processor.

## $\overline{\operatorname{IRO1}}$ (MASKABLE INTERRUPT REQUEST 1)

$\overline{\mathrm{RQ1}}$ is a level-sensitive input which can be used to request an interrupt sequence. The MPU will complete the current instruction before it responds to the request. If the interrupt mask bit (l bit) in the condition code register is clear, the MCU will begin an interrupt sequence. A vector is fetched from \$FFF8 and \$FFF9 (\$BFF8 and \$BFF9 in mode 0), transferred to the program counter, and instruction execution is resumed.

IRO1 typically requires an external $3.3 \mathrm{k} \Omega$ (nominal) resistor to $\mathrm{V}_{\mathrm{CC}}$ for wire-OR applications. $\overline{\mathrm{RQ1}}$ has no internal pullup resistor.

## SC1 AND SC2 (STROBE CONTROL 1 AND 2)

The function of SC1 and SC2 depends on the operating mode. SC1 is configured as an output in all modes except single-chip mode, whereas SC2 is always an output. SC1 and SC2 can drive one Schottky load and 90 pF .

SC1 AND SC2 IN SINGLE-CHIP MODE - In single-chip mode, SC1 and SC2 are configured as an input and output, respectively, and both function as port 3 control lines. SC1 functions as IS3 and can be used to indicate that port 3 input data is ready or output data has been accepted. Three options associated with IS3 are controlled by the port 3 control and status register and are discussed in the port 3 description; refer to P30-P37 (PORT 3). If unused, IS3 can remain unconnected.
SC2 is configured as OS3 and can be used to strobe out put data or acknowledge input data. It is controlled by output strobe select (OSS) in the port 3 control and status register. The strobe is generated by a read (OSS $=0$ ) or write (OSS = 1) to the port 3 data register. OS3 timing is shown in Figure 3.

SC1 AND SC2 IN EXPANDED NON-MULTIPLEXED
MODE - in the expanded non-multiplexed mode, both SC1 and SC2 are configured as outputs. SC1 functions as input/output select (IOS) and is asserted only when $\$ 0100$ through \$01FF is sensed on the internal address bus.
SC2 is configured as read/write and is used to control the direction of data bus transfers. An MPU read is enabled when read/write and E are high.

SC1 AND SC2 IN EXPANDED MULTIPLEXED MODE In the expanded multiplexed modes, both SC1 and SC2 are configured as outputs. SC1 functions as address strobe and can be used to demultiplex the eight least significant addresses and the data bus. A latch controlled by address strobe captures the lower address on the negative edge, as shown in Figure 13.

## FIGURE 20 - EF6801U4/EF6803U4 FAMILY OSCILLATOR CHARACTERISTICS

(a) Nominal Recommended Crystal Parameters

| Nominal Crystal Parameters* |  |
| :---: | :---: | :---: | :---: |
|  3.58 MHz 4.00 MHz <br> RS $60 \Omega$ $50 \Omega$ <br> C0 3.5 pF 6.5 pF <br> C1 0.015 pF 0.025 pF <br> Q $>40 \mathrm{~K}$ $>30 \mathrm{~K}$ | $0.01-0.02 \mathrm{pF}$ |

*NOTE: These are representative AT-cut crystal parameters only Crystals of other types of cut may also be used

$C_{L}=20 \mathrm{pF}$ (typical)


Equivalent Circuit
(b) Oscillator Stabilization Time ( $\mathrm{t}_{\mathrm{RC}}$ )


SC2 is configured as read/write and is used to control the direction of data bus transfers. An MPU read is enabled when read/write and E are high.

## P10-P17 (PORT 1)

Port 1 is a mode independent 8 -bit $1 / 0$ and timer port. Each line can be configured as either an input or output as defined by the port 1 data direction register. Port 1 bits 0,1 , and 2 ( $\mathrm{P} 10, \mathrm{P} 11$, and P 12 ) can also be used to exercise one input edge function and two output compare functions of the timer. The TTL compatible three-state buffers can drive one Schottky TTL load and 30 pF , Darlington transistors, or CMOS devices using external pullup resistors. It is configured as a data input port during $\overline{\text { RESET. Unused pins can }}$ remain unconnected.

## P20-P24 (PORT 2)

Port 2 is a mode-independent, 5 -bit, multipurpose 1/O port. The voltage levels present on P20, P21, and P22 on the rising edge of RESET determine the operating mode of the MCU. The entire port is then configured as a data input port. The port 2 lines can be selectively configured as data output lines by setting the appropriate bits in the port 2 data direction register. The port 2 data register is used to move data through the port. However, if P21 is configured as an output, it is tied to the timer output compare 1 function and cannot be used to provide output from the port 2 data register unless output enable 1 (OE1) is cleared in timer control register 1.
Port 2 can also be used to provide an interface for the serial communications interface and the timer input edge function. These configurations are described in SERIAL COMMUNICATIONS INTERFACE and PROGRAMMABLE TIMER.

The port 2 three-state TTL-compatible output buffers are capable of driving one Schottky TTL load and 30 pF , or CMOS devices using external pullup resistors.

PORT 2 DATA REGISTER.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{PC2}$ | PC 1 | PCO | P 24 | P 23 | P 22 | P 21 | P 20 |

## P30-P37 (PORT 3)

Port 3 can be configured as an I/O port, a bidirectional 8 -bit data bus, or a multiplexed address/data bus depending on the operating mode. The TTL compatible three-state output buffers can drive one Schottky TTL load and 90 pF . Unused lines can remain unconnected.

PORT 3 IN SINGLE-CHIP MODE - Port 3 is an 8 -bit I/O port in the single-chip mode with each line configured by the port 3 data direction register. There are also two lines, IS3 and OS3, which can be used to control port 3 data transfers.
Three port 3 options are controlled by the port 3 control and status register and are available only in single-chip mode: 1) port 3 input data can be latched using IS3 as a control signal, 2) OS3 can be generated by either an MPU read or write to the port 3 data register, and 3) an $\overline{\mathrm{RO1}}$ interrupt can be enabled by an IS3 negative edge. Port 3 latch timing is shown in Figure 4.

PORT 3 CONTROL AND STATUS REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IS3 <br> Flag | $\frac{\text { IS3 }}{\text { IRO1 }}$ | $\times$ | OSS | Latch <br> Enable | $\times$ | $\times$ | $\times$ |

Bits 0-2 Not used.
Bit 3 Latch Enable - This bit controls the input latch for port 3. If set, input data is latched by an IS3 negative edge. The latch is transparent after a read of the port 3 data register. Latch enable is cleared during reset.
Bit 4 OSS (Output Strobe Select) - This bit determines whether OS3 will be generated by a read or write of the port 3 data register. When clear, the strobe is generated by a read; when set, it is generated by a write. OSS is cleared during reset.
Bit 5 Not used.
Bit 6 IS3 $\overline{\mathrm{RO} 1}$ Enable - When set, an $\overline{\mathrm{TRO1}}$ interrupt will be enabled whenever the IS3 flag is set; when clear, the interrupt is inhibited. This bit is cleared during reset.
Bit 7 IS3 Flag - This read-only status bit is set by an IS3 negative edge. It is cleared by a read of the port 3 data register or during reset.

PORT 3 IN EXPANDED NON-MULTIPLEXED MODE Port 3 is configured as a bidirectional data bus (D7-D0) in the expanded non-multiplexed mode. The direction of data transfers is controlled by read/write (SC2). Data is clocked by E (enable).

PORT 3 IN EXPANDED MULTIPLEXED MODE - Port 3 is configured as a time multiplexed address (A7-AO) and data bus (D7-DO) in the expanded multiplexed mode where address strobe (AS) can be used to demultiplex the two buses. Port 3 is held in a high-impedance state between valid address and data to prevent bus conflicts.

## P40-P47 (PORT 4)

Port 4 is configured as an 8 -bit I/O port, as address outputs, or as data inputs depending on the operating mode. Port 4 can drive one Schottky TTL load and 90 pF , and is the only port with internal pullup resistors. Unused lines can remain unconnected.

PORT 4 IN SINGLE-CHIP MODE - In single-chip mode, port 4 functions as an 8 -bit I/O port with each line configured by the port 4 data direction register. Internal pullup resistors allow the port to directly interface with CMOS at 5 -volt levels. External pullup resistors to more than 5 volts, however, cannot be used.

PORT 4 IN EXPANDED NON-MULTIPLEXED MODE Port 4 is configured from reset as an 8 -bit input port where the port 4 data direction register can be written to provide any or all of eight address lines AO to A7. Internal pullup resistors pull the lines high until the port 4 data direction register is configured.

PORT 4 IN EXPANDED MULTIPLEXED MODE - In all expanded multiplexed modes except modes 1 and 6 , port 4 functions as half of the address bus and provides A8 to A15. In modes 1 and 6, the port is configured from reset as an 8 -bit parallel input port where the port 4 data direction register can be written to provide any or all of upper address lines A8 to A15. Internal pullup resistors pull the lines high until the port 4 data direction register is configured where bit 0 controls A8.

## RESIDENT MEMORY

The EF6801U4 provides 4096 bytes of on-chip ROM and 192 bytes of on-chip RAM.

Thirty-two bytes of the RAM are powered through the $V_{C C}$ standby pin and are maintainable during $V_{C C}$ power down. This standby portion of the RAM consists of 32 bytes located from $\$ 40$ through $\$ 5 \mathrm{~F}$ in all modes except mode 3 which is \$D040 through \$D05F.

Power must be supplied to $\mathrm{V}_{\mathrm{CC}}$ standby if the internal RAM is to be used regardless of whether standby power operation is anticipated.
The RAM is controlled by the RAM control register.

## RAM CONTROL REGISTER ( $\$ 14$ )

The RAM control register includes two bits which can be used to control RAM accesses and determine the adequacy of the standby power source during power-down operation. It is intended that RAME be cleared and STBY PWR be set as part of a power-down procedure.

RAM CONTROL REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STBY <br> PWR | RAME | $X$ | $X$ | $X$ | $X$ | $X$ | $X$ |

Bits 0-5 Not used.
Bit 6 RAM Enable - This read/write bit can be used to remove the entire RAM from the internal memory map. RAME is set (enabled) during reset provided standby power is available on the positive edge of $\overline{R E S E T}$. If RAME is clear, any access to a RAM address is external. If RAME is set, the RAM is included in the internal map.
Bit 7 Standby Power - This bit is a read/write status bit which when cleared indicates that $\mathrm{V}_{\mathrm{CC}}$ standby has decreased sufficiently below $\mathrm{V}_{\text {SBB }}$ (minimum) to make data in the standby RAM suspect. It can be set only by software and is not affected during reset.

## PROGRAMMABLE TIMER

The programmable timer can be used to perform measurements on two separate input waveforms while independently generating three output waveforms. Pulse widths can vary from several microseconds to many seconds. A block diagram of the timer is shown in Figure 21.

## COUNTER ( $\$ 09: 0 \mathrm{~A}$ ), ( $\$ 15, \$ 16$ )

The key timer element is a 16 -bit free-running counter
which is incremented by $E$ (enable). It is cleared during reset and is read-only with one exception: in mode 0 a write to the counter ( $\$ 09$ ) will configure it to $\$ F F F 8$. This feature, intended for testing, can disturb serial operations because the counter provides the SCl internal bit rate clock. The TOF is set whenever the counter contains all ones. If ETOI is set, an interrupt will occur when the TOF is set. The counter may also be read as $\$ 15$ and $\$ 16$ to avoid inadvertently clearing the TOF.

## OUTPUT COMPARE REGISTERS (\$0B:OC), (\$1A:1B), (\$1C:1D)

The three output compare registers are 16 -bit read/write registers, each used to control an output waveform or provide an arbitrary time-out flag. They are compared with the free-running counter during the negative half of each E . cycle. When a match occurs, the corresponding output compare flag (OCF) is set and the corresponding output level (OLVL) is clocked to an output level register. If both the corresponding output enable bit and data direction register bit are set, the value represented in the output level register will appear on the corresponding port pin. The appropriate OLVL bit can then be changed for the next compare.

The function is inhibited for one cycle after a write to its high byte ( $\$ 0 \mathrm{~B}, \$ 1 \mathrm{~A}$, or $\$ 1 \mathrm{C}$ ) to ensure a valid compare after a double byte write. Writes can be made to either byte of the output compare register without affecting the other byte. The OLVL value will be clocked out independently of whether the OCF had previously been cleared. The output compare registers are set to \$FFFF during reset.

## INPUT CAPTURE REGISTERS (\$0D:0E), ( $\$ 1 \mathrm{E}: 1 \mathrm{~F}$ )

The two input capture registers are 16 -bit read-only registers used to store the free-running counter when a "proper" input transition occurs as defined by the corresponding input edge bit (IEDG1 or IEDG2). The input pin's data direction register should be configured as an input, but the edge detect circuit always senses P 10 and P 20 even when configured as an output. The counter value will be latched into the input capture registers on the second negative edge of the E clock following the transition.
An input capture can occur independently of ICF; the register always contains the most current value. Counter transfer is inhibited, however, between accesses of a double byte MPU read. The input pulse width must be at least two $E$ cycles to ensure an input capture under all conditions.

## TIMER CONTROL AND STATUS REGISTERS

Four registers are used to provide the EF6801U4/ EF6803U4 with control and status information about the three output compare functions, the timer overflow function, and the two input edge functions of the timer. They are:

Timer Control and Status Register (TCSR)
Timer Control Register 1 (TCR1)
Timer Control Register 2 (TCR2)
Timer Status Register (TSR)


TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08) - The timer control and status register is an 8 -bit register of which all bits are readable, while only bits $0-4$ can be written. All the bits in this register are also accessible through the two timer control registers and the timer status register. The three most significant bits provide the timer status and indicate if:

1. a proper level transition has been detected at $P 20$,
2. a match has occurred between the free-running c.ounter and output compare register 1 , or
3. the free-running counter has overflowed.

Each of the three events can generate an $\overline{\mathrm{RQ} 2}$ interrupt and is controlled by an individual enable bit in the TCSR.

## TIMER CONTROL AND STATUS REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICF1 | OCF1 | TOF | EICII | EOCI1 | ETOI | IEDG1 | OLVL1 |

Bit 0 Output Level 1 - OLVL1 is clocked to output level register 1 by a successful output compare and will appear at P21 if bit 1 of the port 2 data direction register is set and the OE1 control bit in timer control register 1 is set. OLVL1 and output level register 1 are cleared during reset. Refer to TIMER CONTROL REGISTER 1 (TCR1) (\$17).

Bit 1 Input Edge 1 - IEDG1 is cleared during reset and controls which level transition on P20 will trigger a counter transfer to input capture register 1 :

IEDG1 $=0$ transfer on a negative-edge
IEDG1 = 1 transfer on a positive-edge
Refer to TIMER CONTROL REGISTER 1 (TCR1) (\$17).
Bit 2 Enable Timer Overflow Interrupt - Wheñ set, an IRQ2 interrupt will be generated when the timer overflow flag is set; when clear, the interrupt is inhibited. ETOI is cleared during reset. Refer to TIMER CONTROL REGISTER 2 (TCR2) (\$18).

Bit 3 Enable Output Compare Interrupt 1 - When set, an $\overline{\mathrm{RQ2}}$ interrupt will be generated when output compare flag 1 is set; when clear, the interrupt is inhibited. EOCII is cleared during reset. Refer to TIMER CONTROL REGISTER 2 (TCR2) (\$18).
Bit 4 Enable Input Capture Interrupt 1 - When set, an $\overline{\text { IRQ2 }}$ interrupt will be generated when input capture flag 1 is set; when clear, the interrupt is inhibited. EICI1 is cleared during reset. Refer to TIMER CONTROL REGISTER 2 (TCR2) (\$18).

Bit 5 Timer Overflow Flag - The TOF is set when the counter contains all ones ( $\$ F F F F$ ). It is cleared by reading the TCSR or the TSR (with TOF set) and the counter high byte ( $\$ 09$ ), or during reset. Refer to TIMER STATUS REGISTER (TSR) (\$19).
Bit 6 Output Compare Flag 1 - OCF1 is set when output compare register 1 matches the free-running counter. OCF1 is cleared by reading the TCSR or the TSR (with OCF1 set) and then writing to output compare register 1 ( $\$ 0 B$ or $\$ 0 C$ ), or during reset. Refer to TIMER STATUS REGISTER (TSR) (\$19).

Bit 7 Input Capture Flag - ICF1 is set to indicate that a proper level transition has occurred; it is cleared by reading the TCSR or the TSR (with ICF1 set) and the input capture register 1 high byte (\$OD), or during reset. Refer to TIMER STATUS REGISTER (TSR) (\$19).

TIMER CONTROL REGISTER 1 (TCR1) (\$17) - Timer control register 1 is an 8 -bit read/write register which contains the control bits for interfacing the output compare and input capture registers to the corresponding $1 / 0$ pins.

| TIMER CONTROL REGISTER 1 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| OE3 | OE2 | OE1 | IEDG2 | IEDG1 | OLVL3 | OLVL2 | OLVL1 |

$\$ 17$

Bit 0 Output Level 1 - OLVL1 is clocked to output level register 1 by a successful output compare and will appear at P21 if bit 1 of the port 2 data direction register is set and the OE1 control bit is set. OLVL1 and output level register 1 are cleared during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).
Bit 1 Output Level 2 - OLVL2 is clocked to output level register 2 by a successful output compare and will appear at P11 if bit 1 of port 1 data direction register is set and the OE2 control bit is set. OLVL2 and output level register 2 are cleared during reset.
Bit 2 Output Level 3 - OLVL3 is clocked to output level register 3 by a successful output compare and will appear at P12 if bit 2 of port 1 data direction register is set and the OE3 control bit is set. OLVL3 and output level register 3 are cleared during reset.

Bit 3 Input Edge 1 - IEDG1 is cleared during reset and controls which level transition on P20 will trigger a counter transfer to input capture register 1.
|EDG1 $=0$ transfer on a negative-edge
IEDG1=1 transfer on a positive-edge
Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).
Bit 4 Input Edge 2 - IEDG2 is cleared during reset and controls which level transition on P10 will trigger a counter transfer to input capture register 2.

IEDG2 $=0$ transfer on a negative-edge
IEDG2 $=1$ transfer on a positive-edge
Bit 5 Output Enable 1 - OE1 is set during reset and enables the contents of output level register 1 to be connected to P21 when bit 1 of port 2 data direction register is set.

OE1 $=0$ port 2 bit 1 data register output
OE1 = 1 output level register 1
Bit 6 Output Enable 2 - OE2 is cleared during reset and enables the contents of output level register 2 to be connected to P11 when bit 1 of port 1 data direction register is set.

OE2 $=0$ port 1 bit 1 data register output
OE2 $=1$ output level register 2

Bit 7. Output Enable 3-OE3 is cleared during reset and enables the contents of output level register 3 to be connected to P 12 when bit 2 of port 1 data direction register is set

OE3 $=0$ port 7 bit 2 data register output
OE3 $=1$ output level register 3
TIMER CONTROL REGISTER 2 (TCR2) ( $\mathbf{\$ 1 8 )}$ - Timer control register 2 is an 8 -bit read/write register (except bits 0 and 1) which enable the interrupts associated with the freerunning counter, the output compare registers, and the input capture registers. In test mode 0, two more bits (clock and test) are available for checking the timer.

## TIMER CONTROL REGISTER 2 <br> (Non-Test Modes)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $E I C I 2$ | $E I C I 1$ | $E O C I 3$ | $E O C I 2$ | $E O C I 1$ | $E T O I$ | 1 | 1 |

Bits 0-1 Read-Only Bits - When read, these bits return a value of 1 . Refer to TIMER CONTROL REGISTER 2 (Test Mode).
Bit 2 Enable Timer Overflow Interrupt - When set, an $\overline{\mathrm{RQ} 2}$ interrupt will be generated when the timer overflow flag is set; when clear, the interrupt is inhibited. ETOI is cleared during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).
Bit 3 Enable Output Compare Interrupt 1 - When set, an $\overline{\mathrm{RQ2}}$ interrupt will be generated when the output compare flag 1 is set; when clear, the interrupt is inhibited. EOCl1 is cleared during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).
Bit 4 Enable Output Compare Interrupt 2 - When set, an $\overline{\mathrm{RO} 2}$ interrupt will be generated when the output compare flag 2 is set; when clear, the interrupt is inhibited. EOCl! is cleared during reset.
Bit 5 Enable Output Compare Interrupt 3 - When set, an $\overline{\mathrm{RO} 2}$ interrupt will be generated when the output compare flag 3 is set; when clear, the interrupt is inhibited. EOCI3 is cleared during reset.
Bit 6 Enable Input Capture Interrupt 1 - When set, an $\overline{\mathrm{RO} 2}$ interrupt will be generated when the input capture flag 1 is set; when clear, the interrupt is inhibited. EICI1 is cleared during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).
Bit $7 \quad$ Enable Input Capture Interrupt 2 - When set, an $\overline{\mathrm{RQ} 2}$ interrupt will be generated when the input capture flag 2 is set; when clear, the interrupt is inhibited. EICl 2 is cleared during reset.

The timer test bits (test and clock) allow the free-running counter to be tested as two separate 8 -bit counters to speed testing.

## TIMER CONTROL REGISTER 2 (Test Mode)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EICI2 | EICI1 | EOCI3 | EOCI2 | EOCI1 | ETOI | TEST | CLOCK |

Bit 0 CLOCK - The CLOCK control bit selects which half of the 16 -bit free-running counter (MSB or LSB) should be clocked with E. The CLOCK bit is a read/write bit only in mode 0 and is set during reset.

CLOCK $=0$ - Only the eight most significant bits of the free-running counter run with $T E S T=0$.
CLOCK = 1 - Only the eight least significant bits of the free-running counter run when TEST $=0$.
Bit 1 TEST - the TEST control bit enables the timer test mode. TEST is a read/write bit in mode 0 and is set during reset.

TEST $=0$ - Timer test mode enabled:
a) The timer LSB latch is transparent which allows the LSB to be read independently of the MSB.
b) Either the MSB or the L.SB of the timer is clocked by $E$, as defined by the CLOCK bit.
TEST $=1$ - Timer test mode disabled.
Bits 2-7 See TIMER CONTROL REGISTER 2 (Non-Test Modes). (These bits function the same as in the non-test modes.)
TIMER STATUS REGISTER (TSR) (\$19) - The timer status register is an 8 -bit read-only register which contains the flags associated with the free-running counter, the output compare registers, and the input capture registers.
timer status register

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

$\$ 19$
Bits 0-1 Not used.
Bit 2 Timer Overflow Flag - The TOF is set when the counter contains all ones (\$FFFF). It is cleared by reading the TSR or the TCSR (with TOF set) and then the counter high byte ( $\$ 09$ ); or during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).

Bit 3 Output Compare Flag 1 - OCF1 is set when output compare register 1 matches the free-running counter. OCF1 is cleared by reading the TSR or the TCSR (with OCF1 set) and then writing to output compare register 1 ( $\$ O B$ or $\$ 0 C$ ), or during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).
Bit 4 Output Compare Flag 2 - OCF2 is set when output compare register 2 matches the free-running counter. OCF2 is cleared by reading the TSR (with OCF2 set) and then writing to output compare register $2(\$ 1 \mathrm{~A}$ or $\$ 1 \mathrm{~B})$, or during reset.
Bit 5 Output Compare Flag 3 - OCF3 is set when output compare register 3 matches the free-running counter. OCF3 is cleared by reading the TSR (with OCF3 set) and then writing to output compare register 3 ( $\$ 1 \mathrm{C}$ or $\$ 1 \mathrm{D}$ ), or during reset.
Bit 6 Input Capture Flag 1 - ICF1 is set to indicate that a proper level transition has occurred; it is cleared by reading the TSR or the TCSR (with ICF1 set) and the input capture register 1 high byte ( $\$ 0 \mathrm{D}$ ), or during reset. Refer to TIMER CONTROL AND STATUS REGISTER (TCSR) (\$08).

Bit 7 Input Capture Flag 2 - ICF2 is set to indicate that a proper level transition has occurred; it is cleared by reading the TSR (with ICF2 set) and the input capture register 2 high byte ( $\$ 1 \mathrm{E}$ ), or during reset.

## SERIAL COMMUNICATIONS INTERFACE

A full-duplex asynchronous serial communications interface (SCl) is provided with two data formats and a variety of rates. The SCI transmitter and receiver are functionally independent but use the same data format and bit rate. Serial data formats include standard mark/space (NRZ) and biphase and both provide one start bit, eight data bits, and one stop bit. "Baud" and "bit rate" are used synonymously in the following description.

## WAKE-UP FEATURE

In a typical serial loop multiprocessor configuration, the software protocol will usually identify the addressee(s) at the beginning of the message. In order to permit uninterested MPUs to ignore the remainder of the message, wake-up feature is included whereby all further SCl receiver flag (and interrupt) processing can be inhibited until its data line goes idle. An SCl receiver is re-enabled by an idle string of ten consecutive ones or during reset. Software must provide for
the required idle string between consecutive messages and prevent it within messages.

## PROGRAMMABLE OPTIONS

The following features of the SCI are programmable:

- Format: standard mark/space (NRZ) or bi-phase
- Clock: external or internal bit rate clock
- Baud: one of eight per $E$ clock frequency or external clock ( $\times 8$ desired baud)
- Wake-Up Feature: enabled or disabled
- Interrupt Requests: enabled individually for transmitter and receiver
- Clock Output: internal bit rate clock enabled or disabled to P22


## SERIAL COMMUNICATIONS REGISTERS

The serial communications interface includes four addressable registers as depicted in Figure 22. It is controlled by the rate and mode control register and the transmit/receive control and status register. Data is transmitted and received utilizing a write-only transmit register and a read-only receive register. The shift registers are not accessible to software.

FIGURE 22 - SCI REGISTERS


## RATE AND MODE CONTROL REGISTER (RMCR) (\$10)

- The rate and mode control register controls the SCI bit rate, format, clock source, and under certain conditions, the configuration of P22. The register consists of five write-only bits which are cleared during reset. The two least significant bits in conjunction with bit 7 control the bit rate of the internal clock and the remaining two bits control the format and clock source.

RATE AND MODE CONTROL REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EBE | x | x | x | CC 1 | CCO | SS 1 | SS 0 | $\$ 10$

Bit 1:Bit 0 SS1:SS0 Speed Select - These two bits select the baud when using the internal clock. Eight rates may be selected (in conjunction with bit 7) which are a function of the MCU input frequency. Table 6 lists bit time and rates for three selected MCU frequencies.

Bit 3:Bit 2
CC1:CCO Clock Control and Format Select These two bits control the format and select the serial clock source. If CC 1 is set, the DDR value
for P 22 is forced to the complement of CCO and cannot be altered until CC1 is cleared. If CC1 is cleared after having been set, its DDR value is unchanged. Table 7 defines the formats, clock source, and use of P22.

Bits 4-6
Not used.
EBE Enhanced Baud Enable - EBE selects the standard EF6801 baud rates when clear and the additional baud rates when set (Table 6). This bit is cleared by reset and is a write-only control bit.
$E B E=0$ standard EF6801 baud rates
$E B E=1$ additional baud rates
If both CC 1 and CCO are set, an external TTL-compatible clock must be connected to P22 at eight times $(8 \times)$ the desired bit rate, but not greater than $E$, with a duty cycle of $50 \%( \pm 10 \%)$. If $\mathrm{CC} 1: \mathrm{CC}=10$, the internal bit rate clock is provided at P22 regardless of the values for TE or RE.

## NOTE

The source of SCl internal bit rate clock is the timer free-running counter. An MPU write to the counter in mode 0 can disturb serial operations.

TABLE 6 - SCI BIT TIMES AND RATES

| EBE | SS1:SS0 |  | $4 \mathrm{f}_{0} \rightarrow$ | 2.4576 MHz |  | 4.0 MHz |  | 4.9152 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | E | 614.4 kHz |  | 1.0 MHz |  | 1.2288 MHz |  |
|  |  |  | Baud | Time | Baud | Time | Baud | Time |
| 0 | 0 | 0 |  | +16 | 38400.0 | $26 \mu \mathrm{~s}$ | 62500.0 | $16.0 \mu \mathrm{~s}$ | 76800.0 | $13.0 \mu \mathrm{~s}$ |
| 0 | 0 | 1 | + 128 | 4800.0 | $208.3 \mu \mathrm{~s}$ | 7812.5 | $128.0 \mu \mathrm{~s}$ | 9600.0 | $104.2 \mu \mathrm{~S}$ |
| 0 | 1 | 0 | +1024 | 600.0 | 1.67 ms | 976.6 | 1.024 ms | 1200.0 | $833.3 \mu \mathrm{~S}$ |
| 0 | 1 | 1 | +4096 | 150.0 | 6.67 ms | 244.1 | 4.096 ms | 300.0 | 3.33 ms |
| 1 | 0 | 0 | +64 | 9600.0 | $104.2 \mu \mathrm{~s}$ | 15625.0 | $64 \mu \mathrm{~s}$ | 19200.0 | $52.0 \mu \mathrm{~s}$ |
| 1 | 0 | 1 | +256 | 2400.0 | $416.6 \mu \mathrm{~s}$ | 3906.3 | $256 \mu \mathrm{~s}$ | 4800.0 | $208.3 \mu \mathrm{~S}$ |
| 1 | 1 | 0 | +512 | 1200.0 | $833.3 \mu \mathrm{~S}$ | 1953.1 | $512 \mu \mathrm{~s}$ | 2400.0 | $416.6 \mu \mathrm{~s}$ |
| 1 | 1 | 1 | +2048 | 300.0 | 3.33 ms | 488.3 | 2.05 ms | 600.0 | 1.67 ms |
| External (P22)* |  |  |  | 76800.0 | 13.0 \% s | 125000.0 | $8.0 \mu \mathrm{~s}$ | 153600.0 | $6.5 \mu \mathrm{~s}$ |

* Using maximum clock rate

TABLE 7 - SCI FORMAT AND CLOCK SOURCE CONTROL

| CC1:CC0 | Format | Clock <br> Source | Port 2 <br> Bit 2 |
| :---: | :---: | :---: | :---: |
| 00 | Bi-Phase | Internal | Not Used |
| 01 | NRZ | Internal | Not Used |
| 10 | NRZ | Internal | Output |
| 11 | NRZ | External | Input |

TRANSMIT/RECEIVE CONTROL AND STATUS REGISTER (TRCSR) (\$11) The transmit/receive control and status register controls the transmitter, receiver, wakeup) teature, and two individual interrupts, and monitors the status of serial operations. All eight bits are readable while bits 0 to 4 are also writable. The register is initialized to $\$ 20$ by RESET

TRANSMIT/RECEIVE CONTROL AND STATUS REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDRF | ORFE | TDRE | RIE | RE | TIE | TE | WU |

Bit 0 "Wake-Up" on Idle Line - When set, WU enables the wake-up function; it is cleared by ten consecutive ones or during reset. WU will not be set if the line is idie. Refer to WAKE-UP FEATURE.

Bit 1 Transmit Enable - When set, P24 DDR bit is set, cannot be changed, and will remain set if $T E$ is subsequently cleared. When TE is changed from clear to set, the transmitter is connected to P24 and a preamble of nine consecutive ones is transmitted. $T E$ is cleared during reset.
Bit 2 Transmit Interrupt Enable - When set, an $\overline{\mathrm{RQ} 2}$ is set; when clear, the interrupt is inhibited. TE is cleared during reset.
Bit 3 Receive Enable - When set, the P23 DDR bit is cleared, cannot be changed, and will remain clear if $R E$ is subsequently cleared. While RE is set, the SCl receiver is enabled. RE is cleared during reset.
Bit 4 Receiver Interrupt Enable - When set, an $\overline{R_{Q 2}^{2}}$ interrupt is enabled when RDRF and/or ORFE is set; when clear, the interrupt is inhibited. RIE is cleared during reset.
Bit 5 Transmit Data Register Empty - TDRE is set when the transmit data register is transferred to the output serial shift register or during reset. It is cleared by reading the TRCSR (with TDRE set) and then writing to the transmit data register. Additional data will be transmitted only if TDRE has been cleared.

Bit 6 Overrun Framing Error - If set, ORFE indicates elther an overrun or framing error. An overrun is a new byte ready to transfer to the receiver data register with RDRF still set. A receiver framing error has occurred when the byte boundaries of the bit stream are not synchronized to the bit counter. An overrun can be distinguished from a framing error by the state of RDRF: if RDRF is set, then an overrun has occurred; otherwise, a framing error has been detected. Data is not transferred to the receive data register in an overrun condition. Unframed data causing a framing error is transferred to the receive data register. However, subsequent data transfer is blocked until the framing error flag is cleared. ORFE is cleared by reading the TRCSR (with ORFE set) then the receive data register, or during reset.
Bit 7 Receive Data Register Full - RDRF is set when the input serial shift register is transferred to the receive data register, or during reset.

## SERIAL OPERATIONS

The SCl is initialized by writing control bytes first to the rate and mode control register and then to the transmit/receive control and status register. When TE is set, the output of the transmit serial shift register is connected to P24 and serial output is initiated by transmitting a 9 -bit preamble of ones.

At this point, one of two situations exists: 1 ) if the transmit data register is empty (TDRE $=1$ ), a continuous string of ones will be sent indicating an idle line; or 2 ) if a byte has been written to the transmit data register (TDRE $=0$ ), it will be transferred to the output serial shift register (synchronized with the bit rate clock), TDRE will be set, and transmission will begin.

The start bit (0), eight data bits (beginning with bit 0 ), and a stop bit (1) will be transmitted. If TDRE is still set when the next byte transfer occurs, ones will be sent until more data is provided. In bi-phase format, the output toggles at the start of each bit and at half-bit time when a one is sent. Receive operation is controlled by RE which configures P23 as an input and enables the receiver. SCl data formats are illustrated in Figure 23.

FIGURE 23 - SCI DATA FORMATS


## INSTRUCTION SET

The EF6801U4/EF6803U4 is directly source compatible with the EF6801 and upward source and object code compatible with the EF6800. Execution times of key instructions have been reduced and several instructions have been added, including a hardware multiply. A list of new operations added to the EF6800 instruction set is shown in Table 1

In addition, two special opcodes, 4 E and 5 E , are provided for test purposes. These opcodes force the program counter
to increment like a 16 -bit counter causing address lines used in the expanded modes to increment until the device is reset. These opcodes have no mnemonics
The coding of the first (or only) byte corresponding to an executable instruction is sufficient to identify the instruction and the addressing mode. The hexadecimal equivalents of the binary codes, which result from the translation of the 82 instructions in all valid modes of addressing, are shown in Table 8. There are 220 valid machine codes, 34 unassigned codes, and 2 codes reserved for test purposes

TABLE 8 - CPU INSTRUÇTION MAP

| OP | MNEM | MODE | $\sim$ | , | OP | MNEM | MODE | - | * | OP | MNEM | MODE | $\sim$ | \# | OP | MNEM | MODE | $\sim$ | * | OP | MNEM | MODE | - | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | - |  |  |  | 34 | DES | INHER | 3 | 1 | 68 | ASL | INDXD | 6 | 2 | 9C | CPX | DIR | 5 | 2 | D0 | SUBB | DIR | 3 | 2 |
| 01 | NOP | INHER | 2 | 1 | 35 | TXS | A | 3 | 1 | 69 | ROL | 4 | 6 | 2 | 9 D | JSR |  | 5 | 2 | D1 | CMPB | 4 | 3 | 2 |
| 02 | - | A |  |  | 36 | PSHA |  | 3 | 1 | 6A | DEC |  | 6 | 2 | $9 E$ | LDS | $\gamma$ | 4 | 2 | D2 | SBCB |  | 3 | 2 |
| 03 | - |  |  |  | 37 | PSHB |  | 3 | 1 | 68 | $\bullet$ |  |  |  | 9 F | STS | DIR | 4 | 2 | D3 | ADDD |  | 5 | 2 |
| 04 | LSRD |  | 3 | 1 | 38 | PULX |  | 5 | 1 | 6 C | INC |  | 6 | 2 | AO | SUBA | INDXD | 4 | 2 | D4 | ANDB |  | 3 | 2 |
| 05 | ASLD |  | 3 | 1 | 39 | RTS |  | 5 | 1 | 6D | TST |  | 6 | 2 | A1 | CMPA | A | 4 | 2 | D5 | BITB |  | 3 | 2 |
| 06 | TAP |  | 2 | 1 | 3A | $A B X$ |  | 3 | 1 | 6 E | JMP |  | 3 | 2 | A2 | SBCA |  | 4 | 2 | D6 | LDAB |  | 3 | 2 |
| 07 | TPA |  | 2 | 1 | 3B | RTI |  | 10 | 1 | 6 F | CLR | INDXD | 6 | 2 | A3 | SUBD |  | 6 | 2 | D7 | STAB |  | 3 | 2 |
| 08 | INX |  | 3 | 1 | 3C | PSHX |  | 4 | 1 | 70 | NEG | EXTND | 6 | 3 | A4 | ANDA |  | 4 | 2 | D8 | EORB |  | 3 | 2 |
| 09 | DEX |  | 3 | 1 | 3D | MUL |  | 10 | 1 | 71 | - | 4 |  |  | A5 | BITA |  | 4 | 2 | D9 | ADCB |  | 3 | 2 |
| OA | CLV |  | 2 | 1 | 3E | WAI |  | 9 | 1 | 72 | - |  |  |  | A6 | LDAA |  | 4 | 2 | DA | ORAB |  | 3 | 2 |
| OB | SEV |  | 2 | 1 | 3 F | SWI |  | 12 | 1 | 73 | COM |  | 6 | 3 | A7 | STAA |  | 4 | 2 | DB | ADDB |  | 3 | 2 |
| OC | CLC |  | 2 | 1 | 40 | NEGA |  | 2 | 1 | 74 | LSR |  | 6 | 3 | A8 | EORA |  | 4 | 2 | DC | LDD |  | 4 | 2 |
| OD | SEC |  | 2 | 1 | 41 | - |  |  |  | 75 | - |  |  |  | A9 | ADCA |  | 4 | 2 | DD | STD |  | 4 | 2 |
| OE | CLI |  | 2 | 1 | 42 | - |  |  |  | 76 | ROR |  | 6 | 3 | AA | ORAA |  | 4 | 2 | DE | LDX | V | 4 | 2 |
| OF | SEI |  | 2 | 1 | 43 | COMA |  | 2 | 1 | 77 | ASR |  | 6 | 3 | $A B$ | ADDA |  | 4 | 2 | DF | STX | DIR | 4 | 2 |
| 10 | SBA |  | 2 | 1 | 44 | LSRA |  | 2 | 1 | 78 | ASL |  | 6 | 3 | $A C$ | CPX |  | 6 | 2 | EO | SUBB | INDXD | 4 | 2 |
| 11 | CBA |  | 2 | 1 | 45 | - |  |  |  | 79 | ROL |  | 6 | 3 | AD | JSR |  | 6 | 2 | E1 | CMPB | 4 | 4 | 2 |
| 12 | - |  |  |  | 46 | RORA |  | 2 | 1 | 7A | DEC |  | 6 | 3 | $A E$ | LDS | $\downarrow$ | 5 | 2 | E2 | SBCB |  | 4 | 2 |
| 13 | - |  |  |  | 47 | ASRA |  | 2 | 1 | 78 | - |  |  |  | AF | STS | INDXD | 5 | 2 | E3 | ADDD |  | 6 | 2 |
| 14 | - |  |  |  | 48 | ASLA |  | 2 | 1 | 7 C | INC |  | 6 | 3 | BO | SUBA | EXTND | 4 | 3 | E4 | ANDB |  | 4 | 2 |
| 15 | $\bullet$ |  |  |  | 49 | ROLA |  | 2 | 1 | 70 | TST |  | 6 | 3 | B1 | CMPA | A | 4 | 3 | E5 | BITB |  | 4 | 2 |
| 16 | TAB |  | 2 | 1 | 4A | DECA |  | 2 | 1 | 7E | JMP |  | 3 | 3 | B2 | SBCA |  | 4 | 3 | E6 | LDAB |  | 4 | 2 |
| 17 | TBA |  | 2 | 1 | 4 B | - |  |  |  | 7F | CLR | EXTND | 6 | 3 | B3 | SUBD |  | 6 | 3 | E7 | STAB |  | 4 | 2 |
| 18 | - | V |  |  | 4C | INCA |  | 2 | 1 | 80 | SUBA | IMMED | 2 | 2 | B4 | ANDA |  | 4 | 3 | E8 | EORB |  | 4 | 2 |
| 19 | DAA | INHER | 2 | 1 | 4D | TSTA |  | 2 | 1 | 81 | CMPA |  | 2 | 2 | 85 | BITA |  | 4 | 3 | E9 | ADCB |  | 4 | 2 |
| 1 A | - |  |  |  | 4E | T |  |  |  | 82 | SBCA |  | 2 | 2 | B6 | LDAA |  | 4 | 3 | EA | ORAB |  | 4 | 2 |
| 1 B | ABA | INHER | 2 | 1 | 4F | CLRA |  | 2 | 1 | 83 | SUBD |  | 4 | 3 | B7 | STAA |  | 4 | 3 | EB | ADDB |  | 4 | 2 |
| 1 C | - |  |  |  | 50 | NEGB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 | B8 | EORA |  | 4 | 3. | EC | LDD |  | 5 | 2 |
| 10 | - |  |  |  | 51 | - |  |  |  | 85 | BITA |  | 2 | 2 | B9 | ADCA |  | 4 | 3 | ED | STD |  | 5 | 2 |
| 1 E | - |  |  |  | 52 | - |  |  |  | 86 | LDAA |  | 2 | 2 | BA | ORAA |  | 4 | 3 | EE | LDX | , | 5 | 2 |
| 1 F | - |  |  |  | 53 | COMB |  | 2 | 1 | 87 | - |  |  |  | BB | ADDA |  | 4 | 3 | EF | STX | INDXD | 5 | 2 |
| 20 | BRA | REL | 3 | 2 | 54 | LSRB |  | 2 | 1 | 88 | EORA |  | 2 | 2 | BC | CPX |  | 6 | 3 | FO | SUBB | EXTND | 4 | 3 |
| 21 | BRN | 4 | 3 | 2 | 55 | - |  |  |  | 89 | ADCA |  | 2 | 2 | BD | JSR |  | 6 | 3 | F1 | CMPB | A | 4 | 3 |
| 22 | BHI |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 8 A | ORAA |  | 2 | 2 | BE | LDS |  | 5 | 3 | F2 | SBCB |  | 4 | 3 |
| 23 | BLS |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 8 B | ADDA | V | 2 | 2 | BF | STS | EXTND | 5 | 3 | F3 | ADDD |  | 6 | 3 |
| 24 | BCC |  | 3 | 2 | 58 | ASLB |  | 2 | 1 | 8C | CPX | IMMED | 4 | 3 | CO | SUBB | IMMED | 2 | 2 | F4 | ANDB |  | 4 | 3 |
| 25 | BCS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 8 D | BSR | REL | 6 | 2 | C1 | CMPB | , | 2 | 2 | F5 | BITB |  | 4 | 3 |
| 26 | BNE |  | 3 | 2 | 5A | DECB |  | 2 | 1 | 8 E | LDS | IMMED | 3 | 3 | C2 | SBCB |  | 2 | 2 | F6 | LDAB |  | 4 | 3 |
| 27 | BEO |  | 3 | 2 | 5 B | - |  |  |  | 8 F | - |  |  |  | C3 | ADDD |  | 4 | 3 | F7 | STAB |  | 4 | 3 |
| 28 | BVC |  | 3 | 2 | 5 C | INCB |  | 2 | 1 | 90 | SUBA | DIR | 3 | 2 | C4 | ANDB |  | 2 | 2 | F8 | EORB |  | 4 | 3 |
| 29 | BVS |  | 3 | 2 | 50 | TSTB |  | 2 | 1 | 91 | CMPA | A | 3 | 2 | C5 | BITB |  | 2 | 2 | F9 | ADCB |  | 4 | 3 |
| 2 A | BPL |  | 3 | 2 | 5E | T | V |  |  | 92 | SBCA |  | 3 | 2 | C6 | LDAB |  | 2 | 2 | FA | ORAB |  | 4 | 3 |
| 2B | BMI |  | 3 | 2 | 5 F | CLRB | INHER | 2 | 1 | 93 | SUBD |  | 5 | 2 | C7 | - |  |  |  | F8 | ADDB |  | 4 | 3 |
| 2C | BGE |  | 3 | 2 | 60 | NEG | INDXD | 6 | 2 | 94 | ANDA |  | 3 | 2 | C8 | EORB |  | 2 | 2 | FC | LDD |  | 5 | 3 |
| 2 D | BLT |  | 3 | 2 | 61 | - | 4 |  |  | 95 | BITA |  | 3 | 2 | C9 | ADCB |  | 2 | 2 | FD | STD |  | 5 | 3 |
| 2 E | BGT | $V$ | 3 | 2 | 62 | - |  |  |  | 96 | LDAA |  | 3 | 2 | CA | ORAB |  | 2 | 2 | FE | LDX | , | 5 | 3 |
| 2 F | BLE | REL | 3 | 2 | 63 | COM |  | 6 | 2 | 97 | STAA |  | 3 | 2 | CB | ADDB |  | 2 | 2 | FF | STX | EXTND | 5 | 3 |
| 30 | TSX | INHER | 3 | 1 | 64 | LSR |  | 6 | 2 | 98 | EORA |  | 3 | 2 | CC | LDD |  | 3 | 3 |  |  |  |  |  |
| 31 | INS | 4 | 3 | 1 | 65 | - | 1 |  |  | 99 | ADCA |  | 3 | 2 | CD | - |  |  |  |  | * UNDEF | INED OP | CODE |  |
| 32 | PULA | $\downarrow$ | 4 | 1 | 66 | ROR |  | 6 | 2 | 9 A | ORAA |  | 3 | 2 | CE | LDX | IMMED | 3 | 3 |  |  |  |  |  |
| 33 | PULB | $\gamma$ | 4 | 1 | 67 | ASR | INDXD | 6 | 2 | 98 | ADDA | $V$ | 3 | 2 | CF |  |  |  |  |  |  |  |  |  |

NOTES:

1. Addressing Modes

## INHER $\equiv$ Inherent $\quad$ INDXD $\equiv$ Indexed $\quad$ IMMED $\equiv$ Immediate <br> REL $\equiv$ Relative EXTND $\equiv$ Extended $\mathrm{D} \mid \mathrm{R} \equiv$ Direct

2. Unassigned opcodes are indicated by " 0 " and should not be executed.
3. Codes marked by " $T$ " force the PC to function as a 16 -bit counter.

## PROGRAMMING MODEL

A programming model for the EF6801U4/EF6803U4 is shown in Figure 8. Accumulator A can be concatenated with accumulator $B$ and jointly referred to as accumulator $D$ where $A$ is the most significant byte. Any operation which modifies the double accumulator will also modify accumulators $A$ and/or $B$. Other registers are defined as follows:

PROGRAM COUNTER - The program counter is a 16 -bit register which always points to the next instruction.

STACK POINTER - The stack pointer is a 16 -bit register which contains the address of the next available location in a pushdown/pullup (LIFO) queue. The stack resides in random-access memory at a location defined by the programmer.

INDEX REGISTER - The index register is a 16 -bit register which can be used to store data or provide an address for the indexed mode of addressing.

ACCUMULATORS - The MPU contains two 8 -bit accumulators, $A$ and $B$, which are used to store operands and results from the arithmetic logic unit (ALU). They can also be concatenated and referred to as the D (double) accumulator.

CONDITION CODE REGISTER - The condition code register indicates the results of an instruction and includes the following five condition bits: negative ( $N$ ), zero ( $Z$ ), overflow (V), carry/borrow from MSB (C), and half carry from bit $3(\mathrm{H})$. These bits are testable by the conditional branch instructions. Bit 4 is the interrupt mask ( 1 bit) and inhibits all maskable interrupts when set. The two unused bits, $B 6$ and $B 7$, are read as ones.

## ADDRESSING MODES

Six addressing modes can be used to reference memory. A summary of addressing modes for all instructions is presented in Tables 9, 10, 11, and 12 where execution times are provided in E cycles. Instruction execution times are summarized in Table 13. With an input frequency of 4 MHz , one $E$ cycle is equivalent to one microsecond. A cycle-bycycle description of bus activity for each instruction is provided in Table 14 and descriptions of selected instructions are shown in Figure 24.

IMMEDIATE ADDRESSING - The operand or "immediate byte(s)" is contained in the following byte(s) of the
instruction where the number of bytes matches the size of the register. These are two or three byte instructions.

DIRECT ADDRESSING - The least significañt byte of the operand address is contained in the second byte of the instruction and the most significant byte is assumed to be $\$ 00$. Direct addressing allows the user to access $\$ 00$ through $\$ F F$ using two byte instructions and execution time is reduced by eliminating the additional memory access. In most applications, the 256 -byte area is reserved for frequently referenced data.

EXTENDED ADDRESSING - The second and third bytes of the instruction contain the absolute address of the operand. These are three byte instructions.

INDEXED ADDRESSING - The unsigned offset contained in the second byte of the instruction is added with carry to the index register and is used to reference memory without changing the index register. These are two byte instructions.

INHERENT ADDRESSING - The operand(s) is a register and no memory reference is required. These are single byte instructions.

RELATIVE ADDRESSING - Relative addressing is used only for branch instructions. If the branch condition is true, the program counter is overwritten with the sum of a signed single byte displacement in the second byte of the instruction and the current program counter. This provides a branch range of -126 to +129 bytes from the first byte of the instruction. These are two byte instructions.

## SUMMARY OF CYCLE-BY-CYCLE OPERATION

Table 14 provides a detailed description of the information present on the address bus, data bus, and the read/write $(R / \bar{W})$ line during each cycle of each instruction.

The information is useful in comparing actual with expected results during debug of both software and hardware as the program is executed. The information is categorized i, groups according to addressing mode and number of cycles per instruction. In general, instructions with the same addressing mode and number of cycles execute in the same manner. Exceptions are indicated in the table.

Note that during MPU reads of internal locations, the resultant value will not appear on the external data bus except in mode 0 . "High order" byte refers to the most significant byte of a 16 -bit value.

TABLE 9 - INDEX REGISTER AND STACK MANIPULATION INSTRUCTIONS

| Pointer Operations | MNEM | Imrined |  |  | Direct |  |  | Index |  |  | Extnd |  |  | Inherent |  |  | Boolean/ <br> Arithmetic Operation | Condition Codes |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | Op | - | \# |  |  |  | Op | - | $\cdots$ |  |  |  | Op | - | \# |  | Op | - | \# | Op | - | \# | H | 1. | N | Z | V | C |
| Compare Index Register | CPX | 8C | 4 | 3 | 9C | 5 | 2 | AC | 6 | 2 | BC | 6 | 3 |  |  |  | $X-M: M+1$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
| Decrement Index Register | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 3 | 1 | $x-1 \rightarrow x$ | $\bullet$ | - | - | 1 | - | $\bullet$ |
| Decrement Stack Pointer | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 3 | 1 | SP-1 $\rightarrow$ SP | - | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Increment Index Register | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 3 | 1 | $x+1 \rightarrow x$ | - | $\bullet$ | $\bullet$ | $t$ | $\bullet$ | $\bullet$ |
| Increment Stack Pointer | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 3 | 1 | $1 S P+1 \rightarrow$ SP | - | $\bullet$ | - | - | - | $\bullet$ |
| Load Index Register | LDX | CE | 3 | 3 | $D E$ | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 |  |  |  | $M \rightarrow X_{H_{1}}(M+1) \rightarrow X_{L}$ | - | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Load Stack Pointer | LDS | 8 E | 3 | 3 | $9 E$ | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{SP}_{\mathrm{H}^{\prime}}(\mathrm{M}+1) \rightarrow S \mathrm{PL}^{\text {. }}$ | - | - | 1 | $\dagger$ | R | $\bullet$ |
| Store Index Register | STX |  |  |  | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 |  |  |  | $\mathrm{X}_{\mathrm{H}} \rightarrow \mathrm{M}, \mathrm{X}_{L} \rightarrow(\mathrm{M}+1)$ | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
| Store Stack Pointer | STS |  |  |  | 9 F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 |  |  |  | $\mathrm{SP}_{\mathrm{H}} \rightarrow \mathrm{M}, \mathrm{SP}_{\mathrm{L}} \rightarrow(\mathrm{M}+1)$ | - | - | 1 | 1 | R | $\bullet$ |
| Index Reg $\rightarrow$ Stack Pointer | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 3 | 1 | $X-1 \rightarrow S P$ | - | - | - | - | $\bullet$ | - |
| Stack Pntr $\rightarrow$ Index Register | TSX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 3 | 1 | $S P+1 \rightarrow X$ | - | - | - | - | - | $\bullet$ |
| Add | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3 A | 3 | 1 | $B+X \rightarrow X$ | - | - | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Push Data | PSHX |  |  |  |  |  |  |  |  |  |  |  |  | 3C | 4 | 1 | $\begin{aligned} & X_{L} \rightarrow M_{S P}, S P-1 \rightarrow S P \\ & X_{H} \rightarrow M_{S P}, S P-1 \rightarrow S P \end{aligned}$ | - | - | $\bullet$ | - | - | - |
| Pull Data | PULX |  |  |  |  |  |  |  |  |  |  |  |  | 38 | 5 | 1 | $\begin{aligned} & S P+1 \rightarrow S P, M_{S P} \rightarrow X_{H} \\ & S P+1 \rightarrow S P, M_{S P} \rightarrow X_{L} \end{aligned}$ | - | - | - | - | - | - |

TABLE 10 - ACCUMULATOR AND MEMORY INSTRUCTIONS (Sheet 1 of 2)

| Accumulator and Memory Operations | MNEM | Immed |  |  | Direct |  |  | Index |  |  | Extend |  |  | Inher |  |  | Boolean Expression | Condition Codes |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | Op | $\sim$ | \# |  |  |  | Op | $\sim$ | \# |  |  |  | Op | $\sim$ | \# |  | Op | $\sim$ | \# | Op | ~ | \# | H | 1 | N | Z | V | C |
| Add Accumulators | ABA |  |  |  |  |  |  |  |  |  |  |  |  | 1 B | 2 | 1 | $A+B \rightarrow A$ | 1 | - | 1 | 1 | 1 | $t$ |
| Add $B$ to X | ABX |  |  |  |  |  |  |  |  |  |  |  |  | 3A | 3 | 1 | $00: B+X \rightarrow X$ | $\bullet$ | - | - | - | $\bullet$ | $\bullet$ |
| Add with Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | B9 | 4 | 3 |  |  |  | $A+M+C \rightarrow A$ | 1 | - | 1 | $t$ | 1 | 7 |
|  | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 |  |  |  | $B+M+C \rightarrow B$ | 1 | $\bullet$ | 1 | 1 | 7 | $\square$ |
| Add | ADDA | 8 B | 2 | 2 | 9B | 3 | 2 | AB | 4 | 2 | BB | 4 | 3 |  |  |  | $A+M \rightarrow A$ | 1 | $\bullet$ | 1 | 1 | 1 | 1 |
|  | ADDB | CB | 2 | 2 | DB | 3 | 2 | EB | 4 | 2 | FB | 4 | 3 |  |  |  | $B+M \rightarrow A$ | 1 | - | 1 | 1 | $t$ | 1 |
| Add Double | ADDD | C3 | 4 | 3 | D3 | 5 | 2 | E3 | 6 | 2 | F3 | 6 | 3 |  |  |  | $D+M: M+1 \rightarrow D$ | $\bullet$ | $\bullet$ | 1 | $t$ | $\ddagger$ | $\square$ |
| And | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A4 | 4 | 2 | B4 | 4 | 3 |  |  |  | $A \cdot M \rightarrow A$ | - | - | 1 | 1 | R | $\bullet$ |
|  | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 |  |  |  | $B \cdot M \rightarrow B$ | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
| Shift Left, Arithmetic | ASL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  |  | - | - | 1 | $\square$ | 7 | 7 |
|  | ASLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 2 | 1 |  | $\bullet$ | - | 1 | 1 | 7 | 7 |
|  | ASLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 2 | 1 |  | - | - | 1 | 1 | 1 | 7 |
| Shift Left Double | ASLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 3 | 1 |  | - | - | 1 | 1 | 7 | 7 |
| Shift Right, Arithmetic | ASR |  |  |  |  |  |  | 67 | 6 | 2 | 77 | 6 | 3 |  |  |  |  | $\bullet$ | - | 1 | 7 | 7 | 7 |
|  | ASRA |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 2 | 1 |  | $\bullet$ | $\bullet$ | $\dagger$ | 1 | $\ddagger$ | $t$ |
|  | ASRB |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 2 | 1 |  | - | - | 1 | $t$ | $\ddagger$ | 1 |
| Bit Test | BITA | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | B5 | 4 | 3 |  |  |  | $A \cdot M$ | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
|  | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 |  |  |  | $B \cdot M$ | - | - | $t$ | 1 | R | $\bullet$ |
| Compare Accumulators | CBA |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 2 | 1 | A-B | - | - | 1 | $\ddagger$ | 1 | 7 |
| Clear | CLR |  |  |  |  |  |  | 6 F | 6 | 2 | 7F | 6 | 3 |  |  |  | $0 \rightarrow \mathrm{M}$ | $\bullet$ | - | R | S | R | $R$ |
|  | CLRA |  |  |  |  |  |  |  |  |  |  |  |  | 4F | 2 | 1 | $00 \rightarrow A$ | $\bullet$ | - | R | S | R | $R$ |
|  | CLRB |  |  |  |  |  |  |  |  |  |  |  |  | 5 F | 2 | 1 | $00 \rightarrow B$ | - | - | R | S | R | R |
| Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | B1 | 4 | 3 |  |  |  | $A-M$ | - | - | 1 | 1 | 7 | 7 |
|  | CMPB | C1 | 2 | 2 | D1 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 |  |  |  | $B-M$ | - | - | 1 | $t$ | 1 | 1 |
| 1's Complement | COM |  |  |  |  |  |  | 63 | 6 | 2 | 73 | 6 | 3 |  |  |  | $M \rightarrow M$ | $\bullet$ | - | 1 | 1 | R | S |
|  | COMA |  |  |  |  |  |  |  |  |  |  |  |  | 43 | 2 | 1 | $A \rightarrow A$ | - | - | 1 | 1 | R | S |
|  | COMB |  |  |  |  |  |  |  |  |  |  |  |  | 53 | 2 | 1 | $B \rightarrow B$ | - | - | 1 | 1 | R | S |

TABLE 10 - ACCUMULATOR AND MEMORY INSTRUCTIONS (Sheet 2 of 2)

| Accumulator and Memory Operations | MNEM | Immed |  |  | Direct |  |  | Index |  |  | Extend |  |  | Inher |  |  | Boolean Expression | Condition Codes |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | Op | $\sim$ | \# |  |  |  | Op | - | * |  |  |  | Op | - | " |  | Op | $\sim$ | " | O | - | \# | H | 1 | N | Z | V | C |
| Decimal Adjust, A | DAA |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 | Adj binary sum to BCD | - | - | 1 | 1 | $\downarrow$ | 1 |
| Decrement | DEC |  |  |  |  |  |  | 6 A | 6 | 2 | 7A | 6 | 3 |  |  |  | $M-1 \rightarrow M$ | - | $\bullet$ | 1 | 1 | 1 | $\bullet$ |
|  | DECA |  |  |  |  |  |  |  |  |  |  |  |  | 4A | 2 | 1 | $A-1 \rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $\ddagger$ | 1 | $\bullet$ |
|  | DECB |  |  |  |  |  |  |  |  |  |  |  |  | 5A | 2 | 1 | $B-1 \rightarrow B$ | - | $\bullet$ | 1 | 1 | 1 | $\bullet$ |
| Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | B8 | 4 | 3 |  |  |  | $A \oplus M \rightarrow A$ | - | $\bullet$ | 1 | 1 | R | - |
|  | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 |  |  |  | $B \oplus M \rightarrow B$ | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
| Increment | INC |  |  |  |  |  |  | 6C | 6 | 2 | 7C | 6 | 3 |  |  |  | $M+1 \rightarrow M$ | - | $\bullet$ | 1 | 1 | 1 | $\bullet$ |
|  | INCA |  |  |  |  |  |  |  |  |  |  |  |  | 4C | 2 | 1 | $A+1 \rightarrow A$ | - | $\bullet$ | 1 | 1 | 1 | $\bullet$ |
|  | INCB |  |  |  |  |  |  |  |  |  |  |  |  | 5C | 2 | 1 | $B+1 \rightarrow B$ | - | - | 1 | 1 | 1 | - |
| Load Accumulators | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | B6 | 4 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{A}$ | - | $\bullet$ | 1 | 1 | R | $\bullet$ |
|  | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 |  |  |  | $M \rightarrow B$ | - | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Load Double | LDD | CC | 3 | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 |  |  |  | $M: M+1 \rightarrow D$ | $\bullet$ | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Logical Shift, Left | LSL |  |  |  |  |  |  | 68 | 6 | 2 | 78 | 6 | 3 |  |  |  |  | - | $\bullet$ | 1 | 1 | $t$ | 1 |
|  | LSLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 2 | 1 |  | - | - | 1 | 1 | $\ddagger$ | 1 |
|  | LSLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 2 | 1 |  | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | LSLD |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 3 | 2 |  | - | - | 1 | 1 | 1 | 1 |
| Shift Right, Logical | LSR |  |  |  |  |  |  | 64 | 6 | 2 | 74 | 6 | 3 |  |  |  |  | $\bullet$ | $\bullet$ | R | 1 | 1 | 1 |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 2 | 1 |  | $\bullet$ | $\bullet$ | R | 1 | $\dagger$ | 1 |
|  | LSRB |  |  |  |  |  |  |  |  |  |  |  |  | 54 | 2 | 1 |  | $\bullet$ | - | R | 1 | 1 | 1 |
|  | LSRD |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 3 | 1 |  | - | $\bullet$ | R | 1 | $t$ | 1 |
| Multiply | MUL |  |  |  |  |  |  |  |  |  |  |  |  | 3D | 10 | 1 | $\mathrm{A} \times \mathrm{B} \rightarrow \mathrm{D}$ | - | - | - | - | - | 1 |
| 2's Complement (Negate) | NEG |  |  |  |  |  |  | 60 | 6 | 2 | 70 | 6 | 3 |  |  |  | OO-M $\rightarrow$ M | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | NEGA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 2 | 1 | OO-A $\rightarrow A$ | $\bullet$ | $\bullet$ | 1 | $t$ | 1 | 1 |
|  | NEGB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 | $\mathrm{OO}-\mathrm{B} \rightarrow \mathrm{B}$ | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 | $P C+1 \rightarrow P C$ | - | - | - | $\bullet$ | - | $\bullet$ |
| Inclusive OR | ORAA | 8A | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 |  |  |  | $A+M \rightarrow A$ | $\bullet$ | - | 1 | 1 | R | $\bullet$ |
|  | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 |  |  |  | $B+M \rightarrow B$ | - | - | $\dagger$ | 1 | R | $\bullet$ |
| Push DataPull Data | PSHA |  |  |  |  |  |  |  |  |  |  |  |  | 36 | 3 | 1 | $A \rightarrow$ Stack | - | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
|  | PSHB |  |  |  |  |  |  |  |  |  |  |  |  | 37 | 3 | 1 | $\mathrm{B} \rightarrow$ Stack | - | $\bullet$ | - | $\bullet$ | - | - |
|  | PULA |  |  |  |  |  |  |  |  |  |  |  |  | 32 | 4 | 1 | Stack $\rightarrow$ A | - | - | - | - | - | $\stackrel{\square}{*}$ |
|  | PULB |  |  |  |  |  |  |  |  |  |  |  |  | 33 | 4 | 1 | Stack $\rightarrow$ B | $\bullet$ | $\bullet$ | - | - | - | $\stackrel{*}{*}$ |
| Rotate Left | ROL |  |  |  |  |  |  | 69. | 6 | 2 | 79 | 6 | 3 |  |  |  | C | - | - | 1 | 1 | 1 | 1 |
|  | ROLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 2 | 1 |  | $\bullet$ | - | 1 | 1 | 1 | 1 |
|  | ROLB |  |  |  |  |  |  |  |  |  |  |  |  | 59 | 2 | 1 |  | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
| Rotate Right | ROR |  |  |  |  |  |  | 66 | 6 | 2 | 76 | 6 | 3 |  |  |  |  | $\bullet$ | - | 1 | 1 | 1 | 1 |
|  | RORA |  |  |  |  |  |  |  |  |  |  |  |  | 46 | 2 | 1 |  | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
|  | RORB |  |  |  |  |  |  |  |  |  |  |  |  | 56 | 2 | 1 |  | $\bullet$ | $\bullet$ | 1 | 1 | 1 | 1 |
| Subtract Accumulator | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 2 | 1 | $A-B \rightarrow A$ | - | - | 1 | 1 | 1 | 1 |
| Subtract with CarryStore Accumulators | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | B2 | 4 | 3 |  |  |  | $A-M-C \rightarrow A$ | $\bullet$ | - | 1 | 1 | 1 | 1 |
|  | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C \rightarrow B$ | - | - | 1 | 1 | 1 | $!$ |
|  | STAA |  |  |  | 97 | 3 | 2 | A7 | 4 | 2 | B7 | 4 | 3 |  |  |  | $A \rightarrow M$ | $\bullet$ | - | 1 | 1 | R | - |
|  | STAB |  |  |  | D7 | 3 | 2 | E7 | 4 | 2 | F7 | 4 | 3 |  |  |  | $B \rightarrow M$ | - | $\bullet$ | 1 | $\dagger$ | R | - |
|  | STD |  |  |  | DD | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 |  |  |  | $D \rightarrow M M+1$ | - | $\bullet$ | 1 | 1 | R | $\bullet$ |
| Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | B0 | 4 | 3 |  |  |  | $A-M \rightarrow A$ | - | - | 1 | 1 | 1 | 1 |
|  | SUBB | CO | 2 | 2 | D0 | 3 | 2 | EO | 4 | 2 | FO | 4 | 3 |  |  |  | $B \rightarrow M \rightarrow B$ | - | - | 1 | 1 | 1 | 1 |
| Subtract Double | SUBD | 83 | 4 | 3 | 93 | 5 | 2 | A3 | 6 | 2 | B3 | 6 | 3 |  |  |  | $D-M . M+1 \rightarrow D$ | - | - | 1 | 1 | 1 | 1 |
| Transfer Accumulator | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 2 | 1 | $A \rightarrow B$ | - | $\bullet$ | 1 | 1 | R | - |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 2 | 1 | $B \rightarrow A$ | - | - | 1 | 1 | $R$ | - |
| Test, Zero or Mınus | TST |  |  |  |  |  |  | 6 D | 6 | 2 | 7D | 6 | 3 |  |  |  | M -00 | - | - | 1 | 1 | R | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 4 D | 2 | 1 | A -00 | $\bullet$ | - | 1 | $\dagger$ | R | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 5 D | 2 | 1 | B-00 | - | - | 1 | 1 | R | R |

[^8]TABLE 11 - JUMP AND BRANCH INSTRUCTIONS

| Operations | MNEM | Direct |  |  | Relative |  |  | Index |  |  | Extend |  |  | Inherent |  |  | Branch Test | Condition Code Reg. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | Op | - | \# |  |  |  | Op | - | \# |  |  |  | Op | $\sim$ | * |  | Op | - | \# | Op | $\sim$ | 4 | H | 1 | N | Z | V | C |
| Branch Always | BRA |  |  |  | 20 | 3 | 2 |  |  |  |  |  |  |  |  |  | None | - | - | - | - | - | $\bullet$ |
| Branch Never | BRN |  |  |  | 21 | 3 | 2 |  |  |  |  |  |  |  |  |  | None | - | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Carry Clear | BCC |  |  |  | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{C}=0$ | - | - | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If Carry Sei | BCS |  |  |  | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=1$ | - | - | $\bullet$ | - | - | $\bullet$ |
| Branch If = Zero | BEO |  |  |  | 27 | 3 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{Z}=1$ | - | - | - | $\bullet$ | - | $\bullet$ |
| Branch If $\geq$ Zero | BGE |  |  |  | 2C | 3 | 2 |  |  |  |  |  |  |  |  |  | $N \oplus V=0$ | - | - | - | - | $\bullet$ | $\bullet$ |
| Branch If $>$ Zero | BGT |  |  |  | 2 E | 3 | 2 |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | - | - | - | - | - | $\bullet$ |
| Branch If Higher | BHI |  |  |  | 22 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C+Z=0$ | - | - | - | - | - | - |
| Branch If Higher or Same | BHS |  |  |  | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=0$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| Branch If $\leq$ Zero | BLE |  |  |  | 2 F | 3 | 2 |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=1$ | - | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Branch If Carry Set | BLO |  |  |  | 25 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C=1$ | - | - | - | - | - | $\bullet$ |
| Branch If Lower Or Same | BLS |  |  |  | 23 | 3 | 2 |  |  |  |  |  |  |  |  |  | $C+Z=1$ | - | - | - | - | - | - |
| Branch If < Zero | BLT |  |  |  | 2 D | 3 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{N} \oplus \mathrm{V}=1$ | - | - | - | $\bullet$ | - | $\bullet$ |
| Branch If Minus. | BMI |  |  |  | 2B | 3 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{N}=1$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Branch If Not Equal Zero | BNE |  |  |  | 26 | 3 | 2 |  |  |  |  |  |  |  |  |  | $Z=0$ | - | - | - | - | - | $\bullet$ |
| Brarich If Overflow Clear | BVC |  |  |  | 28 | 3 | 2 |  |  |  |  |  |  |  |  |  | $V=0$ | - | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ |
| Branch If Overflow Set | BVS |  |  |  | 29 | 3 | 2 |  |  |  |  |  |  |  |  |  | $V=1$ | - | - | - | - | - | $\bullet$ |
| Branch If Plus | BPL |  |  |  | 2 A | 3 | 2 |  |  |  |  |  |  |  |  |  | $N=0$ | - | - | $\bullet$ | - | - | $\bullet$ |
| Branch To Subroutine | BSR |  |  |  | 8 D | 6 | 2 |  |  |  |  |  |  |  |  |  |  | - | - | - | $\bullet$ | - | $\bullet$ |
| Jump | JMP |  |  |  |  |  |  | 6 E | 3 | 2 | 7 E | 3 | 3 |  |  |  | See Special Operations-Figure 24 | - | - | - | - | - | $\bullet$ |
| Jump To Subroutine | JSR | 9D | 5 | 2 |  |  |  | AD | 6 | 2 | BD | 6 | 3 |  |  |  |  | - | - | - | - | - | $\bullet$ |
| No Operation | NOP |  |  |  |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 |  | - | - | - | - | - | $\bullet$ |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  |  |  |  | 3B | 10 | 1 |  | 1 | 7 | 1 | 1 | 1 | 1 |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 | See Special Operations-Figure 24 | - | - | - | - | - | $\bullet$ |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  |  |  |  | 3 F | 12 | 1 |  | - | S | - | - | - | $\bullet$ |
| Wait For interrupt | WAI |  |  |  |  |  |  |  |  |  |  |  |  | 3 E | 9 | 1 |  | - | - | - | - | - | - |

TABLE 12 - CONDITION CODE REGISTER MANIPULATION INSTRUCTIONS

| Operations | Inherent |  |  |  | Boolean Operation | Condition Code Register |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  | MNEM | Op | - | \# |  | H | 1 | N | Z | V | C |
| Clear Carry | CLC | OC | 2 | 1 |  | $0 \rightarrow \mathrm{C}$ | - | - | - | - | - | R |
| Clear Interrupt Mask | CLI | OE | 2 | 1 | $0 \rightarrow 1$ | - | R | $\bullet$ | - | $\bullet$ | $\bullet$ |
| Clear Overflow | CLV | OA | 2 | 1 | $\mathrm{O} \rightarrow \mathrm{V}$ | - | $\bullet$ | - | - | R | $\bullet$ |
| Set Carry | SEC | OD | 2 | 1 | $1 \rightarrow \mathrm{C}$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ | S |
| Set Interrupt Mask | SEI | OF | 2 | 1 | $1 \rightarrow 1$ | $\bullet$ | S | - | $\bullet$ | $\bullet$ | $\bullet$ |
| Set Overflow | SEV | OB | 2 | 1 | $1 \rightarrow \mathrm{~V}$ | - | - | - | - | S | $\bullet$ |
| Accumulator $A \rightarrow$ CCR | TAP | 06 | 2 | 1 | $A \rightarrow C C R$ | 1 | 1 | 1 | 1 | 1 | 1 |
| $\mathrm{CCR} \rightarrow$ Accumulator A | TPA | 07 | 2 | 1 | $\mathrm{CCR} \rightarrow \mathrm{A}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |

## LEGEND

Op Operation Code (Hexadecimal)
~ Number of MPU Cycles
MSP Contents of memory iocation pointed to by Stack Pointer
\# Number of Program Bytes

+ Arithmetic Plus
- Arithmetic Minus
- Boolean AND

X Arithmetic Multiply

+ Boolean Inclusive OR
$\oplus$ Boolean Exclusive OR
M Complement of $M$
$\rightarrow$ Transfer Into
0 Bit=Zero
00 Byte=Zero


## CONDITION CODE SYMBOLS

H. Half-carry from bit 3

I Interrupt mask
$N$ : Negative (sign bit)
Z Zero (byte)
$\checkmark$ Overflow, 2's complement
C Carry/Borrow from MSB
R Reset Always
$S$ Set Always
1 Affected

- Not Affected

TABLE 13 －INSTRUCTION EXECUTION TIMES IN E－CYCLES

|  | ADDRESSING MODE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { © } \\ & \text { © } \\ & \text { © } \\ & E \\ & E \\ & E \end{aligned}$ | － ¢ － |  | O ¢ ¢ ¢ ¢ c | $\xrightarrow{\sim}$ | $\underset{\sim}{\infty}$ |
| ABA | － | － | － | － | 2 | － |
| $A B X$ | － | － | － | － | 3 | － |
| ADC | 2 | 3 | 4 | 4 | － | － |
| ADD | 2 | 3 | 4 | 4 | － | － |
| ADDD | 4 | 5 | 6 | 6 | $\bullet$ | － |
| AND | 2 | 3 | 4 | 4 | － | － |
| ASL | $\bigcirc$ | － | 6 | 6 | 2 | － |
| ASLD | － | － | － | － | 3 | － |
| ASR |  | － | 6 | 6 | 2 | － |
| BCC | － | － | － | － | － | 3 |
| BCS |  | － | － | － | － | 3 |
| BEQ |  | － | － | － | － | 3 |
| BGE |  | － | － | － | － | 3 |
| BGT | － | － | － | － | － | 3 |
| BHI |  | － |  | － |  | 3 |
| BHS |  | － | － | － | － | 3 |
| BIT | 2 | 3 | 4 | 4 | － | － |
| BLE | － | － | － | － | － | 3 |
| BLO | － | － | － | － | － | 3 |
| BLS | － | － | － | － | － | 3 |
| BLT | － | － | － | － | － | 3 |
| BMI | － | $\bigcirc$ | － | $\bigcirc$ | － | 3 |
| BNE | － | － | － | － | － | 3 |
| BPL | － | － | － | － | － | 3 |
| BRA | － | － | － | － | － | 3 |
| BRN | － | － | － | － | － | 3 |
| BSR | － | － | － | － | － | 6 |
| BVC | － | － | － | $\bigcirc$ | － | 3 |
| BVS | － | － | $\bullet$ | $\bigcirc$ | $\bigcirc$ | 3 |
| CBA | － | － | － | － | 2 | － |
| CLC | － | － | － | － | 2 | － |
| CLI | － | － | － | － | 2 | － |
| CLR | － | － | 6 | 6 | 2 | － |
| CLV | － | － | － | － | 2 | \％ |
| CMP | 2 | 3 | 4 | 4 | － | － |
| COM | $\bigcirc$ | － | 6 | 6 | 2 | － |
| CPX | 4 | 5 | 6 | 6 | － | － |
| DAA | － | － | － | － | 2 | － |
| DEC | － | － | 6 | 6 | 2 | － |
| DES | － | － | － | － | 3 | － |
| DEX | － | － | － | － | 3 | － |
| EOR | 2 | 3 | 4 | 4 | － | － |
| INC | － | － | 6 | 6 | － | － |
| INS | － | 0 | － | － | 3 |  |


|  | $\left\|\begin{array}{llllll} \infty & \infty & \infty & \infty & \infty & \infty \\ \sum_{0}^{c} & c & \frac{1}{x} & -1 & -1 & n \\ 0 & \infty & \cdots & 0 & \infty \end{array}\right\|$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| －－ | A $N$ | N | －－－N | －－－－ | $\omega \omega \omega N$－ | Immediate |
| －－ | －vcmath | －$\omega$－ | －－$\omega$ | － $0^{\circ}$ | A A A M O | Direct |
| －a | －asanala | $A \bullet$－ | のの－－－ | －o－o o | uncramw | Extended |
| －a－－ | －のavala | －－－－ | のロー－－ | －の－の－の | Ouvacm | Indexed |
| $\omega \omega \omega N$ NNNN | $\stackrel{\rightharpoonup}{n} \cdot 0 \cdot \bullet \cdot$ | NNNONUO | NNOA | NN ${ }_{0} \omega \boldsymbol{\omega} \omega \mathrm{~N}$ | －－$\omega$ | Inherent |
| －－－－ | －－－－ | － | －－－－ | － | － | Relative |

TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 1 of 5)

| Address Mode and Instructions |  | Cycles | Cycle <br> \# | Address Bus | $\begin{aligned} & R / \bar{W} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMMEDIATE |  |  |  |  |  |  |
| $\begin{aligned} & \text { ADC } \\ & \text { ADD } \\ & \text { AND } \\ & \text { BIT } \\ & \text { CMP } \end{aligned}$ | $\begin{aligned} & \text { EOR } \\ & \text { LDA } \\ & \text { ORA } \\ & \text { SBC } \\ & \text { SUB } \end{aligned}$ | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address Opcode Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Opcode } \\ & \text { Operand Data } \end{aligned}$ |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \\ & \hline \end{aligned}$ |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
|  |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Upcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Upcode <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) <br> Low Byte of Restart Vector |
| DIRECT |  |  |  |  |  |  |
| $\begin{array}{\|l\|} \hline \text { ADC } \\ \text { ADD } \\ \text { AND } \\ \text { BIT } \\ \text { CMP } \end{array}$ | $\begin{aligned} & \text { EOR } \\ & \text { LDA } \\ & \text { ORA } \\ & \text { SBC } \\ & \text { SUB } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Address of Operand Operand Data |
| STA |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Destination Address <br> Data from Accumulator |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \end{aligned}$ |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address of Operand <br> Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Address of Operand <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \\ & \text { STD } \end{aligned}$ |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address of Operand <br> Address of Operand + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Address of Operand <br> Register Data (High Order Byte) <br> Register Data (Low Order Byte) |
| CPX <br> SUBD <br> ADDD |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Operand Address <br> Operand Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Address of Operand <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) <br> Low Byte of Restart Vector |
| JSR |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Subroutine Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Irrelevant Data <br> First Subroutine Opcode <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 2 of 5)

| Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EXTENDED |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Jump Address (High Order Byte) <br> Jump Address (Low Order Byte) |
|   <br> ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Address of Operand <br> Address of Operand (Low Order Byte) <br> Operand Data |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Destination Address (High Order Byte) <br> Destination Address (Low Order Byte) <br> Data from Accumulator |
| $\begin{aligned} & \text { LDS } \\ & \text { LDX } \\ & \text { LDD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| $\begin{aligned} & \hline \text { STS } \\ & \text { STX } \\ & \text { STD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
|   <br> ASL LSR <br> ASR NEG <br> CLR ROL <br> COM ROR <br> DEC TST* <br> INC  | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Address of Operand <br> Address Bus FFFF <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Current Operand Data <br> Low Byte of Restart Vector <br> New Operand Data |
| CPX <br> SUBD <br> ADDD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> Operand Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Address (High Order Byte) <br> Operand Address (Low Order Byte) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) <br> Low Byte of Restart Vector |
| JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Subroutine Starting Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Address of Subroutine (High Order Byte) <br> Address of Subroutine (Low Order Byte) <br> Opcode of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

[^9]TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 3 of 5)

| Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & R / \bar{W} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INDEXED |  |  |  |  |  |
| JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector |
|   <br> ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector Operand Data |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector Operand Data |
| $\begin{array}{\|l\|} \hline \text { LDS } \\ \text { LDX } \\ \text { LDD } \end{array}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Index Register Plus Offset + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \\ & \text { STD } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Index Register Plus Offset + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| ASL LSR <br> ASR NEG <br> CLR ROL <br> COM ROR <br> DEC TST* <br> INC  | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register Plus Offset <br> Address Bus FFFF <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Current Operand Data <br> Low Byte of Restart Vector <br> New Operand Data |
| CPX <br> SUBD <br> ADDD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register + Offset <br> Index Register + Offset + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) <br> Low Byte of Restart Vector |
| JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Index Register + Offset <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Offset <br> Low Byte of Restart Vector <br> First Subroutine Opcode <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

[^10]TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 4 of 5)

| Address Mode and <br> Instructions | Cycles | Cycle <br> $\#$ | Address Bus | $\mathrm{R} / \overline{\mathrm{W}}$ <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |


| INHERENT |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ABA <br> ASL <br> ASR <br> CBA <br> CLC <br> CLI <br> CLR <br> CLV <br> COM | DAA SEC <br> DEC SEI <br> INC SEV <br> LSR TAB <br> NEG TAP <br> NOP TBA <br> ROL TPA <br> ROR TST <br> SBA  | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address Opcode Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Opcode Opcode of Next Instruction |
| ABX |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode <br> Irrelevant Data <br> Low Byte of Restart Vector |
| $\begin{aligned} & \text { ASLD } \\ & \text { LSRD } \end{aligned}$ |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data Low Byte of Restart Vector |
| $\begin{aligned} & \text { DES } \\ & \text { INS } \end{aligned}$ |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Previous Stack Pointer Contents | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction Irrelevant Data |
| $\begin{array}{\|l\|} \hline \operatorname{INX} \\ \mathrm{DEX} \end{array}$ |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode Opcode of Next Instruction Low Byte of Restart Vector |
| $\begin{aligned} & \text { PSHA } \\ & \text { PSHB } \end{aligned}$ |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Opcode of Next Instruction Accumulator Data |
| TSX |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Opcode of Next Instruction Irrelevant Data |
| TXS |  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Opcode Address Opcode Address + 1 Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode Opcode of Next Instruction Low Byte of Restart Vector |
| PULA PULB |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode Opcode of Next Instruction Irrelevant Data Operand Data from Stack``` |
| PSHX |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Opcode <br> Irrelevant Data <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) |
| PULX |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 <br> Stack Pointer +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode \\ Irrelevant Data \\ Irrelevant Data \\ Index Register (High Order Byte) \\ Index Register (Low Order Byte)``` |
| RTS |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode Irrelevant Data Irrelevant Data Address of Next Instruction (High Order Byte) Address of Next Instruction (Low Order Byte)``` |
| WAI |  | 9 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer-2 <br> Stack Pointer - 3 <br> Stack Pointer-4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Opcode of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) <br> Contents of Accumulator $A$ <br> Contents of Accumulator B <br> Contents of Condition Code Register |

TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 5 of 5)

| Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{array}{\|l\|} \hline R / \bar{W} \\ \text { Line } \end{array}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INHERENT |  |  |  |  |  |
| MUL | 10 | $\begin{gathered} \hline 1 \\ 2 \\ 3 \\ 4 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 8 \\ 9 \\ 10 \end{gathered}$ | Opcode Address Opcode Address + 1 Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF Address Bus FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Irrelevant Data <br> Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector Low Byte of Restart Vector |
| RTI | 10 | $\begin{gathered} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 <br> Stack Pointer +2 <br> Stack Pointer +3 <br> Stack Pointer +4 <br> Stack Pointer +5 <br> Stack Pointer +6 <br> Stack Pointer +7 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode Irrelevant Data Irrelevant Data Contents of Condition Code Register from Stack Contents of Accumulator B from Stack Contents of Accumulatot A from Stack Index Register from Stack (High Order Byte) Index Register from Stack (Low Order Byte) Next Instruction Address from Stack (High Order Byte) Next Instruction Address from Stack (Low Order Byte)``` |
| SWI | 12 | 10 1 2 3 4 5 6 7 8 9 10 11 12 | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Stack Pointer-3 <br> Stack Pointer-4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 <br> Stack Pointer-7 <br> Vector Address FFFA (Hex) <br> Vector Address FFFB (Hex) | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Irrelevant Data <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Index Register (Low Order Byte) <br> Index Register (High Order Byte) <br> Contents of Accumulator A <br> Contents of Accumulator B <br> Contents of Condition Code Register <br> Irrelevant Data <br> Address of Subroutine (High Order Byte) <br> Address of Subroutine (Low Order Byte) |
| RELATIVE |  |  |  |  |  |
| BCC BHT BNE BLO <br> BCS BLE BPL BHS <br> BEQ BLS BRA BRN <br> BGE BLT BVC  <br> BGT BMI BVS  | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Buss FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Branch Offset <br> Low Byte of Restart Vector |
| BSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Address Bus FFFF <br> Subroutine Starting Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode <br> Branch Offset <br> Low Byte of Restart Vector <br> Opcode of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) |

JSR, Jump to Subroutine

$$
\begin{aligned}
& \text { INDXD }
\end{aligned}
$$



| Sp | Stack |
| :---: | :---: |
| SP-7 |  |
| SP-6 | Condition Code |
| SP-5 | Acmitr $B$ |
| SP-4 | Acmitr A |
| SP-3 | Index Register ( $\mathrm{X}_{\mathrm{H}}$ ) |
| SP-2 | Index Register ( $\mathrm{X}_{\mathrm{L}}$ ) |
| SP-1 | RTN $_{\text {H }}$ |
| SP | $\mathrm{RTN}_{\mathrm{L}}$ |


JMP, Jump
INDXD


[^11]Legend:
RTN $=$ Address of next instruction in Main Program to be executed upon return from subroutine
RTN $_{H}=$ Most significant byte of Return Address
RTN $\mathrm{L}_{\mathrm{L}}=$ Least significant byte of Return Address
$\rightarrow=$ Stack Pointer After Execution
$\mathrm{K}=8$-bit Unsigned Value


CB-182


CB-521


## ORDERING INFORMATION

The information required when ordering a custom MCU is listed below. The ROM proyram may be transmitted to THOMSON SEMICONDUCTEURS on EPROM(s) or an EFDOS/MDOS* disk file.

To initiate a ROM pattern for the MCU, it is necessary to first contact your local THOMSON SEMICONDUCTEURS representative or distributor.

## EPROMs

Two ET2716 or one ET2732 type EPROMs, programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. The EPROM must be clearly marked to indicate which EPROM corresponds to which address space. The recommended marking procedure is illustrated below :

$X X X=$ Customer ID
After the EPROM(s) are marked, they should be placed in conductive IC carriers and securely packed. Do not use styrofoam.

## VERIFICATION MEDIA

All original pattern media (EPROMs or floppy disk) are filed for contractual purposes and are not returned. A computer listing of the ROM code will be generated and returned along with a listing verification form. The listing should be thoroughly checked and the verification form completed signed, and returned to THOMSON SEMICONDUCTEURS. The signed verification form constitutes the
contractual agreement for creation of the customer mask. If desired, THOMSON SEMICONDUCTEURS will program on blank EPROM from the data file used to create the custom mask and aid in the verification process.

## ROM VERIFICATION UNITS (RVUs)

Ten MCUs containing the customer's ROM pattern will be sent for program verification. These units will have been made using the custom mask but are for the purpose of ROM verification only. For expediency they are usually unmarked, packaged in ceramic, and tested only at room temperature and 5 volts. These RVUs are included in the mask charge and are not production parts. The RVUs are thus not guaranteed by THOMSON SEMICONDUCTEURS. Quality Assurance, and should be discarded after verification is completed.

## FLEXIBLE DISKS

The disk media submitted must be single-sided, EFDOS/ MDOS* compatible floppies.
The customer must write the binary file name and company name on the disk with a felt-tip-pen. The minimum EFDOS/MDOS* system files, as well as the absolute binary object file (Filename .LO type of file) from the 6801 cross assembler, must be on the disk. An object file made from a memory dump using the ROLLOUT command is also acceptable. Consider submitting a source listing as well as the following files: filename .LX (DEVICE/EXORciser loadable format) and filename .SA (ASCII Source Code). These files will of course be kept confidential and are used 1) to speed up the process in-house if any problems arise, and 2) to speed up the user-to-factory interface if the user finds any software errors and needs assistance quickly from THOMSON SEMICONDUC TEURS factory representatives.

EFDOS is THOMSON SEMICONDUCTEURS' Disk Operating System available on development systems such as DEVICE,...
MDOS* is MOTOROLA's Disk Operating System available on development systems such as EXORciser,...
*Requires prior factory approval.

Whenever ordering a custom MCU is required, please contact your local THOMSON SEMICONDUCTEURS representative or THOMSON SEMICONDUCTEURS distributor and/or complete and send the attached "MCU customer ordering sheet" to your local THOMSON SEMICONDUCTEURS representative.

## ORDERING INFORMATION

| EF6801U4 ${ }^{\text {a }}$ ( ${ }^{\text {P }}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| The table below horizontally level. Other possibilities |  |  |  |  | tions | pa |  |  |  |  | scr | ing |
| DEVICE | PACKAGE |  |  |  |  | OPER. TEMP |  |  | SCREENING LEVEL |  |  |  |
|  | c | $J$ | P | E | FN | L* | V | M | Std | D | G/B | B/B |
| EF6801/03 U4 ( 1.0 MHz ) |  |  | $\bullet$ |  | - | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  |  |  | - |  |  |  | - |  | - |  |  |  |
| EF6801/03 U4-1 (1.25 MHz) |  |  | $\bullet$ |  | - | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  |  |  | $\bullet$ |  |  |  | $\bullet$ |  | - |  |  |  |
| EF68A01/03 U4 (1.5 MHz) |  |  | $\bullet$ |  |  | $\bullet$ |  |  | $\bullet$ |  |  |  |
| Examples : EF6801P, EF6801FN, EF6801PV |  |  |  |  |  |  |  |  |  |  |  |  |
| Package : C : Ceramic DIL, J : Cerdip DIL, P : Plastic DIL, E : LCCC, FN : PLCC. <br> Oper. temp. : $\mathrm{L}^{*}: 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}:-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{M}:-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$, ${ }^{*}$ : may be omitted. <br> Screening level: Std : (no-end suffix), D: NFC 96883 level D, <br> G/B : NFC 96883 level G, B/B : NFC 96883 level B and MIL-STD-883C level B. |  |  |  |  |  |  |  |  |  |  |  |  |

[^12]

The EF6809 is a revolutionary high-performance 8 -bit microprocessor which supports modern programming techniques such as position indepen. dence, reentrancy, and modular programming.

This third-generation addition to the 6800 Family has major architectural improvements which include additional registers, instructions, and addressing modes.

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The EF6809 has the most complete set of addressing modes avallable on any 8 -bit microprocessor today

The EF6809 has hardware and software teatures which make it an ideal processor for higher level language execution or standard controller applica tions.

## EF6800 COMPATIBLE

- Hardware - Interfaces with All 6800 Peripherals
- Software - Upward Source Code Compatıble Instruction Set and Addressing Modes


## ARCHITECTURAL FEATURES

- Two 16-Bit Index Registers
- Two 16-Bit Indexable Stack Pointers
- Two 8-Bit Accumulators can be Concatenated to Form One 16-Bit Accumulator
- Direct Page Register Allows Direct Addressing Throughout Memory


## HARDWARE FEATURES

- On-Chip Oscillator (Crystal Frequency $=4 \times \mathrm{E}$ )
- DMA/BREQ Allows DMA Operation on Memory Refresh
- Fast Interrupt Request Input Stacks Only Condition Code Register and Program Counter
- MRDY Input Extends Data Access Times for Use with Slow Memory
- Interrupt Acknowledge Output Allows Vectoring by Devices
- Sync Acknowledge Output Allows for Synchronization to External Event
- Single Bus-Cycle RESET
- Single 5-Volt Supply Operation
- $\overline{N M I}$ Inhibited After RESET Until After First Load of Stack Pointer
- Early Address Valid Allows Use with Slower Memories
- Early Write Data for Dynamic Memories


## SOFTWARE FEATURES

- 10 Addressing Modes
- 6800 Upward Compatible Addressing Modes
- Direct Addressing Anywhere in Memory Map
- Long Relative Branches
- Program Counter Relative
- True Indirect Addressing
- Expanded Indexed Addressing
$0-5-5$-, or 16 -Bit Constant Offsets
8 - or 16 -Bit Accumulator Offsets
Auto Increment/Decrement by 1 or 2
- Improved Stack Manipulation
- 1464 Instructions with Unique Addressing Modes
- $8 \times 8$ Unsigned Multiply
- 16-Bit Arithmetic
- Transfer/Exchange All Registers
- Push/Pull Any Registers or Any Set of Registers
- Load Effective Address


## HMOS

(HIGH DENSITY N-CHANNEL, SILICON-GATE)

## 8-BIT <br> MICROPROCESSING UNIT



PIN ASSIGNMENT


| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -03 to +70 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{in}}$ | -03 to +70 | V |
| Operating Temperature Range |  | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |  |
| EF6809, EF68A09, EF68B09 | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| EF6809, EF68A09, EF68B09 : V suffix |  | -40 to +85 |  |
| EF6809, EF68A09 : M suffix |  | -55 to +125 |  |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Ceramic | $\theta \mathrm{JA}$ | 50 |  |
| Cerdip |  | 60 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic |  | 100 |  |
| PLCC |  | 100 |  |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit. Reliability of operation is enhanced if unused inputs are thed to an appropriate logic voltage levels le.g., either $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$.

The average chip-junction temperature, $T_{J}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{align*}
& T_{J}=T_{A}+\left(P D^{\bullet} \theta J A\right)  \tag{1}\\
& \text { Where: }
\end{align*}
$$

```
\[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}} \equiv \text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
& \theta_{J A} \equiv \text { Package Thermal Resistance, Junction-to-Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
& \text { PD } \equiv \text { PINT }+ \text { PPORT } \\
& \text { PINT } \equiv \text { ICC } \times \mathrm{V}_{C C} \text {, Watts - Chip Internal Power } \\
& \text { PPORT } \equiv \text { Port Power Dissipation, Watts - User Determined }
\end{aligned}
\]
0JA \equivPackage Thermal Resistance, Junction-to-Ambient, *}\mp@subsup{}{}{\circ}\textrm{C}/\textrm{W
= \ VCC, Watts - Chıp Internal Power
Cations PPORT <PINT and can be neglected PP年 Port Power Dissipation, Watts - User Determined
```

t wr most applications PPORT $<$ PINT and can be neglected. PPORT may become significant if the device is configured to drive: Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P D=K \div\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P D \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \bullet P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P_{D}$ and $T J$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

## ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$ unless otherwise noted)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage $\quad$ Logic, EXTAL $\frac{\overline{\text { RESET }}}{}$ | $\begin{gathered} V_{I H} \\ V_{I H R} \end{gathered}$ | $\begin{aligned} & \mathrm{v}_{S S}+2.0 \\ & v_{S S}+4.0 \end{aligned}$ | - | $V_{C C}$ <br> $V_{C C}$ | V |
| Input Low Voltage Logic, EXTAL, $\overline{\text { RESET }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{S S}-0.3$ | - | $\mathrm{V}_{\text {SS }}+0.8$ | V |
| Input Leakage Current $\left(\mathrm{V}_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\max \right)$ | 1 in | - | - | 2.5 | $\mu \mathrm{A}$ |
| dc Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & V_{S S}+2.4 \\ & V_{S S}+2.4 \\ & V_{S S}+2.4 \\ & \hline \end{aligned}$ | - | - | V |
| dc Output Low Voltage <br> ( ${ }_{\text {Load }}=2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{min}$ ) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $\mathrm{V}_{\text {SS }}+0.5$ | V |
| Internal Power Dissipation (Measured at $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ in Steady State Operation) | PINT | - | - | 1.0 | W |
| $\begin{aligned} & \text { Capacitance } \\ & \left(V_{\text {In }}=0, T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right) \quad \text { Logic Inputs, EXTAL, XTAL } \end{aligned}$ | $\mathrm{C}_{1 \mathrm{n}}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & 15 \\ & 15 \end{aligned}=$ | pF |
| A0-A15, R/ $\bar{W}, B A, B S$ | $\mathrm{C}_{\text {out }}$ | - | - | 15 | pF |
| Frequency of Operation EF6809 <br> (Crystal or External Input) EF68A09 <br>  EF68B09 | ${ }^{\text {f X TAL }}$ | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 0.4 \end{aligned}$ | - | $\begin{aligned} & 4 \\ & 6 \\ & 8 \end{aligned}$ | MHz |
| HI-Z (Off State) Input Current D0-D7 <br> $\left(V_{\text {in }}=04\right.$ to $24 \mathrm{~V}, V_{C C}=$ max $)$ A0-A $15, R / \bar{W}$ | ITSI | - | 2.0 | $\begin{gathered} 10 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |

[^13]

BUS TIMING CHARACTERISTICS (See Notes 1 and 2 )

| Ident. <br> Number | Characteristic | Symbol | EF6809 |  | EF68A09 |  | EF68B09 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time (See Note 5) | ${ }^{1} \mathrm{cyc}$ | 1.0 | 10 | 0.667 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| 2 | Pulse Width, E Low | PWEL | 430 | 5000 | 280 | 5000 | 210 | 5000 | ns |
| 3 | Puise Width. E High | PWEH | 450 | 15500 | 280 | 15700 | 220 | 15700 | ns |
| 4 | Clock Rise and Fall Tıme | $\mathrm{t}_{\mathrm{r}}$, If | - | 25 | - | 25 | - | 20 | ns |
| 5 | Pulse Width, Q High | PWOH | 430 | 5000 | 280 | 5000 | 210 | 5000 | ns |
| 6 | Puise Width, Q Low | PWOL | 450 | 15500 | 280 | 15700 | 220 | 15700 | ns |
| 7 | Delay Tıme, E to Q Rise | ${ }^{\text {t }}$ AVS | 200 | 250 | 130 | 165 | 80 | 125 | ns |
| 9 | Address Hold Time* (See Note 4) | ${ }^{1} \mathrm{AH}$ | 20 | - | 20 | - | 20 | - | ns |
| 10 | BA, BS, R/ $\bar{W}$, and Address Valid Time to 0 Rise | IAQ | 50 | - | 25 | - | 15 | - | ns |
| 17 | Read Data Setup Time | tosR | 80 | - | 60 | - | 40 | - | ns |
| 18 | Read Data Hold Time* | ${ }^{\text {I DHR }}$ | 10 | - | 10 | - | 10 | - | ns |
| 20 | Data Delay Time from O | todo | - | 200 | - | 140 | - | 110 | ns |
| 21 | Write Data Hold Time* | t ${ }^{\text {d }}$ WW | 30 | - | 30 | - | 30 | - | ns |
| 29 | Usable Access Time (See Note 3) | t ACC | 695 | - | 440 | - | 330 | - | ns |
|  | Processor Control Setup Time (MRDY, Interrupts, $\overline{\text { DMA:BREQ }}$, $\overline{\text { HAL.T, }} \overline{\text { RESET }}$ ) (Figures 6, 8, 9, 10, 12, and 13) | tPCS | 200 | - | 140 | - | 110 | - | ns |
|  | Crystal Oscillator Start Time (Figures 6 and 7) | tr | - | 100 | - | 100 | - | 100 | ms |
|  | Processor Control Rise and Fall Time (Figures 6 and 8) | tPCr, tPCf | - | 100 | - | 100 | - | 100 | ns |

*Address and data hold times are periodically tested rather than 100\% tested

## NOTES:

1 Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4 \mathrm{~V}, \mathrm{~V}_{H} \geq 2.4 \mathrm{~V}$. unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.0 V , unless otherwise specified.
3. Usable access tume is computed by: 1-4-7 max $+10-17$.
4. Hold time ( 9 ) for BA and BS is not specified.
5. Maximum ${ }^{\mathrm{t}} \mathrm{Cyc}$ during MRDY or $\overline{\mathrm{DMA}} / \overline{\mathrm{BREQ}}$ is $16 \mu \mathrm{~s}$.

FIGURE 2 - EF6809 EXP ANDED BLOCK DIAGRAM


FIGURE 3 - bus timing test load

$C=30 \mathrm{pF}$ for $\mathrm{BA}, \mathrm{BS}$
130 pF for DO-D7, E, Q 90 pF for AO-A15, R/W
$R=11.7 \mathrm{k}$ for $D 0-D 7$
$16.5 \mathrm{k} \Omega$ for $\mathrm{A} 0-\mathrm{A} 15, \mathrm{E}, \mathrm{Q}, \mathrm{R} / \overline{\mathrm{W}}$ $24 \mathrm{k} \Omega$ for $B A, B S$

PROGRAMMING MODEL
As shown in Figure 4, the EF6809 adds th ree registers to the set available in the EF6800. The added registers include a direct page register, the user stack pointer, and a second index register.

ACCUMULATORS (A, B, D)
The $A$ and $B$ registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data.

Certain instructions concatenate the $A$ and $B$ registers to form a single 16 -bit accumulator. This is referred to as the $D$ register, and is formed with the $A$ register as the most significant byte.

## DIRECT PAGE REGISTER (DP)

The direct page register of the EF6809 serves to enhance the direct addressing mode. The content of this register appears at the higher address outputs (A8-A15) during direct addressing instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure 6800 compatiblity, all bits of this register are cleared during processor reset.


## INDEX REGISTERS ( $\mathrm{X}, \mathrm{Y}$ )

The index registers are used in indexed mode of athtrass ing. The 16 tht address in this register takes part in the: calculation of effective addresses. This adderess may be: used to point to data directly or may be: modifeed by an optional constant or register offset During some indexed morfers, the: contents of the index register are incremented or decrembent ed to point to the: next item of tathular type: data All four pointer registers $i X$. Y. U. Si may tee used as index reegisters.

## STACK POINTER (U,S)

The hardware stack pointer (S) is wsed automaturally by the processor during subroutine calls and interrupts The: stack pointers of the EF6809 point to the top of the stack, in contrast to the EF6800 stack pomter, which pointed to the: next free location on the stack. The user stack pointer (U) is controlled exclusively by the programmer. This allows arguments to be passed to and from subroutines with eise: Both stack pointers have the same indexed mode addressing capabilities as the $X$ and $Y$ registers, but also support Push and Pull instructions. This allows the EF6809 to tee usede:fti ciently as a stack processor, greatly enhancing its ability to support higher level languages and modular programrimirig

## PROGRAM COUNTER

The program counter is used by the processor to point to the address of the next instruction to be executed by the pro cessor. Relative addressing is provided aliowing the program counter to be used like an index register in some situations

## CONDITION CODE REGISTER

The condition code register defines the state of the pro cessor at any given time. See Figure 5

FIGURE 5 CONDITION CODE REGISTER FORMAT


## CONDITION CODE REGISTER DESCRIPTION

## BIT 0 (C)

Bit 0 is the carry flagg, and is usually the: carry from the: tenary ALU C is also used to reperesent a 'borrow' from suttritct likeinstructions (CMP. NEG. SUB. SBC) and is the: comple:rnent of the carry from the binary $A L U$

## BIT 1 (V)

Bit 1 is the overflow flayg, and is set to a one by an opera tion which causes a signed two's complemment arithmetir. overflow. This overflow is detected in in operation in which the carry from the MSB in the ALU does hot mate.h the c carry from the MSB 1.

BIT 2 (Z)
Bit 2 is the zero flag. ande is sef to a orie: if the restult of the: previous operation was infentically $2: r 0$

## BIT 3 (N)

Bit 3 is the negative flag, which contans exactly the value of the MSB of the result of the preceding operation. Thus, a negative two's-complement result will leave $N$ set to a one.

## BIT 4 (I)

Bit 4 is the $\overline{\mathrm{RO}}$ mask bit. The processor will not recognize interrupts from the $\overline{\mathrm{RQ}}$ line if this bit is set to a one. $\overline{\mathrm{NMI}}$, $\overline{F I R Q}, \overline{I R O}, \overline{R E S E T}$, and SWI all set I to a one. SWI2 and SWI3 do not affect 1

## BIT 5 (H)

Bit 5 is the half-carry bit, and is used to indicate a carry from bit 3 in the ALU as a result of an 8-bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is undefined in all subtract-like instructions.

## BIT 6 (F)

Bit 6 is the $\overline{F I R Q}$ mask bit. The processor will not recognize interrupts from the $\overline{F I R Q}$ line if this bit is a one. $\overline{\mathrm{NMI}}, \overline{\mathrm{FIRQ}}$, SWI, and $\overline{\mathrm{RESET}}$ all set $F$ to a one. $\overline{\mathrm{IRQ}}$, SWI2, and SWI3 do not affect $F$.

## BIT 7 (E)

Bit 7 is the entire flag, and when set to a one indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current $E$ left in the condition code register represents past action.

## PIN DESCRIPTIONS

## POWER (VSS, $\mathrm{V}_{\mathrm{CC}}$ )

Two pins are used to supply power to the part: $V_{S S}$ is ground or 0 volts, while $V_{C C}$ is $+5.0 \mathrm{~V} \pm 5 \%$.

## ADDRESS BUS (A0-A15)

Sixteen pins are used to output address information from the MPU onto the address bus. When the processor does not require the bus for a data transfer, it will output address FFFF $16, R / \bar{W}=1$, and $B S=0$; this is a "dummy access" or $\overline{\mathrm{VMA}}$ cycle. Addresses are valid on the rising edge of Q . All address bus drivers are made high impedance when output bus available (BA) is high. Each pin will drive one Schottky TTL load or four LSTTL loads, and 90 pF .

## DATA BUS (D0-D7)

These eight pins provide communication with the system bidirectional data bus. Each pin will drive one Schottky TTL load or four LSTTL loads, and 130 pF .

## READ/WRITE (R/W)

This signal indicates the direction of data transfer on the data bus. A low indicates that the MPU is writing data onto the data bus. $R / \bar{W}$ is made high impedance when $B A$ is high. $R / \bar{W}$ is valid on the rising edge of $Q$.

## RESET

A low level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in Figure 6. The reset vectors are fetched from locations FFFE 16 and FFFF 16 (Table 1 ) when interrupt acknowledge is true, ( $\overline{\mathrm{BA}} \cdot \mathrm{BS}=1$ ). During initial power on, the RESET line should be held low until the clock oscillator is fully operational. See Figure 7.

Because the EF6809 RESET pin has a Schmitt-trigger input with a threshold voltage higher than that of standard peripherals, a simple R/C network may be used to reset the entire system. This higher threshold voltage ensures that all peripherals are out of the reset state before the processor

## $\overline{\text { HALT }}$

A low level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven high indicating the buses are high impedance. BS is also high which indicates the processor is in the halt or bus grant state. While halted, the MPU will not respond to external real-time requests ( $\overline{F I R Q}, \overline{1 / Q Q}$ ) although $\overline{\mathrm{DMA}} / \overline{\mathrm{BREQ}}$ will always be accepted, and $\overline{\mathrm{NMI}}$ or $\overline{\mathrm{RESET}}$ will be latched for later response. During the halt state, $Q$ and $E$ continue to run normally. If the MPU is not running ( $\overline{R E S E T}$, $\overline{\mathrm{DMA}} / \overline{\mathrm{BREQ}})$, a halted state $(\mathrm{BA} \bullet \mathrm{BS}=1)$ can be achieved by pulling $\overline{\text { HALT }}$ low while $\overline{\operatorname{RESET}}$ is still low. If $\overline{\mathrm{DMA}} / \overline{\mathrm{BREQ}}$ and HALT are both pulled low, the processor will reach the last cycle of the instruction (by reverse cycle stealing) where the machine will the become halted. See Figure 8.

## BUS AVAILABLE, BUS STATUS (BA, BS)

The bus available output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. This signal does not imply that the bus will be available for more than one cycle. When BA goes low, a dead cycle will elapse before the MPU acquires the bus.

The bus status output signal, when decoded with BA, represents the MPU state (valid with leading edge of Q ).

| MPU State |  | MPU State Definition |
| :---: | :---: | :---: |
| BA | BS |  |
| 0 | 0 | Normal (Running) |
| 0 | 1 | Interrupt or Reset Acknowledge |
| 1 | 0 | Sync Acknowledge |
| 1 | 1 | Halt or Bus Grant Acknowledge |



NOTES: 1. Parts with date codes prefixed by 7F or 5A will come out of $\overline{\text { RESET }}$ one cycle sooner than shown.
2. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.
3. FFFE appears on the bus during $\overline{\operatorname{RESET}}$ low time. Following the active transition of the $\overline{\text { RESET }}$ line, three more FFFE cycles will appear followed by the vector fetch.

FIGURE 7 - CRYSTAL CONNECTIONS AND OSCILLATOR START UP


NOTE: Waveform measurements for all inputs and outputs are specified at logic high 2.0 V and logic low 0.8 V unless otherwise specified.



NOTE: Waveform measurements for all inputs and outputs are specified at logic high 2.0 V and logic low 0.8 V unless otherwise specified.

INTERRUPT ACKNOWLEDGE is indicated during both cycles of a hardware vector-fetch ( $\overline{\mathrm{RESET}}, \overline{\mathrm{NM}}$ ) $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRQ}}$, SWI, SWI2, SW $\mid 3$ ). This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 1
SYNC ACKNOWLEDGE is indicated while the MPU is waiting for external synchronization on an interrupt line.

HALT/BUS GRANT is true when the MC6809 is in a halt or bus grant condition.

TABLE 1 - MEMORY MAP FOR INTERRUPT VECTORS

| Memory Map For <br> Vector Locations |  | Interrupt Vector <br> Description |
| :---: | :---: | :---: |
| MS | LS | $\overline{\text { RESET }}$ |
| FFFE | FFFF | $\overline{\text { NMI }}$ |
| FFFC | FFFD | SWI |
| FFFA | FFFB | $\overline{\mid R Q}$ |
| FFF8 | FFF9 | $\overline{\text { FIRQ }}$ |
| FFF6 | FFF7 | SWI2 |
| FFF4 | FFF5 | SWI3 |
| FFF2 | FFF3 | Reserved |
| FFF0 | FFF1 |  |

## NON MASKABLE INTERRUPT (NMI) *

A negative transition on this input requests that a nonmaskable interrupt sequence be generated. A non-maskable
interrupt cannot be inhibited by the program, and also has a higher priority than $\overline{\mathrm{FIRQ}}, \overline{\mathrm{RO}}$, or software interrupts. During recognition of an NMI, the entire machine state is saved on the hardware stack. After reset, an $\overline{N M I}$ will not be recognized until the first program load of the hardware stack pointer ( S ). The pulse width of NMI low must be at least one E cycle. If the $\overline{N M I}$ input does not meet the minimum set up with respect to $Q$, the interrupt will not be recognized until the next cycle. See Figure 9.

## FAST-INTERRUPT REQUEST ( $\overline{\text { FIRQ }})^{*}$

A low level on this input pin will initiate a fast interrupt sequence, provided its mask bit (F) in the CC is clear. This sequence has priority over the standard interrupt request ( $\overline{\mathrm{RO}}$ ), and is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 10.

## INTERRUPT REQUEST ( $\overline{\mathrm{RQ}}$ ) *

A low level input on this pin will initiate an interrupt request sequence provided the mask bit (1) in the CC is clear. Since $\overline{\mathrm{RO}}$ stacks the entire machine state it provides a slower response to interrupts than $\overline{\mathrm{FIRQ}} . \overline{\mathrm{RO}}$ also has a lower priority than $\overline{\mathrm{FIRQ}}$. Again, the interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 9.

[^14]

NOTE: Waveform measurements for all inputs and outputs are specified at logic high $=2.0 \mathrm{~V}$ and logic low $=0.8 \mathrm{~V}$ unless otherwise specified
E clock shown for reference only


NOTE: Waveform measurements for all inputs and outputs are specified at logic high $=2.0 \mathrm{~V}$ and logic low $=0.8 \mathrm{~V}$ unless otherwise specified.
*E clock shown for reference only

## XTAL, EXTAL

These inputs are used to connect the on-chip oscillator to an external parallel-resonant crystal. Alternately, the pin EXTAL may be used as a TTL level input for external timing by grounding XTAL. The crystal or external frequency is four times the bus frequency. See Figure 7. Proper RF layout techniques should be observed in the layout of printed circuit boards.

E, Q
$E$ is similar to the EF6800 bus timing signal phase $2 ; Q$ is a quadrature clock signal which leads E. Q has no parrallel on the EF6800. Addresses from the MPU will be valid with the leading edge of $Q$. Data is latched on the falling edge of $E$. Timing for $E$ and $Q$ is shown in Figure 11.

## MRDY*

This input control signal allows stretching of E and Q to extend data-access time. E and Q operate normally while MRDY is high. When MRDY is low, $E$ and $Q$ may be stretched in integral multiples of quarter ( $1 / 4$ ) bus cycles, thus allowing interface to slow memories, as shown in Figure 12(a). During non-valid memory access ( $\overline{\mathrm{VMA}}$ cycles), MRDY has no effect on stretching $E$ and $Q$; this inhibits slowing the processor during "don't care" bus accesses. MRDY may also be
used to stretch clocks (for slow memory) when bus control has been transferred to an external device (through the use of $\overline{\mathrm{HALT}}$ and $\overline{\mathrm{DMA/BREQ})}$.

## $\overline{\text { DMA/BREQ }}$ *

The DMA/BREQ input provides a method of suspending execution and acquiring the MPU bus for another use, as shown in Figure 13. Typical uses include DMA and dynamic memory refresh.

A low level on this pin will stop instruction execution at the end of the current cycle unless pre-empted by self-refresh. The MPU will acknowledge DMA/BREQ by setting BA and BS to a one. The requesting device will now have up to 15 bus cycles before the MPU retrieves the bus for self-refresh. Self-refresh requires one bus cycle with a leading and trailing dead cycle. See Figure 14. The self-refresh counter is only cleared if DMA/BREQ is inactive for two or more MPU cycles

Typically, the DMA controller will request to use the bus by asserting $\overline{\mathrm{DMA} / B R E Q}$ pin low on the leading edge of $E$ When the MPU replies by setting BA and BS to a one, that cycle will be a dead cycle used to transfer bus mastership to the DMA controller.

False memory accesses may be prevented during any dead cycles by developing a system DMAVMA signal which is LOW in any cycle when BA has changed.


NOTE: Waveform measurements for all inputs and outputs are specified at logic high 2.0 V and logic low 0.8 V unless otherwise specified.

* The on-board clock generator furnishes E and $Q$ to both the system and the MPU. When MRDY is pulled low, both the system clocks and the internal MPU clocks are stretched. Assertion of DMA/ BREQ input stops the internal MPU clocks while allowing the external system clocks to RUN (i.e., release the bus to a DMA controller). The internal MPU clocks resume operation after $\overline{D M A} / \overline{B R E Q}$ is released or after 16 bus cycles ( 14 DMA, two dead), whichever occurs first. While $\overline{D M A} / \overline{B R E D}$ is asserted it is sometimes necessary to pull MRDY low to allow DMA to/from slow memory/peripherals. As both MRDY and $\overline{D M A} / \overline{B R E D}$ control the internal MPU clocks, care must be exercised not to violate the maximum $t_{\text {cyc }}$ specification for MRDY or $\overline{\mathrm{DMA}} / \overline{\mathrm{BREQ}}$. (Maximum $\mathrm{t}_{\mathrm{cyc}}$ during MRDY or $\overline{\mathrm{DMA}} / \overline{\mathrm{BREQ}}$ is $16 \mu \mathrm{~s}$.)

When BA goes low (either as a result of DMA/BRED $=$ HIGH or MPU self refresh), the DMA device should be taken off the bus. Another dead cycle will elapse before the MPU accesses memory to allow transfer of bus mastership without contention.

## MPU OPERATION

During normal operation, the MPU fetches an instruction from memory and then executes the requested function.

This sequence begins after RESET and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Software instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI, and SYNC. An interrupt, पALT, or DMA/BRED can also alter the normal execution of instructions. Figure 15 illustrates the flowchart for the EF6809.

(b) Synchronization



FIGURE 14 - AUTO-REFRESH DMA TIMING (> 14 CYCLES) (REVERSE CYCLE STEALING)


[^15]NOTE: Waveform measurements for all inputs and outputs are specified at logic high 2.0 V and logic low 0.8 V unless otherwise specified.


## ADDRESSING MODES

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The EF6809 has the most complete set of addressing modes available on any microcomputer today. For example, the EF6809 has 59 basic instructions; however, it recognizes 1464 different variations of instructions and addressing modes. The addressing modes support modern programming techniques. The following addressing modes are available on the EF6809 :
Inherent (includes accumulator)
Immediate
Extended
Extended Indirect
Direct
Register
Indexed
Zero-Offset
Constant Offset
Accumulator Offset
Auto Increment/Decrement
Indexed Indirect
Relative
Short/Long Relative Branching
Program Counter Relative Addressing

## INHERENT (INCLUDES ACCUMULATOR)

In this addressing mode, the opcode of the instruction contains all the address information necessary. Examples of inherent addressing are: ABX, DAA, SWI, ASRA, and CLRB.

## IMMEDIATE ADDRESSING

In immediate addressing, the effective address of the data is the location immediately following the opcode (i.e., the data to be used in the instruction immediately following the opcode of the instruction). The EF6809 uses both 8- and 16 -bit immediate values depending on the size of argument specified by the opcode. Examples of instructions with immediate addressing are:

```
LDA #$20
LDX #$FOOO
LDY #CAT
```


## NOTE

\# signifies Immediate addressing; \$ signifies hexadecimal value.

## EXTENDED ADDRESSING

In extended addressing, the contents of the two bytes immediately following the opcode fully specify the 16 -bit effective address used by the instruction. Note that the address generated by an extended instruction defines an absolute address and is not position independent. Examples of extended addressing include:

| LDA | CAT |
| :--- | :--- |
| STX | MOUSE |
| LDD | $\$ 2000$ |

EXTENDED INDIRECT - As in the special case of indexed addressing (discussed below), one level of indirection may be added to extended addressing. In extended indirect, the two bytes following the postbyte of an indexed instruction contain the address of the data.

| LDA | [CAT] |
| :--- | :--- |
| LDX | [\$FFFE] |
| STU | [DOG] |

## DIRECT ADDRESSING

Direct addressing is similar to extended addressing except that only one byte of address follows the opcode. This byte specifies the lower eight bits of the address to be used. The upper eight bits of the address are supplied by the direct page register. Since only one byte of address is required in direct addressing, this mode requires less memory and executes faster than extended addressing. Of course, only 256 locations (one page) can be accessed without redefining the contents of the DP register. Since the DP register is set to $\$ 00$ on reset, direct addressing on the EF6809 is compatible with direct addressing on the 6800. Indirection is not allowed in direct addressing. Some examples of direct addressing are:

```
LDA $30
SETDP $10 (assembler directive)
LDB $1030
LDD < CAT
NOTE
< is an assembler directive which forces direct addressing.
```


## REGISTER ADDRESSING

Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction. This is called a postbyte. Some examples of register addressing are:

| TFR | $X, Y$ | Transfers $X$ into $Y$ |
| :--- | :--- | :--- |
| EXG | A, B | Exchanges A with B |
| PSHS | A, B, X, Y | Push Y, X, B and A onto S |
| PULU | $X, Y, D$ | Pull D, X, and Y from U |

## INDEXED ADDRESSING

In all indexed addressing, one of the pointer registers ( X , $Y, U, S$, and sometimes $P C$ ) is used in a calculation of the ef fective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode as well as the pointer register to be used. Figure 16 lists the legal formats for the postbyte. Table 2 gives the assembler form and the number of cycles and bytes added to the basic values for indexed addressing for each variation.

FIGURE 16 - INDEXED ADDRESSING POSTBYTE REGISTER BIT ASSIGNMENTS


ZERO-OFFSET INDEXED - In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode. Examples are:

```
LDD O.X
LDA S
```

CONSTANT OFFSET INDEXED-In this mode, a two's complement offset and the contents of one of the pointer registers are added to form the effective address of the operand. The pointer register's initial content is unchanged by the addition.

Three sizes of offsets are available:

$$
\begin{aligned}
& 5 \text { bit }(-16 \text { to }+15) \\
& 8 \text { bit }(-128 \text { to }+127) \\
& 16 \text { bit }(-32768 \text { to }+32767)
\end{aligned}
$$

The two's complement 5 -bit offset is included in the postbyte and, therefore, is most efficient in use of bytes and cycles. The two's complement 8 -bit offset is contained in a single byte following the postbyte. The twos complement 16 -bit offset is in the two bytes following the postbyte. In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically.

Examples of constant-offset indexing are:

| LDA | $23, X$ |
| :--- | :--- |
| LDX | $-2, S$ |
| LDY | $300, X$ |
| LDU | $C A T, Y$ |

TABLE 2 - INDEXED ADDRESSING MODE

| Type | Forms | Non Indirect |  | $+$ | $\begin{aligned} & + \\ & \# \end{aligned}$ | Indirect. |  | + | + |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Assembler Form | Postbyte Opcode |  |  | Assembler Form | Postbyte Opcode |  |  |
| Constant Offset From R | No Offset | , R | 1RR00100 | 0 | 0 | [, R] | 1RR10100 | 3 | 0 |
| (2s Complement Offsets) | 5-Bit Offset | $n, R$ | ORRnnnnn | 1 | 0 | defaults to 8 -bit |  |  |  |
|  | 8-Bit Offset | $n, R$ | 1RR01000 | 1 | 1 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11000 | 4 | 1 |
|  | 16-Bit Offset | $n, R$ | 1RR01001 | 4 | 2 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11001 | 7 | 2 |
| Accumulator Offset From R (2s Complement Offsets) | A Register Offset | A, R | 1 1RR00110 | 1 | 0 | [ $\mathrm{A}, \mathrm{R}$ ] | 1RR10110 | 4 | 0 |
|  | B Register Offset | B, R | 1 RR00101 | 1 | 0 | [ $B, R]$ | 1RR10101 | 4 | 0 |
|  | D Register Offset | D, B | 1RR01011 | 4 | 0 | [D, R] | 1RR11011 | 7 | 0 |
| Auto Increment/ Decrement R | Increment By 1 | , R + | 1RR00000 | 2 | 0 | not allowed |  |  |  |
|  | Increment By 2 | , R+ + | 1RR00001 | 3 | 0 | [, R + + ] | 1RR10001 | 6 | 0 |
|  | Decrement By 1 | , -R | 1 RR00010 | 2 | 0 | not allowed |  |  |  |
|  | Decrement By 2 | , - - R | 1 RR00011 | 3 | 0 | [, - - R] | 1RR10011 | 6 | 0 |
| Constant Offset From PC (2s Complement Offsets) | 8-Bit Offset | n, PCR | $1 \times \times 01100$ | 1 | 1 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11100$ | 4 | 1 |
|  | 16-Bit Offset | n, PCR | 1xx01101 | 5 | 2 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11101$ | 8 | 2 |
| Extended indirect | 16-Bit Address | - | - | - | - | [ n ] | 10011111 | 5 | 2 |
| $R=X, Y, U$, or $S$ $R R:$ <br> $X=$ Don't Care $00=X$ <br>  $01=Y$ <br>  $10=U$ <br>  $r 1=S$ |  |  |  |  |  |  |  |  |  |

[^16]ACCUMULATOR-OFFSET INDEXED This mode is similar to constant offset indexed except that the two's complement value in one of the accurnulators (A, B, or D) and the contents of one of the pointer registers are added to form the effective address of the operand. The contents of both the accumulator and the pointer register are unchanged by the addition. The postbyte specifies which accumulator to use as an offset and no additional bytes are required. The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run-time.
Some examples are:

| LDA | $B, Y$ |
| :--- | :--- |
| LDX | $D, Y$ |
| LEAX | $B, X$ |

AUTO INCREMENT/DECREMENT INDEXED - In the auto increment addressing mode, the pointer register contains the address of the operand. Then, after the pointer register is used it is incremented by one or two. This äddressing mode is useful in stepping through tables, moving data, or for the creation of software stacks. In auto decrement, the pointer register is decremented prior to use as the address of the data. The use of auto decrement is similar to that of auto increment; but the tables, etc., are scanned from the high to low addresses. The size of the increment/ decrement can be either one or two to allow for tables of either 8 - or 16 -bit data to be accessed and is selectable by the programmer. The pre-decrement, post-increment nature of these modes allows them to be used to create additional software stacks that behave identically to the $U$ and $S$ stacks.

Some examples of the auto increment/decrement addressing modes are:

| LDA | ,$X+$ |
| :--- | :--- |
| STD | ,$Y++$ |
| LDB | ,$-Y$ |
| LDX | ,$--S$ |

Care should be taken in performing operations on 16 -bit pointer registers ( $X, Y, U, S$ ) where the same register is used to calculate the effective address.
Consider the following instruction:

$$
\text { STX } 0, X++(X \text { initialized to } 0)
$$

The desired result is to store zero in locations $\$ 0000$ and $\$ 0001$ then increment $\cdot X$ to point to $\$ 0002$. In reality, the following occurs:

| $0 \rightarrow$ temp | calculate the EA; temp is a holding register |
| :--- | :--- |
| $X+2 \rightarrow X$ | perform auto increment |
| $X \rightarrow$ (temp) | do store operation |

INDEXED INDIRECT - All of the indexing modes, with the exception of auto increment/decrement by one or a $\pm 4$-bit offset, may have an additional level of indirection specified. In indirect addressing, the effective address is contained at the location specified by the contents of the index register plus any offset. In the example below, the A accumulator is loaded indirectly using an effective address calculated from the index register and an offset.

|  | $\begin{aligned} & \text { Before Execution } \\ & A=X X(\text { don't care) } \\ & X=\$ F 000 \end{aligned}$ |  |
| :---: | :---: | :---: |
| \$0100 | LDA $\|\$ 10, \mathrm{X}\|$ | EA is now \$F010 |
| \$F010 | \$F1 | \$F150 is now the |
| \$F011 | \$50 | new EA |
| \$F150 | $\$ A A$ |  |
|  | After Execution |  |
|  | $A=\$ A A$ Actual Data Loaded |  |

All modes of indexed indirect are included except those which are meaningless (e.g., auto increment/decrement by one indirect). Some examples of indexed indirect are:

| LDA | $[, X]$ |
| :--- | :--- |
| LDD | $[10, S]$ |
| LDA | $[B, Y]$ |
| LDD | $[, X++]$ |

## RELATIVE ADDRESSING

The byte(s) following the branch opcode is (are) treated as a signed offset which may be added to the program counter If the branch condition is true, then the calculated address (PC + signed offset) is loaded into the program counter. Program execution continues at the new location as indicated by the PC; short (one byte offset) and long (two bytes offset) relative addressing modes are available. All of memory can be reached in long relative addressing as an effective address is interpreted modulo $2^{16}$. Some examples of relative addressing are:

|  | BEQ | CAT | (short) |
| :--- | :--- | :--- | :--- |
|  | BGT | DOG | (short) |
| CAT | LBEQ | RAT | (long) |
| DOG | LBGT | RABBIT | (long) |
|  | $\bullet$ |  |  |
|  | $\bullet$ |  |  |
| RAT | NOP |  |  |
| RABBIT | NOP |  |  |

PROGRAM COUNTER RELATIVE - The PC can be used as the pointer register with 8 - or 16 -bit signed offsets. As in relative addressing, the offset is added to the current PC to create the effective address. The effective address is then used as the address of the operand or data. Program counter relative addressing is used for writing position independent programs. Tables related to a particular routine will maintain the same relationship after the routine is moved, if referenced relative to the program counter. Examples are:

```
LDA CAT, PCR
LEAX TABLE, PCR
```

Since program counter relative is a type of indexing, an additional level of indirection is available.

```
LDA [CAT, PCR]
LDU [DOG, PCR]
```


## INSTRUCTION SET

The instruction set of the EF6809E is similar to that of the 6800 and is upward compatible at the source code level. The number of opcodes has been reduced from 72 to 59, but because of the expanded architecture and additional addressing modes, the number of available opcodes (with different addressing modes) has risen from 197 to 1464.
Some of the new instructions are described in detail below.

## PSHU/PSHS

The push instructions have the capability of pushing onto etther the hardware stack (S) or user stack (U) any single register or set of registers with a single instruction.

## PULU/PULS

The pull instructions have the same capability of the push instruction, in reverse order. The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled. The actual push/pull sequence is fixed; each bit defines a unique register to push or pull, as shown below.

## Push/Pull Postbyte


Stacking Order
Pull Order
CC
A
B
DP
$\times$ Hi
$\times$ Lo
Y Hi
Y Lo
U/S Hi
U/S Lo
PC Hi
PC Lo
$\uparrow$
Push Order
Increasing
Memory
$\downarrow$

## TFR/EXG

Within the EF6809E, any register may be transferred to or exchanged with another of like size, i.e., 8 bit to 8 bit or 16 bit to 16 bit. Bits $4-7$ of postby te define the source register, while bits $0-3$ represent the destination register. These are denoted as follows:
Transfer/Exchange Postbyte

Register Field

| 0000 | $=D(A: B)$ | $1000=A$ |  |
| ---: | :--- | ---: | :--- |
| 0001 | $=X$ | $1001=B$ |  |
| 0010 | $=Y$ | $1010=C C R$ |  |
| 0011 | $=U$ | $1011=D P R$ |  |
| 0100 | $=\mathrm{S}$ |  |  |
| 0101 | $=P C$ |  |  |

All other combinations are undefined and INVALID.

## LEAX/LEAY/LEAU/LEAS

The LEA (load effective address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in Table 3.
The LEA instruction also allows the user to access data and tables in a position independent manner. For example:

```
LEAX MSG1,PCR
LBSR PDATA (print message routine)
\bullet
\bullet
```

MSG1 FCC 'MESSAGE'

This sample program prints: 'MESSAGE'. By writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the $X$ pointer register. This code is totally position independent.

The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the auto increment and auto decrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows: LEAa, $\mathrm{b}+\quad$ lany of the 16 -bit pointer registers $\mathrm{X}, \mathrm{Y}$,
$U$, or $S$ may be substituted for $a$ and $b$ )

1. $b \rightarrow$ temp
2. $b+1 \rightarrow b$
(calculate the EA)
(modify b, postincrement)
(load a)
LEAa , - b
3. $\mathrm{b}-1 \rightarrow$ temp (calculate EA with predecrement)
4. $b-1 \rightarrow b \quad$ (modify b, predecrement)
5. temp $\rightarrow a \quad$ (load $a)$

TABLE 3 - LEA EXAMPLES

| Instruction | Operation | Comment |
| :---: | :---: | :---: |
| LEAX 10, $X$. | $x+10 \rightarrow x$ | Adds 5-Bit Constant 10 to X |
| LEAX 500, $X$ | $X+500 \rightarrow X$ | Adds 16-Bit Constant 500 to $X$ |
| LEAY A, Y | $Y+A \rightarrow Y$ | Adds 8-Bit A Accumulator to $Y$ |
| LEAY D, Y | $Y+D \rightarrow Y$ | Adds 16-Bit D Accumulator to $Y$ |
| LEAU - 10, U | $U-10 \rightarrow U$ | Substracts 10 from U |
| LEAS - 10, S | $\mathrm{S}-10 \rightarrow \mathrm{~S}$ | Used to Reserve Area on Stack |
| LEAS 10, S | $S+10 \rightarrow S$ | Used to 'Clean Up' Stack |
| LEAX 5, S | $S+5 \rightarrow X$ | Transfers As Well As Adds |

Auto increment-by-two and auto decrement-by-two instructions work similarly. Note that LEAX; $X+$ does not change $X$; however, LEAX, $-X$ does decrement; LEAX 1, X should be used to increment $X$ by one

## MUL

Multiplies the unsigned binary numbers in the $A$ and $B$ accumulator and places the unsigned result into the 16 -bit $D$ accumulator. The unsigned multiply also allows multipleprecision multiplications

## LONG AND SHORT RELATIVE BRANCHES

The EF6809 has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 - or 16 -bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64 K memory map. Position-independent code can be easily generated through the use of relative branching. Both short ( 8 -bit) and long (16-bit) branches are available.

## SYNC

After encountering a sync instruction, the MPU enters a sync state, stops processing instructions, and waits for an interrupt. If the pending interrupt is non-maskable (NM) or maskable ( $\overline{F I R Q}, \overline{\mathrm{RQ}}$ ) with its mask bit (F or I) clear, the processor will clear the sync state and perform the normal interrupt stacking and service routine. Since $\overline{F I R Q}$ and $\overline{\mathrm{RQ}}$ are not edge-triggered, a low level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{RQ}}$ ) with its mask bit (F or I) set, the processor will clear the sync state and continue processing by executing the next in:tine instruction. Figure 17 depicts sync timing.

## SOFTWARE INTERRUPTS

A software interrupt is an instruction which will cause an interrupt and its associated vector fetch. These software interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on the EF6809, and are prioritized in the following order: SWI, SWI2, SWI3.

## 16-BIT OPERATION

The EF6809, has the capability of processing 16 -bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes, and pulls.

## CYCLE-BY-CYCLE OPERATION

The address bus cycle-by-cycle performance chart (Figure 18) illustrates the memory-access sequence corresponding to each possible instruction and addressing mode in the EF6809. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this technique considerably speeds throughput.) Next, the operation of each opcode will follow the flowchart. $\overline{\mathrm{VMA}}$ is an indication of FFFF 16 on the address bus, $R / \bar{W}=1$ and $B S=0$. The following examples illustrate the use of the chart.

Example 1: LBSR (Branch Taken) Before Execution SP $=\mathrm{F} 000$

|  | $\bullet$ |  |
| :--- | :--- | :--- |
| $\$ 8000$ |  | LBSR |
|  |  | CAT |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

CYCLE-BY-CYCLE FLOW

| Cycle \# | Address | Data | R/ $\overline{\mathbf{W}}$ | Description |
| :---: | :---: | :---: | :---: | :--- |
| 1 | 8000 | 17 | 1 | Opcode Fetch |
| 2 | 8001 | 20 | 1 | Offset High Byte |
| 3 | 8002 | 00 | 1 | Offset Low Byte |
| 4 | FFFF | $*$ | 1 | $\overline{\text { VMA Cycle }}$ |
| 5 | FFFF | $*$ | 1 | $\overline{\text { VMA Cycle }}$ |
| 6 | AOOO | $*$ | 1 | Computed Branch Address |
| 7 | FFFF | $*$ | 1 | VMA Cycle |
| 8 | EFFF | 80 | 0 | Stack High Order Byte of <br> Return Address <br> 9 |
|  | EFFE | 03 | 0 | Stack Low Order Byte of <br> Return Address |

Example 2: DEC (Extended)

| $\$ 8000$ | DEC | @A000 |
| :--- | :--- | :--- |
|  |  |  |
| $\$ A 8000$ | $\$ 80$ |  |

CYCLE-BY-CYCLE FLOW

| Cycle \# | Address | Data | R/ $\overline{\mathbf{W}}$ | Description |
| :---: | :---: | :---: | :---: | :--- |
| 1 | 8000 | 7A | 1 | Opcode Fetch |
| 2 | 8001 | A0 | 1 | Operand Address, High Byte |
| 3 | 8002 | 00 | 1 | Operand Address, Low Byte |
| 4 | FFFF | $*$ | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | $*$ | 1 | $\overline{\text { VMA Cycle }}$ |
| 7 | A000 | 7F | 0 | Store the Decremented Data |

*The data bus has the data at that particular address.

## INSTRUCTION SET TABLES

The instructions of the EF6809 have been broken down into five different categories. They are as follows:

8 -bit operation (Table 4)
16-bit operation (Table 5)
Index register/stack pointer instructions (Table 6)
Relative branches (long or short) (Table 7) Miscellaneous instructions (Table 8)
Hexadecimal values for the instructions are given in Table 9.

## PROGRAMMING AID

Figure 19 contains a compilation of data that will assist in programming the EF6809.


NOTES:

1. If the associated mask bit is set when the interrupt is requested, this cycle will be an instruction fetch from address location PC +1 . However, if the interrupt is accepted ( (NMI or an unmasked $\overline{\mathrm{FIRO}}$ or $\overline{\mathrm{RO})}$ interrupt processing continues with this cycle as m on Figures 9 and 10 (Interrupt Timing)
If mask bits are clear, $\overline{\mathrm{RO}}$ and $\overline{\mathrm{FIRO}}$ must be held low for three cycles to guarantee interrupt to be taken, although only one cycle is necessary to bring the processor out of SYNC
2. Waveform measurements for all inputs and outputs are specified at logic high 2.0 V and logic low 0.8 V unless otherwise specified.



FIGURE 18 - CYCLE-BY-CYCLE PERFORMANCE (Sheet 3 of 9)


FIGURE 18 - CYCLE-BY-CYCLE PERFORMANCE (Sheet 4 of 9 )


FIGURE 18 - CYCLE-BY-CYCLE PERFORMANCE (Sheet 5 of 9)





Effective Address (EA)
$\frac{\text { Constant Offset from R }}{\text { No Offset }}$
No Offset
It Offset
8-Bit Offset
16-Bit Offset

Accumulator Offset from R
A Register Offset
B Register Offset
D Register Offset
Auto Increment/Decrement R
Increment by 1
Increment by 2
Decrement by 1
Decrement by 2
Constant Offset from PC
8-Bit Offset
16-Bit Offset

## Direct

Extended
Immediate
*The index register is incremented following the indexed access

Index Register
Index Register
Index Register + Post Byte
Index Register + Post Byte High: Post Byte Low

Index Register + A Register
Index Register + B Register
Index Register + D Register

Index Register**
Index Register *
Index Register - 1
Index Register - 2

Program Counter + Offset Byte
Program Counter + Offset High Byte. Offset Low Byte
Direct Page Register Address Low
Address High Address Low
NNNN + 1


Effective Address (EA)

| Constant Offset from R |
| :--- |
| No Offset |
| 5-Bit Offset |
| 8-Bit Offset |
| 16-Bit Offset |

Accumulator Offset from R
A Register Offset
B Register Offset
D Register Offset

Auto Increment/Decrement R
Increment by 1
Increment by 2
Decrement by 1
Decrement by 2

$\frac{\text { Constant Offset from PC }}{8-\text { Bit Offset }}$
16 -Bit Offset

## Direct

Extended
Immediate

[^17][^18]TABLE 4 - 8-BIT ACCUMULATOR AND MEMORY INSTRUCTIONS

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADCA, ADCB | Add memory to accumulator with carty |
| ADDA, ADDB | Add memory to accumulator |
| ANDA, ANDB | And memory with accumulator |
| ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left |
| ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right |
| BITA, BITB | Bit test memory with accumulator |
| CLR, CLRA, CLRB | Clear accumulator or memory location |
| CMPA, CMPB | Compare memory from accumulator |
| COM, COMA, COMB | Complement accumulator or memory location |
| DAA | Decimal adjust A accumulator |
| DEC, DECA, DECB | Decrement accumulator or memory location |
| EORA, EORB | Exclusive or memory with accumulator |
| EXG R1, R2 | Exchange R1 with R2 (R1, R2 $=$ A, B, CC, DP) |
| INC, INCA, INCB | Increment accumulator or memory location |
| LDA, LDB | Load accumulator from memory |
| LSL, LSLA, LSLB | Logical shift left accumulator or memory location |
| LSR, LSRA, LSRB | Logical shift right accumulator or memory location |
| MUL | Unsigned multiply (A $\times$ B $\rightarrow$ D) |
| NEG, NEGA, NEGB | Negate accumulator or memory |
| ORA, ORB | Or memory with accumulator |
| ROL, ROLA, ROLB | Rotate accumulator or memory left |
| ROR, RORA, RORB | Rotate accumulator or memory right |
| SBCA, SBCB | Subtract memory from accumulator with borrow |
| STA, STB | Store accumulator to memory |
| SUBA, SUBB | Subtract memory from accumulator |
| TST, TSTA, TSTB | Test accumulator or memory location |
| TFR R1, R2 | Transfer R1 to R2 (R1, R2 $=$ A, B, CC, DP) |

NOTE: A, B, CC, or DP may be pushed to (pulled from) stack with either PSHS, PSHU (PULS, PULU) instructions.

TABLE 5 - 16-BIT ACCUMULATOR AND MEMORY INSTRUCTIONS

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADDD | Add memory to $D$ accumulator |
| CMPD | Compare memory from $D$ accumulator |
| EXG D, R | Exchange D with $X, Y, S, U$, or PC |
| LDD | Load D accumulator from memory |
| SEX | Sign Extend B accumulator into A accumulator |
| STD | Store D accumulator to memory |
| SUBD | Subtract memory from $D$ accumulator |
| TFR D, R | Transfer $D$ to $X, Y, S, U$, or PC |
| TFR R, D | Transfer $X, Y, S, U$, or PC to $D$ |

NOTE: D may be pushed (pulled) to stack with either PSHS, PSHU (PULS, PULU) instructions.

TABLE 6 - INDEX REGISTER/STACK POINTER INSTRUCTIONS

| Instruction | Description |
| :---: | :---: |
| CMPS, CMPU | Compare memory from stack pointer |
| CMPX, CMPY | Compare memory from index register |
| EXG R1, R2 | Exchange D, X, Y, X, U, or PC with D, X Y, S, U, or PC |
| LEAS, LEAU | Load effective address into stack pointer |
| LEAX, LEAY | Load effective address into index register |
| LDS, LDU | Load stack pointer from memory |
| LDX, LDY | Load index register from memory |
| PSHS | Push A, B, CC, DP, D, X, Y, U, or PC onto hardware stack |
| PSHU | Push A, B, CC, DP, D, X, Y, S, or PC onto user stack |
| PULS | Pull A, B, CC, DP, D, X, Y, U, or PC from hardware stack |
| PULU | Pull A, B, CC, DP, D, X, Y, S. or PC from hardware stack |
| STS, STU | Store stack pointer to memory |
| STX, STY | Store index register to memory |
| TFR R1, R2 | Transter D, X, Y, S, U or PC to D, X, Y, S, U, or PC |
| $A B X$ | Add B accumulator to $X$ (unsigned) |

TABLE 7 - BRANCH INSTRUCTIONS

| Instruction | Description |
| :---: | :---: |
| SIMPLE BRANCHES |  |
| BEO, LBEQ | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BMI, LBMI | Branch if minus |
| BPL, LBPL | Branch if plus |
| BCS, LBCS | Branch if carry set |
| BCC, LBCC | Branch if carry clear |
| BVS, LBVS | Branch if overflow set |
| BVC, LBVC | Branch if overflow clear |
| SIGNED BRANCHES |  |
| BGT, LBGT | Branch if greater (signed) |
| BVS, LBVS | Branch if invalid 2s complement result |
| BGE, LBGE | Branch if greater than or equal (signed) |
| BEQ, LBEQ | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BLE, LBLE | Branch if less than or equal (signed) |
| BVC, LBVC | Branch if valid 2s complement result |
| BLT, LBLT | Branch if less than (signed) |
| UNSIGNED BRANCHES |  |
| BHI, LBHI | Branch if higher (unsigned) |
| BCC, LBCC | Branch if higher or same (unsigned) |
| BHS, LBHS | Branch if higher or same (unsigned) |
| BEQ, LBEO | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BLS, LBLS | Branch if lower or same (unsigned) |
| BCS, LBCS | Branch if lower (unsigned) |
| BLO, LBLO | Branch if lower (unsigned) |
| OTHER BRANCHES |  |
| BSR, LBSR | Branch to subroutine |
| BRA, LBRA | Branch always |
| BRN, LBRN | Branch never |

TABLE 8 - MISCELLANEOUS INSTRUCTIONS

| Instruction | Description |
| :--- | :--- |
| ANDCC | AND condition code register |
| CWAI | AND condition code register, then wait for interrupt |
| NOP | No operation |
| ORCC | OR condition code register |
| JMP | Jump |
| JSR | Jump to subroutine |
| RTI | Return from interrupt |
| RTS | Return from subroutine |
| SWI, SWI2, SWI3 | Software interrupt labsolute indirect) |
| SYNC | Synchronize with interrupt line |


| OP | Mnem | Mode | $\sim$ | * | OP | Mnem | Mode | $\sim$ | \# | OP | Mnem | Mode | - | * |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | $4+$ | $2+$ | 60 | NEG | Indexed | $6+$ | $2+$ |
| 01 | * | A |  |  | 31 | LEAY |  | $4+$ | $2+$ | 61 |  | 4 |  |  |
| 02 | * |  |  |  | 32 | LEAS |  | $4+$ | $2+$ | 62 | * |  |  |  |
| 03 | COM |  | 6 | 2 | 33 | LEAU | indexed | $4+$ | $2+$ | 63 | COM |  | $6+$ | $2+$ |
| 04 | LSR |  | 6 | 2 | 34 | PSHS | Immed | $5+$ | 2 | 64 | LSR |  | $6+$ | $2+$ |
| 05 | * |  |  |  | 35 | PULS | 1 mmed | $5+$ | 2 | 65 | * |  |  |  |
| 06 | ROR |  | 6 | 2 | 36 | PSHU | Immed | $5+$ | 2 | 66 | ROR |  | $6+$ | $2+$ |
| 07 | ASR |  | 6 | 2 | 37 | PULU | Immed | $5+$ | 2 | 67 | ASR |  | $6+$ | $2+$ |
| 08 | ASL, LSL |  | 6 | 2 | 38 | * | -- |  |  | 68 | ASL, LSL |  | $6+$ | $2+$ |
| 09 | ROL |  | 6 | 2 | 39 | RTS | Inherent | 5 | 1 | 69 | ROL |  | $6+$ | $2+$ |
| OA | DEC |  | 6 | 2 | 3 A | $A B X$ | 4 | 3 | 1 | 6 A | DEC |  | $6+$ | $2+$ |
| OB | * |  |  |  | 3B | RTI |  | 6/15 | 1 | 6 B | * |  |  |  |
| OC | INC |  | 6 | 2 | 3 C | CWAI | $\downarrow$ | $\geq 20$ | 2 | 6 C | INC |  | $6+$ | $2+$ |
| OD | TST |  | 6 | 2 | 3D | MUL | Inhetent | 11 | 1 | 6D | TST |  | $6+$ | $2+$ |
| OE | JMP | $\checkmark$ | 3 | 2 | 3E | * | - |  |  | 6 E | JMP | $\dagger$ | $3+$ | $2+$ |
| OF | CLR | Direct | 6 | 2 | 3F | SWI | Inherent | 19 | 1 | 6 F | CLR | Indexed | $6+$ | $2+$ |
| 10 | Page 2 | - | - | - | 40 | NEGA | Inherent | 2 | 1 | 70 | NEG | Extended | 7 | 3 |
| 11 | Page 3 | - | - | - | 41 |  | 4 |  |  | 71 | * | $\uparrow$ |  |  |
| 12 | NOP | Inherent | 2 | 1 | 42 | * |  |  |  | 72 | * |  |  |  |
| 13 | SYNC | Inherent | $\geq 4$ | 1 | 43 | COMA |  | 2 | 1 | 73 | COM |  | 7 | 3 |
| 14 | * |  |  |  | 44 | LSRA |  | 2 | 1 | 74 | LSR |  | 7 | 3 |
| 15 | * |  |  |  | 45 | * |  |  |  | 75 | * |  |  |  |
| 16 | LBRA | Relative | 5 | 3 | 46 | RORA |  | 2 | 1 | 76 | ROR |  | 7 | 3 |
| 17 | LBSR | Relative | 9 | 3 | 47 | ASRA |  | 2 | 1 | 77 | ASR |  | 7 | 3 |
| 18 | * |  |  |  | 48 | ASLA, LSLA |  | 2 | 1 | 78 | ASL, LSL |  | 7 | 3 |
| 19 | DAA | Inherent | 2 | 1 | 49 | ROLA |  | 2 | 1 | 79 | ROL |  | 7 | 3 |
| 1 A | ORCC | 1 mmed | 3 | 2 | 4A | DECA |  | 2 | 1 | 7 A | DEC |  | 7 | 3 |
| 1B | * | - |  |  | 4 B | * |  |  |  | 7 B | * |  |  |  |
| 1C | ANDCC | Immed | 3 | 2 | 4 C | INCA |  | 2 | 1 | 7 C | INC |  | 7 | 3 |
| 1D | SEX | Inherent | 2 | 1 | 4D | TSTA |  | 2 | 1 | 70 | TST |  | 7 | 3 |
| 1E | EXG | 1 mmed | 8 | 2 | 4 E | * | $\nabla$ |  |  | 7 E | JMP | $\checkmark$ | 4 | 3 |
| 1F | TFR | 1 mmed | 6 | 2 | 4F | CLRA | Inherent | 2 | 1 | 7F | CLR | Extended | 7 | 3 |
| 20 | BRA | Relative | 3 | 2 | 50 | NEGB |  | 2 | 1 |  |  | Immed | 2 | 2 |
| 21 | BRN | 4 | 3 | 2 | 51 | * | 4 |  |  | 81 | CMPA | 4 | 2 | 2 |
| 22 | BHI |  | 3 | 2 | 52 | * |  |  |  | 82 | SBCA |  | 2 | 2 |
| 23 | BLS |  | 3 | 2 | 53 | COMB |  | 2 | 1 | 83 | SUBD |  | 4 | 3 |
| 24 | BHS, BCC |  | 3 | 2 | 54 | LSRB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 |
| 25 | BLO, BCS |  | 3 | 2 | 55 | * |  |  |  | 85 | BITA |  | 2 | 2 |
| 26 | BNE |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 86 | LDA |  | 2 | 2 |
| 27 | BEO |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 87 | * |  |  |  |
| 28 | BVC |  | 3 | 2 | 58 | ASLB, LSLB |  | 2 | 1 | 88 | EORA |  | 2 | 2 |
| 29 | BVS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 89 | ADCA |  | 2 | 2 |
| 2A | BPL |  | 3 | 2 | 5A | DECB |  | 2 | 1 | 8A | ORA | $J$ | 2 | 2 |
| 2 B | BMI |  | 3 | 2 | 5B | * |  |  |  | 8B | ADDA | $\nabla$ | 2 | 2 |
| 2 C | BGE |  | 3 | 2 | 5 C | INCB |  | 2 | 1 | 8C | CMPX | Immed | 4 | 3 |
| 2D | BLT |  | 3 | 2 | 5D | TSTB |  | 2 | 1 | 8 D | BSR | Relative | 7 | 2 |
| 2 E | BGT | $\downarrow$ | 3 | 2 | 5 E | * | , |  |  | 8 E | LDX | 1 mmed | 3 | 3 |
| 2 F | BLE | Relative | 3 | 2 | 5 F | CLRB | Inherent | 2 | 1 | 8 F | * |  |  |  |

LEGEND
~ Number of MPU cycles (less possible push pull or indexed-mode cycles)
\# Number of program bytes

* Denotes unused opcode

TABLE 9 - HEXADECIMAL VALUES OF MACHINE CODES (CONTINUED)


FIGURE 19 - PROGRAMMING AID


FIGURE 19 - PROGRAMMING AID (CONTINUED)

| Instruction | Forms | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Description | $\frac{5}{H}$ |  | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Immediate |  |  | Direct |  |  | Indexed 1 |  |  | Extended |  |  | Inherent |  |  |  |  | 3 |  |  |  |
|  |  | Op | $\sim$ | 7 | Op | - | \# | Op | $\checkmark$ | 7 | Op | $\sim$ | \# | Op | - | \# |  |  | N | Z | V | C |
| LSL | $\begin{aligned} & \text { LSLA } \\ & \text { LSLB } \\ & \text { LSL } \end{aligned}$ |  |  |  | 08 | 6 | 2 | 68 | $6+$ | $2+$ | 78 | 7 | 3 | $\begin{aligned} & 48 \\ & 58 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\bullet \cdot$ | 1 <br> 1 <br> 1 | 1 <br> 1 <br> 1 | 1 <br> $\vdots$ <br> 1 | 1 <br> 1 <br> 1 |
| L.SR | $\begin{aligned} & \text { LSRA } \\ & \text { LSRB } \\ & \text { LSR } \end{aligned}$ |  |  |  | 04 | 6 | 2 | 64 | $0+$ | $2+$ | 74 | 7 | 3 | $\begin{aligned} & 44 \\ & 54 \end{aligned}$ | 2 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\left.\begin{array}{c} A \\ B \\ M \end{array}\right\} 0 \rightarrow \prod_{B_{7}} \prod \prod_{0} \prod_{C} \rightarrow \prod_{C}$ | $\bullet \cdot$ | $\begin{array}{\|l\|} \hline 0 \\ 0 \\ 0 \end{array}$ | 1 $\vdots$ 1 | $\bullet \cdot$ | 1 1 |
| MUL |  |  |  |  |  |  |  |  |  |  |  |  |  | 3D | 11 | 1 | $A \times B-D$ (Unsigned) | $\bullet$ | $\bullet$ | 1 | - | 9 |
| NEG | $\begin{array}{\|l\|} \hline \text { NEGA } \\ \text { NEGB } \\ \text { NEG } \\ \hline \end{array}$ |  |  |  | 00 | 6 | 2 | 60 | $6+$ | $2+$ | 70 | 7 | 3 | $\begin{aligned} & 40 \\ & 50 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \overline{\bar{A}}+1-\mathrm{A} \\ & \bar{B}+1-B \\ & \bar{M}+1 \rightarrow M \end{aligned}$ | $\begin{aligned} & 8 \\ & 8 \\ & 8 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} \hline 1 \\ 1 \\ 1 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 <br> 1 <br> 1 | $\begin{array}{\|c} 1 \\ 1 \\ 1 \\ \hline \end{array}$ |
| NOP |  |  |  |  |  |  |  |  |  |  |  |  |  | 12 | 2 | 1 | No Operation | - | - | - | - | $\bullet$ |
| OR | $\begin{array}{\|l\|} \hline \text { ORA } \\ \text { ORB } \\ \text { ORCC } \\ \hline \end{array}$ | $\begin{aligned} & \hline 8 A \\ & C A \\ & 1 A \\ & \hline \end{aligned}$ | $\begin{array}{r} 2 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 9 A \\ & D A \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{AA} \\ & \mathrm{EA} \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \mathrm{BA} \\ & \mathrm{FA} \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A \vee M-A \\ & B \vee M-B \\ & C C \vee M M-C C \\ & \hline \end{aligned}$ | $\bullet$ | $1$ | $1$ | $\begin{array}{\|l\|} \hline 0 \\ 0 \\ 7 \\ \hline \end{array}$ | $\bullet$ |
| PSH | $\begin{aligned} & \text { PSHS } \\ & \text { PSHU } \end{aligned}$ | $\begin{aligned} & 34 \\ & 36 \\ & \hline \end{aligned}$ | $\begin{aligned} & 5+4 \\ & 5+4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | Push Registers on S Stack Pish Registers on U Stack | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| PUL | PULS <br> pulu | $\begin{aligned} & 35 \\ & 37 \end{aligned}$ | $\begin{aligned} & 5+4 \\ & 5+4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | Pull Registers from S Stack Pull Registers from U Stack | $\bullet$ | $\bullet$ | - | - | - |
| ROL | $\begin{aligned} & \text { ROLA } \\ & \text { ROLB } \\ & \text { ROL } \end{aligned}$ |  |  |  | 09 | 6 | 2 | 69 | $6+$ | $2+$ | 79 | 7 | 3 | $\begin{aligned} & 49 \\ & 59 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\stackrel{-}{\bullet}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 <br> 1 <br> 1 | 1 <br> 1 <br> 1 <br> 1 | 1 <br> 1 <br> 1 |
| ROR | $\begin{aligned} & \text { RORA } \\ & \text { RORB } \\ & \text { ROR } \end{aligned}$ |  |  |  | 06 | 6 | 2 | 66 | $6+$ | $2+$ | 76 | 7 | 3 | $\begin{aligned} & 46 \\ & 56 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $1$ |  | $\stackrel{\rightharpoonup}{\bullet}$ | 1 1 1 | 1 1 1 | $\bullet \cdot$ | 1 <br> 1 <br> 1 |
| RTI |  |  |  |  |  |  |  |  |  |  |  |  |  | 3B | 6/15 | 1 | Return From Interrupt |  |  |  |  | 7 |
| RTS |  | . |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 | Return from Subroutine | $\bullet$ | - | - | - | $\bullet$ |
| SBC | $\begin{aligned} & \text { SBCA } \\ & \text { SBCB } \end{aligned}$ | $\begin{aligned} & 82 \\ & \mathrm{C} 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 92 \\ & \mathrm{D} 2 \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{A} 2 \\ & \mathrm{E} 2 \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \text { B2 } \\ & \text { F2 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | 3 |  |  |  | $A-M-C-A$ | $\begin{aligned} & 8 \\ & 8 \end{aligned}$ | $1$ | ! | $!$ | 1 <br> 1 |
| SEX |  |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 2 | 1 | Sign Extend $B$ into $A$ | - | 1 | 1 | 0 | $\bullet$ |
| ST | $\begin{aligned} & \hline \text { STA } \\ & \text { STB } \\ & \text { STD } \\ & \text { STS. } \\ & \text { STU } \\ & \text { STX } \\ & \text { STY } \end{aligned}$ |  |  |  | $\begin{aligned} & 97 \\ & D 7 \\ & D D \\ & 10 \\ & D F \\ & D F \\ & 9 F \\ & 10 \\ & 9 F \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 5 \\ & 6 \\ & 5 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & \hline 2 \\ & 2 \\ & 2 \\ & 3 \\ & 2 \\ & 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{gathered} \text { A7 } \\ E 7 \\ E D \\ 10 \\ E F \\ E F \\ A F \\ 10 \\ A F \end{gathered}$ | $\begin{array}{\|l\|} \hline 4+ \\ 4+ \\ 5+ \\ 6+ \\ 5+ \\ 5+ \\ 6+ \\ \hline \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \\ & 3+ \\ & 2+ \\ & 2+ \\ & 3+ \end{aligned}$ | $\begin{aligned} & \text { B7 } \\ & \text { F7 } \\ & \text { FD } \\ & 10 \\ & F F \\ & F F \\ & B F \\ & 10 \\ & B F \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 6 \\ & 7 \\ & 6 \\ & 6 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 3 \\ & 3 \\ & 4 \end{aligned}$ |  |  |  | $\begin{aligned} & A \rightarrow M \\ & B \rightarrow M \\ & D \rightarrow M: M+1 \\ & S \rightarrow M: M+1 \\ & U \rightarrow M: M+1 \\ & X \rightarrow M: M+1 \\ & Y \rightarrow M: M+1 \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \\ 1 \end{array}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{array}{\|l\|} \hline 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \end{array}$ | - |
| SUB | $\begin{array}{\|l} \hline \text { SUBA } \\ \text { SUBB } \\ \text { SUBD } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 80 \\ \mathrm{CO} \\ 83 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 90 \\ & \text { DO } \\ & 93 \\ & \hline \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 6 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{AO} \\ & \mathrm{EO} \\ & \mathrm{~A} 3 \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 4+ \\ 4+ \\ 6+ \\ \hline \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{BO} \\ & \mathrm{FO} \\ & \mathrm{~B} 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & \hline \end{aligned}$ |  |  |  | $\begin{aligned} & A-M \rightarrow A \\ & B-M \rightarrow B \\ & D-M: M+1 \rightarrow D \end{aligned}$ | 8 <br> 8 | 1 | 1 <br> 1 <br> 1 | 1 1 1 | 1 <br> 1 <br> 1 |
| SWI | SWI ${ }^{6}$ $S W 12^{6}$ SWI3 |  |  | $\bullet$ |  |  |  |  |  |  |  |  |  | $\begin{aligned} & 3 F \\ & 10 \\ & 3 F \\ & 11 \\ & 3 F \end{aligned}$ | $\begin{aligned} & 19 \\ & 20 \\ & 20 \end{aligned}$ | $\begin{aligned} & 1 \\ & 2 \\ & 1 \end{aligned}$ | Software Interrupt 1 Software Interrupt 2 <br> Software Interrupt 3 |  |  |  |  | - |
| SYNC |  |  |  |  |  |  |  |  |  |  |  |  |  | 13 | $\geq 4$ | 1 | Synchronize to interrupt | $\bullet$ | - | $\bullet$ | - | $\bullet$ |
| TFR | R1, R2 | $1 F$ | 6 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $R 1-R 2^{2}$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| TST | $\begin{aligned} & \text { TSTA } \\ & \text { TSTB } \\ & \text { TST } \end{aligned}$ |  |  |  | OD | 6 | 2 | 6D | $6+$ | $2+$ | 7 D | 7 | 3 | $\begin{aligned} & 4 D \\ & 5 D \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Test A <br> Test B <br> Test M | $\bullet$ | 1 1 1 | 1 <br> 1 <br> 1 | 0 0 0 | $\bullet \bullet$ |

NOTES:

1. This column gives a base cycle and byte count. To obtain total count, add the values obtained from the INDEXED ADDRESSING MODE table, Table 2.
2. R1 and R2 may be any pair of 8 bit or any pair of 16 bit registers.

The 8 bit registers are: $A, B, C C, D P$
The 16 bit registers are: $X, Y, U, S, D, P C$
3. $E A$ is the effective address.
4. The PSH and PUL instructions require 5 cycles plus 1 cycle for each byte pushed or pulled.
5. $5(6)$ means: 5 cycles if branch not taken, 6 cycles if taken (Branch instructions).
6. SWI sets I and F bits. SWI2 and SWI3 do not affect I and F.
7. Conditions Codes set as a direct result of the instruction.
8. Vaue of half-carry flag is undefined.
9. Special Case - Carry set if b7 is SET.

| Instruction | Forms | Addressing Mode |  |  | Description | 5 | N | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | OP | -5 | , |  | H | N | 2 | V | C |
| BCC | $\begin{aligned} & \text { BCC } \\ & \text { LBCC } \end{aligned}$ | $\begin{aligned} & 24 \\ & 10 \\ & 24 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch C=0 Long Branch $C=0$ |  | - | - | - | - |
| BCS | $\begin{aligned} & \hline \text { BCS } \\ & \text { LBCS } \end{aligned}$ | $\begin{aligned} & 25 \\ & 10 \\ & 25 \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\mathrm{C}=1$ Long Branch $\mathrm{C}=1$ |  | - | - |  | - |
| BEO | $\begin{aligned} & \mathrm{BEO} \\ & \text { LBEQ } \end{aligned}$ | $\begin{aligned} & 27 \\ & 10 \\ & 27 \end{aligned}$ | $\begin{array}{\|c\|} 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $Z=1$ L.ong Branch Z $=0$ |  | - | - |  | $\bullet$ |
| BGE | $\begin{aligned} & \text { BGE } \\ & \text { LBGE } \end{aligned}$ | $\begin{aligned} & \hline 2 \mathrm{C} \\ & 10 \\ & 2 \mathrm{C} \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $2$ | Branch $\geq$ Zero <br> Long Branch $\geq$ Zero | $\bullet$ | - | - |  | - |
| BGT | $\begin{aligned} & \hline \text { BGT } \\ & \text { LBGT } \end{aligned}$ | $\begin{aligned} & 2 \mathrm{E} \\ & 10 \\ & 2 \mathrm{E} \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $2$ | Branch > Zero Long Branch $>$ Zero |  | - | - |  | - |
| BHI | $\begin{aligned} & \hline \mathrm{BHI} \\ & \text { LBHI } \end{aligned}$ | $\begin{aligned} & \hline 22 \\ & 10 \\ & 22 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $2$ | Branch Higher Long Branch Higher |  | - | - | - | - |
| BHS | $\begin{aligned} & \text { BHS } \\ & \text { LBHS } \end{aligned}$ | $\begin{aligned} & 24 \\ & 10 \\ & 24 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | 2 | Branch Higher <br> or Same <br> Long Branch Higher <br> or Same | - | - | - | - | - |
| BLE | $\begin{array}{\|l\|} \hline \text { BLE } \\ \text { LBLE } \end{array}$ | $\begin{aligned} & 2 F \\ & 10 \\ & 2 F \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\leq$ Zero Long Branch $\leq$ Zero |  | - | - |  | $\bullet$ |
| BLO | $\begin{aligned} & \hline \text { BLO } \\ & \text { LBLO } \end{aligned}$ | $\begin{aligned} & 25 \\ & .10 \\ & 25 \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch lower Long Branch Lower | $\bullet$ | - | - | - | - |


| Instruction | Forms | $\begin{gathered} \text { Addressing } \\ \text { Mode } \\ \hline \text { Relative } \\ \hline \end{gathered}$ |  |  | Description |  |  | 2 |  | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |
|  |  | OP | -5 | 1 |  |  |  |  |  |  |  |
| BLS | $\begin{aligned} & \text { BLS } \\ & \text { LBLS } \end{aligned}$ | $\begin{aligned} & 23 \\ & 10 \\ & 23 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | 2 | Branch Lower or Same Long Branch Lower or Same | - | - | - | - |  | - |
| BLT | $\begin{array}{\|l\|} \hline B L T \\ L B L T \end{array}$ | $\begin{aligned} & 2 \mathrm{D} \\ & 10 \\ & 20 \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & \hline 2 \\ & 4 \end{aligned}$ | Branch < Zero <br> Long Branch < Zero | - | - |  |  |  | - |
| BMI | $\begin{array}{\|l\|} \hline \text { BMI } \\ \text { LBMI } \end{array}$ | $\begin{array}{\|l\|} \hline 2 B \\ 10 \\ 2 B \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $2$ | Branch Minus Long Branch Minus | $\bullet$ | - |  |  |  | - |
| BNE | BNE LBNE | $\begin{array}{\|l\|} \hline 26 \\ 10 \\ 26 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | $\begin{gathered} \text { Branch } Z=0 \\ \text { Long Branch } \\ Z \neq 0 \end{gathered}$ | $\bullet$ | - |  |  |  | $\bullet$ |
| BPL | BPL LBPL | $\begin{array}{\|l\|} \hline 2 A \\ 10 \\ 2 A \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch Plus Long Branch Plus |  | - |  |  |  | - |
| BRA | $\begin{aligned} & \text { BRA } \\ & \text { LBRA } \end{aligned}$ | $\begin{array}{\|l\|} \hline 20 \\ 16 \\ \hline \end{array}$ | $\begin{aligned} & 3 \\ & 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | Branch Always Long Branch Always |  | - |  |  | - | $\bullet$ |
| BRN | $\begin{aligned} & \hline \text { BRN } \\ & \text { LBRN } \end{aligned}$ | $\begin{array}{\|l\|} \hline 21 \\ 10 \\ 21 \\ \hline \end{array}$ | $\begin{aligned} & 3 \\ & 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch Never Long Branch Never | - | - |  |  |  | $\bullet$ |
| BSR | $\begin{aligned} & \hline \text { BSR } \\ & \text { LBSR } \end{aligned}$ | $\begin{array}{\|l\|} \hline 8 D \\ 17 \\ \hline \end{array}$ | $\begin{aligned} & 7 \\ & 9 \end{aligned}$ | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | Branch to Subroutine Long Branch to Subroutine | - | - |  |  | - | - |
| BVC | $\begin{aligned} & \mathrm{BVC} \\ & \mathrm{LBVC} \end{aligned}$ | $\begin{array}{\|l\|} \hline 28 \\ 10 \\ 28 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | 2 | $\begin{aligned} & \text { Branch } V=0 \\ & \text { Long Branch } \\ & V=0 \end{aligned}$ | - | - |  |  | - | $\stackrel{\square}{\bullet}$ |
| BVS | $\begin{aligned} & \hline \text { BVS } \\ & \text { LBVS } \end{aligned}$ | $\begin{array}{\|l\|} \hline 29 \\ 10 \\ 29 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | 2 | Branch $V=1$ Long Branch $V=1$ | - | - |  | - | $\bullet$ | $\bullet$ |

SIMPLE BRANCHES

|  | OP | $\sim$ | $\#$ |
| :--- | ---: | ---: | ---: |
| BRA | 20 | 3 | 2 |
| LBRA | 16 | 5 | 3 |
| BRN | 21 | 3 | 2 |
| LBRN | 1021 | 5 | 4 |
| BSR | $8 D$ | 7 | 2 |
| LBSR | 17 | 9 | 3 |

## SIMPLE CONDITIONAL BRANCHES (Notes 1-4)

| Test | True | OP | False | OP |
| :--- | :--- | :--- | :--- | :--- |
| $N=1$ | BMI | $2 B$ | $B P L$ | $2 A$ |
| $Z=1$ | BEQ | 27 | BNE | 26 |
| $V=1$ | BVS | 29 | $B V C$ | 28 |
| $C=1$ | BCS | 25 | BCC | 24 |

SIGNED CONDITIONAL BRANCHES (Notes 1-4)

| Test | True | OP | False | OP |
| :--- | :--- | :--- | :--- | :--- |
| $r>m$ | BGT | $2 E$ | BLE | $2 F$ |
| $r \geq m$ | BGE | $2 C$ | BLT | $2 D$ |
| $r=m$ | BEQ | 27 | BNE | 26 |
| $r \leq m$ | BLE | $2 F$ | BGT | $2 E$ |
| $r<m$ | BLT | $2 D$ | BGE | $2 C$ |

UNSIGNED CONDITIONAL BRANCHES (Notes 1-4)

| Test | True | OP | False | OP |
| :--- | :---: | :---: | :---: | :---: |
| $r>m$ | BHI | 22 | BLS | 23 |
| $r \geq m$ | BHS | 24 | BLO | 25 |
| $r=m$ | BEQ | 27 | BNE | 26 |
| $r \leq m$ | BLS | 23 | BHI | 22 |
| $r<m$ | BLO | 25 | BHS | 24 |

NOTES:

1. All conditional branches have both short and long variations.
2. All short branches are two bytes and require three cycles.
3. All conditional long branches are formed by prefixing the short branch opcode with $\$ 10$ and using a 16 -bit destination offset.
4. All conditional long branches require four bytes and six cycles if the branch is taken or five cycles if the branch is not taken.



ALSO AVAILABLE
JSUFFIX
CERDIP PACKAGE
C SUFFIX CERAMIC PACKAGE

## ORDERING INFORMATION



CB-521


CB-708


E SUFFIX
LCCC 44


The EF6809E is a revolutionary high performance 8-bit microprocessor which supports modern programming techniques such as position independ ence, reentrancy, and modular programming

This third-generation addition to the 6800 Family has major architectural improvements which include additional registers, instructions, and addressing modes

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The EF6809E has the most complete set of ${ }^{-}$addressing modes available on any 8 -bit microprocessor today

The EF6809E has hardware and software features which make it an ideal processor for higher level language execution or standard controller applications. External clock inputs are provided to allow synchronization with peripherals, systems, or other MPUs

## EF6800 COMPATIBLE

- Hardware - Interfaces with All 6800 Peripherals
- Software - Upward Source Code Compatible Instruction Set and Addressing Modes
ARCHITECTURAL FEATURES
- Two 16-Bit Index Registers
- Two 16-Bit Indexable Stack Pointers
- Two 8-Bit Accumulators can be Concatenated to Form One 16-Bit Accumulator
- Direct Page Register Allows Direct Addressing Throughout Memory

HARDWARE FEATURES

- External Clock Inputs, E and Q, Allow Synchronization
- TSC Input Controls Internal Bus Buffers
- LIC Indicates Opcode Fetch
- AVMA Allows Efficient Use of Common Resources in a Multiprocessor System
- BUSY is a Status Line for Multiprocessing
- Fast Interrupt Request Input Stacks Only Condition Code Register and Program Counter
- Interrupt Acknowledge Output Allows Vectoring By Devices
- Sync Acknowledge Output Allows for Synchronization to External Event
- Single Bus-Cycle $\overline{R E S E T}$
- Single 5-Volt Supply Operation
- NMI Inhibited After RESET Until After First Load of Stack Pointer
- Early Address Valid Allows Use With Slower Memories
- Early Write Data for Dynamic Memories


## SOFTWARE FEATURES

- 10 Addressing Modes
- 6800 Upward Compatible Addressing Modes
- Direct Addressing Anywhere in Memory Map
- Long Relative Branches
- Program Counter Relative
- True Indirect Addressing
- Expanded Indexed Addressing $0-, 5-, 8$-, or 16 -Bit Constant Offsets 8 - or 16-Bit Accumulator Offsets Auto-Increment/Decrement by 1 or 2
- Improved Stack Manipulation
- 1464 Instruction with Unique Addressing Modes
- $8 \times 8$ Unsigned Multiply
- 16-Bit Arithmetic
- Transfer/Exchange All Registers
- Push/Pull Any Registers or Any Set of Registers
- Load Effective Address


## HMOS

(HIGH-DENSITY N-CHANNEL, SILICON-GATE)

8-BIT<br>MICROPROCESSING UNIT

CB-521

FN SUFFIX
PLCC 44


MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range |  | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |  |
| EF6809E, EF68A09E, EF68B09E | $\mathrm{T}_{\mathrm{A}}$ |  <br>  <br> to +70 <br> EF6809E, EF68A09E, E F68B09E, C suffix |  |
| EF6809E, EF68A09E $: M$ suffix |  | -55 to +125 |  |
| Storage Temperature Range |  | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$ ).

## THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Ceramic |  | 50 |  |
| Cerdip | $\theta_{J A}$ | 60 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic |  | 100 |  |
| PLCC |  | 100 |  |

## POWER CONSIDERATIONS

The average chip-junction temperature, $T_{J}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T J=T A+\left(P D^{\bullet} \theta J A\right) \tag{1}
\end{equation*}
$$

Where:

$$
\begin{aligned}
& \mathrm{T}_{A} \equiv \text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
& \theta_{J A} \equiv \text { Package Thermal Resistance, Junction-to-Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
& \mathrm{PD}_{\mathrm{D}} \equiv \text { PINT }+ \text { PPORT } \\
& \text { PINT } \equiv \text { ICC } \times \text { VCC, Watts - Chip Internal Power } \\
& \text { PPORT } \equiv \text { Port Power Dissipation, Watts - User Determined }
\end{aligned}
$$

For most applications PPORT $<$ PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K+\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \bullet P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P_{D}$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}\right.$ to $T_{H}$ unless otherwise noted)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Logic, Q, <br> RESET  <br> E  | $\begin{aligned} & V_{1 H} \\ & V_{1 H R} \\ & V_{1 H C} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{S S}+2.0 \\ & V_{S S}+4.0 \\ & V_{C C}-0.75 \end{aligned}$ | - | $v_{C C}$ $v_{C C}$ $V_{C C}+0.3$ | V |
| Input Low Voltage <br> Logic, $\overline{\text { RESET }}$ | $\begin{gathered} V_{I L} \\ V_{\text {ILC }} \\ v_{\text {ILO }} \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{S S}-0.3 \\ & \mathrm{~V}_{S S}-0.3 \\ & \mathrm{~V}_{S S}-0.3 \end{aligned}$ | - | $\begin{aligned} & v_{S S}+0.8 \\ & v_{S S}+0.4 \\ & v_{S S}+0.6 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Input Leakage Current $\left(\mathrm{V}_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{C C}=\max \right)$ | 1 in | - | - | $\begin{aligned} & 2.5 \\ & 100 \end{aligned}$ | $\mu \mathrm{A}$ |
| dc Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & V_{S S}+2.4 \\ & V_{S S}+2.4 \\ & V_{S S}+2.4 \end{aligned}$ | - | - | V |
| dc Output Low Voltage $\text { (load } \left.=2.0 \mathrm{~mA}, V_{C C}=\mathrm{min}\right)$ | $\mathrm{V}_{\text {OL }}$ | - | - | $V_{S S}+0.5$ | V |
| Internal Power Dissipation (Measured at $\mathrm{T}_{A}=0^{\circ} \mathrm{C}$ in Steady State Operation) | PINT | - | - | 1.0 | W |
| $\begin{aligned} & \text { Capacitance } \\ & \quad\left(\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \quad \text { DO-D7, Logic Inputs, } \mathrm{Q}, \overline{\mathrm{RESET}} \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | - | $\begin{aligned} & 10 \\ & 30 \end{aligned}$ | $\begin{aligned} & 15 \\ & 50 \end{aligned}$ | pF |
| A0-A15, R/W, BA, BS, <br> LIC, AVMA, BUSY | Cout | - | 10 | 15 | pF |
| Frequency of Operation EF6809E <br> (E and $Q$ Inputs) EF68A09E <br>  EF68B09E | $f$ | $\begin{aligned} & 0.1 \\ & 0.1 \\ & 0.1 \end{aligned}$ | - | $\begin{aligned} & 1.0 \\ & 1.5 \\ & 2.0 \end{aligned}$ | MHz |
| $\mathrm{H}_{1}-Z$ (Off State) Input Current  <br> $\left(\mathrm{V}_{\text {in }}=0.4\right.$ to $\left.2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\max \right)$ DO-D7 | ${ }^{\prime}$ TSI | - | 2.0 | $\begin{gathered} 10 \\ 100 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |

[^19]BUS TIMING CHARACTERISTICS (See Notes 1, 2, 3, and 4)

| Ident. Number | Characteristics | Symbol | EF6809E |  | EF68A09E |  | EF68B09E |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }^{\text {c }} \mathrm{CyC}$ | 10 | 10 | 0667 | 10 | 05 | 10 | $\mu \mathrm{s}$ |
| 2 | Pulse Width, E Low | PWEL | 450 | 9500 | 295 | 9500 | 210 | 9500 | ns |
| 3 | Pulse Width. E High | PWEH | 450 | 9500 | 280 | 9500 | 220 | 9500 | ns |
| 4 | Clock Rise and Fall Time | If. If | - | 25 | " | 25 | - | 20 | ns |
| 5 | Pulse Width, Q High | $\mathrm{PW}_{\text {QH }}$ | 450 | 9500 | 280 | 9500 | 220 | 9500 | ns |
| 7 | Deiay Time, E to O Rise | 'EQ1 | 200 | -- | 130 | - | 100 | - | ns |
| 7A | Delay Time, Q High to E Rise | 'EQ2 | 200 | - | 130 | - | 100 | - | ns |
| 7 B | Delay Time, E High to Q Fall | 'E03 | 200 | -' | 130 | - | 100 | - | ns |
| 7 C | Delay Time, O High to E Fall | teg4 | 200 | - | 130 | - | 100 | - | ns |
| 9 | Address Hold Time | 1 AH | 20 | - | 20 | - | 20 | - | ns |
| 11 | Address Delay Time from E Low (BA, BS. R, $\bar{W}$ ) | 1 AD |  | 200 | - | 140 | -- | 110 | ns |
| 17 | Read Data Setup Time | 'DSR | 80 |  | 60 | - | 40 | - | ns |
| 18 | Read Data Hold Time | ${ }^{\text {I }}$ DHR | 10 | - | 10 | - | 10 | -- | ns |
| 20 | Data Delay Time from 0 | '0DO | -- | 200 | - | 140 | - | 110 | ns |
| 21 | Write Data Hold Time | ${ }^{1}$ DHW | 30 | * | 30 | - | 30 | . | ns |
| 29 | Usable Access Time | IACC | 695 | - | 440 | - | 330 |  | ns |
| 30 | Control Delay Time | ${ }^{1} \mathrm{CD}$ | - | 300 | - | 250 | - | 200 | ns |
|  | Interrupts, $\overline{\mathrm{HALT}}, \overline{\mathrm{RESET}}$, and TSC Setup Time (Figures 6, 7, 8, 9, 12, and 13) | IPCS | 200 | - | 140 | - | 110 | - | ns |
|  | TSC Drive to Vahd Logic Level (Figure 13) | ITSV | - | 210 | - | 150 | . | 120 | ns |
|  | TSC Release MOS Buffers to High Impedance (Figure 13) | ITSR | - | 200 | - | 140 | $\cdots$ | 110 | ns |
|  | TSC HI-Z Delay Time (figure 13) | ${ }^{\text {T TSD }}$ | . | 120 | - | 85 | - | 80 | ns |
|  | Processor Control Rise and Fall Time (Figure 7) | $\begin{aligned} & \mathrm{tPCr}, \\ & \mathrm{tPCt} \\ & \hline \end{aligned}$ | - | 100 | - | 100 | . | 100 | ns |

FIGURE 1 - READ/WRITE DATA TO MEMORY OR PERIPHERALS TIMING DIAGRAM


[^20]

## PROGRAMMING MODEL

FIGURE 3 - BUS TIMING TEST LOAD

$\mathrm{C}=30 \mathrm{pF}$ for $\mathrm{BA}, \mathrm{BS}, \mathrm{LIC}, \mathrm{AVMA}, \mathrm{BUSY}$
130 pF for DO-D7
90 pF for $\mathrm{AO}-\mathrm{A} 15, \mathrm{R} / \overline{\mathrm{W}}$
$R=11.7 \mathrm{k} \Omega$ for DO-D7
16.5 ka for $\mathrm{AO}-\mathrm{A} 15, \mathrm{R} / \overline{\mathrm{W}}$
$24 \mathrm{k} \Omega$ for BA, BS, LIC, AVMA, BUSY

As shown in Figure 4, the EF6809E adds three registers to the set available in the EF6800. The added registers include a direct page register, the user stack pointer, and a second index register.

## ACCUMULATORS (A, B, D)

The $A$ and $B$ registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data.
Certain instructions concatenate the $A$ and $B$ registers to form a single 16 -bit accumulator. This is referred to as the $D$ register, and is formed with the A register as the most significant byte.

## DIRECT PAGE REGISTER (DP)

The direct page register of the EF6809E serves to enhance the direct addressing mode. The content of this register appears at the higher address outputs (A8-A15) during direct addressing instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure 6800 compatibility, all bits of this register are cleared during processor reset.


INDEX REGISTERS ( $\mathrm{X}, \mathrm{Y}$ )
The index registers are used in indexed mode of addressing. The 16 -bit address in this register takes part in the calculation of effective addresses. This address may be used to point to data directly or may be modified by an optional constant or register offset. During some indexed modes, the contents of the index register are incremented and decremented to point to the next item of tabular type data. All four pointer registers ( $X, Y, U, S$ ) may be used as index registers.

## STACK POINTER (U, S)

The hardware stack pointer ( S ) is used automatically by the processor during subroutine calls and interrupts. The user stack pointer ( $U$ ) is controlled exclusively by the programmer. This allows arguments to be passed to and from subroutines with ease. The $U$ register is frequently used as a stack marker. Both stack pointers have the same indexed mode addressing capabilities as the $X$ and $Y$ registers, but also support Push and Pull instructions. This allows the EF6809E to be used efficiently as a stack processor, greatly enhancing its ability to support higher level languages and modular programming.

## NOTE

The stack pointers of the EF6809E point to the top of the stack in contrast to the EF6800 stack pointer, which pointed to the next free location on stack.

## PROGRAM COUNTER

The program counter is used by the processor to point to the address of the next instruction to be executed by the processor. Relative addressing is provided allowing the program counter to be used like an index register in some situations.

## CONDITION CODE REGISTER

The condition code register defines the state of the processor at any given time. See Figure 4.

FIGURE 5 - CONDITION CODE REGISTER FORMAT


## CONDITION CODE REGISTER DESCRIPTION

## BIT 0 (C)

Bit 0 is the carry flag and is usually the carry from the binary ALU, C is also used to represent a "borrow" from subtract like instructions (CMP, NEG, SUB, SBC) and is the complement of the carry from the binary ALU.

## BIT 1 (V)

Bit 1 is the overflow flag and is set to a one by an operation which causes a signed twos complement arithmetic overflow. This overflow is detected in an operation in which the carry from the MSB in the ALU does not match the carry from the MSB-1.

## BIT 2 (Z)

Bit 2 is the zero flag and is set to a one if the result of the previous operation was identically zero.

## BIT 3 (N)

Bit 3 is the negative flag, which contains exactly the value of the MSB of the result of the preceding operation. Thus, a negative twos complement result will leave N set to a one.

BIT 4 (I)
Bit 4 is the $\overline{I R Q}$ mask bit. The processor will not recognize interrupts from the $\overline{\mathrm{RQ}}$ line if this bit is set to a one. $\overline{\mathrm{NMI}}$, $\overline{F I R O}, \overline{I R Q}, \overline{R E S E T}$, and SWI all set I to a one. SWI2 and SWI3 do not affect 1 .

## BIT 5 (H)

Bit 5 is the half-carry bit, and is used to indicate a carry from bit 3 in the $A L U$ as a result of an 8 -bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is undefined in all subtract-like instructions.

## BIT 6 (F)

Bit 6 is the $\overline{\text { FIRQ }}$ mask bit. The processor will not recognize interrupts from the $\overline{F I R Q}$ line if this bit is a one. $\overline{\text { NMI }}, \overline{F I R Q}$, SWI, and $\overline{R E S E T}$ all set $F$ to a one. $\overline{\text { IRQ, SWI2, }}$ and SWI3 do not affect $F$.

## BIT 7 (E)

Bit 7 is the entire flag, and when set to a one indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current $E$ left in the condition code register represents past action.

## PIN DESCRIPTIONS

POWER ( $\mathrm{V}_{\mathrm{SS}}, \mathrm{V}_{\mathrm{CC}}$ )
Two pins are used to supply power to the part: $V_{S S}$ is ground or 0 volts, while $\mathrm{V}_{\mathrm{CC}}$ is $+5.0 \mathrm{~V} \pm 5 \%$.

## ADDRESS BUS (A0-A15)

Sixteen pins are used to output address information from the MPU onto the address bus. When the processor does not require the bus for a data transfer, it will output address FFFF $16 . \mathrm{R} / \overline{\mathrm{W}}=1$, and BS $=0$; this is a "dummy access" or $\overline{V M A}$ cycle. All address bus drivers are made highimpedance when output bus available ( BA ) is high or when TSC is asserted. Each pin will drive one Schottky TTL load or four LSTTL loads and 90 pF .

## DATA BUS (D0-D7)

These eight pins provide communication with the system bidirectional data bus. Each pin will drive one Schottky TTL load or four LSTTL loads and 130 pF .

## READ/WRITE (R/W)

This signal indicates the direction of data transfer on the data bus. A low indicates that the MPU is writing data onto the data bus. $R / \bar{W}$ is made high impedance when $B A$ is high or when TSC is asserted.

## RESET

A low level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in Figure 6. The
reset vectors are fetched from locations FFFE 16 and FFFFF 16 (Table 1) when interrupt acknowledge is true, $(\overline{B A} \bullet B S=1)$. During initial power on, the reset line should be held low until the clock input signals are fully operational.

Because the EF6809E RESET pin has a Schmitt-trigger input with a threshold voltage higher than that of standard peripherals, a simple R/C network may be used to reset the entire system. This higher threshold voltage ensures that all peripherals are out of the reset state before the processor.

## $\overline{\text { HALT }}$

A low level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven high indicating the buses are high impedance. BS is also high which indicates the processor is in the halt state. While halted, the MPU will not respond to external real-time requests ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{IRO}}$ ) although $\overline{\mathrm{NMI}}$ or $\overline{R E S E T}$ will be latched for later response. During the halt state, Q and E should continue to run-normally. A halted state $(B A \cdot B S=1)$ can be achieved by pulling HALT low while $\overline{\text { RESET }}$ is still low. See Figure 7.

## BUS AVAILABLE, BUS STATUS (BA, BS)

The bus available output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. When BA goes low, a dead cycle will elapse before the MPU acquires the bus. BA will not be asserted when TSC is active, thus allowing dead cycle consistency.
The bus status output signal, when decoded with BA, represents the MPU state (valid with leading edge of Q ).

| MPU State |  | MPU State Definition |
| :---: | :---: | :--- |
| BA | BS |  |
| 0 | 0 | Normal (Running) |
| 0 | 1 | Interrupt or Reset Acknowledge |
| 1 | 0 | Sync Acknowledge |
| 1 | 1 | Halt Acknowledge |

Interrupt Acknowledge is indicated during both cycles of a hardware vector fetch ( $\overline{\mathrm{RESET}}, \overline{\mathrm{NMI}}, \overline{\mathrm{FIRO}}, \overline{\mathrm{IRO}}, \mathrm{SWI}$, SWI2, SWI3). This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 1.

TABLE 1 - MEMORY MAP FOR INTERRUPT VECTORS

| Memory Map For <br> Vector Locations |  | Interrupt Vector <br> Description |
| :--- | :---: | :---: |
| MS | LS |  |
| FFFE | FFFF | $\overline{\text { NMI }}$ |
| FFFC | FFFD | SWI |
| FFFA | FFFB | $\overline{\text { IRQ }}$ |
| FFF8 | FFF9 | $\overline{\text { FIRQ }}$ |
| FFF6 | FFF7 | SWI2 |
| FFF4 | FFF5 | SWI3 |
| FFF2 | FFF3 | Reserved |
| FFF0 | FFF1 |  |



NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

FIGURE 7 - $\overline{\text { HALT }}$ AND SINGLE INSTRUCTION EXECUTION TIMING FOR SYSTEM DEBUG


NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

Sync Acknowledge is indicated while the MPU is waiting for external synchronization on an interrupt line.
Halt Acknowledge is indicated when the EF6809E is in a halt condition.

## NON MASKABLE INTERRUPT (NMI)*

A negative transition on this input requests that a nonmaskable interrupt sequence be generated. A non-maskable interrupt cannot be inhibited by the program and also has a higher priority than FIRQ, $\overline{\mathrm{IRO}}$, or software interrupts. During recognition of an $\overline{\text { NMI, }}$, the entire machine state is saved on the hardware stack. After reset, an NMI will not be recognized until the first program load of the hardware stack pointer (S). The pulse width of $\overline{\mathrm{NMI}}$ low must be at least one $E$ cycle. If the $\overline{N M I}$ input does not meet the minimum set up with respect to Q , the interrupt will not be recognized until the next cycle. See Figure 8

## FAST-INTERRUPT REQUEST ( $\overline{\text { FIRQ }}$ )*

A low level on this input pin will initiate a fast interrupt sequence, provided its mask bit (F) in the CC is clear. This sequence has priority over the standard interrupt request ( $\overline{\mathrm{RQ}}$ ) and is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 9.

## INTERRUPT REQUEST ( $\overline{\mathrm{RO}})^{*}$

A low level input on this pin will initiate an interrupt request sequence provided the mask bit (1) in the CC is clear. Since $\overline{\mathrm{RO}}$ stacks the entire machine state, it provides a slower response to interrupts than $\overline{\mathrm{FIRO}} . \overline{\mathrm{IQ}}$ also has a lower priority than $\overline{\mathrm{FIRO}}$. Again, the interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 8.

## CLOCK INPUTS E, Q

$E$ and $Q$ are the clock signals required by the EF6809E. Q must lead E ; that is, a transition on Q must be followed by a similar transition on E after a minimum delay. Addresses will be valid from the MPU, tAD after the falling edge of $E$, and data will be latched from the bus by the falling edge of $E$. While the Q input is fully TTL compatible, the E input directly drives internal MOS circuitry and, thus, requires a high level above normal TTL levels. This approach minimizes clock skew inherent with an internal buffer. Refer to BUS TIMING CHARACTERISTICS for $E$ and $Q$ and to Figure 10 which shows a simple clock generator for the EF68C9E.

## BUSY

BUSY will be high for the read and modify cycles of a read-modify-write instruction and during the access of the first byte of a double-byte operation (e.g., LDX, STD, ADDDI. BUSY is also high during the first byte of any indirect or other vector fetch (e.g., jump extended, SWI indirect, etc.).
In a multiprocessor system, BUSY indicates the need to
defer the rearbitration of the next bus cycle to insure the integrity of the above operations. This difference provides the indivisible memory access required for a "test-and-set" primitive, using any one of several read-modify-write instructions.

BUSY does not become active during PSH or PUL operations. A typical read-modify-write instruction (ASL) is shown in Figure 11. Timing information is given in Figure 12. BUSY is valid $\mathrm{t}_{\mathrm{C}} \mathrm{C}$ after the rising edge of O .

## AVMA

AVMA is the advanced VMA signal and indicates that the MPU will use the bus in the following bus cycle. The predictive nature of the AVMA signal allows efficient shared-bus multiprocessor systems. AVMA is low when the MPU is in either a HALT or SYNC state. AVMA is valid tCD after the rising edge of Q .

## LIC

LIC (last instruction cycle) is high during the last cycle of every instruction, and its transition from high to low will indicate that the first byte of an opcode will be latched at the end of the present bus cycle. LIC will be high when the MPU is halted at the end of an instruction (i.e., not in CWAI or $\overline{\text { RESET }}$, in sync state, or while stacking during interrupts. LIC is valid ${ }^{T} C D$ after the rising edge of $Q$.

TSC
TSC (three-state control) will cause MOS address, data, and $R / \bar{W}$ buffers to assume a high-impedance state. The control signals (BA, BS, BUSY, AVMA, and LIC) will not go to the high-impedance state. TSC is intended to allow a single bus to be shared with other bus masters (processors or DMA controllers).

While E is low, TSC controls the address buffers and R/W directly. The data bus buffers during a write operation are in a high-impedance state until $Q$ rises at which time, if TSC is true, they will remain in a high-impedance state. If TSC is held beyond the rising edge of $E$, then it will be internally latched, keeping the bus drivers in a high-impedance state for the remainder of the bus cycle. See Figure 13.

## MPU OPERATION

During normal operation, the MPU fetches an instruction from memory and then executes the requested function. This sequence begins after $\overline{\text { RESET }}$ and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Software instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI, and SYNC. An interrupt or $\overline{\text { HALT }}$ input can also alter the normal execution of instructions. Figure 14 is the flowchart for the EF6809E.

[^21]
## FIGURE 8 - $\overline{\operatorname{Ro}}$ AND $\overline{\text { NMI }}$ INTERRUPT TIMING



* E clock shown for reference only

NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted

## FIGURE 9 - $\overline{\text { FIRQ }}$ INTERRUPT TIMING




* E clock shown for reference only.

NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

FIGURE 10 - CLOCK GENERATOR


FIGURE 11 - READ-MODIFY-WRITE INSTRUCTION EXAMPLE (ASL EXTENDED INDIRECT)



FIGURE 13 - TSC TIMING


NOTES

1. Data will be asserted by the MPU only during the interval while $R / \bar{W}$ is low and ( $E$ or $Q$ ) is high. A composite bus cycle is shown to give most cases of timing.
2. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted


NOTES: 1. Asserting $\overline{\text { RESET }}$ will result in entering the reset sequence from any point in the flowchart.
2. BUSY is high during first vector fetch cycle

| Bus State | BA | BS |
| :--- | :---: | :---: |
| Running | 0 | 0 |
| Interrupt or Reset Acknowledge | 0 | 1 |
| Sync Acknowledge | 1 | 0 |
| Halt Acknowledge | 1 | 1 |

## ADDRESSING MODES

The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The EF6809E has the most complete set of addressing miodes -available on any microcomputer today. For example, the EF6809E has 59 basic instructions; however, it recognizes 1464 different variations of instructions and addressing modes. The addressing modes support modern programming techniques. The following addressing modes are avarlable on the EF6809E :

Inherent (Includes Accumulator)
Immediate
Extended
Extended Indirect
Direct
Register
Indexed
Zero-Offset
Constant Offset
Accumulator Offset
Auto Increment/Decrement
Indexed Indirect
Relative
Short/Long Relative Branching
Program Counter Relative Addressing

## INHERENT (INCLUDES ACCUMULATOR)

In this addressing mode, the opcode of the instruction contains all the address information necessary. Examples of inherent addressing are: ABX, DAA, SWI, ASRA, and CLRB

## IMMEDIATE ADDRESSING

In immediate addressing, the effective address of the data is the location immediately following the opcode (i.e., the data to be used in the instruction immediately following the opcode of the instruction). The EF6809E uses both 8 -and 16 -bit immediate values depending on the size of argument specified by the opcode. Examptes of instructions with immediate addressing are:

| LDA | $\# \$ 20$ |
| :--- | :--- |
| LDX | $\# \$ F 000$ |
| LDY | $\# C A T$ |

## NOTE

\# signifies immediate addressing; \$ signifies hexadecimal value to the EF6809 assembler.

## EXTENDED ADDRESSING

In extended addressing, the contents of the two bytes immediately following the opcode fully specify the 16 -bit effective address used by the instruction. Note that the address generated by an extended instruction defines an absolute address and is not position independent. Examples of extended addressing include:

LDA CAT
STX MOUSE
LDD \$2000

## EXTENDED INDIRECT

As a special case of indexed addressing (discussed below), one level of indirection may be added to extended addressing. In extended indirect, the two bytes following the postbyte of an indexed instruction contain the address of the data.

| LDA | [CAT] |
| :--- | :--- |
| LDX | [SFFFE] |
| STU | [DOG] |

## DIRECT ADDRESSING

Direct addressing is similar to extended addressing except that only one byte of address follows the opcode. This byte specifies the lower eight bits of the address to be used. The upper eight bits of the address are supplied by the direct page register. Since only one byte of address is required in direct addressing, this mode requires less memory and executes faster than extended addressing. Of course, only 256 locations (one page) can be accessed without redefining the contents of the DP register. Since the DP register is set to $\$ 00$ on reset, direct addressing on the EF6809E is upward compatible with direct addressing on the 6800. Indirection is not allowed in direct addressing. Some examples of direct addressing are:

$$
\begin{array}{ll}
\text { LDA } & \text { where } D P=\$ 00 \\
\text { LDB } & \text { where } D P=\$ 10 \\
\text { LDD } & <C A T
\end{array}
$$

## NOTE

< is an assembler directive which forces direct addressing.

## REGISTER ADDRESSING

Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction. This is called a postbyte. Some examples of register addressing are:

| TFR | $X, Y$ | Transfers $X$ into $Y$ |
| :--- | :--- | :--- |
| EXG | A, B | Exchanges A with B |
| PSHS | A, B, X, YPush $Y, X, B$ and $A$ onto $S$ <br> stack |  |
| PULU | $X, Y, D$ | Pull D, $X$, and $Y$ from U <br> stack |

## INDEXED ADDRESSING

In all indexed addressing, one of the pointer registers ( X , $Y, U, S$, and sometimes $P C$ ) is used in a calculation of the effective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode, as well as the pointer register to be used. Figure 15 lists the legal formats for the postbyte. Table 2 gives the assembler form and the number of cycles and bytes added to the basic values for indexed addressing for each variation.

FIGURE 15 - INDEXED ADDRESSING POSTBYTE REGISTER BIT ASSIGNMENTS

| Post-Byte Register Bit |  |  |  |  |  |  |  | Indexed <br> Addressing Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0 | R | R | d | d | d | d | d | $E A=, R+5$ Bit Offset |
| 1 | R | R | 0 | 0 | 0 | 0 | 0 | , R + |
| 1 | R | R | 1 | 0 | 0 | 0 | 1 | . $\mathrm{R}+$ + |
| 1 | R | R | 0 | 0 | 0 | 1 | 0 | , -R |
| 1 | R | R | $i$ | 0 | 0 | 1 | 1 | . - -R |
| 1 | R | R | i | 0 | 1 | 0 | 0 | $E \cdot A=, R+0$ Offset |
| 1 | R | R | $i$ | 0 | 1 | 0 | 1 | $E A=, R+A C C B$ Offset |
| 1 | R | R | 1 | 0 | 1 | 1 | 0 | $E A=, R+A C C A$ Offset |
| 1 | R | R | 1 | 1 | 0 | 0 | 0 | $E A=, R+8$ Bit Offset |
| 1 | R | R | 1 | 1 | 0 | 0 | 1 | $E A=, R+16$ Bit Offset |
| 1 | R | R | 1 | 1 | 0 | 1 | 1 | $E A=, R+D$ Offset |
| 1 | x | x | 1 | 1 | 1 | 0 | 0 | $E A=, P C+8$ Bit Offset |
| 1 | x | x | 1 | 1 | 1 | 0 | 1 | $E A=, P C+16$ Bit Offset |
| 1 | R | R | 1 | 1 | 1 | 1 | 1 | $E A=$ [,Address] |
| $\begin{aligned} & x=1 \\ & d=0 \\ & i=0= \\ & 1= \end{aligned}$ |  |  |  |  |  |  |  | _Addressing Mode Field <br> Indirect Field $($ Sign Bit when b7 $=0$ ) $\qquad$ Register Field: RR $\begin{aligned} & 00=X \\ & 01=Y \\ & 10=U \\ & 11=S \end{aligned}$ |

ZERO-OFFSET INDEXED - In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode.

Examples are:

$$
\begin{array}{ll}
\text { LDD } & 0, x \\
\text { LDA } & \mathrm{S}
\end{array}
$$

CONSTANT OFFSET INDEXED - In this mode, twos complement offset and the contents of one of the pointer registers are added to form the effective address of the operand. The pointer register's initial content is unchanged by the addition.

Three sizes of offset are available:

$$
\begin{aligned}
& 5 \text {-bit }(-16 \text { to }+15) \\
& 8 \text {-bit }(-128 \text { to }+127) \\
& \text { 16-bit }(-32768 \text { to }+32767)
\end{aligned}
$$

The twos complement 5 -bit offset is included in the postbyte and, therefore, is most efficient in use of bytes and cycles. The twos complement 8 -bit offset is contained in a single byte following the postbyte. The twos complement 16 -bit offset is in the two bytes following the postbyte. In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically.

Examples of constant-offset indexing are:

| LDA | $23, X$ |
| :--- | :--- |
| LDX | $-2, \mathrm{~S}$ |
| LDY | $300, X$ |
| LDU | CAT, $Y$ |

TABLE 2 - INDEXED ADDRESSING MODE

| Type | Forms | Non Indirect |  |  |  | Indirect |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Assembler Form | Postbyte Opcode | $\pm$ | $\begin{aligned} & + \\ & \hline \end{aligned}$ | Assembler Form | Postbyte Opicode | $\pm$ | $+$ |
| Constant Offset From R (2s Complement Offsets) | No Offset | R | 1RR00100 | 0 | 0 | [R] | 1RR10100 | 3 | 0 |
|  | 5-Bit Offset | $n, R$ | ORRnnnnn | 1 | 0 | defaults to 8-bit |  |  |  |
|  | 8-Bit Offset | $n, R$ | 1RR01000 | 1 | 1 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11000 | 4 | 1 |
|  | 16-Bit Offset | n, R | 1RR01001 | 4 | 2 | [ $\mathrm{n}, \mathrm{R}$ ] | 1RR11001 | 7 | 2 |
| Accumulator Offset From R (2s Complement Offsets) | A Register Offset | A, R | 1RR00110 | 1 | 0 | [A, R] | 1RR10110 | 4 | 0 |
|  | B Register Offset | B, R | 1RR00101 | 1 | 0 | [B, R] | 1RR10101 | 4 | 0 |
|  | D Register Offset | D, R | 1RR01011 | 4 | 0 | [D, R] | 1RR11011 | 7 | 0 |
| Auto Increment/Decrement R | Increment By 1 | , $\mathrm{R}+$ | 1RR00000 | 2 | 0 | not allowed |  |  |  |
|  | Increment By 2 | , $\mathrm{R}+\mathrm{+}$ | 1RR00001 | 3 | 0 | [, R + + ] | 1RR10001 | 6 | 0 |
|  | Decrement By 1 | ,-R | 1RR00010 | 2 | 0 | not allowed |  |  |  |
|  | Decrement By 2 | ,$--R$ | 1RR00011 | 3 | 0 | [, - - R] | 1RR10011 | 6 | 0 |
| Constant Offset From PC (2s Complement Offsets) | 8-Bit Offset | n, PCR | 1xx01100 | 1 | 1 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11100$ | 4 | 1 |
|  | 16-Bit Offset | n, PCR | 1xx01101 | 5 | 2 | [ $\mathrm{n}, \mathrm{PCR}$ ] | $1 \times \times 11101$ | 8 | 2 |
| Extended Indirect | 16-Bit Address | - | - | - | - | [ n ] | 10011111 | 5 | 2 |
| $R=X, Y, U$ or $S$ $R R:$ <br> $X=$ Don't Care $\infty=X$ <br>  $01=Y$ <br>  $10=U$ <br>  $11=S$ |  |  |  |  |  |  |  |  |  |

$\underset{\sim}{\sim}{ }^{+}{ }^{+}$indicate the number of additional cycles and bytes respectively for the particular indexing variation.

ACCUMULATOR-OFFSET INDEXED - This mode is similar to constant offset indexed except that the twos complement value in one of the accumulators ( $\mathrm{A}, \mathrm{B}$, or D ) and the contents of one of the pointer registers are added to form the effective address of the operand. The contents of both the accumulator and the pointer register are unchanged by the addition. The postbyte specifies which accumulator to use as an offset and no additional bytes are required. The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run-time.
Some examples are

| LDA | $B, Y$ |
| :--- | :--- |
| LDX | $D, Y$ |
| LEAX | $B, X$ |

AUTO INCREMENT/DECREMENT INDEXED - in the auto increment addressing mode, the pointer register contains the address of the operand. Then, after the pointer register is used, it is incremented by one or two. This addressing mode is useful in stepping through tables, moving data, or creating software stacks. In auto decrement, the pointer register is decremented prior to use as the address of the data. The use of auto decrement is similar to that of auto increment, but the tables, etc., are scanned from the high to low addresses. The size of the increment/decrement can be either one or two to allow for tables of either 8 - or 16 -bit data to be accessed and is selectable by the programmer. The pre-decrement, post-increment nature of these modes allows them to be used to create additional software stacks that behave identically to the $U$ and $S$ stacks.

Some examples of the auto increment/decrement addressing modes are:

| LDA | ,$X+$ |
| :--- | :--- |
| STD | ,$Y++$ |
| LDB | ,$-Y$ |
| LDX | ,$--S$ |

Care should be taken in performing operations on 16 -bit pointer registers ( $X, Y, U, S$ ) where the same register is used to calculate the effective address.

Consider the following instruction:

$$
\text { STX } 0, X++(X \text { initialized to } 0)
$$

The desired result is to store a zero in locations $\$ 0000$ and $\$ 0001$, then increment $X$ to point to $\$ 0002$. In reality, the following occurs:
$0 \rightarrow$ temp $\quad$ calculate the EA; temp is a holding register
$X+2 \rightarrow X \quad$ perform auto increment
$X \rightarrow$ (temp) do store operation

## INDEXED INDIRECT

All of the indexing modes, with the exception of auto increment/decrement by one or a $\pm 5$-bit offset, may have an additional level of indirection specified. In indirect addressing, the effective address is contained at the location specified by the contents of the index register plus any offset. In the example below, the A accumulator is loaded indirectly using an effective address calculated from the index register and an offset.

[^22]| $\$ 0100$ | LDA $[\$ 10, X]$ | EA is now $\$ F 010$ |
| :--- | :--- | :--- |
|  |  |  |
| $\$ F 010$ | $\$ F 1$ | \$F150 is now the |
| \$F011 | $\$ 50$ | new EA |

After Execution<br>$A=\$ A A$ (actual data loaded)<br>$X=\$ F 000$

All modes of indexed indirect are included except those which are meaningless (e.g., auto increment/decrement by 1 indirect). Some examples of indexed indirect are

| LDA | $[, \mathrm{X}]$ |
| :--- | :--- |
| LDD | $[10, \mathrm{~S}]$ |
| LDA | $[\mathrm{B}, \mathrm{Y}]$ |
| LDD | $[, \mathrm{X}++]$ |

## RELATIVE ADDRESSING

The byte(s) following the branch opcode is (are) treated as a signed offset which may be added to the program counter. If the branch condition is true, then the calculated address ( $\mathrm{PC}+$ signed offset) is loaded into the program counter. Program execution continues at the new location as indicated by the PC; short (one byte offset) and long (two bytes offset) relative addressing modes are available. All of memory can be reached in long relative addressing as an effective address interpreted modulo $2^{16}$. Some examples of relative addressing are:

|  | BEQ | CAT | (short) |
| :--- | :--- | :--- | :--- |
|  | BGT | DOG | (short) |
| CAT | LBEQ | RAT | (long) |
| DOG | LBGT | RABBIT | (long) |
|  | $\bullet$ |  |  |
|  | $\bullet$ |  |  |
| RAT | $\bullet$ |  |  |
| RABBIT | NOP |  |  |

## PROGRAM COUNTER RELATIVE

The PC can be used as the pointer register with 8 - or 16 -bit signed offsets. As in relative addressing, the offset is added to the current PC to create the effective address. The effective address is then used as the address of the operand or data. Program counter relative addressing is used for writing position independent programs. Tables related to a particular routine will maintain the same relationship after the routine is moved, if referenced relative to the program counter. Examples are:

```
LDA CAT, PCR
LEAX TABLE, PCR
```

Since program counter relative is a type of indexing, an additional level of indirection is available.

| LDA | [CAT, PCR] |
| :--- | :--- |
| LDU | [DOG, PCR] |

INSTRUCTION SET

The instruction set of the EF6809E is similar to that of the EF6800 and is upward compatible at the source code level. The number of opcodes has been reduced from 72 to 59, but because of the expanded architecture and additional addressing modes, the number of available opcodes (with different addressing modes) has risen from 197 to 1464.
Some of the new instructions are described in detail below.

## PSHU/PSHS

The push instructions have the capability of pushing onto either the hardware stack (S) or user stack (U) any single register or set of registers with a single instruction.

## PULU/PULS

The pull instructions have the same capability of the push instruction, in reverse order. The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled. The actual push/pull sequence is fixed; each bit defines a unique register to push or pull, as shown below.

## Push/Pull Postbyte

Stacking Order
Pull Order
CC
A
B
DP
X Hi
X Lo
Y Hi
Y Lo
U/S Hi
U/S Lo
PC Hi
PC Lo
$\uparrow$
Push Order

Increasing Memory
$\downarrow$


All other combinations are undefined and INVALID.

## LEAX/LEAY/LEAU/LEAS

The LEA (load effective address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in Table 3.

The LEA instruction also allows the user to access data and tables in a position independent manner. For example:

| LEAX | MSG1, PCR |
| :--- | :--- |
| LBSR | PDATA (Print message routine) |
| $\bullet$ |  |
| - |  |

This sample program prints: 'MESSAGE'. By writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the $X$ pointer register. This code is totally position independent.
The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the auto increment and auto decrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows: LEAa , b+
(any of the 16 -bit pointer registers $X, Y$,
$U$, or $S$ may be substituted for $a$ and $b$.)

1. $b \rightarrow$ temp
2. $b+1 \rightarrow b$
(calculate the EA)
(modify b, postincrement)
(load a)
LEAa , - b
3. $\mathrm{b}-1 \rightarrow$ temp (calculate EA with predecrement)
4. $b-1 \rightarrow b \quad$ (modify $b$, predecrement)
5. temp $\rightarrow a \quad$ (load a)

TABLE 3 - LEA EXAMPLES

| Instruction | Operation | Comment |
| :---: | :---: | :---: |
| LEAX 10, X | $x+10 \rightarrow x$ | Adds 5-Bit Constant 10 to X |
| LEAX 500, $X$ | $X+500 \rightarrow X$ | Adds 16-Bit Constant 500 to $X$ |
| LEAY A, Y | $Y+A \rightarrow Y$ | Adds 8-Bit A Accumulator to $Y$ |
| LEAY D, Y | $Y+D \rightarrow Y$ | Adds 16-Bit D Accumulator to Y |
| LEAU - 10, U | $U-10 \rightarrow U$ | Substracts 10 from U |
| LEAS - 10, S | $\mathrm{S}-10 \rightarrow \mathrm{~S}$ | Used to Reserve Area on Stack |
| LEAS 10, S | $S+10 \rightarrow S$ | Used to 'Clean Up' Stack |
| LEAX 5, S | $S+5 \rightarrow X$ | Transfers As Well As Adds |

Auto increment-by-two and auto decrement-by-two instructions work similarly. Note that LEAX,$X+$ does not change $X$; however LEAX, $-X$ does decrement X.LEAX $1, X$ should be used to increment $X$ by one.

## MUL

Multiplies the unsigned binary numbers in the $A$ and $B$ accumulator and places the unsigned result into the 16 -bit $D$ accumulator. This unsigned multiply also allows multipleprecision multiplications.

## LONG AND SHORT RELATIVE BRANCHES

The EF6809E has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 - or 16 -bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64 K memory map. Position independent code can be easily generated through the use of relative branching. Both short ( 8 bit ) and long ( 16 bit ) branches are available.

## SYNC

After encountering a sync instruction, the MPU enters a sync state, stops processing instructions, and waits for an interrupt. If the pending interrupt is non-maskable (NMI) or maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{RO}}$ ) with its mask bit (F or I) clear, the processor will clear the sync state and perform the normal interrupt stacking and service routine. Since $\overline{\mathrm{FIRO}}$ and $\overline{\mathrm{RO}}$ are not edge triggered, a low level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable ( $\overline{\mathrm{FIRQ}}, \overline{\mathrm{RO}}$ ) with its mask bit (F or I) set, the processor will clear the sync state and continue processing by executing the next in-line instruction. Figure 16 depicts sync timing.

## SOFTWARE INTERRUPTS

A software interrupt is an instruction which will cause an interrupt and its associated vector fetch. These software interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on this EF6809E and are prioritized in the following order: SWI, SWI2, SWI3.

## 16-BIT OPERATION

The EF6809E has the capability of processing 16 -bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes, and pulls.

## CYCLE-BY-CYCLE OPERATION

The address bus cycle-by-cycle performance chart (Figure 16) illustrates the memory-access sequence corresponding to each possible instruction and addressing mode in the EF6809E. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this technique considerably speeds throughput.) Next, the operation of each opcode will follow the flowchart. $\overline{\mathrm{VMA}}$ is an indication of FFFF 16 on the address bus, $\mathrm{R} / \overline{\mathrm{W}}=1$ and $\mathrm{BS}=0$. The following examples illustrate the use of the chart

Example 1: LBSR (Branch Taken)
Before Execution SP = F000

|  | $\bullet$ |  |
| :--- | :--- | :--- |
| $\$ 8000$ |  | $\bullet$ |
|  |  | $\bullet$ |
|  |  | $\bullet$ |
|  |  | $\bullet$ |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

CYCLE-BY-CYCLE FLOW

| Cycle \# | Address | Data | R/ $\overline{\mathrm{W}}$ | Description |
| :---: | :---: | :---: | :---: | :--- |
| 1 | 8000 | 17 | 1 | Opcode Fetch |
| 2 | 8001 | 20 | 1 | Offset High Byte |
| 3 | 8002 | 00 | 1 | Offset Low Byte |
| 4 | FFFF | $*$ | 1 | $\overline{\mathrm{VMA}}$ Cycle |
| 5 | FFFF | $*$ | 1 | $\overline{\text { VMA Cycle }}$ |
| 6 | A000 | $*$ | 1 | Computed Branch Address |
| 7 | FFFF | $*$ | 1 | $\overline{\mathrm{VMA}}$ Cycle |
| 8 | EFFF | 80 | 0 | Stack High Order Byte of <br> Return Address |
| 9 | EFFE | 03 | 0 | Stack Low Order Byte of <br> Return Address |

Example 2: DEC (Extended)

| $\$ 8000$ | DEC | $\$ A 00 \dot{0}$ |
| :--- | :--- | :--- |
| $\$ A 000$ | FCB | $\$ 80$ |

CYCLE-BY-CYCLE FLOW

| Cycle \# | Address | Data | R/ $\overline{\mathrm{W}}$ | Description |
| :---: | :---: | :---: | :---: | :--- |
| 1 | 8000 | 7A | 1 | Opcode Fetch |
| 2 | 8001 | A0 | 1 | Operand Address, High Byte |
| 3 | 8002 | 00 | 1 | Operand Address, Low Byte |
| 4 | FFFF | $*$ | 1 | VMA Cycle |
| 5 | A000 | 80 | 1 | Read the Data |
| 6 | FFFF | $*$ | 1 | VMA Cycle |
| 7 | FFFF | $7 F$ | 0 | Store the Decremented Data |

* The data bus has the data at that particular address.


## INSTRUCTION SET TABLES

The instructions of the EF6809E have been broken down into five different categories. They are as follows: 8-bit operation (Table 4)
16-bit operation (Table 5)
Index register/stack pointer instructions (Table 6)
Relative branches (long or short) (Table 7)
Miscellaneous instructions (Table 8)
Hexadecimal values for the instructions are given in Table 9.

## PROGRAMMING AID

Figure 18 contains a compilation of data that will assist you in programming the EF6809E.


NOTES: 1. If the associated mask bit is set when the interrupt is requested, LIC will go low and this cycle will be an instruction fetch from address location PC +1 . However, if the interrupt is accepted ( $\overline{N M I}$ or an unmasked FIRX or IRO) LIC will remain high and interrupt processing will start with this cycle as m on Figures 8 and 9 (Interrupt Timing).
2. If mask bits are clear, $\overline{\mathrm{IRO}}$ and $\overline{\mathrm{FIRQ}}$ must be held low for three cycles to guarantee that interrupt will be taken, although only one cycle is necessary to bring the processor out of SYNC.
3. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.



FIGURE 17 - CYCLE-BY-CYCLE PERFORMANCE (Sheet 3 of 9)


FIGURE 17 - CYCLE-BY-CYCLE PERFORMANCE (Sheet 4 of 9)


FIGURE 17 - CYCLE-BY-CYCLE PERFORMANCE (Sheet 5 of 9)




(8)

Effective Address (EA)

Constant Offset from R
No Offset
5-Bit Offset
8-Bit Offset
16-Bı Offse
Accumulator Offset from R
A Register Offset
B Register Offset
D Register Offset
Auto Increment/Decrement R
Increment by 1
Increment by 2
Decrement by 1
Decrement by 2

Constant Offset from PC 8-Bit Offset
16. Bit Offset

Direct
Extended
mmediate

[^23]Index Register
Index Register
Index Register + Post Byte
Index Register + Post Byte High: Post Byte Low

Index Register + A Register
Index Register + B Register
Index Register + D Register

Index Register**
Index Register ${ }^{*}$
Index Register - 1
Index Register - 2

Program Counter + Offset Byte
Program Counter + Offset High Byte Offset Low Byte
Direct Page Register Address Low

Address High Address L.ow

NNNN + 1


Effective Address (EA)

| Constant Offset from R |
| :--- |
| No Offset |
| 5-Bit Offset |
| 8-Bit Offset |
| 16-Bit Offset |

Accumulator Offset from $R$
A Register Offset
B Register Offset
D Register Offset
Auto Increment/Decrement R
Increment by 1
Increment by 2
Decrement by 1
Decrement by 2

$\frac{\text { Constant Offset from PC }}{\text { 8-Bit Offset }}$| 16-Bit Offset |
| :--- |

## Direct

Extended
Immediate

[^24]Index Register
Index Register
Index Register + Post Byte
Index Register + Post Byte High Post Byte Low
Index Register + A Register
Index Register + B Register
Index Register + D Register
Index Register**
Index Register
Index Register - 1
Index Register - 2
Program Counter + Offset Byte
Program Counter + Offset High Byte Offset Low Byte
Direct Page Register Address Low
Address High Address Low
NNNN + I
Index Register + A Register
Index Register + B Register
Index Register + D Register
Index Register**
Index Register
Index Register -
Index Register - 2
Program Counter + Offset Byte
Program Counter + Offset High Byte Offset Low Byte.
Direct Page Regıster Address Low
NNNN + 1

TABLE 4 - 8-BIT ACCUMULATOR AND MEMORY INSTRUCTIONS

| Mnemonic(s) | Operation |
| :---: | :---: |
| ADCA, ADCB | Add memory to accumulator with carry |
| ADDA, ADDB | Add memory to accumulator |
| ANDA, ANDB | And memory with accumulator |
| ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left |
| ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right |
| BITA, BITB | Bit test memory with accumulator |
| CLR, CLRA, CLRB | Clear accumulator or memory location |
| CMPA, CMPB | Compare memory from accumulator |
| COM, COMA, COMB | Complement accumulator or memory location |
| DAA | Decimal adjust A accumulator |
| DEC, DECA, DECB | Decrement accumulator or memory location |
| EORA, EORB | Exclusive or memory with accumulator |
| EXG R1, R2 | Exchange R1 with R2 (R1, R2 $=A, B, C C, D P)$ |
| INC, INCA, INCB | Increment accumulator or memory location |
| LDA, LDB | Load accumulator from memory |
| LSL, LSLA, LSLB | Logical shift left accumulator or memory location |
| LSR, LSRA, LSRB | Logical shift right accumulator or memory location |
| MUL | Unsigned multiply ( $\mathrm{A} \times \mathrm{B} \rightarrow \mathrm{D}$ ) |
| NEG, NEGA, NEGB | Negate accumulator or memory |
| ORA, ORB | Or memory with accumulator |
| ROL, ROLA, ROLB | Rotate accumulator or memory left |
| ROR, RORA, RORB | Rotate accumulator or memory right |
| SBCA, SBCB | Subtract memory from accumulator with borrow |
| STA, STB | Store accumulator to memory |
| SUBA, SUBB | Subtract memory from accumulator |
| TST, TSTA, TSTB | Test accumulator or memory location |
| TFR R1, R2 | Transfer R1 to R2 (R1, R2 $=\mathrm{A}, \mathrm{B}, \mathrm{CC}, \mathrm{DP}$ ) |

NOTE: A, B, CC or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULU) instructions.

TABLE 5 - 16-BIT ACCUMULATOR AND MEMORY INSTRUCTIONS

| Mnemonic(s) | Operation |
| :--- | :--- |
| ADDD | Add memory to D accumulator |
| CMPD | Compare memory from $D$ accumulator |
| EXG D, R | Exchange D with $X, Y, S, U$ or PC |
| LDD | Load D accumulator from memory |
| SEX | Sign Extend B accumulator into $A$ accumulator |
| STD | Store D accumulator to memory |
| SUBD | Subtract memory from $D$ accumulator |
| TFR D, R | Transfer $D$ to $X, Y, S, U$ or PC |
| TFR R, D | Transfer $X, Y, S, U$ or PC to $D$ |

NOTE: D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions.

TABLE 6 - INDEX REGISTER/STACK POINTER INSTRUCTIONS

| Instruction | Description |
| :--- | :--- |
| CMPS, CMPU | Compare memory from stack pointer |
| CMPX, CMPY | Compare memory from index register |
| EXG R1, R2 | Exchange $D, X, Y, S, U$ or PC with $D, X, Y, S, U$ or PC |
| LEAS, LEAU | Load effective address into stack pointer |
| LEAX, LEAY | Load effective address into index register |
| LDS, LDU | Load stack pointer from memory |
| LDX, LDY | Load index register from memory |
| PSHS | Push $A, B, C C, D P, D, X, Y, U$, or PC onto hardware stack |
| PSHU | Push A, B, CC, DP, D, X, Y, S, or PC onto user stack |
| PULS | Pull A, B, CC, DP, D, X, Y, U or PC from hardware stack |
| PULU | Pull A, B, CC, DP, D, X, Y, S or PC from hardware stack |
| STS, STU | Store stack pointer to memory |
| STX, STY | Store index register to memory |
| TFR R1, R2 | Transfer $D, X, Y, S, U$ or PC to $D, X, Y, S, U$ or PC |
| ABX | Add B accumulator to $X$ lunsigned) |

TABLE 7 - BRANCH INSTRUCTIONS

| Instruction | Description |
| :---: | :---: |
| SIMPLE BRANCHES |  |
| BEO. LBEO | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BMI, LBMI | Branch if minus |
| BPL, LBPL | Branch if plus |
| BCS, LBCS | Branch if carry set |
| BCC, LBCC | Branch if carry clear |
| BVS, LBVS | Branch if overflow set |
| BVC, LBVC | Branch if overflow clear |
| SIGNED BRANCHES |  |
| BGT, LBG I | Branct; it greater (signed) |
| BVS, LBVS | Branch if invalid 2's complement result |
| BGE, LBGE | Branch if greater than or equal (signed) |
| BEQ, LBEQ | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BLE, LBLE | Branch if less than or equal (signed) |
| BVC. LBVC | Branch if valid 2's complement result |
| BLT, LBLT | Branch if less than (signed) |
| UNSIGNED BRANCHES |  |
| BHI, LBHI | Branch if higher (unsigned) |
| BCC, LBCC | Branch if higher or same (unsigned) |
| BHS, LBHS | Branch if higher or same (unsigned) |
| BEQ. LBEQ | Branch if equal |
| BNE, LBNE | Branch if not equal |
| BLS, LBLS | Branch if lower or same (unsigned) |
| BCS, LBCS | Branch if lower (unsigned) |
| BLO, LBLO | Branch if lower (unsigned) |
| OTHER BRANCHES |  |
| BSR, LBSR | Branch to subroutine |
| BRA, LBRA | Branch always |
| BRN, LBRN | Branch never |

TABLE 8 - MISCELSLANEOUS INSTRUCTIONS

| Instruction | Description |
| :--- | :--- |
| ANDCC | AND condition code register |
| CWAI | AND condition code register, then wait for interrupt |
| NOP | No operation |
| ORCC | OR condition code register |
| JMP | Jump |
| JSR | Jump to subroutine |
| RTI | Return from interrupt |
| RTS | Return from subroutine |
| SWI, SWI2, SWI3 | Software interrupt (absolute indirect) |
| SYNC | Synchronize with interrupt line |


| OP | Mnem | Mode | $\sim$ | 1 | OP | Mnem | Mode | - | 1 | OP | Mnem | Mode | $\sim$ | * |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\infty$ | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | $4+$ | $2+$ | 60 | NEG | Indexed | $6+$ | $2+$ |
| 01 | * | $\uparrow$ |  |  | 31 | LEAY | 4 | 4+ | $2+$ | 61 |  | $\uparrow$ |  |  |
| 02 | * |  |  |  | 32 | LEAS | $\checkmark$ | 4+ | $2+$ | 62 | * |  |  |  |
| 03 | COM |  | 6 | 2 | 33 | LEAU | Indexed | $4+$ | $2+$ | 63 | COM |  | $6+$ | $2+$ |
| 04 | LSR |  | 6 | 2 | 34 | PSHS | Immed | $5+$ | 2 | 64 | LSR |  | 6+ | $2+$ |
| 05 | * |  |  |  | 35 | PULS | Immed | $5+$ | 2 | 65 | * |  |  |  |
| 06 | ROR |  | 6 | 2 | 36 | PSHU | Immed | $5+$ | 2 | 66 | ROR |  | $6+$ | $2+$ |
| 07 | ASR |  | 6 | 2 | 37 | PULU | Immed | $5+$ | 2 | 67 | ASR |  | 6+ | $2+$ |
| 08 | ASL, LSL |  | 6 | 2 | 38 | * | - |  |  | 68 | ASL, LSL. |  | 6+ | $2+$ |
| 09 | ROL |  | 6 | 2 | 39 | RTS | Inherent | 5 | 1 | 69 | ROL |  | $6+$ | $2+$ |
| OA | DEC |  | 6 | 2 | 3A | ABX | 4 | 3 | 1 | 6 A | DEC |  | $6+$ | $2+$ |
| OB | * 1 |  |  |  | 3B | RTI |  | 6/15 | 1 | 6 B | * |  |  |  |
| OC | INC |  | 6 | 2 | 3 C | CWAI | $\downarrow$ | $\geq 20$ | 2 | 6C | INC |  | 6+ | $2+$ |
| OD | TST |  | 6 | 2 | 3D | MUL | Inherent | 11 | 1 | 6D | TST |  | 6+ | $2+$ |
| OE | JMP | $\gamma$ | 3 | 2 | 3E |  | - |  |  | 6 E | JMP | $\downarrow$ | $3+$ | $2+$ |
| OF | CLR | Direct | 6 | 2 | 3F | SWI | Inherent | 19 | 1 | 6 F | CLR | Indexed | 6+ | $2+$ |
| 10 | Page 2 | - | - | - | 40 |  | Inherent | 2 | 1 | 70 | NEG | Extended | 7 | 3 |
| 11 | Page 3 | - | - | - | 41 | * | 4 |  |  | 71 | * |  |  |  |
| 12 | NOP | Inherent | 2 | 1 | 42 | * |  |  |  | 72 | * |  |  |  |
| 13 | SYNC | Inherent | $\geq 4$ | 1 | 43 | COMA |  | 2 | 1 | 73 | COM |  | 7 | 3 |
| 14 | * |  |  |  | 44 | LSRA |  | 2 | 1. | 74 | LSR |  | 7 | 3 |
| 15 | * |  |  |  | 45 | * |  |  |  | 75 | * |  |  |  |
| 16 | LBRA | Relative | 5 | 3 | 46 | RORA |  | 2 | 1 | 76 | ROR |  | 7 | 3 |
| 17 | LBSR | Relative | 9 | 3 | 47 | ASRA |  | 2 | 1 | 77 | ASR |  | 7 | 3 |
| 18 | * |  |  |  | 48 | ASLA, LSLA |  | 2 | 1 | 78 | ASL, LSL |  | 7 | 3 |
| 19 | DAA | Inherent | 2 | 1 | 49 | ROLA |  | 2 | 1 | 79 | ROL |  | 7 | 3 |
| 1A | ORCC | Immed | 3 | 2 | 4A | DECA |  | 2 | 1 | 7A | DEC |  | 7 | 3 |
| 1 B | * | - |  |  | 4B | * |  |  |  | 7 B | * |  |  |  |
| 1 C | ANDCC | Immed | 3 | 2 | 4 C | INCA |  | 2 | 1 | 7 C | INC |  | 7 | 3 |
| 1D | SEX | Inherent | 2 | 1 | 4D | TSTA | , | 2 | 1 | 7 D |  |  | 7 | 3 |
| 1 E | EXG | Immed | 8 | 2 | 4 E |  | $\checkmark$ |  |  | 7 E | JMP | $\downarrow$ | 4 | 3 |
| 1 F | TFR | Immed | 6 | 2 | 4F | CLRA | Inherent | 2 | 1 | 7F | CLR | Extended | 7 | 3 |
| 20 | BRA | Relative | 3 | 2 | 50 | NEGB | inherent | 2 | 1 | 80 | SUBA | Immed | 2 | 2 |
| 21 | BRN | 4 | 3 | 2 | 51 |  | 4 |  |  | 81 | CMPA | 4 | 2 | 2 |
| 22 | BHI |  | 3 | 2 | 52 | * |  |  |  | 82 | SBCA |  | 2 | 2 |
| 23 | BLS |  | 3 | 2 | 53 | COMB |  | 2 | 1 | 83 | SUBD |  | 4 | 3 |
| 24 | BHS, BCC |  | 3 | 2 | 54 | LSRB |  | 2 | 1 | 84 | ANDA |  | 2 | 2 |
| 25 | BLO, BCS |  | 3 | 2 | 55 | * |  |  |  | 85 | BITA |  | 2 | 2 |
| 26 | BNE |  | 3 | 2 | 56 | RORB |  | 2 | 1 | 86 | LDA |  | 2 | 2 |
| 27 | BEQ |  | 3 | 2 | 57 | ASRB |  | 2 | 1 | 87 | * |  |  |  |
| 28 | BVC |  | 3 | 2 | 58 | ASLB, LSLB |  | 2 | 1 | 88 | EORA |  | 2 | 2 |
| 29 | BVS |  | 3 | 2 | 59 | ROLB |  | 2 | 1 | 89 | ADCA |  | 2 | 2 |
| 2A | BPL |  | 3 | 2 | 5 A | DECB |  | 2 | 1 | 8 A | ORA |  | 2 | 2 |
| 2B | BMI |  | 3 | 2 | 5 B | * |  |  |  | 8B | ADDA | $\downarrow$ | 2 | 2 |
| 2 C | BGE |  | 3 | 2 | 5 C | INCB |  | 2 | 1 | 8 C | CMPX | Immed | 4 | 3 |
| 2D | BLT |  | 3 | 2 | 5 D | TSTB |  | 2 | 1 | 8D | BSR | Relative | 7 | 2 |
| 2 E | BGT | 1 | 3 | 2 | 5 E | * | $\downarrow$ |  |  | 8 E | LDX | Immed | 3 | 3 |
| 2 F | BLE | Relative | 3 | 2 | 5 F | CLRB | Inherent | 2 | 1 | 8F | * |  |  |  |

LEGEND:

[^25]TABLE 9 - HEXADECIMAL VALUES OF MACHINE CODES (CONTINUED)


FIGURE 18 - PROGRAMMING AID

| Instruction | Forms | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Description | H | (3 | 2 | 1 | O |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Immediate |  |  | Direct |  |  | Indexed |  |  | Extended |  |  | Inherent |  |  |  |  |  |  |  |  |
|  |  | Op | - | * | Op | - | * | Op | $\sim$ | 1 | Op | $\sim$ | * | Op | $\sim$ | * |  |  |  |  |  |  |
| ABX |  |  |  |  |  |  |  |  |  |  |  |  |  | 3A | 3 | 1 | $B+X \rightarrow X$ (Unsigned) | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| ADC | ADCA <br> ADCB | $\begin{array}{\|l\|} \hline 89 \\ \mathrm{C} 9 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 99 \\ & \text { D9 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { A9 } \\ & \text { E9 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \\ & \hline \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \text { B9 } \\ & \text { F9 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A+M+C-A \\ & B+M+C-B \end{aligned}$ | $t$ | 1 | 1 | 1 | 1 <br> 1 |
| ADD | $\begin{aligned} & \text { ADDA } \\ & \text { ADDB } \\ & \text { ADDD } \end{aligned}$ | $\begin{aligned} & \hline 8 \mathrm{~B} \\ & \mathrm{CB} \\ & \mathrm{C} 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 98 \\ & \text { DB } \\ & \text { D3 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 6 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { AB } \\ & \text { EB } \\ & \text { E3 } \end{aligned}$ | $\begin{array}{\|l\|} \hline 4+ \\ 4+ \\ 6+ \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \mathrm{BB} \\ & \mathrm{FB} \\ & \mathrm{F3} \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A+M-A \\ & B+M-B \\ & D+M M+1 \rightarrow D \end{aligned}$ | ! | 1 1 1 1 | 1 1 1 1 | 1 1 1 | 1 $t$ $t$ |
| AND | $\begin{aligned} & \text { ANDA } \\ & \text { ANDB } \\ & \text { ANDCC } \\ & \hline \end{aligned}$ | $\begin{aligned} & 84 \\ & \mathrm{C4} \\ & 1 \mathrm{C} \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 94 \\ & \text { D4 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{A} 4 \\ & \mathrm{E} 4 \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \mathrm{B4} \\ & \mathrm{~F} 4 \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A \Lambda M \rightarrow A \\ & B \Lambda M \rightarrow B \\ & C C \Lambda \mid M M-C C \end{aligned}$ | - | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 1 | 0 | $\bullet$ <br> $\bullet$ <br> 7 |
| ASL | $\begin{aligned} & \text { ASLA } \\ & \text { ASLB } \\ & \text { ASL } \end{aligned}$ |  |  |  | 08 | 6 | 2 | 68 | $6+$ | $2+$ | 78 | 7 | 3 | $\begin{aligned} & 48 \\ & 58 \end{aligned}$ | 2 | 1 |  | 8 <br> 8 <br> 8 | 1 1 1 | 1 1 1 | 1 <br> 1 <br> 1 | 1 <br> $t$ <br> 1 |
| ASR | $\begin{aligned} & \hline \text { ASRA } \\ & \text { ASRB } \\ & \text { ASR } \\ & \hline \end{aligned}$ |  |  |  | 07 | 6 | 2 | 67 | $6+$ | $2+$ | 77 | 7 | 3 | $\begin{aligned} & \hline 47 \\ & 57 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 8 \\ 8 \\ 8 \\ \hline \end{array}$ | $\begin{array}{\|l} 1 \\ 1 \\ 1 \end{array}$ | 1 1 1 1 | $\stackrel{\bullet}{\bullet}$ | 1 <br> 1 <br> 1 |
| BIT | $\begin{aligned} & \text { BITA } \\ & \text { BITB } \end{aligned}$ | $\begin{aligned} & 85 \\ & C 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 95 \\ & \text { D5 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { E5 } \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \mathrm{B5} \\ & \mathrm{~F} 5 \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ |  |  |  | Bit Tes: A (M A A) Bit Tesi B (M $\boldsymbol{\Lambda}$ B) | $\bullet$ | 1 | 1 | 0 | $\bullet$ |
| CLR | $\begin{array}{\|l} \hline \text { CLRA } \\ \text { CLRB } \\ \text { CLR } \end{array}$ |  |  |  | OF | 6 | 2 | 6 F | $6+$ | $2+$ | 7F | 7 | 3 | $\begin{aligned} & 4 F \\ & 5 F \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | $\begin{aligned} & 0 \rightarrow A \\ & 0 \rightarrow B \\ & 0 \rightarrow M \end{aligned}$ | $\bullet \cdot$ | 1 0 0 0 | 1 1 1 | 0 0 0 0 | 0 <br> 0 <br> 0 |
| CMP | CMPA CMPB CMPD <br> CMPS <br> CMPU <br> CMPX <br> CMPY | $\begin{aligned} & 81 \\ & \mathrm{C} 1 \\ & 10 \\ & 83 \\ & 11 \\ & 8 \mathrm{C} \\ & 11 \\ & 83 \\ & 8 \mathrm{C} \\ & 10 \\ & 8 \mathrm{C} \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 5 \\ & 5 \\ & 5 \\ & 5 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 4 \\ & 4 \\ & 4 \\ & 4 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & \hline 91 \\ & \mathrm{D} 1 \\ & 10 \\ & 93 \\ & 11 \\ & 9 \mathrm{C} \\ & 11 \\ & 93 \\ & 9 C \\ & 10 \\ & 9 C \\ & \hline \end{aligned}$ | 4 <br> 4 <br> 7 <br> 7 <br> 7 <br> 6 7 | $\begin{aligned} & 2 \\ & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & \hline A 1 \\ & E 1 \\ & 10 \\ & A 3 \\ & 11 \\ & A C \\ & 11 \\ & A 3 \\ & A C \\ & 10 \\ & A C \\ & \hline \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \\ & 7+ \\ & 7+ \\ & 7+ \\ & 6+ \\ & 7+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 3+ \\ & 3+ \\ & 3+ \\ & 2+ \\ & 3+ \end{aligned}$ | B1 F1 10 $B 3$ 11 $B C$ 11 $B 3$ $B C$ 10 $B C$ |  | 3 <br> 3 <br> 4 <br> 4 <br> 4 <br> 3 <br> 4 |  |  |  | Compare $M$ from $A$ Compare $M$ from B Compare $M: M+1$ from $D$ <br> Compare $M: M+1$ from $S$ <br> Compare $M: M+1$ from $U$ <br> Compare $\mathrm{M}: \mathrm{M}+1$ from X Compare $M: M+1$ from $Y$ | $\begin{array}{\|l\|} \hline 8 \\ 8 \\ \bullet \\ \bullet \\ \bullet \\ \bullet \\ \bullet \end{array}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ <br> 1 <br> 1 | 1 <br> 1 <br> 1 <br> 1 <br> 1 <br> 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 1 1 1 1 1 1 1 |
| COM | $\begin{aligned} & \text { COMA } \\ & \text { COMB } \\ & \text { COM } \end{aligned}$ |  |  |  | 03 | 6 | 2 | 63 | $6+$ | $2+$ | 73 | 7 | 3 | $\begin{aligned} & 43 \\ & 53 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \bar{A} \rightarrow A \\ & \bar{B} \rightarrow B \\ & \bar{M} \rightarrow M \end{aligned}$ | $\bullet$ - | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 <br> 1 <br> 1 | 0 0 0 | 1 <br> 1 <br> 1 |
| CWAI |  | 3C | $\geq 20$ | 2 |  |  |  |  |  |  |  |  |  |  |  |  | CC $\Lambda$ IMM $\rightarrow$ CC Wait for Interrupt |  |  |  |  | 7 |
| DAA |  |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 | Decimal Adjust A | - | 1 | 1 | 0 | 1 |
| DEC | $\begin{aligned} & \text { DECA } \\ & \text { DECB } \\ & \text { DEC } \end{aligned}$ |  |  |  | OA | 6 | 2 | 6 A | $6+$ | $2+$ | -7A | 7 | 3 | $\begin{aligned} & 4 \mathrm{~A} \\ & 5 \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & A-1 \rightarrow A \\ & B-1 \rightarrow B \\ & M-1 \rightarrow M \end{aligned}$ | $\bullet$ | 1 <br> 1 <br> 1 | 1 1 1 | 1 <br> 1 <br> 1 | $\stackrel{-}{\bullet}$ |
| EOR | EORA EORB | $\begin{aligned} & 88 \\ & \mathrm{C} 8 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 98 \\ & \text { D8 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { A8 } \\ & \text { E8 } \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { B8 } \\ & \text { F8 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & \hline 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A \forall M \rightarrow A \\ & B \forall M \rightarrow B \end{aligned}$ | $\bullet$ | $\begin{array}{\|l} \hline 1 \\ 1 \\ \hline \end{array}$ | 1 | 1 0 0 | $\bullet \cdot$ |
| EXG | R1, R2 | 1 E | 8 | 2 |  |  |  | . |  |  |  |  |  |  |  |  | $R 1-R 2^{2}$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| INC | $\begin{array}{\|l} \hline \text { INCA } \\ \text { INCB } \\ \text { INC } \\ \hline \end{array}$ |  |  |  | OC | 6 | 2 | 6 C | 6+ | $2+$ | 7 C | 7 | 3 | $\begin{aligned} & 4 \mathrm{C} \\ & 5 \mathrm{C} \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | $\begin{aligned} & A+1-A \\ & B+1 \rightarrow B \\ & M+1 \rightarrow M \end{aligned}$ | $\stackrel{\bullet}{\bullet}$ | 1 <br> 1 <br> 1 <br>  <br>  | 1 1 1 | 1 1 1 | $\bullet \cdot$ |
| JMP |  |  |  |  | OE | 3 | 2 | 6 E | $3+$ | $2+$ | 7 E | 4 | 3 |  |  |  | $E A^{3}-P C$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| JSR |  |  |  |  | 9D | 7 | 2 | AD | $7+$ | $2+$ | BD | 8 | 3 |  |  |  | Jump to Subroutine | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| LD | $\begin{aligned} & \text { LDA } \\ & \text { LDB } \\ & \text { LDD } \\ & \text { LDS } \\ & \text { LDU } \\ & \text { LDX } \end{aligned}$ | 86 C 6 CC 10 CE CE 8 E 10 8 E | $\begin{aligned} & 2 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 3 \\ & 4 \\ & 3 \\ & 3 \\ & 4 \end{aligned}$ | 96 <br> 96 <br> $D C$ <br> 10 <br> $D E$ <br> $D E$ <br> $9 E$ <br> 10 <br> $9 E$ | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 5 \\ & 6 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 3 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ | A6 <br> E6 <br> EC <br> 10 <br> EE <br> EE <br> AE <br> 10 <br> AE | $\begin{array}{\|l\|} \hline 4+ \\ 4+ \\ 5+ \\ 6+ \\ 5+ \\ 5+ \\ 6+ \\ \hline \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \\ & 3+ \\ & 2+ \\ & 2+ \\ & 3+ \end{aligned}$ | B 6 F 6 FC 10 FE FE BE 10 BE | $\begin{aligned} & 5 \\ & 5 \\ & 6 \\ & 7 \\ & \\ & \hline 6 \\ & 6 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ |  |  |  | $\begin{aligned} & M \rightarrow A \\ & M \rightarrow B \\ & M: M+1 \rightarrow D \\ & M: M+1 \rightarrow S \\ & M: M+1 \rightarrow U \\ & M: M+1 \rightarrow X \\ & M: M+1 \rightarrow Y \end{aligned}$ |  | $\begin{aligned} & t \\ & t \\ & t \\ & t \\ & t \\ & t \\ & t \end{aligned}$ | $\left.\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned} \right\rvert\,$ | $\begin{array}{\|l\|} \hline 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \end{array}$ |  |
| LEA | LEAS <br> LEAU <br> LEAX <br> LEAY |  |  |  |  |  |  | $\begin{aligned} & 32 \\ & 33 \\ & 30 \\ & 31 \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \\ & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \\ & 2+ \end{aligned}$ |  |  |  |  |  |  | $\begin{aligned} & E A^{3}-S \\ & E A^{3} \rightarrow U \\ & E A^{3}-X \\ & E A^{3}-Y \end{aligned}$ | $\stackrel{\bullet}{\bullet}$ | - | - | $\bullet \bullet$ | $\stackrel{\bullet}{\bullet}$ |

OP Operation Code (Hexadecimal)
~ Number of MPU Cycles

* Number of Program Bytes
+ Arithmetic Plus
- Arithmetic Minus
- Multiply
$\bar{M}$ Complement of $M$
$\rightarrow$ Transfer Into
H Half-carry (from bit 3)
$\mathrm{N} \quad$ Negative (sign bit)
$Z$ Zero result
$\checkmark$ Overflow, 2's complement
C Carry from ALU

1 Test and set if true, cleared otherwise

- Not Affected

CC Condition Code Register
: Concatenation
$\checkmark$ Logical or
$\Lambda$ Logical and
$\forall$ Logical Exclusive or

FIGURE 18 - PROGRAMMING AID (CONTINUED)

| Instruction | Forms | Addressing Modes |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Description | 5 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Immediate |  |  | Direct |  |  | Indexed 1 |  |  | Extended |  |  | Inherent |  |  |  |  |  |  |  |  |
|  |  | Op | ~ | 7 | Op | - | \% | Op | - | 7 | Op | ~ | \% | Op | - | 7 |  | H | N | Z | V | C |
| LSL | $\begin{aligned} & \text { LSLA } \\ & \text { LSLB } \\ & \text { LSL } \end{aligned}$ |  |  |  | 08 | 6 | 2 | 68 | $6+$ | $2+$ | 78 | $\cdots$ | 3 | 48 58 | 2 | 1 |  | $\stackrel{-}{\bullet}$ | 1 <br> 1 <br> 1 | 1 1 1 1 | 1 <br> 1 <br> 1 | 1 1 1 |
| LSR | $\begin{array}{\|l\|l\|} \hline \text { LSRA } \\ \text { LSRB } \\ \text { LSR } \\ \hline \end{array}$ |  |  |  | 04 | 6 | 2 | 64 | $6+$ | $2+$ | 74 | 7 | 3 | $\begin{aligned} & 44 \\ & 54 \end{aligned}$ | 2 | 1 |  | $\stackrel{\bullet}{\bullet}$ | $\begin{array}{\|l\|} \hline 0 \\ 0 \\ 0 \end{array}$ | 1 <br> 1 <br> 1 <br> 1 | $\bullet \cdot$ | 1 <br> 1 <br> 1 |
| MUL |  |  |  |  |  |  |  |  |  |  |  |  |  | 3D | 11 | 1 | $A \times B-D$ (Unsigned) | - | - | 1 | - | 9 |
| NEG | NEGA NEGB NEG |  |  |  | 00 | 6 | 2 | 60 | $6+$ | $2+$ | 70 | 7 | 3 | $\begin{aligned} & 40 \\ & 50 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | $\begin{aligned} & \overline{\bar{A}}+1 \rightarrow A \\ & \bar{B}+1 \rightarrow B \\ & \bar{M}+1 \rightarrow M \end{aligned}$ | $\begin{aligned} & 8 \\ & 8 \\ & 8 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 <br> 1 <br> 1 <br> 1 | 1 <br> 1 <br> 1 | 1 <br> 1 <br> 1 |
| NOP |  |  |  |  |  |  |  |  |  |  |  |  |  | 12 | 2 | 1 | No Operation | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
| OR | ORA ORB ORCC | $\begin{aligned} & 8 \mathrm{~A} \\ & \mathrm{CA} \\ & 1 \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 9 A \\ & \mathrm{DA} \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{AA} \\ & \mathrm{EA} \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \mathrm{BA} \\ & \mathrm{FA} \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A \vee M \rightarrow A \\ & B \vee M \rightarrow B \\ & C C \vee I M M \rightarrow C C \\ & \hline \end{aligned}$ | $\bullet$ | $1$ | 1 | $\begin{array}{\|l} \hline 0 \\ 0 \\ 7 \\ \hline \end{array}$ | $\bullet$ |
| PSH | $\begin{aligned} & \text { PSHS } \\ & \text { PSHU } \end{aligned}$ | 34 36 | $\begin{array}{\|l\|} \hline 5+4 \\ 5+4 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | Push Registers on S Stack Push Registers on U Stack | $\bullet$ | - | $\bullet$ | - | $\bullet$ |
| PUL | PULS PULU | 35 37 | $\begin{array}{\|l\|} 5+4 \\ 5+4 \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | Pull Registers from S Stack Pull Registers from U Stack | $\bullet$ | $\bullet$ | $\bullet$ | - | - |
| ROL | ROLA <br> ROLB <br> ROL |  |  |  | 09 | 6 | 2 | 69 | $6+$ | $2+$ | 79 | 7 | 3 | $\begin{aligned} & 49 \\ & 59 \end{aligned}$ | 2 | 1 |  | $\stackrel{\bullet}{\bullet}$ | 1 1 1 1 | 1 <br> 1 <br> 1 | 1 1 1 | 1 1 |
| ROR | $\begin{aligned} & \text { RORA } \\ & \text { RORB } \\ & \text { ROR } \end{aligned}$ |  |  |  | 06 | 6 | 2 | 66 | $6+$ | $2+$ | 76 | 7 | 3 | $\begin{aligned} & 46 \\ & 56 \end{aligned}$ | 2 | 1 |  |  | 1 1 1 | 1 1 1 | - | 1 <br> 1 <br> 1 |
| RTI |  |  |  |  |  |  |  |  |  |  |  |  |  | 3B | 6/15 | 1 | Return From Interrupt |  |  |  |  | 7 |
| RTS |  |  |  |  |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 | Return from Subroutine | - | - | - | - | - |
| SBC | $\begin{aligned} & \text { SBCA } \\ & \text { SBCB } \end{aligned}$ | $\begin{aligned} & 82 \\ & \mathrm{C} 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 92 \\ & \text { D2 } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{A} 2 \\ & \mathrm{E} 2 \end{aligned}$ | $\begin{aligned} & 4+ \\ & 4+ \end{aligned}$ | $\begin{aligned} & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \text { B2 } \\ & \text { F2 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ |  |  |  | $\begin{aligned} & A-M-C-A \\ & B-M-C-B \end{aligned}$ | $\begin{array}{\|l\|} \hline 8 \\ 8 \end{array}$ | $1$ | $1$ | 1 | 1 |
| SEX |  |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 2 | 1 | Sign Extend $B$ into $A$ | $\bullet$ | 1 | 1 | 0 | $\bullet$ |
| ST | $\begin{aligned} & \text { STA } \\ & \text { STB } \\ & \text { STD } \\ & \text { STS } \\ & \text { STU } \\ & \text { STX } \\ & \text { STY } \end{aligned}$ |  |  |  | $\begin{aligned} & 97 \\ & \mathrm{D7} \\ & \mathrm{DD} \\ & 10 \\ & \mathrm{DF} \\ & \mathrm{DF} \\ & 9 \mathrm{~F} \\ & 10 \\ & 9 \mathrm{~F} \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 5 \\ & 6 \\ & \hline 5 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 3 \\ & 2 \\ & 2 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{gathered} \hline A 7 \\ E 7 \\ E D \\ 10 \\ E F \\ E F \\ A F \\ 10 \\ A F \end{gathered}$ | $\begin{array}{\|l\|} \hline 4+ \\ 4+ \\ 5+ \\ 6+ \\ 5+ \\ 5+ \\ 6+ \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \\ & 3+ \\ & 2+ \\ & 2+ \\ & 3+ \end{aligned}$ | $\begin{aligned} & \hline B 7 \\ & \text { F7 } \\ & \text { FD } \\ & 10 \\ & \text { FF } \\ & \text { FF } \\ & \text { BF } \\ & 10 \\ & B F \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 6 \\ & 7 \\ & 6 \\ & 6 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 3 \\ & 3 \\ & 4 \end{aligned}$ |  |  |  | $\begin{aligned} & A \rightarrow M \\ & B \rightarrow M \\ & D \rightarrow M: M+1 \\ & S \rightarrow M: M+1 \\ & U \rightarrow M: M+1 \\ & X \rightarrow M: M+1 \\ & Y \rightarrow M: M+1 \end{aligned}$ |  | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & \vdots \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | - |
| SUB | $\begin{aligned} & \hline \text { SUBA } \\ & \text { SUBB } \\ & \text { SUBD } \\ & \hline \end{aligned}$ | $\begin{aligned} & 80 \\ & \mathrm{C0} \\ & 83 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 4 \end{aligned}$ | $\begin{array}{\|l} \hline 2 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & 90 \\ & \mathrm{DO} \\ & 93 \end{aligned}$ | $\begin{aligned} & \hline 4 \\ & 4 \\ & 6 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { EO } \\ & \text { A3 } \\ & \hline \end{aligned}$ | $\begin{array}{\|l\|} \hline 4+ \\ 4+ \\ 6+ \\ \hline \end{array}$ | $\begin{aligned} & 2+ \\ & 2+ \\ & 2+ \end{aligned}$ | $\begin{aligned} & \text { B0 } \\ & \text { F0 } \\ & \text { B3 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \\ & 7 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & \hline \end{aligned}$ |  |  |  | $\begin{aligned} & A-M-A \\ & B-M-B \\ & D-M: M+1 \rightarrow D \end{aligned}$ | 8 <br> 8 | 1 1 1 | 1 | 1 <br> 1 <br> 1 | t |
| SWI | $\begin{aligned} & \text { SWI6 } \\ & \text { SWI26 } \\ & \text { SWI36 } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{aligned} & 3 F \\ & 10 \\ & 3 F \\ & 11 \\ & 3 F \end{aligned}$ | $\begin{aligned} & 19 \\ & 20 \\ & 20 \end{aligned}$ | $\begin{aligned} & 1 \\ & 2 \\ & 1 \end{aligned}$ | Software Interrupt 1 Software Interrupt 2 <br> Software Interrupt 3 |  |  |  |  | - |
| SYNC |  |  |  |  |  |  |  |  |  |  |  |  |  | 13 | $\geq 4$ | 1 | Synchronize to Interrupt | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| TFR | R1, R2 | IF | 6 | 2 |  |  |  |  |  |  |  |  |  |  |  |  | $R 1 \rightarrow R 2^{2}$ | $\bullet$ | - | $\bullet$ | - | $\bullet$ |
| TST | $\begin{array}{\|l} \hline \text { TSTA } \\ \text { TSTB } \\ \text { TST } \end{array}$ |  |  |  | OD | 6 | 2 | 6D | $6+$ | $2+$ | 7D | 7 | 3 | $\begin{aligned} & 4 D \\ & 5 D \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | Test A <br> Test B <br> Test M | $\stackrel{-}{\bullet}$ | 1 1 1 | 1 | 0 0 0 | $\bullet \cdot$ |

NOTES:

1. This column gives a base cycle and byte count. To obtain total count, add the values obtained from the INDEXED ADDRESSING MODE table, Table 2.
2. R1 and R2 may be any pair of 8 bit or any pair of 16 bit registers

The 8 bit registers are: $A, B, C C, D P$
The 16 bit registers are: $X, Y, U, S, D, P C$
3. $E A$ is the effective address.
4. The PSH and PUL instructions require 5 cycles plus 1 cycle for each byte pushed or pulled.
5. 5(6) means: 5 cycles if branch not taken, 6 cycles if taken (Branch instructions).
6. SWI sets I and F bits. SWI2 and SWI3 do not affect I and F.
7. Conditions Codes set as a direct result of the instruction.
8. Vaue of half-carry flag is undefined.
9. Special Case - Carry set if b7 is SET.

Branch Instructions

| Instruction | Forms | Addressing Mode |  |  | Description | 5 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  | OP | -5 | 1 |  | H | N | 2 | V | C |
| BCC | $\begin{aligned} & \mathrm{BCC} \\ & \angle B C C \end{aligned}$ | $\begin{aligned} & 24 \\ & 10 \\ & 24 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\mathrm{C}=0$ Long Branch $C=0$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| BCS | $\begin{aligned} & \text { BCS } \\ & \text { LBCS } \end{aligned}$ | $\begin{array}{r} 25 \\ 10 \\ 25 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\mathrm{C}=1$ Long Branch $C=1$ | $\bullet$ | - | - |  | - |
| BEO | $\begin{aligned} & \text { BEQ } \\ & \text { LBEQ } \end{aligned}$ | $\begin{aligned} & 27 \\ & 10 \\ & 27 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $Z=1$ Long Branch $z=1$ | $\bullet$ | - | - | - | $\bullet$ |
| BGE | $\begin{aligned} & \text { BGE } \\ & \text { LBGE } \end{aligned}$ | $\begin{aligned} & 2 \mathrm{C} \\ & 10 \\ & 2 \mathrm{C} \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\geqslant$ Zero Long Branch $\geq$ Zero | $\bullet$ | - | - | $\bullet$ | - |
| BGT | $\begin{array}{\|l\|} \hline \text { BGT } \\ \text { LBGT } \end{array}$ | $\begin{aligned} & 2 \mathrm{E} \\ & 10 \\ & 2 \mathrm{E} \\ & \hline \end{aligned}$ | $\begin{gathered} 3 \\ 5(6) \end{gathered}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch > Zero Long Branch > Zero | $\bullet$ | - | - | $\bullet$ | $\bullet$ |
| BHI | $\begin{aligned} & \mathrm{BHI} \\ & \mathrm{LBHI} \end{aligned}$ | $\begin{aligned} & 22 \\ & 10 \\ & 22 \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch Higher Long Branch Higher | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| BHS | $\begin{aligned} & \mathrm{BHS} \\ & \text { LBHS } \end{aligned}$ | $\begin{aligned} & 24 \\ & 10 \\ & 24 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | 2 | Branch Higher or Same Long Branch Higher of Same | - | - | - | - | - |
| BLE | $\begin{aligned} & \text { BLE } \\ & \text { LBLE } \end{aligned}$ | $\begin{aligned} & 2 \mathrm{~F} \\ & 10 \\ & 2 \mathrm{~F} \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $\leqslant$ Zero Long Branch $\leq$ Zero | $\bullet$ | - | - | - | - |
| BLO | $\begin{aligned} & \hline \text { BLO } \\ & \text { LBLO } \end{aligned}$ | $\begin{aligned} & 25 \\ & 10 \\ & 25 \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch lower Long Branch Lower | - | - | $\because$ | - | - |


| Instruction | Forms | Addressing$\qquad$ |  |  | Description | [5 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  | OP | -5 | 1 |  |  | N | 2 | V | C |
| BLS | BLS <br> LBLS | $\begin{aligned} & 23 \\ & 10 \\ & 23 \\ & \hline \end{aligned}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \\ \hline \end{array}$ | $2$ <br> 4 | Branch Lower or Same Long Branch Lower or Same |  | - | - | - | - |
| BLT | $\begin{aligned} & \text { BLT } \\ & \text { LBLT } \end{aligned}$ | $\begin{array}{\|l\|} \hline 2 \mathrm{D} \\ 10 \\ 2 \mathrm{D} \end{array}$ | $\begin{gathered} 3 \\ 5 i 6) \end{gathered}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | $\begin{aligned} & \text { Branch < Zero } \\ & \text { Long Branch < Zero } \end{aligned}$ |  | $\bullet$ | $\bullet$ |  | $\bullet$ |
| BM1 | BMI LBMI | $\begin{array}{\|l\|} \hline 2 B \\ 10 \\ 28 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch Minus Long Branch Minus |  |  | $\bullet$ |  | $\bullet$ |
| BNE | BNE LBNE | $\begin{array}{\|l\|} \hline 26 \\ 10 \\ 26 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | $\begin{aligned} & \text { Branch } Z=0 \\ & \text { L.ong Branch } \\ & Z=0 \end{aligned}$ |  | $\bullet$ | $\bullet$ | $\bullet$ | - |
| BPL | $\begin{aligned} & \text { BPL } \\ & \text { LBPL } \end{aligned}$ | $\begin{array}{\|r\|} \hline 2 \mathrm{~A} \\ 10 \\ 2 \mathrm{~A} \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch Plus Long Branch Plus |  | - | - | $\bullet$ | - |
| BRA | BRA LBRA | $\begin{array}{\|l\|} \hline 20 \\ 16 \\ \hline \end{array}$ | $\begin{aligned} & 3 \\ & 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 \\ & 3 \\ & \hline \end{aligned}$ | Branch Always Long Branch Always | $\bullet$ | - | - | - | - |
| BRN | BRN LBRN | $\begin{array}{\|l\|} \hline 21 \\ 10 \\ 21 \\ \hline \end{array}$ | $\begin{aligned} & 3 \\ & 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch Never Long Branch Never | $\bullet$ | - | - | - | - |
| B'SR | $\begin{aligned} & \text { BSR } \\ & \text { LBSR } \end{aligned}$ | $\begin{array}{\|c\|} \hline 8 D \\ 17 \end{array}$ | $\begin{aligned} & 7 \\ & 9 \end{aligned}$ | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | Branch to Subroutine Long Branch to Subroutine | - | - | - | - | $\stackrel{ }{\bullet}$ |
| BVC | $\begin{aligned} & \text { BVC } \\ & \text { LBVC } \end{aligned}$ | $\begin{array}{\|l\|} \hline 28 \\ 10 \\ 28 \\ \hline \end{array}$ | $\begin{gathered} 3 \\ 5(6) \end{gathered}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $V=0$ Long Branch $V=0$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - |
| BVS | $\begin{aligned} & \text { BVS } \\ & \text { LBVS } \end{aligned}$ | $\begin{array}{\|l\|} \hline 29 \\ 10 \\ 29 \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 3 \\ 5(6) \end{array}$ | $\begin{aligned} & 2 \\ & 4 \end{aligned}$ | Branch $V=1$ Long Branch $V=1$ | $\bullet$ | - | - | - | $\bullet$ |

SIMPLE BRANCHES

|  | OP | $\sim$ | 1 |
| :--- | ---: | ---: | ---: |
| BRA | 20 | 3 | 2 |
| LBRA | 16 | 5 | 3 |
| BRN | 21 | 3 | 2 |
| LBRN | 1021 | 5 | 4 |
| BSR | $8 D$ | 7 | 2 |
| LBSR | 17 | 9 | 3 |

SIMPLE CONDITIONAL BRANCHES (Notes 1-4)

| Test | True | OP | False | OP |
| :--- | :--- | :--- | :--- | :--- |
| $N=1$ | BMI | $2 B$ | $B P L$ | $2 A$ |
| $Z=1$ | BEQ | 27 | BNE | 26 |
| $V=1$ | BVS | 29 | BVC | 28 |
| $C=1$ | BCS | 25 | BCC | 24 |

SIGNED CONDITIONAL BRANCHES (Notes 1-4)

| Test | True | OP | False | OP |
| :--- | :--- | :--- | :--- | :--- |
| $r>m$ | BGT | $2 E$ | BLE | $2 F$ |
| $r \geq m$ | BGE | $2 C$ | BLT | $2 D$ |
| $r=m$ | BEQ | 27 | BNE | 26 |
| $r \leq m$ | BLE | $2 F$ | BGT | $2 E$ |
| $r<m$ | BLT | $2 D$ | BGE | $2 C$ |

UNSIGNED CONDITIONAL BRANCHES (Notes 1-4)

| Test | True | OP | False | OP |
| :--- | :--- | :--- | :--- | :--- |
| $r>m$ | BHI | 22 | BLS | 23 |
| $r \geq m$ | BHS | 24 | BLO | 25 |
| $r=m$ | BEQ | 27 | BNE | 26 |
| $r \leq m$ | BLS | 23 | BHI | 22 |
| $r<m$ | BLO | 25 | BHS | 24 |

NOTES:

1. All conditional branches have both short and long variations.
2. All short branches are 2 bytes and require 3 cycles.
3. All conditional long branches are formed by prefixing the short branch opcode with $\$ 10$ and using a 16 -bit destination offset.
4. All conditional long branches require 4 bytes and 6 cycles if the branch is taken or 5 cycles if the branch is not taken.
5. $5(6)$ means: 5 cycles if branch not taken, 6 cycles if taken.

INDEXED ADDRESSING MODES


INDEXED ADDRESSING POSTBYTE
REGISTER BIT ASSIGNMENTS

| Post-Byte Register Bit |  |  |  |  |  |  |  | Indexed Addressing Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0 | R | R | x | X | x | $\times$ | $\times$ | $\mathrm{EA}=, \mathrm{R}+5 \mathrm{Bit}$ Offset |
| 1 | R | R | 0 | 0 | 0 | 0 | 0 | R + |
| 1 | R | R | 1 | 0 | 0 | 0 | 1 | R + + |
| 1 | R | R | 0 | 0 | 0 | 1 | 0 | ,-R |
| 1 | R | R | 1 | 0 | 0 | 1 | 1 | -- R |
| 1 | R | R | 10 | 0 | 1 | 0 | 0 | $E A=, R+0$ Offset |
| 1 | R | R | 1 | 0 | 1 | 0 | 1 | $E A=, R+A C C B$ Offset |
| 1 | R | R | 1 | 0 | 1 | 1 | 0 | $E A=, R+$ ACCA Offset |
| 1 | R | R | 1 | 1 | 0 | 0 | 0 | $E A=, R+8$-Bit Offset |
| 1 | R | R | 1 | 1 | 0 | 0 | 1 | $E A=, R+16-$ Bit Offset |
| 1 | R | R | 1 | 1 | 0 | 1 | 1 | $E A=, R+D$ Offset |
| 1 | x | $\times$ | 1 | 1 | 1 | 0 | 0 | $E A=, P C+8$-Bit Offset |
| 1 | $x$ | $x$ | 1 | 1 | 1 | 0 | 1 | $E A=, P C+16$-Bit Offset |
| 1 | R | R | 1 | 1 | 1 | 1 | 1 | $E A=$ [, Address] |
|  |  |  |  |  |  |  |  |  |



## Push/Pull Post Byte

Transfer/Exchange Post Byte
Source $\quad$ Destination
Register Field

| $0000=D(A-B)$ | $0101=P C$ |
| :--- | :--- |
| $0001=X$ | $1000=A$ |
| $0010=Y$ | $1001=B$ |
| $0011=U$ | $1010=C C R$ |
| $0100=S$ | $1011=D P R$ |

$0101=P C$
$0001=X$
$1001=B$
$0011=U$
$1011=$ DPR

$0100=S$

6809 Stacking Order

|  |  |
| :---: | :---: |
| A |  |
| B |  |
| DP | 6809 Vectors |
| $\times \mathrm{Hi}$ | FFFE Restart |
| $\times$ Lo | FFFC NMI |
| Y Hi | FFFA SWI |
| Y Lo | FFF8 IRO |
| U/S Hi | FFF4 SW12 |
| U/S Lo | FFF2 SW13 |
| PC Hi | FFFO Reserved |
| $\underset{f}{P C}$ |  |
| Push Order |  |
|  |  |
| Increasing Mem |  |

## ORDERING INFORMATION




J SUFFIX CERDIP PACKAGE

CB-182


ALSO AVAILABLE

C SUFFIX CERAMIC PACKAGE

CB-521


FN SUFFIX PLCC 44


## CHAPTER 2-6800 PERIPHERALS

## 6800 PERIPHERALS SELECTION GUIDE

| Part number | Description | Technology | Alt source | CLK freq. (MHz) | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { EF6821 } \\ & \text { EF68A21 } \\ & \text { EF68B21 } \end{aligned}$ | Peripheral Interface Adapter (PIA) <br> Two bidirectional 8-bit buses for interface to peripherals - Two programmable control registers - Two programmable data direction registers | NMOS | $\begin{aligned} & \text { MC6821 } \\ & \text { MC68A21 } \\ & \text { MC68B21 } \end{aligned}$ | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 2-3 |
| $\begin{aligned} & \hline \text { EF6840 } \\ & \text { EF68A40 } \\ & \text { EF68B40 } \end{aligned}$ | Programmable Timer Module (PTM) <br> Three 16-bit - Binary counters - Selectable gating <br> For frequency or pulse-width comparison | NMOS | MC6840 <br> MC68A40 <br> MC68B50 | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 2-15 |
| $\begin{aligned} & \text { EF6850 } \\ & \text { EF68A50 } \\ & \text { EF68B50 } \end{aligned}$ | Asynchronous Communication Interface Adapter (ACIA) - 8 and 9-bit transmission Peripheral/modem control functions | NMOS | MC6850 MC68A50 MC68B50 | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 2-31 |
| EF6854 EF68A54 EF68B54 | Advanced Data-Link Controller (ADLC) | NMOS | MC6854 MC68A54 MC68B54 | $\begin{gathered} 1 \\ 1.5 \\ 2 \end{gathered}$ | 2-41 |

The EF6821 Peripheral Interface Adapter provides the universal means of interfacing peripheral equipment to the 6800 family of microprocessors. This device is capable of interfacing the MPU to peripherals through two 8 -bit bidirectional peripheral data buses and four control lines. No external logic is required for interfacing to most peripheral devices.

The functional configuration of the PIA is programmed by the MPU during system initialization. Each of the peripheral data lines can be programmed to act as an input or output, and each of the four control/interrupt lines may be programmed for one of several control modes. This allows a high degree of flexibility in the overall operation of the interface.

- 8-Bit Bidirectional Data Bus for Communication with the MPU
- Two Bidirectional 8-Bit Buses for Interface to Peripherals
- Two Programmable Control Registers
- Two Programmable Data Direction Registers
- Four Individually-Controlled Interrupt Input Lines; Two Usable as Peripheral Control Outputs
- Handshake Control Logic for Input and Output Peripheral Operation
- High-Impedance Three-State and Direct Transistor Drive Peripheral Lines
- Program Controlled Interrupt and Interrupt Disable Capability
- CMOS Drive Capability on Side A Peripheral Lines
- Two TTL Drive Capability on All A and B Side Buffers
- TTL-Compatible
- Static Operation
- Three available versions: EF6821 (1.0 MHz)

EF68A21 (1.5 MHz)
EF68B21 ( 2.0 MHz )

## MOS

in-ChANNEL, SILICON-GATE, DEPLETION LOAD)

PERIPHERAL INTERFACE
ADAPTER


MAXIMUM RATINGS

| Characteristics | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range |  | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{TH}_{\mathrm{H}}$ |  |
| EF6821, EF68A21, EF68B21 | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| EF6821, EF68A21, EF68821: |  | -40 to +85 |  |
| V suffix |  | -55 to +125 |  |
| EF6821, EF68A21 : M suffix |  |  |  |
| Storage Temperature. Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Ceramic | $\theta$ JA | 50 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic |  | 100 |  |
| Cerdip |  | 60 |  |
| PLCC | 100 |  |  |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid applications of any voltage higher than maximum rated voltages to this highimpedance circuit. For proper operation it is recommended that $V_{\text {in }}$ and $V_{\text {out }}$ be constrained to the range $G N D \leq I V_{\text {in }}$ or $\mathrm{V}_{\text {out }} \leq \mathrm{V}_{\text {CC }}$.
Unused inputs must always be tied to an appropriate logic voltage level (e.g., either GND or $\mathrm{V}_{\mathrm{CC}}$.

## POWER CONSIDERATIONS

The average chip-junction temperature, $T J$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
T_{J}=T_{A}+\left(P_{D}{ }^{\bullet} J_{J A}\right)
$$

Where:
$T_{A}=$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta J A=$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
$P_{D}=P_{I N T}+P_{\text {PORT }}$
$P_{\text {INT }} \equiv I_{C C} \times V_{C C}$, Watts - Chip Internal Power
PPORT $\equiv$ Port Power Dissipation, Watts - User Determined
For most applications PPORT \& PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K+\left(T_{J}+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta_{J A} \bullet P_{D} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P D$ and $T J$ can be obtained by solving equations (1) and (2) iteratively for any value of TA.

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$ unless otherwise noted).

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| BUS CONTROL INPUTS (R/W, Enable, $\overline{\text { RESET, RS0, RS1, CS0, CS1, CS2) }}$ |  |  |  |  |  |
| Input High Voltage | $V_{\text {IH }}$ | $\mathrm{V}_{S S}+2.0$ | - | V CC | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{S S}-0.3$ | - | VSS +0.8 | V |
| Input Leakage Current ( $\mathrm{V}_{\text {in }}=0$ to 5.25 V ) | lin | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| Capacitance ( $\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}$ ) | $\mathrm{Cin}_{\text {in }}$ | - | - | 7.5 | pF |

## INTERRUPT OUTPUTS (IRQA, IRQB)

| Output Low Voltage ( Load $=1.6 \mathrm{~mA})$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $\mathrm{V}_{\mathrm{SS}}+0.4$ |
| :--- | :---: | :---: | :---: | :---: |
| Hi-Z Output Leakage Current | $\mathrm{I}_{\mathrm{OZ}}$ | - | V |  |
| Capacitance $\left(\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | 10 | $\mu \mathrm{~A}$ |  |  |

DATA BUS (D0-D7)

| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {SS }}+2.0$ | - | $\mathrm{V}_{\mathrm{CC}}$ | V |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage | $V_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | - | $\mathrm{V}_{\mathrm{SS}}+0.8$ | V |
| Hi-Z Input Leakage Current ( $\mathrm{V}_{\text {in }}=0.4$ to 2.4 V ) | IIZ | - | 2.0 | 10 | $\mu \mathrm{A}$ |
| Output High Voltage ( 1 Load $=-205 \mu \mathrm{~A}$ ) | V OH | $\mathrm{V}_{\text {SS }}+2.4$ | - | - | V |
| Output Low Voltage ( Load $=1.6 \mathrm{~mA}$ ) | VOL | - | - | $\mathrm{V}_{\text {SS }}+0.4$ | V |
| Capacitance ( $\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ ) | $\mathrm{C}_{\text {in }}$ | - | - | 12.5 | pF |

DC ELECTRICAL CHARACTERISTICS (Continued)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PERIPHERAL BUS (PA0-PA7, PB0-PB7, CA1, CA2, CB1, CB2) |  |  |  |  |  |
| Input Leakage Current $\quad \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{RESET}}, \mathrm{RS} 0, \mathrm{RS} 1, \mathrm{CS} 0, \mathrm{CS} 1, \overline{\mathrm{CS} 2}, \mathrm{CA} 1$, $\left(\mathrm{V}_{\text {in }}=0\right.$ to 5.25 V$)$ CB1, Enable | 1 In | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| Hi-Z Input Leakage Current ( $\mathrm{V}_{\text {in }}=0.4$ to 2.4 V ) PB0-PB7, CB2 | IIZ | - | 2.0 | 10 | $\mu \mathrm{A}$ |
| Input High Current ( $\mathrm{V}_{1 \mathrm{H}}=2.4 \mathrm{~V}$ ) PA0-PA7, CA2 | 1 H | $-200$ | -400 | - | $\mu \mathrm{A}$ |
| Darlington Drive Current ( $\left.\mathrm{V}_{\mathrm{O}}=1.5 \mathrm{~V}\right) \quad$ PB0-PB7, CB2 | ${ }^{1} \mathrm{OH}$ | -1.0 | - | - 10 | mA |
| Input Low Current (VIL $=0.4 \mathrm{~V}$ ) PA0.PA7, CA2 | IIL | - | $-1.3$ | -2.4 | mA |
| Output High Voltage  <br> ("Load $=-200 \mu \mathrm{~A}$ )  <br> ("Load $=-10 \mu \mathrm{~A}$ ) PA0-PA7, PB0-PB7, CA2, CB2 <br> OA0-PA7, CA2  | VOH | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+2.4 \\ & \mathrm{~V}_{\mathrm{CC}}-1.0 \end{aligned}$ | - | - | V |
| Output Low Voltage ( Load $^{\text {a }}$ ( 3.2 mA ) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | VSS +0.4 | V |
| Capacitance ( $\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{\text {A }}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ ) | $\mathrm{Cin}_{\text {in }}$ | - | - | 10 | pF |
| POWER REQUIREMENTS |  |  |  |  |  |
| Internal Power Dissipation (Measured at $\mathrm{T}_{\mathrm{L}}=0^{\circ} \mathrm{C}$ ) | PINT | - | - | 550 | mW |

BUS TIMING CHARACTERISTICS (See Notes 1 and 2)

| Ident. <br> Number | Characteristic | Symbol | EF6821 |  | EF68A21 |  | EF68B21 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }^{\text {c }}$ cyc | 1.0 | 10 | 0.67 | 10 | 0.5 | 10 | $\mu \mathrm{S}$ |
| 2 | Pulse Width, E Low | PW ${ }_{\text {EL }}$ | 430 | - | 280 | - | 210 | - | ns |
| 3 | Pulse Width, E High | $\mathrm{PW}_{\text {EH }}$ | 450 | - | 280 | - | 220 | - | ns |
| 4 | Clock Rise and Fall Time | $\mathrm{tr}_{\mathrm{r}}, \mathrm{tf}_{\text {f }}$ | - | 25 | - | 25 | - | 20 | ns |
| 9 | Address Hold Time | ${ }^{\text {t }}$ A H | 10 | - | 10 | - | 10 | - | ns |
| 13 | Address Setup Time Before E | ${ }^{\text {tas }}$ | 80 | - | 60 | - | 40 | - | ns |
| 14 | Chip Select Setup Time Before E | ${ }^{\text {t }} \mathrm{CS}$ | 80 | - | 60 | - | 40 | - | ns |
| 15 | Chip Select Hold Time | ${ }^{\text {t }} \mathrm{CH}$ | 10 | - | 10 | - | 10 | - | ns |
| 18 | Read Data Hold Time | to ${ }^{\text {d }}$ | 20 | $50^{*}$ | 20 | $50^{\circ}$ | 20 | $50^{\circ}$ | ns |
| 21 | Write Data Hold Time | tDHW | 10 | - | 10 | - | 10 | - | ns |
| 30 | Output Data Delay Time | ${ }^{\text {t DDR }}$ | - | 290 | - | 180 | - | 150 | ns |
| 31 | Input Data Setup Time | 'DSW | 165 | - | 80 | - | 60 | - | ns |

-The data bus output buffers are no longer sourcing or sinking current by tDHRmax (High Impedance)


Notes:

1. Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}} \geq 2.4 \mathrm{~V}$, unless otherwise specified
2. Measurement points shown are 0.8 V and 2.0 V , unless otherwise specified.

PERIPHERAL TIMING CHARACTERISTICS $\left(\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$ unless otherwise specified)

| Characteristic | Symbol | EF6821 |  | EF68A21 |  | EF68B21 |  | Unit | Reference Fig. No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| Data Setup Time | tPDS | 200 | - | 135 | - | 100 | - | ns | 6 |
| Data Hold Time | tPDH | 0 | - | 0 | - | 0 | - | ns | 6 |
| Delay Time, Enable Negative Transition to CA2 Negative Transition | t CA2 | - | 1.0 | - | 0.670 | - | 0.500 | $\mu \mathrm{S}$ | 3, 7, 8 |
| Delay Time, Enable Negative Transition to CA2 Positive Transition | TRS1 | - | 1.0 | - | 0.670 | - | 0.500 | $\mu \mathrm{S}$ | 3,7 |
| Rise and Fall Times for CA1 and CA2 Input Signals | $\mathrm{t}_{\mathrm{r}}, \mathrm{tf}^{\text {f }}$ | - | 1.0 | - | 1.0 | - | 1.0 | $\mu \mathrm{S}$ | 8 |
| Delay Time from CA1 Active Transition to CA2 Positive Transition | tRS2 | - | 2.0 | - | 1.35 | - | 1.0 | $\mu \mathrm{S}$ | 3, 8 |
| Delay Time, Enable Negative Transition to Data Valid | tPDW | - | 1.0 | - | 0.670 | - | 0.5 | $\mu \mathrm{S}$ | 3, 9, 10 |
| Delay Time, Enable Negative Transition to CMOS Data Valid PAO-PA7, CA2 | ${ }^{\text {t CMOS }}$ | - | 2.0 | - | 1.35 | - | 1.0 | $\mu \mathrm{S}$ | 4, 9 |
| Delay Time, Enable Positive Transition to CB2 Negative Transition | ${ }^{\text {t }}$ CB2 | - | 1.0 | - | 0.670 | - | 0.5 | $\mu \mathrm{S}$ | 3,11,12 |
| Delay Time, Data Valid to CB2 Negative Transition | tDC | 20 | - | 20 | - | 20 | - | ns | 3, 10 |
| Delay Time, Enable Positive Transition to CB2 Positive Transition | tRS1 | - | 1.0 | - | 0.670 | - | 0.5 | $\mu \mathrm{S}$ | 3, 11 |
| Control Output Pulse Width, CA2/CB2 | PW ${ }_{\text {CT }}$ | 500 | - | 375 | - | 250 | - | ns | 3, 11 |
| Rise and Fall Time for CB1 and CB2 Input Signals | $\mathrm{tr}_{\mathrm{r}}, \mathrm{tf}_{\mathrm{f}}$ | - | 1.0 | - | 1.0 | - | 1.0 | $\mu$ | 12 |
| Delay Time, CB1 Active Transition to CB2 Positive Transition | tRS2 | - | 2.0 | - | 1.35 | - | 1.0 | $\mu \mathrm{S}$ | 3, 12 |
| Interrupt Release Time, $\overline{\mathrm{RQA}}$ and IROB | t/R | - | 1.60 | - | 1.10 | - | 0.85 | $\mu \mathrm{S}$ | 5, 14 |
| Interrupt Response Time | tRS3 | - | 1.0 | - | 1.0 | - | 1.0 | $\mu \mathrm{S}$ | 5, 13 |
| Interrupt Input Pulse Time | PW 1 | 500 | - | 500 | - | 500 | - | ns | 13 |
| $\overline{\text { RESET }}$ Low Time* | trL | 1.0 | - | 0.66 | - | 0.5 | - | $\mu \mathrm{S}$ | 15 |

- The $\overline{\text { RESET }}$ line must be high a minimum of $1.0 \mu$ s before addressing the PIA.

FIGURE 2 - BUS TIMING TEST LOADS


FIGURE 4 - CMOS EQUIVALENT TEST LOAD
(PAO-PA7, CA2)



FIGURE 5 - NMOS EQUIVALENT TEST LOAD


FIGURE 6 - PERIPHERAL DATA SETUP AND HOLD TIMES (Read Mode)


FIGURE 8 - CA2 DELAY TIME
(Read Mode; CRA-5 $=1$, CRA $-3=C R A-4=0$ )


FIGURE 10 - PERIPHERAL DATA AND CB2 DELAY TIMES (Write Mode; CRB-5 $=$ CRB-3 $=1, C R B-4=0$ )

*CB2 goes low as a result of the positive transition of Enable.

Figure 12 - CB2 delay time (Write Mode; $C R B-5=1$, CRB-3 $=C R B-4=0$ )


FIGURE 7 - CA2 DELAY TIME
(Read Mode; CRA-5 $=$ CRA3 $=1$, CRA-4 $=0$ )


FIGURE 9 - PERIPHERAL CMOS DATA DELAY TIMES (Write Mode; CRA-5 = CRA-3 $=1$, CRA $-4=0$ )


FIGURE 11 - CB2 DELAY TIME (Write Mode; CRB-5 = CRB-3 = 1, CRB-4 $=0$ )


- Assumes part was deselected during the previous E pulse

FIGURE 13 - INTERRUPT PULSE WIDTH AND $\overline{\operatorname{IRO}}$ RESPONSE


Note: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted.

FIGURE 14 - $\overline{\text { IRO }}$ RELEASE TIME
FIGURE 15 - $\overline{\text { RESET }}$ LOW TIME

-The $\overline{\text { RESET }}$ line must be a $V_{I H}$ for a minimum of $1.0 \mu \mathrm{~s}$ before addressing the PIA.

Note: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted.

FIGURE 16 - EXPANDED BLOCK DIAGRAM


The PIA interfaces to the 6800 bus with an 8 -bit bidirectional data bus, three chip select lines, two register select lines, two interrupt request lines, a read/write line, an enable line and a reset line. To ensure proper operation with the EF6800, EF6802, or EF6808 microprocessors, VMA should be used as an active part of the address decoding.

Bidirectional Data (D0-D7) - The bidirectional data lines (D0-D7) allow the transfer of data between the MPU and the PIA. The data bus output drivers are three-state devices that remain in the high-impedance (off) state except when the MPU performs a PIA read operation. The read/write line is in the read (high) state when the PIA is selected for a read operation.

Enable (E) - The enable pulse, $E$, is the only timing signal that is supplied to the PIA. Timing of all other signals is referenced to the leading and trailing edges of the E pulse.

Read/Write ( $\mathrm{R} / \overline{\mathrm{W})}$ - This signal is generated by the MPU to control the direction of data transfers on the data bus. A low state on the PIA read/write line enables the input buffers and data is transferred from the MPU to the PIA on the E signal if the device has been selected. A high on the read/write line sets up the PIA for a transfer of data to the bus. The PIA output buffers are enabled when the proper address and the enable pulse $E$ are present.
$\overline{\text { RESET }}$ - The active low $\overline{\text { RESET }}$ line is used to reset all register bits in the PIA to a logical zero (low). This line can be used as a power-on reset and as a master reset during system operation.

Chip Selects (CS0, CS1, and $\overline{\mathrm{CS} 2}$ ) - These three input signals are used to select the PIA. CSO and CS1 must be high and $\overline{\mathrm{CS} 2}$ must be low for selection of the device. Data transfers are then performed under the control of the enable and read/write signals. The chip select lines must be stable
for the duration of the $E$ pulse. The device is deselected when any of the chip selects are in the inactive state.

Register Selects (RS0 and RS1) - The two register select lines are used to select the various registers inside the PIA. These two lines are used in conjunction with internal Control Registers to select a particular register that is to be written or read.

The register and chip select lines should be stable for the duration of the $E$ pulse while in the read or write cycle.

Interrupt Request (IRQA and $\overline{\mathrm{IRQB}})$ - The active low Interrupt Request lines ( $\overline{\mathrm{RQA}}$ and $\overline{\mathrm{IRQB}})$ act to interrupt the MPU either directly or through interrupt priority circuitry. These lines are "open drain" (no load device on the chip) This permits all interrupt request lines to be tied together in a wire-OR configuration.

Each interrupt Request line has two internal interrupt flag bits that can cause the Interrupt Request line to go low. Each flag bit is associated with a particular peripheral interrupt line. Also, four interrupt enable bits are provided in the PIA which may be used to inhibit a particular interrupt from a peripheral device.

Servicing an interrupt by the MPU may be accomplished by a software routine that, on a prioritized basis, sequentially reads and tests the two control registers in each PIA for interrupt flag bits that are set.

The interrupt flags are cleared (zeroed) as a result of an MPU Read Peripheral Data Operation of the corresponding data register. After being cleared, the interrupt flag bit cannot be enabled to be set until the PIA is deselected during an E pulse. The E pulse is used to condition the interrupt control lines (CA1, CA2, CB1, CB2). When these lines are used as interrupt inputs, at least one E pulse must occur from the inactive edge to the active edge of the interrupt input signal to condition the edge sense network. If the interrupt flag has been enabled and the edge sense circuit has been properly conditioned, the interrupt flag will be set on the next active transition of the interrupt input pin.

## PIA PERIPHERAL INTERFACE LINES

The PIA provides two 8 -bit bidirectional data buses and four interrupt/control lines for interfacing to peripheral devices.

Section A Peripheral Data (PA0-PA7) - Each of the peripheral data lines can be programmed to act as an input or output. This is accomplished by setting a " 1 " in the corresponding Data Direction Register bit for those lines which are to be outputs. A " 0 " in a bit of the Data Direction Register causes the corresponding peripheral data line to act as an input. During an MPU Read Peripheral Data Operation, the data on peripheral lines programmed to act as inputs appears directly on the corresponding MPU Data Bus lines. In the input mode, the internal pullup resistor on these lines represents a maximum of 1.5 standard TTL loads.

The data in Output Register A will appear on the data lines that are programmed to be outputs. A logical " 1 " written into the register will cause a "high" on the corresponding data
line while a " 0 " results in a "low." Data in Output Register A may be read by an MPU "Read Peripheral Data A" operatıon when the corresponding lines are programmed as outputs. This data will be read properly if the voltage on the peripheral data lines is greater than 2.0 volts for a logic " 1 " output and less than 0.8 volt for a logic " 0 " output. Loading the output lines such that the voltage on these lines does not reach full voltage causes the data transferred into the MPU on a Read operation to differ from that contained in the respective bit of Output Register $A$.

Section B Peripheral Data (PB0-PB7) - The peripheral data lines in the B Section of the PIA can be programmed to act as either inputs or outputs in a similar manner to PA0PA7. They have three-state capability, allowing them to enter a high-impedance state when the peripheral data line is used as an input. In addition, data on the peripheral data lines

PB0-PB7 will be read properly from those lines programmed as outputs even if the voltages are below 2.0 volts for a "high" or above 0.8 V for a "low". As outputs, these lines are compatible with standard TTL and may also be used as a source of at least 1 milliampere at 1.5 volts to directly drive the base of a transistor switch.

Interrupt Input (CA1 and CB1) - Peripheral input lines CA1 and CB1 are input only lines that set the interrupt flags of the control registers. The active transition for these signals is also programmed by the two control registers.

Peripheral Control (CA2) - The peripheral control line CA2 can be programmed to act as an interrupt input or as a
peripheral control output. As an output, this line is compatible with standard TTL; as an input the internal pullup resistor on this line represents 1.5 standard TTL loads. The function of this signal line is programmed with Control Register A.

Peripheral Control (CB2) - Peripheral Control line CB2 may also be programmed to act as an interrupt input or peripheral control output. As an input, this line has high input impedance and is compatible with standard TTL. As an output it is compatible with standard TTL and may also be used as a source of up to 1 milliampere at 1.5 volts to directly drive the base of a transistor switch. This line is programmed by Control Register B.

## INTERNAL CONTROLS

## INITIALIZATION

A $\overline{\text { RESET }}$ has the effect of zeroing all PIA registers. This will set PA0-PA7, PBO-PB7, CA2 and CB2 as inputs, and all interrupts disabled. The PIA must be configured during the restart program which follows the reset.
There are six locations within the PIA accessible to the MPU data bus: two Peripheral Registers, two Data Direction Registers, and two Control Registers. Selection of these locations is controlled by the RS0 and RS1 inputs together with bit 2 in the Control Register, as shown in Table 1.
Details of possible configurations of the Data Direction and Control Register are as follows:

TABLE 1 - INTERNAL ADDRESSING

| RS 1 | RSO | Control <br> Register Bit |  | Location Selected |
| :---: | :---: | :---: | :---: | :---: |
|  |  | CRA 2 | CR 8.2 |  |
| 0 | 0 | 1 | $\times$ | Perrpheral Register A |
| 0 | 0 | 0 | $\times$ | Data Direction Register $A$ |
| 0 | 1 | $\times$ | $\times$ | Control Register A |
| 1 | 0 | x | 1 | Peripheral Register B |
| 1 | 0 | X | 0 | Data Direction Register B |
| 1 | 1 | $\times$ | $\times$ | Contral Register B |

$x$ Don't Care

## PORT A-B HARDWARE CHARACTERISTICS

As shown in Figure 17, the EF6821 has a pair of I/O ports whose characteristics differ greatly. The A side is designed to drive CMOS logic to normal $30 \%$ to $70 \%$ levels, and incorporates an internal pullup device that remains connected even in the input mode. Because of this, the $A$ side requires more drive current in the input mode than Port B. In contrast, the B side uses a normal three-state NMOS buffer which cannot pullup to CMOS levels without external resistors. The B side can drive extra loads such as Darlingtons without problem. When the PIA comes out of reset, the A port represents inputs with pullup resistors, whereas the $B$ side (input mode also) will float high or low, depending upon the load connected to it.

Notice the differences betweeri a Port A and Port B read operation when in the output mode. When reading Port $A$, the actual pin is read, whereas the $B$ side read comes from an output latch, ahead of the actual pin.

## CONTROL REGISTERS (CRA and CRB)

The two Control Registers (CRA and CRB) allow the MPU to control the operation of the four peripheral control lines CA1, CA2, CB1, and CB2. In addition they allow the MPU to enable the interrupt lines and monitor the status of the interrupt flags. Bits 0 through 5 of the two registers may be written or read by the MPU when the proper chip select and register select signals are applied. Bits 6 and 7 of the two registers are read only and are modified by external interrupts occurring on control lines CA1, CA2, CB1, or CB2. The format of the control words is shown in Figure 18.

## DATA DIRECTION ACCESS CONTROL BIT ICRA-2 and CRB-2)

Bit 2, in each Control Register (CRA and CRB), determines selection of either a Peripheral Output Register or the corresponding Data Direction E Register when the proper register select signals are applied to RSO and RS1. A " 1 " in bit 2 allows access of the Peripheral Interface Register, while a " 0 " causes the Data Direction Register to be addressed.

Interrupt Flags (CRA-6, CRA-7, CRB-6, and CRB-7) The four interrupt flag bits are set by active transitions of signals on the four Interrupt and Peripheral Control lines when those lines are programmed to be inputs. These bits cannot be set directly from the MPU Data Bus and are reset indirectly by a Read Peripheral Data Operation on the appropriate section.

Control of CA2 and CB2 Peripheral Control Lines (CRA-3, CRA-4, CRA-5, CRB-3, CRB-4, and CRB-5) - Bits 3, 4, and 5 of the two control registers are used to control the CA2 and CB2 Peripheral Control lines. These bits determine if the control lines will be an interrupt input or an output control signal. If bit CRA-5 (CRB-5) is low, CA2 (CB2) is an interrupt input line similar to CA1 (CB1). When CRA-5 (CRB-5) is high, CA2 (CB2) becomes an output signal that may be used to control peripheral data transfers. When in the output mode, CA2 and CB2 have slightly different loading characteristjics.

Control of CA1 and CB1 Interrupt Input Lines (CRA-0, CRB-0, CRA-1, and CRB-1) - The two lowest-order bits of the control registers are used to control the interrupt input lines CA1 and CB1. Bits CRA-0 and CRB-0 are used to
enable the MPU interrupt signals $\overline{\mathbb{R Q A}}$ and $\overline{\mathrm{RQB}}$, respectively. Bits CRA- 1 and CRB-1 determine the active transition of the interrupt input signals CA1 and CB1.

FIGURE 17 - PORT A AND PORT B EQUIVALENT CIRCUITS


## ORDERING INFORMATION



Interrupt Flag IRQA(B)1 - (bit 7)
$\mathrm{b} 1=0$ : $\mid \operatorname{RQA}(\mathrm{B}) 1$ set by high-to-low transition on CA (CB1)
$b 1=1: \mid R Q A(B) 1$ set by low-to-high transition on CA1. (CB1).

CA1 (CB1) Interrupt Request Enable/Disable
$\mathrm{b} 0=0$ : Disables IRQA(B) MPU Interrupt by CA1 (CB1) active transition. ${ }^{1}$
$\mathrm{b0}=1$ : Enable IRQA(B) MPU Interrupt by CA1 (CB1) active transition.

1. IRQA(B) will occur on next (MPU generated) positive transition of b0 if CA1 (CB1) active transition occurred while interrupt was disabled.

Goes high on active transition of CA1 (CB1); Automatically cleared by MPU Read of Output Register A(B)

## PHYSICAL DIMENSIONS



CB-182


PSUFFIX PLASTIC PACKAGE

ALSO AVAILABLE

JSUFFIX
CERDIP PACKAGE CERAMIC PACKAGE

CB-521


FN SUFFIX
PLCC 44


The EF6840 is a programmable subsystem component of the 6800 family designed to provide variable system time intervals.
The EF6840 has three 16 -bit binary counters, three corresponding control registers and a status register. These counters are under software control and may be used to cause system interrupts and/or generate output signals. The EF6840 may be utilized for such tasks as frequency measurements, event counting, interval measuring and similar tasks. The device may be used for square wave generation, gated delay signals, single pulses of controlled duration, and pulse width modulation as well as system interrupts.

- Operates from a single 5 V power supply
- Fully TTL compatible
- Single system clock required (Enable)
- Selectable prescaler on timer 3 capable of 4 MHz for the EF6840, 6 MHz for the EF68A40 and 8 MHz for the EF68B40.
- Programmable interrupts ( $\overline{\mathrm{IRQ}}$ ) output to MPU
- Readable down counter indicates counts to go to time-out,
- Selectable gating for frequency or pulse-width comparison'
- RESET input
- Three asynchronous external clock and gate/trigger inputs internally synchronized
- Three maskable outputs
- Three available versions : EF6840 (1.0 MHz)

EF68A40 ( 1.5 MHz )
EF68B40 ( 2.0 MHz )

## MOS

PROGRAMMABLE TIMER
(N-CHANNEL, SILICON-GATE DEPLETION LOAD)



FIGURE 2 - BLOCK DIAGRAM


## POWER CONSIDERATIONS

The average chip-junction temperature, $\mathrm{T}_{\mathrm{J}}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T_{J}=T_{A}+\left(P_{D} \bullet \theta J A\right) \tag{1}
\end{equation*}
$$

Where:
${ }^{\top} A \equiv$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta J A \equiv$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
PD $\equiv$ PINT + PPORT
PINT $\equiv$ ICC $\times$ VCC, Watts - Chip Internal Power
PPORT $\equiv$ Port Power Dissipation, Watts - User Determined
For most applications PPORT \&PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between PD and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K+\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K \quad P_{D} \cdot\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta_{J A} \cdot P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P D$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {In }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range $-\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ <br> EF6840, EF68A40, EF68B40 |  |  |  |
| EF6840, EF68A40, EF68B40 :V suffix | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 <br> -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| EF6840, EF68A40 M suffix |  |  |  |

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Cerdip | $\theta J A$ | 65 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic |  | 115 | ${ }^{\prime}$ |
| Ceramic |  | 60 |  |
| PLCC |  | 100 |  |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields, however, it is ad vised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit For proper operation it is recommended that $V_{\text {in }}$ and $V_{\text {out }}$ be constrained to the range $V_{S S} \leq V_{V_{\text {in }}}$ or $V_{\text {out }}{ }^{\prime}$ $\leq V_{C C}$. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$ ).

DC ELECTRICAL CHARACTERISTICS $V_{C C}=5.0 \vee d c \pm 5 \%, V_{S S}=0, T_{A}=T_{L}$ to $T_{H}$ unless otherwise noted)

| Characteristic |  | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage |  | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{S S}+2.0$ | - | $\mathrm{V}_{\text {CC }}$ | V |
| Input Low Voltage |  | $V_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | - | $\mathrm{V}_{\text {SS }}+0.8$ | V |
| Input Leakage Current ( $\mathrm{V}_{\text {in }}=0$ to 5.25 V ) |  | In | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| $\mathrm{H}_{1}-\mathrm{Z}$ (Off State) Input Current ( $\mathrm{V}_{\text {in }}=0.5$ to 2.4 V ) | D0-D7 | ITSI | - | 2.0 | 10 | $\mu \mathrm{A}$ |
| $\begin{array}{r} \hline \text { Output High Voltage } \\ \text { (ILoad }=-205 \mu \mathrm{~A} \text { ) } \\ \text { (ILoad }=-200 \mu \mathrm{~A} \text { ) } \\ \hline \end{array}$ | $\begin{array}{r} \text { DO-D7 } \\ \text { Other Outputs } \\ \hline \end{array}$ | VOH | $\begin{aligned} & V S S+2.4 \\ & V S S+2.4 \\ & \hline \end{aligned}$ | - | - | V |
| $\begin{gathered} \hline \text { Output Low Voltage } \\ \text { (ILoad }=1.6 \mathrm{~mA} \text { ) } \\ \text { ( } \text { Load }=3.2 \mathrm{~mA} \text { ) } \\ \hline \end{gathered}$ | $\begin{array}{r} \overline{\mathrm{RQ}}, \mathrm{DO}-\mathrm{D7} \\ 01.03 \end{array}$ | VOL | - - - | - | $\begin{aligned} & V_{S S}+0.4 \\ & v_{S S}+0.4 \\ & \hline \end{aligned}$ | V |
| Output Leakage Current ( Off State) ( $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ ) | $\overline{\mathrm{RQ}}$ | l LOH | - | 1.0 | 10 | $\mu \mathrm{A}$ |
| Internal Power Dissipation (Measured at $T_{A}=T_{L}$ ) |  | PINT | - | 470 | 700 | mW |
| Input Capacitance $\left(V_{1 \text { In }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=10 \mathrm{MHz}\right)$ | DO-D7 <br> All Others | $\mathrm{Cin}_{\text {in }}$ | - | - | $\begin{gathered} 12.5 \\ 7.5 \end{gathered}$ | pF |
| $\begin{aligned} & \text { Output Capacıtance } \\ & \left(\mathrm{V}_{\text {In }}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \end{aligned}$ | $\begin{array}{r} \overline{\text { IRO }} \\ 01,02,03 \\ \hline \end{array}$ | $\mathrm{C}_{\text {out }}$ | - | - | $\begin{array}{r} 5.0 \\ 10 \\ \hline \end{array}$ | pF |

AC OPERATING CHARACTERISTICS (See Figures 4.9)

| Characteristic | Symbol | EF6840 |  | EF68A40 |  | EF68B40 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Input Rise and Fall Times (Figures 4 and 5 ) $\overline{\mathrm{C}}, \overline{\mathrm{G}}$, and $\overline{\mathrm{RESET}}$ | $\mathrm{t}_{\mathrm{r}}$, If | - | $1.0^{*}$ | - | $0.666^{*}$ | - | $0.500^{\circ}$ | $\mu \mathrm{S}$ |
| Input Pulse Width Low (Figure 4) (Asynchronous Input) $\overline{\mathrm{C}}, \overline{\mathrm{G}}$, and $\overline{\mathrm{RESET}}$ | PW ${ }_{\text {L }}$ | ${ }^{\text {cheyce }}+t_{\text {su }}+$ thd | - | ${ }^{\text {chyce }}+$ tsu $^{\text {+ }}$ thd | - | ${ }^{\text {cheyce }}+$ tsu + thd | - | ns |
| Input Pulse Width High (Figure 5) (Asynchronous Input) ट, 飞 | PWH |  | - | ${ }^{\text {t }}$ CVCE $+I_{\text {su }}+$ thd $^{\text {d }}$ | - | ${ }^{\text {t }} \mathrm{CyCE}+\mathrm{t}_{\text {su }}+\mathrm{thd}^{\text {d }}$ | - | ns |
| Input Setup Time (Figure 6) (Synchronous Input) $\overline{\mathrm{C}}, \overline{\mathrm{G}}$, and $\overline{\mathrm{RESET}}$ | tsu | 200 | -- | 120 | - | 75 | - | ns |
| Input Hold Time (Figure 6) ISynchionous Input\| $\overline{\mathrm{C}}, \overline{\mathrm{G}}$, and $\overline{\mathrm{RESET}}$ | tha | 50 |  | 50 | - | 50 | - | ns |
| Input Synchronization Time (Figure 9) $\overline{\mathrm{C} 3}$ :-8 Prescaler Mode Only) | tsync | 250 | - | 200 | - | 175 | - | ns |
| Input Pulse Width C3 $1-8$ Prescaler Mode Onlv) | PW ${ }_{\text {L }}, P W_{H}$ | 120 | - | 80 | - | 60 | - | ns |
| Output Delay, 01.03 (Figure 7) $r$  <br> $\mathrm{~V}_{\mathrm{OH}}=24 \mathrm{~V}$. Load B) TTL <br> $\mathrm{V}_{\mathrm{OH}}=24 \mathrm{~V}$. Load Di MOS <br> $\mathrm{V}_{\mathrm{OH}}=07 \mathrm{~V}$ DD. Load DI CMOS | $\begin{array}{r} t_{\mathrm{CO}} \\ \mathrm{t}_{\mathrm{cm}} \\ \mathrm{t}_{\mathrm{cmos}} \\ \hline \end{array}$ | - | $\begin{aligned} & 700 \\ & 450 \\ & 20 \\ & \hline \end{aligned}$ | - | $\begin{array}{r} 460 \\ 450 \\ 1.35 \\ \hline \end{array}$ | - | $\begin{aligned} & 340 \\ & 340 \\ & 1.0 \\ & \hline \end{aligned}$ | ns <br> ns <br> $\mu \mathrm{S}$ |
| Interrupt Release Time | I/R | - | 12 | - | 09 | - | 0.7 | $\mu \mathrm{S}$ |

[^26]BUS TIMING CHARACTERISTICS (See Notes 1, 2, and 3)

| Ident. Number | Characteristic | Symbol | EF6840 |  | EF68A40 |  | EF68B40 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Crcle Time | toyc | 1.0 | 10 | 0.67 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| 2 | Pulse Widit, E Low | PWEL | 430 | 9500 | 280 | 9500 | 210 | 9500 | ns |
| 3 | Pulse Widin, E High | PWEH | 450 | 9500 | 280 | 9500 | 220 | 9500 | ns |
| 4 | Clock Rise and Fall Time | $\mathrm{t}_{\mathrm{r}, \mathrm{if}}$ | -- | 25 | - | 25 | - | 20 | ns |
| 9 | Address Hold Time | IAH | 10 | - | 10 | - | 10 | - | ris |
| 13 | Address Setup Time Before E | IAS | 80 | - | 60 | - | 40 | - | ns |
| 14 | Chip Select Setup Time Betore E | tCS | 80 | $\cdots$ | 60 | - | 40 | - | ns |
| 15 | Chip Select Hold Time | ${ }^{1} \mathrm{CH}$ | 10 | - | 10 | - | 10 | - | ns |
| 18 | Read Data Hold Time | IDHR | 20 | $50^{*}$ | 20 | $50^{\circ}$ | 20 | $50^{*}$ | ns |
| 21 | Write Data Hold Time | IDHW | 10 | - | 10 | - | 10 | - | ns |
| 30 | Perripheral Output Data Delay Time | IDOR | - | 290 | - | 180 | - | 150 | ns |
| 31 | Peripheral Input Data Setup Time | IDSW | 165 | - | 80 | - | 60 | - | ns |

- The data bus output buffers are no longer sourcing or sinking current by tDHR max (High Impedance).

FIGURE 3 - BUS TIMING


FIGURE 4 - INPUT PULSE WIDTH LOW
FIGURE 5 - INPUT PULSE WIDTH HIGH


[^27]FIGURE 6 - INPUT SETUP AND HOLD TIMES


FIGURE 7 - OUTPUT DELAY


FIGURE 8 - $\overline{\text { IRO }}$ RELEASE TIME


FIGURE 10 - BUS TIMING TEST LOADS


NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted.

## DEVICE OPERATION

The EF6840 is part of the 6800 microprocessor family and is fully bus compatible with 6800 systems. The three timers in the EF6840 operate independently and in several distinct modes to fit a wide variety of measurement and synthesis applications.

The EF6840 is an integrated set of three distinct counter/timers (Figure 1). It consists of three 16 -bit data latches, three 16 -bit counters (clocked independently), and the comparison and enable circuitry necessary to implement various measurement and synthesis functions. In addition, it contains interrupt drivers to alert the processor that a particular function has been completed.

In a typical application, a timer will be loaded by first storing two bytes of data into an associated Counter Latch. This data is then transferred into the counter via a Counter Initialization cycle. If the counter is enabled, the counter decrements on each subsequent clock period which may be an external clock, or Enable (E) until one of several predetermined conditions causes it to halt or recycle. The timers are thus programmable, cyclic in nature, controllable by external inputs or the MIPU program, and accessible by the MPU at any time.

## BUS INTERFACE

The Programmable Timer Module (PTM) interfaces to the 6800 Bus with an 8 -bit bidirectional datà bus, two Chip Select lines, a Read/Write line, a clock (Enable) line, and Interrupt Request line, an external Reset line, and three Register select lines. VMA should be utilized in conjunction with an MPU address line into a Chip Select of the PTM when using the EF6800/6802/6808.

BIDIRECTIONAL DATA (D0-D7) - The bidirectional data lines (DO-D7) allow the transfer of data between the MPU and PTM. The data bus output drivers are three-state devices which remain in the high-impedance (off) state except when the MPU performs a PTM read operation (Read/Write and Enable lines high and PTM Chip Selects activated).

CHIP SELECT ( $\overline{\mathrm{CS} 0}, \mathrm{CS} 1$ ) - These two signals are used to activate the Data Bus interface and allow transfer of data from the PTM. With $\overline{\operatorname{CSO}}=0$ and $\operatorname{CS} 1=1$, the device is selected and data transfer will occur.

READ/WRITE (R/W) - This signal is generated by the MPU to control the direction of data transfer on the Data Bus. With the PTM selected, a low state on the PTM R/W line enables the input buffers and data is transferred from the MPU to the PTM on the trailing edge of the $E$ (Enable) clock. Alternately, (under the same conditions) $R / \bar{W}=1$ and Enable high allows data in the PTM to be read by the MPU.

ENABLE (E CLOCK) - The E clock signal synchronizes data transfer between the MPU and the PTM. It also performs an equivalent synchronization function on the external clock, reset, and gate inputs of the PTM.

INTERRUPT REQUEST ( $\overline{\mathrm{RQ}}$ ) - The active low Interrupt Request signal is normally tied directly (or through priority interrupt circuitry) to the $\overline{\mathrm{RQ}}$ input of the MPU. This is an
"open drain" output (no load device on the chip) which permits other similar interrupt request lines to be tied together in a wire-OR configuration.

The $\overline{I R Q}$ line is activated if, and only if, the Composite Interrupt Flag (Bit 7 of the Internal Status Register) is asserted. The conditions under which the $\overline{\mathrm{IQ}}$ line is activated are discussed in conjunction with the Status Register.
$\overline{\text { RESET }}$ - A low level at this input is clocked into the PTM by the E (Enable) input. Two Enable pulses are required to synchronize and process the signal. The PTM then recognizes the active "low" or inactive "high" on the third Enable pulse. If the $\overline{\text { RESET signal is asynchronous, an addi- }}$ tional Enable period is required if setup times are not met. The RESET input must be stable High/Low for the minimum time stated in the AC Operating Characteristics.

Recognition of a low level at this input by the PTM causes the following action to occur:
a. All counter latches are preset to their maximum count values.
b. All Control Register bits are cleared with the exception of CR10 (internal reset bit) which is set.
c. All counters are preset to the contents of the latches.
d. All counter outputs are reset and all counter clocks are disabled.
e. All Status Register bits (interrupt flags) are cleared.

REGISTER SELECT LINES (RS0, RS1, RS2) - These iriputs are used in conjunction with the R/W line to select the internal registers, counters and latches as shown in Table 1.

## NOTE:

The PTM is accessed via MPU Load and Store operations in much the same manner as a memory device. The instructions available with the $\mathbf{6 8 0 0}$ family of MPUs which perform read-modify-write operations on memory should not be used when the PTM is accessed. These instructions actually fetch a byte from memory, perform an operation, then restore it to the same address location. Since the PTM uses the R/W line as an additional register select input, the modified data will not be restored to the same register if these instructions are used.

## CONTROL REGISTER

Each timer in the EF6840 has a corresponding write-only Control Register. Control Register \#2 has a unique address space ( $\mathrm{RSO}=1, \mathrm{RS}=0, \mathrm{RS} 2=0$ ) and tıerefore may be written into at any time. The remaining Control Registers (\#1 and \#3) share the Address Space selected by a logic zero on all Register Select inputs.

CR20 - The least-significant bit of Control Register \#2 (CR20) is used as an additional addressing bit for Control Registers \#1 and \#3. Thus, with all Register selects and R/W inputs at logic zero, Control Register \#1 will be written into if CR20 is a logic one. Under the same conditions, Control Register \#3 can also be written into after a $\overline{\operatorname{RESET}}$ low condition has occurred, since all control register bits (except CR10) are cleared. Therefore, one may write in the sequence CR3, CR2, CR1.

TABLE 1 - REGISTER SELECTION

| Register Select Inputs |  |  | Operations |  |
| :---: | :---: | :---: | :---: | :---: |
| RS2 | RS1 | RSO | R/ $\bar{W}=0$ | $\mathrm{R} / \bar{W}=1$ |
| 0 | 0 | 0 | CR20 $=0$ Write Control Register \#3 | No Operation |
|  |  |  | CR20 $=1 \quad$ Write Control Register \#1 |  |
| 0 | 0 | 1 | Write Control Register \#2 | Read Status Register |
| 0 | 1 | 0 | Write MSB Buffer Register | Read Timer \#1 Counter |
| 0 | 1 | 1 | Write Timer \#1 Latches | Read LSB Buffer Register |
| 1 | 0 | 0 | Write MSB Buffer Register | Read Timer \#2 Counter |
| 1 | 0 | 1 | Write Timer \#2 Latches | Read LSB Buffer Register |
| 1 | 1 | 0 | Write MSB Buffer Register | Read Timer \#3 Counter |
| 1 | 1 | 1 | Write Timer \#3 Latches | Read LSB Buffer Register |

CR10 - The least significant bit of Control Register \#1 is used as an Internal Reset bit. When this bit is a logic zero, all timers are allowed to operate in the modes prescribed by the remaining bits of the control registers. Writing a "one" into CR10 causes all counters to be preset with the contents of the corresponding counter latches, all counter clocks to be disabled, and the timer outputs and interrupt flags (Status Register) to be reset. Counter Latches and Control Registers are undisturbed by an Internal Reset and may be written into regardless of the state of CR10.

The least signifcant bit of Control Register \#3 is used as a selector for a $\div 8$ prescaler which is available with Timer \#3 only. The prescaler, if selected, is effectively placed between
the clock input circuitry and the input to Counter \#3. It can therefore be used with either the internal clock (Enable) or an external clock source.

## NOTE

When initializing Timer 3 into the divide-by-eight mode on consecutive E-cycles (i.e., with DMA), Control Register 3 must be initialized after Timer Latch \#3 to insure proper timer initialization.

CR30 - The functions depicted in the foregoing discussions are tabulated in Table 2 for ease of reference.

TABLE 2 - CONTROL REGISTER BITS


Control Register Bits CR10, CR20, and CR30 are unique in that each selects a different function. The remaining bits 11 through 7) of each Control Register select common functions, with a particular Control Register affecting only its corresponding timer.

CRX1 - Bit 1 of Control Register \#1 (CR11) selects whether an internal or external clock source is to be used with Timer \#1. Similarly, CR21 selects the clock source for Timer \#2, and CR31 performs this function for Timer \#3. The function of each bit of Control Register " $X$ " can therefore be defined as shown in the remaining section of Table 2.

CRX2 - Control Register Bit 2 selects whether the binary information contained in the Counter Latches land subsequently loaded into the counter) is to be treated as a single 16 -bit word or two 8 -bit bytes. In the single 16 -bit Counter Mode $(C R X 2=0)$ the counter will decrement to zero after $N+1$ enabled ( $G=0$ ) clock periods, where $N$ is defined as the 16 -bit number in the Counter Latches. With $C R X 2=1$, a similar Time Out will occur after $(L+1) \cdot(M+1)$ enabled clock periods, where $L$ and $M$, respectively, refer to the LSB and MSB bytes in the Counter Latches.

CRX3-CRX7 - Control Register Bits 3, 4, and 5 are explained in detail in the Timer Operating Mode section. Bit 6 is an interrupt mask bit which will be explained more fully in conjunction with the Status Register, and bit 7 is used to enable the corresponding Timer Output. A summary of the control register programming modes is shown in Table 3.

## STATUS REGISTER/INTERRUPT FLAGS

The EF6840 has an internal Read-Only Status Register which contains four Interrupt Flags. (The remaining four bits of the register are not used, and defaults to zeros when being read.) Bits 0, 1, and 2 are assigned to Timers 1, 2, and 3, respectively, as individual flag bits, while Bit 7 is a Composite Interrupt Flag. This flag bit will be asserted if any of the individual flag bits is set while Bit 6 of the corresponding Conrtrol Register is at a logic one. The conditions for asserting the composite Interrupt Flag bit can therefore be expressed as:

$$
\begin{aligned}
& \text { INT }=11 \cdot \mathrm{CR} 16+12 \cdot \mathrm{CR} 26+13 \cdot \mathrm{CR} 36 \\
& \text { where } \begin{array}{l}
\mathrm{INT}
\end{array}=\text { Composite Interrupt Flag (Bit 7) } \\
& 11=\text { Timer \#1 Interrupt Flag (Bit 0) } \\
& 12=\text { Timer \#2 Interrupt Flag (Bit 1) } \\
& 13=\text { Timer \#3 Interrupt Flag (Bit 2) }
\end{aligned}
$$

An interrupt flag is cleared by a Timer Reset condition, i.e., External $\overline{\mathrm{RESET}}=0$ or Internal Reset Bit $(C R 10)=1$. It will also be cleared by a Read Timer Counter Command provided that the Status Register has previously been read while the interrupt flag was set. This condition on the Read Status Register-Read Timer Counter (RS-RT) sequence is designed to prevent missing interrupts which might occur after the status register is read, but prior to reading the Timer Counter.

An Individual Interrupt Flag is also cleared by a Write Timer Latches (W) command or a Counter Initialization (CI) sequence, provided that W or Cl affects the Timer corresponding to the individual Interrupt Flag.

## COUNTER LATCH INITIALIZATION

Each of the three independent timers consists of a 16-bit addressable counter and a 16 -bit addressable latch. The counters are preset to the binary numbers stored in the latches. Counter initialization results in the transfer of the latch contents to the counter. See notes in Table 4 regarding the binary number $N, L$, or $M$ placed into the Latches and their relationship to the output waveforms and counter Time-Outs.

Since the PTM data bus is 8 -bits wide and the counters are 16-bits wide, a temporary register (MSB Buffer Register) is provided. This "write only" register is for the MostSignificant Byte of the desired latch data. Three addresses are provided for the MSB Buffer Register (as indicated in Table 1), but they all lead to the same Buffer. Data from the MSB Buffer will automatically be transferred into the MostSignificant Byte of Timer \#X when a Write Timer \#X Latches Command is performed. So it can be seen that the EF6840 has been designed to allow transfer of two bytes of data into the counter latches provided that the MSB is transferred first. The storage order must be observed to ensure proper latch operation.

In many applications, the source of the data will be a 6800 Family MPU. It should be noted that the 16 -bit store operations of the 6800 family microprocessors (STS and STX) transfer data in the order required by the PTM. A Store Index Register Instruction, for example, results in the MSB of the $X$ register being transferred to the selected address, then the LSB of the $X$ register being written into the next higher location. Thus, either the index register or stack pointer may be transferred directly into a selected counter latch with a single instruction.

A logic zero at the $\overline{\text { RESET input also initializes the counter }}$ latches. In this case, all latches will assume a maximum count of 65,53510 . It is important to note that an Internal

| CRX4 |  |  | TABLE 3 - PTM OPERATING MODE SELECTION |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Continuous Operating Mode: Gate I or Write to Latches or Reset Causes Counter Initialization |
| 1 | 0 | 0 | Frequency Comparison Mode: Interrupt If Gate $\sqrt{\square}$ is<Counter Time Out |
| 0 | 1 | 0 | Continuous Operating Mode: Gate 1 or Reset Causes Counter Initialization |
| 1 | 1 | 0 | Pulse Width Comparison Mode: Interrupt if Gate $\boldsymbol{\sim}$, is $<$ Counter Time Out |
| 0 | 0 | 1 | Single Shot Mode: Gate $\downarrow$ or Write to Latches or Reset Causes Counter Initialization |
| 1 | 0 | 1 | Frequency Comparison Mode: Interrupt If Gate $\square$ is $>$ Counter Time Out |
| 0 | 1 | 1 | Single Shot Mode: Gate ! or Reset Causes Counter Initialization |
| 1 | 1 | 1 | Pulse Width Comparison Mode: Interrupt If Gate 4 is $>$ Counter Time Out |

Reset (Bit zero of Control Register 1 Set) has no effect on the counter latches.

## COUNTER INITIALIZATION

Counter Intialization is defined as the transfer of data from the latches to the counter with subsequent clearing of the In. dividual Interrupt Flag associated with the counter. Counter Intialization always occurs when a reset condition $\overline{(\text { RESET }}=0$ or CR10 $=1$ ) is recognized. It can also occur depending on Timer Mode - with a Write Timer Latches command or recognition of a negative transition of the Gate input.

Counter recycling or re-initralization occurs when a negative transition of the clock input is recognized after the counter has reached an all-zero state. In this case, data is transferred from the Latches to the Counter.

## ASYNCHRONOUS INPUT/OUTPUT LINES

Each of the three timers within the PTM has external clock and gate inputs as well as a counter output line. The inputs are high-impedance, TTL-compatible lines and ouputs are capable of driving two standard TTL loads.

CLOCK INPUTS $\overline{(C 1}, \overline{\mathrm{C}}$, and $\overline{\mathrm{C} 3}$ ) - Input pins $\overline{\mathrm{C} 1}, \overline{\mathrm{C} 2}$, and $\overline{\mathrm{C}}$ will accept asynchronous TTL voltage level signals to decrement Timers 1, 2, and 3, respectively. The high and low levels of the external clocks must each be stable for at least one system clock period plus the sum of the setup and hold times for the clock inputs. The asynchronous clock rate can vary from dc to the limit imposed by the Enable Clock Setup, and Hold times.

The external clock inputs are clocked in by Enable pulses. Three Enable periods are used to synchronize and process the external clock. The fourth Enable pulse decrements the internal counter. This does not affect the input frequency, it merely creates a delay between a clock input transition and internal recognition of that transition by the PTM. All references to C inputs in this document relate to internal recognition of the input transition. Note that a clock high or low level which does not meet setup and hold time specifications may require an additional Enable pulse for recognition. When observing recurring events, a lack of synchronization will result in "jitter" being observed on the output of the PTM when using asynchronous clocks and gate input signals. There are two types of jitter. "System jitter" is the result of the input signals being out of synchronization with Enable, permitting signals with marginal setup and hold time to be recognized by either the bit time nearest the input transition or the subsequent bit time.
"Input jitter" can be as great as the time between input signal negative going transitions plus the system jitter, if the first transition is recognized during one system cycle, and not recognized the next cycle, or vice versa. See Figure 11.

FIGURE 11 - INPUT JITTER


CLOCK INPUT $\overline{\mathrm{C} 3}$ (-8 PRESCALER MODE) - External clock input $\overline{\mathrm{C}}$ represents a special case when Timer \#3 is programmed to utilize its optional - 8 prescaler mode.

The divide-by- 8 prescaler contains an asynchronous ripple counter; thus, input setup ( tsu ) and hold times (thd) do not apply. As long as minımum input pulse widths are maintained, the counter will recognize and process all input clock $(\overline{\mathrm{C} 3})$ transitions. However, in order to guarantee that a clock transition is processed during the current E cycle, a certain amount of synchronization time ( $t_{\text {sync }}$ ) is required between the $\overline{\mathrm{C}}$ transition and the falling edge of Enable (see Figure 9). If the synchronization time requirement is not met, it is possible that the $\overline{\mathrm{C} 3}$ transition will not be processed until the following E cycle.

The maximum input frequency and allowable duty cycles for the $\div 8$ prescaler mode are specified under the $A C$ Operatıng Characterıstics. Internally, the $\div 8$ prescaler output is treated in the same manner as the previously discussed clock inputs.

GATE INPUTS $(\overline{\mathrm{G} 1}, \overline{\mathrm{G} 2}, \overline{\mathrm{G} 3})$ - Input pins $\overline{\mathrm{G} 1}, \overline{\mathrm{G} 2}$, and $\overline{\mathrm{G} 3}$ accept asynchronous TTL-compatible signals which are used as triggers or clock gating functions to Timers 1, 2, and 3, respectively. The gating inputs are clocked into the PTM by the $E$ (enable) clock in the same manner as the previously discussed clock inputs. That is, a Gate transition is recogniz. ed by the PTM on the fourth Enable pulse (provided setup and hold time requirements are met), and the high or low levels of the Gate input must be stable for at least one system clock period plus the sum of setup and hold times. All references to $G$ transition in this document relate to internal recognition of the input transition.

The Gate inputs of ail timers directly affect the internal 16 -bit counter. The operation of $\overline{\mathrm{G} 3}$ is therefore independent of the -8 prescaler selection.

TIMER OUTPUTS $(01,02,03)$-- Timer outputs O1, O2, and $O 3$ are capable of driving up to two TTL loads and produce a defined output waveform for either Continuous of Single-Shot Timer modes. Output waveform definition is ac. complished by selecting either Single 16 -bit or Dual 8 bit operating modes. The Single 16 -bit mode will produce a square-wave output in the continuous mode and a single pulse in the single-shot mode. The Dual 8 -bit mode will pro. duce a variable duty cycle pulse in both the continuous and single-shot timer modes. One bit of each Control Register (CRX7) is used to enable the corresponding output. If this bit is cleared, the output will remain low ( $\mathrm{V}_{\mathrm{OL}}$ ) regardless of the operating mode. If it is cleared while the output is high the output will go low during the first enable cycle following a write to the Control Register.

The Continuous and Single-Shot Timer Modes are the only ones for which output response is defined in this data sheet. Refer to the Programmable Timer Fundamentals and Applications manual for a discussion of the output signals in other modes. Signals appear at the outputs (unless $C R \times 7=0$ ) during Frequency and Pulse Width comparison modes, but the actual waveform is not predictable in typical applications.

## TIMER OPERATING MODES

The EF6840 has been designed to operate effectively in a wide variety of applications. This is accomplished by using three bits of each control register (CRX3, CRX4, and CRX5) to define different operating modes of the Timers. These modes are divided into WAVE SYNTHESIS and WAVE MEASUREMENT modes, and are outlined in Table 4.

TABLE 4 - OPERATING MODES

| Control Register |  |  | Timer Operating Mode |  |
| :---: | :---: | :---: | :---: | :---: |
| CRX3 | CRX4 | CRX5 |  |  |
| 0 | - | 0 | Continuous | Synthesizer |
| 0 | - | 1 | Single-Shot |  |
| 1 | 0 | - | Frequency Comparison | Measurement |
| 1 | 1 | - | Pulse Width Comparison |  |

- Defines Additional Timer Function Selection.

One of the WAVE SYNTHESIS modes is the Continuous Operating mode, which is useful for cyclic wave generation. Either symmetrical or variable duty-cycle waves can be generated in this mode. The other wave synthesis mode, the Single-Shot mode, is similar in use to the Continuous operating mode, however, a single pulse is generated, with a programmable preset width.
The WAVE MEASUREMENT modes include the Frequency Comparison and Pulse Width Comparison modes which are used to measure cyclic and singular pulse widths, respectively.
In addition to the four timer modes in Table 4, the remaining control register bit is used to modify counter initialization and enabling or interrupt conditions.

## WAVE SYNTHESIS MODES

CONTINUOUS OPERATING MODE (TABLE 5) - The continuous mode will synthesize a continuous wave with a period proportional to the preset number in the particular timer latches. Any of the timers in the PTM may be programmed to operate in a continuous mode by writing zeroes into bits 3 and 5 of the corresponding control register. Assuming
that the timer output is enabled (CRX7 $=1$ ), either a square wave or a variable duty cycle waveform will be generated at the Timer Output, OX. The type of output is selected via Control Register Bit 2
Either a Timer Reset (CR10 $=1$ or External Reset $=0$ ) condition or internal recognition of a negative transition of the Gate input results in Counter Initialization. A Write Timer latches command can be selected as a Counter Initialization signal by clearing CRX4
The counter is enabled by an absence of a Timer Reset condition and a logic zero at the Gate input. In the 16 -bit mode, the counter will decrement on the first clock cycle during or after the counter initialization cycle. It continues to decrement on each clock signal so long ás $G$ remains low and no reset condition exists. A Counter Time Out (the first clock after all counter bits $=0$ ) results in the Individual Interrupt Flag being set and reinitialization of the counter.

In the Dual 8 -bit mode $(C R \times 2=1)$ (refer to the example in Figure 10 and Tables 5 and 6 I the MSB decrements once for every full countdown of the $L S B+1$. When the $L S B=0$, the MSB is unchanged; on the next clock pulse the LSB is reset to the count in the LSB Latches, and the MSB is decremented by 1 (one). The output, if enabled, remains low during and after initialization and will remain low until the counter MSB is all zeroes. The output will go high at the beginning of the next clock pulse. The output remains high until both the LSB and MSB of the counter are all zeroes. At the beginning of the next clock pulse the defined Time Out (TO) will occur and the output will go low. In the Dual 8 -bit mode the period of the output of the example in Figure 12 would span 20 clock pulses as opposed to 1546 clock pulses using the normal 16 -bit mode.
A special time-out condition exists for the dual 8 -bit mode ( $C R \times 2=1$ ) if $\mathrm{L}=0$. In this case, the counter will revert to a mode similar to the single 16 -bit mode, except Time Out occurs after $M+1^{*}$ clock pulses. The output, if enabled, goes low during the Counter Initialization cycle and reverses state at each Time Out. The counter remains cyclical (is reinitialized at each Time Out) and the Individual Interrupt Flag is set when Time Out occurs. If $M=L=0$, the internal counters do not change, but the output toggles at a rate of $1 / 2$ the clock frequency.

TABLE 5 - CONTINUOUS OPERATING MODES

| Synthes | Modes | CONTINUOUS MODE$(C R \times 3=0, C R \times 5=0)$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Control Register |  | Initialization/Output Waveforms |  |  |  |
| CRX2 | CRX4 | Counter Initialization | *Timer Output (OX) $(\mathrm{CRX7}=1)$ |  |  |
| 0 | 0 | $\bar{G} \downarrow+W+R$ |  |  |  |
| 0 | 1 | $\overline{\mathrm{G}} \downarrow+\mathrm{R}$ |  |  |  |
| 1 | 0 | $\bar{G}!+W+R$ |  |  |  |
| 1 | 1 | $\bar{G} \downarrow+R$ |  |  |  |

FIGURE 12 - TIMER OUTPUT WAVEFORM EXAMPLE
(Continuous Dual 8-Bit Mode Using Internal Enable)


The discussion of the Continuous Mode has assumed that the application requires an output signal. It should be noted that the Timer operates in the same manner with the output disabled (CRX7 $=0$ ). A Read Timer Counter command is valid regardless of the state of CRX7.

SINGLE-SHOT TIMER MODE - This mode is identical to the Continuous Mode with three exceptions. The first of these is obvious from the name - the output returns to a low level after the initial Time Out and remains low until another Counter Initialization cycle occurs.

As indicated in Table 6, the internal counting mechanism remains cyclical in the Single-Shot Mode. Each Time Out of
the counter results in the setting of an Individual Interrupt Flag and re-initialization of the counter.

The second major difference between the Single-Shot and Continuous modes is that the internal counter enable is not dependent on the Gate input level reamining in the low state for the Single-Shot mode.

Another special condition is introduced in the Single-Shot mode. If $L=M=0$ (Dual 8 -bit) or $N=0$ (Single 16 -bit), the output goes low on the first clock received during or after Counter Initialization. The output remains low until the Operating Mode is changed or nonzero data is written into the Counter Latches. Time Outs continue to occur at the end of each clock period.

TABLE 6 - SINGLE-SHOT OPERATING MODES

| Synthe | Modes | SINGLE-SHOT MODE (CRX3 $=0, C R \times 7=1, C R \times 5=1$ ) |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Control Register |  | Initialization/Output Waveforms |  |  |
| CRX2 | CRX4 | Counter Initialization |  |  |
| 0 | 0 | $\overline{\mathbf{G}}_{\downarrow}+W+R$ |  |  |
| 0 | 1 | $\overline{\mathrm{G}} \downarrow+\mathrm{R}$ |  |  |
| 1 | 0 | $\bar{G}_{\downarrow}+\mathbf{W}+\mathrm{R}$ |  |  |
| 1 | 1 | $\mathrm{G} \downarrow+\mathrm{R}$ |  |  |

[^28]The three differences between Single-Shot and Continous Timer Mode can be summarized as attributes of the SingleShot mode:

1. Output is enabled for only one pulse until it is reinitialized.
2. Counter Enable is independent of Gate.
3. $L=M=0$ or $N=0$ disables output.

Aside from these differences, the two modes are identical.

## WAVE MEASUREMENT MODES

TIME INTERVAL MODES - The Time Interval Modes are the Frequency (period) Measurement and Pulse Width Comparison Modes, and are provided for those applications which require more flexibility of interrupt generation and Counter Initialization. Individual Interrupt Flags are set in these modes as a function of both Counter Time Out and transitions of the Gate input. Counter Initialization is also affected by Interrupt Flag status.
A timer's output is normally not used in a Wave Measurement mode, but it is defined. If the output is enabled, it will operate as follows. During the period between reinitialization of the timer and the first Time Out, the output will be a logical zero. If the first Time Out is completed (regardless of its method of generation), the output will go high. If further TO's occur, the output will change state at each completion of a Time-Out.
The counter does operate in either Single 16 -bit or Dual 8 -bit modes as programmed by CRX2. Other features of the Wave Measurement Modes are outlined in Table 7.

Frequency Comparison Or Period Measurement Mode (CRX3=1, CRX4=0) - The Frequency Comparison Mode with $C R X 5=1$ is straightforward. If Time Out occurs prior to the first negative transition of the Gate input after a Counter Initialization cycle, an Individual Interrupt Flag is set. The counter is disabled, and a Counter Initialization cycle cannot begin until the interrupt flag is cleared and a negative transition on $\overline{\mathrm{G}}$ is detected.
If CRX5 $=0$, as shown in Tables 7 and 8, an interrupt is generated if Gate input returns low prior to a Time Out. If a Counter Time Out occurs first, the counter is recycled and continues to decrement. A bit is set within the timer on the initial Time Out which precludes further individual interrupt
generation until a new Counter Initialization cycle has been completed. When this internal bit is set, a negative transition of the $\overline{\text { Gate }}$ input starts a new Counter Initialization cycle. (The condition of G.JT.TO is satisfied, since a Time Out has occurred and no individual interrupt has been generated.)

Any of the timers within the PTM may be programmed to compare the period of a pulse (giving the frequency after calculations) at the Gate input with the time period requested for Counter Time Out. A negative transition of the Gate Input enables the counter and starts a Counter Initialization cycle - provided that other conditions, as noted in Table 8, are satisfied. The counter decrements on each clock signal recognized during or after Counter Initialization until an Interrupt is generated, a Write Timer Latches command is issued, or a Timer Reset condition occurs. It can be seen from Table 8 that an interrupt condition will be generated if CRX5 $=0$ and the period of the pulse (single pulse or measured separately repetitive pulses) at the Gate input is less than the Counter Time Out period. If $C R X 5=1$, an interrupt is generated if the reverse is true.

Assume now with $C R X 5=1$ that a Counter Initialization has occurred and that the Gate input has returned low prior to Counter Time Out. Since there is no Individual Interrupt Flag generated, this automatically starts a new Counter Initialization Cycle. The process will continue with frequency comparison being performed on each Gate input cycle until the mode is changed, or a cycle is determined to be above the predetermined limit.

Pulse Width Comparison Mode (CRX3 $=1, \operatorname{CRX4}=1$ ) This mode is similar to the Frequency Comparison Mode except for a positive, rather than negative, transition of the Gate input terminates the count. With $C R \times 5=0$, an Individual Interrupt Flag will be generated if the zero level pulse applied to the Gate input is less than the time period required for Counter Time Out. With CRX5 $=1$, the interrupt is generated when the reverse condition is true.

As can be seen in Table 8, a positive transition of the Gate input disables the counter. With $C R X 5=0$, it is therefore possible to directly obtain the width of any pulse causing an interrupt. Similar data for other Time Interval Modes and conditions can be obtained, if two sections of the PTM are dedicated to the purpose.
figure 7 - output delay

| CRX3 $=1$ |  |  |  |
| :---: | :---: | :---: | :--- |
| CRX4 | CRX5 | Application | Condition for Setting Individual Interrupt Flag |
| 0 | 0 | Frequency Comparison | Interrupt Generated if $\overline{\text { Gate }}$ <br> than Counter Time Out (TO) |
| 0 | 1 | Frequency Comparison Period (1/F) is less | Interrupt Generated if $\overline{\text { Gate }}$ <br> than Counter Time Out (TO) |
| 1 | 0 | Pulse Width Comparison | Interrupt Generated if $\overline{\text { Gate }}$ <br> than Counter Time Out (TO) |
| 1 | 1 | Pulse Width Comparison | Interrupt Generated if $\overline{\text { Gate }}$ Input "Down Time" is less <br> than Counter Time Out (TO) |

TABLE 8 - FREQUENCY COMPARISON MODE

| Mode | Bit 3 | Bit 4 | Control Reg. Bit 5 | Counter Initialization | Counter Enable Flip-Flop Set (CE) | Counter Enable Flip-Flop Reset (CE) | Interrupt Flag Set (1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Frequency | 1 | 0 | 0 | G7. $1 \pm$ TCE + TOI + R | G.-W.R.İ | W.R. I | (i) Betwere I() |
| Comparison | 1 | 0 | 1 | $\overline{\mathrm{Gl}} \cdot \mathrm{T}+\mathrm{R}$ | $\overline{\mathrm{G}} \cdot \mathrm{C} \cdot \overline{\mathrm{W}} \cdot \overline{\mathrm{R}} \cdot \overline{\mathrm{i}}$ | W.R.1 | 10) Beture $\overline{\text { at }}$ |
| Pulse Width | 1 | 1 | 0 | $\overline{\mathrm{G} 1 \cdot \bar{T}+\bar{R}}$ | $\overline{\mathrm{G}} \backslash \bar{W} \cdot \overline{\mathrm{R}} \cdot \overline{\mathrm{T}}$ | W, R - I C | is Betore ${ }^{\text {a }}$ (1) |
| Comparison | 1 | 1 | 1 | $\overline{\mathrm{G}} 1 \cdot \overline{\bar{T}}+\overline{\mathrm{R}}$ | $\overline{\mathrm{G}}!\cdot \overline{\mathrm{W}} \cdot \overline{\mathrm{R}} \cdot \overline{\overline{1}}$ | W,R.1. G | Git Betome 10 |

[^29]
## ORDERING INFORMATION

| The table below horizontally shows all available suffix combinations for package, operating temperature and screening level. Other possibilities on request. |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
| DEVICE | PACKAGE |  |  |  |  | OPER. TEMP |  |  | SCREENING LEVEL |  |  |  |
|  | c | $J$ | P | E | FN | L* | v | M | Std | D | G/B | B/B |
| EF6840 (1.0 MHz) | $\bullet \cdot$ | $\bullet$ | $\bullet$ |  | $\bullet$ | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ | $\bullet$ | $\bullet$ |  |  |  | $\bullet$ |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  |  | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  | $\bullet$ | $\bullet$ |
|  |  | $\bullet$ |  |  |  |  |  | $\bullet$ | $\bullet$ |  | $\bullet$ |  |
| EF68A40 (1.5 MHz) | $\bullet$ | $\bullet$ | $\bullet$ |  |  | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ | $\bullet$ | $\bullet$ |  |  |  | $\bullet$ |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  |  | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  | $\bullet$ | $\bullet$ |
|  |  | - |  |  |  |  |  | $\bullet$ | $\bullet$ |  | - |  |
| EF68B40 ( 2.0 MHz ) | $\bullet$ | $\bullet$ | $\bullet$ |  |  | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ | $\bullet$ |  |  |  |  | $\bullet$ |  | $\bullet$ |  | $\bullet$ |  |
| Examples: EF6840C, EF6840CV, EF6840CM, EF6840JM |  |  |  |  |  |  |  |  |  |  |  |  |
| Package : C : Ceramic DIL, J : Cerdip DIL, P : Plastic DIL, E : LCCC, FN : PLCC. <br> Oper. temp. : $\mathrm{L}^{*}: 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}:-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{M}:-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C},{ }^{*}$ : may be omitted. <br> Screening level : Std : (no-end suffix), D: NFC 96883 level D, <br> G/B : NFC 96883 level G, B/B : NFC 96883 level B and MIL-STD-883C level B. |  |  |  |  |  |  |  |  |  |  |  |  |

## PHYSICAL DIMENSIONS



CB-132


P SUFFIX
PLASTIC PACKAGE

ALSO AVAILABLE
JSUFFIX CERDIP PACKAGE

C SUFFIX CERAMIC PACKAGE

CB-520
uacaranames
fN SUFFIX
PLCC 28



The EF6850 Asynchronous Communications Interface Adapter provides the data formatting and control to interface serial asynchronous data communications information to bus organized systems such as the EF6800 Microprocessing Unit.

The bus interface of the EF6850 includes select, enable, read/write, interrupt and bus interface logic to allow data transfer over an 8 -bit bidrectional data bus. The parallel data of the bus system is serially transmitted and received by the asynchronous data interface, with proper formatting and error checking. The functional configuration of the ACIA is programmed via the data bus during system initialization. A programmable Control Register provides variable word lengths, clock division ratios, transmit control, receive control, and interrupt control. For peripheral or modem operation, three control lines are provided.

- 8- and 9-Bit Transmission
- Optional Even and Odd Parity
- Parity, Overrun and Framing Error Checking
- Programmable Control Register
- Optional + 1, + 16, and +64 Clock Modes
- Up to 1.0 Mbps Transmission
- False Start Bit Deletion
- Peripheral/Modem Control Functions
- Double Buffered
- One- or Two-Stop Bit Operation


## MOS

(N-CHANNEL, SILICON-GATE)

## ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER



ALSO AVAILABLE

JSUFFIX
CERDIP PACKAGE
CB-520

fN SUFFIX PLCC 28

C SUFFIX CERAMIC PACKAGE


ESUFFIX LCCC 28

Hi-Rel versions available - See chapter 9

EF6850 ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER BLOCK DIAGRAM


PIN ASSIGNMENT

| $V_{S S} 1$ | 24 |
| :---: | :---: |
| Rx Data 2 | 23 |
| R×CLK ${ }^{\text {a }}$ | 22 |
| Tx CLK ${ }^{\text {d }}$ | 21 |
| $\overline{\text { RTS }} 5$ | 20 |
| Tx Data 6 | 19 |
| पिQ 7 | 18 |
| CSO 8 | 17 |
| CS2 9 | 16 |
| CS10 10 | 15 |
| RS 11 | 14 |
| $v_{\text {CC }}{ }_{12}$ | 13 |


| Characteristics | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to + 7.0 | $\checkmark$ |
| Operating Temperature Range EF6850, EF68A50, EF68B50 EF6850, EF68A50, EF68B50 : V suffix EF6850, EF68A50 : M suffix | TA | $\begin{gathered} T_{L} \text { to } T_{H} \\ 0 \text { to } 70 \\ -40 \text { to }+85 \\ -55 \text { to }+125 \\ \hline \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $T_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

## THERMAL CHARACTERISTICS

THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Plastic | $\theta J J$ | 120 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic |  | 60 |  |
| Cerdip |  | 65 |  |
| PLCC |  | 100 |  |

## POWER CONSIDERATIONS

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this highimpedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$ )

The average chip-junction temperature, $T_{J}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T_{J}=T_{A}+\left(P D^{\bullet} \cdot \theta J A\right) \tag{1}
\end{equation*}
$$

Where:
$T_{A} \equiv$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta J A \equiv$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
PD $=$ PINT + PPORT
PINT $=$ ICC $\times$ VCC , Watts - Chip Internal Power
PPORT $=$ Port Power Dissipation, Watts - User Determined
For most applications PPORT \&PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P D=K+\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta_{J A} \cdot P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known TA. Using this value of $K$ the values of PD and $T_{j}$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

DC ELECTRICAL CHARACTERISTICS $\mathcal{V}_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}$ to $T_{H}$ unless otherwise noted.)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {SS }}+2.0$ | - | $V_{C C}$ | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{S S}-0.3$ | - | $\mathrm{V}_{\text {SS }}+0.8$ | V |
| Input Leakage Current $R / \bar{W}, C S 0, C S 1, \overline{C S 2}$, Enable <br> $\left(V_{\text {in }}=0\right.$ to 5.25 V$)$ $R S, R \times D, R \times C, \overline{C T S}, \overline{D C D}$ | lin | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| Hi-Z (Off State) Input Current $\left(\mathrm{V}_{\mathrm{in}}=0.4 \text { to } 2.4 \mathrm{~V}\right)$ | ITSI | - | 2.0 | 10 | $\mu \mathrm{A}$ |
|  | VOH | $\begin{aligned} & V_{S S}+2.4 \\ & V_{S S}+2.4 \end{aligned}$ | - | - | V |
| Output Low Voltage ( $\mathrm{Load}=1.6 \mathrm{~mA}$, Enable Pulse Width $<25 \mu \mathrm{~s}$ ) | VOL | - | - | VSS +0.4 | V |
| Output Leakage Current (Off State) ( $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ ) $\quad$ IRQ | ILOH | - | 1.0 | 10 | $\mu \mathrm{A}$ |
| Internal Power Dissipation (Measured at $\top^{\prime}=0^{\circ} \mathrm{C}$ ) | PINT | - | 300 | 525* | mW |
| Internal Input Capacitance $\begin{aligned} &\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}\right.=1.0 \mathrm{MHz}) \\ & E, T \times C L K, R \times C L K \\ & R \end{aligned} \bar{W}, R S, R \times \text { Data, CSO}, C S 1, \overline{C S 2}, \overline{C T S}, \overline{D C D}$ | $\mathrm{Cin}_{\text {in }}$ | - | $\begin{aligned} & 10 \\ & 7.0 \end{aligned}$ | $\begin{gathered} 12.5 \\ 7.5 \end{gathered}$ | pF |
| Output Capacitance  <br> $\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ RTS, Tx Data <br> IRQ  | Cout | - | - | $\begin{aligned} & .10 \\ & 5.0 \end{aligned}$ | pF |

* For temperatures less than $T_{A}=0^{\circ} \mathrm{C}$, PINT maximum will increase.

SERIAL DATA TIMING CHARACTERISTICS

| Characteristic | Symbol | EF6850 |  | EF68A50 |  | EF68B50 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Data Clock Pulse Width, Low $+16,+64 \text { Modes }$ <br> ISee Figure 11 | PW ${ }_{\text {CL }}$ | $\begin{aligned} & 600 \\ & 900 \end{aligned}$ | - | $\begin{aligned} & 450 \\ & 650 \end{aligned}$ | - | $\begin{aligned} & 280 \\ & 500 \end{aligned}$ | - | ns |
| Data Clock Pulse Width, High (See Figure 2) | $\mathrm{PW}_{\text {CH }}$ | $\begin{aligned} & 600 \\ & 900 \end{aligned}$ | - | $\begin{aligned} & 450 \\ & 650 \end{aligned}$ | - | $\begin{aligned} & 280 \\ & 500 \end{aligned}$ | - | ns |
| Data Clock Frequency $\quad \begin{aligned}+16, & +64 \text { Modes } \\ & +1 \text { Mode }\end{aligned}$ | ${ }^{f} \mathrm{C}$ | - | $\begin{aligned} & 0.8 \\ & 500 \end{aligned}$ | - | $\begin{aligned} & 1.0 \\ & 750 \end{aligned}$ | - | $\begin{gathered} 1.5 \\ 1000 \end{gathered}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{kHz} \end{aligned}$ |
| Data Clock-to-Data Delay for Transmitter (See Figure 3) | tTDD | - | 600 | - | 540 | - | 460 | ns |
| Receıve Data Setup Time (See Figure 4) +1 Mode | trDS | 250 | - | 100 | - | 30 | - | ns |
| Receive Data Hold Time (See Figure 5) + 1 Mode | ${ }^{\text {tr }}$ (th | 250 | - | 100 | - | 30 | - | ns |
| Interrupt Request Release Time (See Figure 6) | IIR | - | 1.2 | - | 0.9 | - | 0.7 | $\mu \mathrm{S}$ |
| Request-to-Send Delay Time (See Figure 6) |  | - | 560 | - | 480 | - | 400 | ns |
| Input Rise and Fall Times (or 10\% of the pulse width if smaller) | tr, it | - | 1.0 | - | 0.5 | - | 0.25 | $\mu \mathrm{S}$ |

FIGURE 1 - CLOCK PULSE WIDTH, LOW-STATE


FIGURE 3 - TRANSMIT DATA OUTPUT DELAY


FIGURE 2 - CLOCK PULSE WIDTH, HIGH-STATE


FIGURE 4 - RECEIVE DATA SETUP TIME ( + 1 Mode)


FIGURE 6 - REQUEST-TO-SEND DELAY AND INTERRUPT-REQUEST RELEASE TIMES


[^30]BUS TIMING CHARACTERISTICS (See Notes 1 and 2 and Figure 7)

| Ident. <br> Number | Characteristic | Symbol | EF6850. |  | EF68A50 |  | EF68B50 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }_{\text {t }}$ cyc | 1.0 | 10 | 0.67 | 10 | 0.5 | 10 | $\mu \mathrm{S}$ |
| 2 | Pulse Width, E Low | PW EL. | 430 | 9500 | 280 | 9500 | 210 | 9500 | ns |
| 3 | Pulse Width, E High | PWEH | 450 | 9500 | 280 | 9500 | 220 | 9500 | ns |
| 4 | Clock Rise and Fall Time | $t_{r}, \mathrm{If}_{\text {f }}$ | - | 25 | - | 25 | - | 20 | ns |
| 9 | Address Hold Time | ${ }_{\text {t }}$ AH | 10 | - | 10 | - | 10 | - | ns |
| 13 | Address Setup Time Before E | tAS | 80 | - | 60 | - | 40 | - | ns |
| 14 | Chip Select Setup Time Before E | ${ }^{\text {t }} \mathrm{CS}$ | 80 | - | 60 | - | 40 | - | ns |
| 15 | Chip Select Hold Time | ${ }^{\text {t }} \mathrm{CH}$ | 10 | - | 10 | - | 10 | - | ns |
| 18 | Read Data Hold Time | ${ }^{\text {t }}$ DHR | 20 | $50^{\circ}$ | 20 | $50^{*}$ | 20 | $50^{\circ}$ | ns |
| 21 | Write Data Hold Time | tDHW | 10 | - | 10 | - | 10 | - | ns |
| 30 | Output Data Delay Time | ${ }^{\text {t }}$ DDR | - | 290 | - | 180 | - | 150 | ns |
| 31 | Input Data Setup Time | ${ }^{\text {t }}$ DSW | 165 | - | 80 | - | 60 | - | ns |

-The data bus output buffers are no longer sourcing or sinking current by tDHRmax (High Impedance).

FIGURE 7 - BUS TIMING CHARACTERISTICS


FIGURE 8 - BUS TIMING TEST LOADS
Load A (00.07, $\overline{R T S}, T \times$ Data)


$$
\begin{aligned}
C & =130 \mathrm{pF} \text { for DO D7 } \\
& =30 \mathrm{pF} \text { for } \overline{R T S} \text { and } T \times \text { Data }
\end{aligned}
$$

[^31]

## DEVICE OPERATION

At the bus interface, the ACIA appears as two addressable memory locations. Internally, there are four registers: two read-only and two write-only registers. The read-only registers are Status and Receive Data; the write-only registers are Control and Transmit Data. The serial interface consists of serial input and output lines with independent clocks, and three peripheral/modem control lines.

## POWER ON/MASTER RESET

The master reset (CRO, CR1) should be set during system initialization to insure the reset condition and prepare for programming the ACIA functional configuration when the communications channel is required. During the first master reset, the $\overline{\mathrm{RO}}$ and $\overline{\mathrm{RTS}}$ outputs are held at level 1 . On all other master resets, the $\overline{\text { RTS }}$ output can be programmed high or low with the $\overline{\operatorname{RQ}}$ output held high. Control bits CR5 and CR6 should also be programmed to define the state of $\overline{\text { RTS }}$ whenever master reset is utilized. The ACIA also contains internal power-on reset logic to detect the power line turn-on transition and hold the chip in a reset state to prevent erroneous output transitions prior to initialization. This circuitry depends on clean power turn-on transitions. The
power-on reset is released by means of the bus-programmed master reset which must be applied prior to operating the ACIA. After master resetting the ACIA, the programmable Control Register can be set for a number of options such as variable clock divider ratios, variable word length, one or two stop bits, parity (even, odd, or none), etc.

## TRANSMIT

A typical transmitting sequence consists of reading the ACIA Status Register either as a result of an interrupt or in the ACIA's turn in a polling sequence. A character may be written into the Transmit Data Register if the status read operation has indicated that the Transmit Data Register is empty. This character is transferred to a Shift Register where it is serialized and transmitted from the Transmit Data output preceded by a start bit and followed by one or two stop bits. Internal parity (odd or even) can be optionally added to the character and will occur between the last data bit and the first stop bit. After the first character is written in the Data Register, the Status Register can be read again to check for a Transmit Data Register Empty condition and current peripheral status. If the register is empty, another character can be loaded for transmission even though the first character is in the process of being transmitted (because of
double buffering). The second character will be automatically transferred into the Shift Register when the first character transmission is completed. This sequence continues until all the characters have been transmitted.

## RECEIVE

Data is received from a peripheral by means of the Receive Data input. A divide-by-one clock ratio is provided for an externally synchronized clock (to its data) while the divide-by-16 and 64 ratios are provided for internal synchronization. Bit synchronization in the divide-by-16 and 64 modes is initiated by the detection of 8 or 32 low samples on the receive line in the divide-by- 16 and 64 modes respectively. False start bit deletion capability insures that a full half bit of a start bit has been received before the internal clock is synchronized to the bit time. As a character is being received, parity lodd or even) will be checked and the error indication will be available in the Status Register along with framing error, overrun error, and Receive Data Register full. In a typical receiving sequence, the Status Register is read to determine if a character has been received from a peripheral. If the Receiver Data Register is full, the character is placed on the 8 -bit ACIA bus when a Read Data command is received from the MPU. When parity has been selected for a 7 -bit word ( 7 bits plus parity), the receiver strips the parity bit ( $D 7=0$ ) so that data alone is transferred to the MPU. This feature reduces MPU programming. The Status Register can continue to be read to determine when another character is available in the Receive Data Register. The receiver is also double buffered so that a character can be read from the data register as another character is being received in the shift register. The above sequence continues until all characters have been received.

## INPUT/OUTPUT FUNCTIONS

## ACIA INTERFACE SIGNALS FOR MPU

The ACIA interfaces to the 6800 MPU with an 8 -bit bidirectional data bus, three chip select lines, a register select line, an interrupt request line, read/write line, and enable line. These signals permit the MPU to have complete control over the ACIA.

ACIA Bidirectional Data (D0-D7) - The bidirectional data lines (DO-D7) allow for data transfer between the ACIA and the MPU. The data bus output drivers are three-state devices that remain in the high-impedance (off) state except when the MPU performs an ACIA read operation.

ACIA Enable (E) - The Enable signal, $E$, is a highimpedance TTL-compatible input that enables the bus input/output data buffers and clocks data to and from the ACIA. This signal will normally be a derivative of the EF6800 \$2 Clock or EF6809E clock.

Read/Write ( $\mathbf{R} / \overline{\mathbf{W}}$ ) - The Read/Write line is a highimpedance input that is TTL compatible and is used to control the direction of data flow through the ACIA's input/output data bus interface. When Read/Write is high (MPU Read cycle), ACIA output drivers are turned on and a selected register is read. When it is low, the ACIA output drivers are
turned off and the MPU writes into a selected register. Therefore, the Read/Write signal is used to select read-only or write-only registers within the ACIA.

Chip Select (CS0, CS1, $\overline{\mathbf{C S} 2)}$ - These three highimpedance TTL-compatible input lines are used to address the ACIA. The ACIA is selected when CSO and CS1 are high and $\overline{\mathrm{CS}}$ is low. Transfers of data to and from the ACIA are then performed under the control of the Enable Signal, Read/Write, and Register Select.

Register Select (RS) - The Register Select line is a highimpedance input that is TTL compatible. A high level is used to select the Transmit/Receive Data Registers and a low level the Control/Status Registers. The Read/Write signal line is used in conjunction with Register Select to select the read-only or write-only register in each register pair.

Interrupt Request ( $\overline{\mathrm{RQ}}$ ) - Interrupt Request is a TTLcompatible, open-drain (no internal pullup), active low output that is used to interrupt the MPU. The $\overline{\mathrm{RO}}$ output remains low as long as the cause of the interrupt is present and the appropriate interrupt enable within the ACIA is set. The $\overline{\mathrm{IRO}}$ status bit, when high, indicates the $\overline{\mathrm{RO}}$ output is in the active state.

Interrupts result from conditions in both the transmitter and receiver sections of the ACIA. The transmitter section causes an interrupt when the Transmitter Interrupt Enabled condition is selected (CR5 $\cdot \overline{\mathrm{CR} 6}$ ), and the Transmit Data Register Empty (TDRE) status bit is high. The TDRE status bit indicates the current status of the Transmitter Data Register except when inhibited by Clear-to-Send ( $\overline{\mathrm{CTS}}$ ) being high or the ACIA being maintained in the Reset condition. The interrupt is cleared by writing data into the Transmit Data Register. The interrupt is masked by disabling the Transmitter Interrupt via CR5 or CR6 or by the loss of $\overline{\text { CTS }}$ which inhibits the TDRE status bit. The Receiver section causes an interrupt when the Receiver Interrupt Enable is set and the Receive Data Register Full (RDRF) status bit is high, an Overrun has occurred, or Data Carrier Detect ( $\overline{D C D}$ ) has gone high. An interrupt resulting from the RDRF status bit can be cleared by reading data or resetting the ACIA. Interrupts caused by Overrun or loss of $\overline{D C D}$ are cleared by reading the status register after the error condition has occurred and then reading the Receive Data Register or resetting the ACIA. The receiver interrupt is masked by resetting the Receiver Interrupt Enable.

## CLOCK INPUTS

Separate high-impedance TTL-compatible inputs are provided for clocking of transmitted and received data. Clock frequencies of 1,16 , or 64 times the data rate may be selected.

Transmit Clock (Tx CLK) - The Transmit Clock input is used for the clocking of transmitted data. The transmitter initiates data on the negative transition of the clock.

Receive Clock (RxCLK) - The Receive Clock input is used for synchronization of received data. In the +1 mode, the clock and data must be synchronized externally.) The receiver samples the data on the positive transition of the clock.

## SERIAL INPUT/OUTPUT LINES

Receive Data (R× Data) - The Receive Data line is a highimpedance TTL-compatible input through which data is received in a serial format. Synchronization with a clock for detection of data is accomplished internally when clock rates of 16 or 64 times the bit rate are used.

Transmit Data (Tx Data) - The Transmit Data output line transfers serial data to a modem or other peripheral.

## PERIPHERAL/MODEM CONTROL

The ACIA includes several functions that permit limited control of a peripheral or modem. The functions included are Clear-to-Send, Request-to-Send and Data Carrier Detect.

Clear-to-Send (CTS) - This high-impedance TTLcompatible input provides automatic control of the transmitting end of a communications link via the modem Clear-toSend active low output by inhibiting the Transmit Data Register Empty (TDRE) status bit.

Request-to-Send (ㅈTSS) - The Request-to-Send output enables the MPU to control a peripheral or modem via the data bus. The RTS output corresponds to the state of the Control Register bits CR5 and CR6. When CR6 $=0$ or both CR5 and CR6 $=1$, the $\overline{\text { RTS }}$ output is low (the active state). This output can also be used for Data Terminal Ready (DTR).

Data Carrier Detect ( $\overline{\mathrm{DCD}}$ ) - This high-impedance TTLcompatible input provides automatic control, such as in the receiving end of a communications link by means of a modem Data Carrier Detect output. The $\overline{\mathrm{DCD}}$ input inhibits and initializes the receiver section of the ACIA when high. A low-to-high transition of the Data Carrier Detect initiates an interrupt to the MPU to indicate the occurrence of a loss of carrier when the Receive Interrupt Enable bit is set. The Rx CLK must be running for proper $\overline{\mathrm{DCD}}$ operation.

## ACIA REGISTERS

The expanded block diagram for the ACIA indicates the internal registers on the chip that are used for the status, control, receiving, and transmitting of data. The content of each of the registers is summarized in Table 1.

## TRANSMIT DATA REGISTER (TDR)

Data is written in the Transmit Data Register during the negative transition of the enable (E) when the ACIA has been adidressed with RS high and R/W low. Writing data into the register causes the Transmit Data Register Empty bit in the Status Register to go low. Data can then be transmitted. If the transmitter is idling and no character is being transmitted, then the transfer will take place within 1 -bit time of the trailing edge of the Write command. If a character is being transmitted, the new data character will commence as soon as the previous character is complete. The transfer of data causes the Transmit Data Register Empty (TDRE) bit to indicate empty.

## RECEIVE DATA REGISTER (RDR)

Data is automatically transferred to the empty Receive Data Register (RDR) from the receiver deserializer (a shift register) upon receiving a complete character. This event causes the Receive Data Register Full bit (RDRF) in the status buffer to go high (full). Data may then be read through the bus by addressing the ACIA and selecting the Receive Data Register with RS and R/W high when the ACIA is enabled. The non-destructive read cycle causes the RDRF bit to be cleared to empty although the data is retained in the RDR. The status is maintained by RDRF as to whether or not the data is current. When the Receive Data Register is full, the automatic transfer of data from the Receiver Shift Register to the Data Register is inhibited and the RDR contents remain valid with its current status stored in the Status Register.

TABLE 1 - DEFINITION OF ACIA REGISTER CONTENTS

| Data <br> Bus <br> Line <br> Number | Buffer Address |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | RS • R/W <br> Transmit Data <br> Register | RS • R/W <br> Receive <br> Data <br> Register | $\overline{\mathrm{RS}} \cdot \overline{\mathrm{R} \bar{W}}$ <br> Control <br> Register | $\overline{\mathrm{RS}} \bullet \mathrm{R} / \overline{\mathrm{W}}$ <br> Status <br> Register |
|  | (Write Only) | (Read Only) | (Write Only) | (Read Only) |
| 0 | Data Bit $0^{*}$ | Data Bit 0 | Counter Divide <br> Select 1 (CRO) | Receive Data Register Full (RDRF) |
| 1 | Data Bit 1 | Data Bit 1 | Counter Divide Select 2 (CR1) | Transmit Data Register Empty (TDRE) |
| 2 | Data Bit 2 | Data Bit 2 | Word Select 1 (CR2) | Data Carrier Detect (DCD) |
| 3 | Data Bit 3 | Data Bit 3 | Word Select 2 (CR3) | Clear to Send ( $\overline{\mathrm{CTS}}$ ) |
| 4 | Data Bit 4 | Data Bit 4 | Word Select 3 (CR4) | Framing Error (FE) |
| 5 | Data Bit 5 | Data Bit 5 | Transmit Control 1 (CR5) | Receiver Overrun (OVRN) |
| 6 | Data Bit 6 | Data Bit 6 | Transmit Control 2 (CR6) | Paritv Error (PE) |
| 7 | Data Bit $7 \cdots$ | Data Bit $7 \cdots$ | Receive Interrupt Enable (CR7) | $\begin{aligned} & \text { Interrupt Request } \\ & \text { (IRQ) } \end{aligned}$ |

- Leading bit $=$ LSB $=8$ it 0
... Data bit will bezero in 7 bit plus parity modes
.. Data bit is "don't care" in 7 bit plus parity modes.


## CONTROL REGISTER

The ACIA Control Register consists of eight bits of writeonly buffer that are selected when RS and R/W are low. This register controls the function of the receiver, transmitter, interrupt enables, and the Request-to-Send peripheral/modem control output.

Counter Divide Select Bits (CR0 and CR1) - The Counter Divide Select Bits (CRO and CR1) determine the divide ratios utilized in both the transmitter and receiver sections of the ACIA. Additionally, these bits are used to provide a master reset for the ACIA which clears the Status Register (except for external conditions on $\overline{\mathrm{CTS}}$ and $\overline{\mathrm{DCD}}$ ) and initializes both the receiver and transmitter. Master reset does not affect other Control Register bits. Note that after power-on or a power fail/restart, these bits must be set high to reset the ACIA. After resetting, the clock divide ratio may be selected. These counter select bits provide for the following clock divide ratios:

| CR1 | CR0 | Function |
| :---: | :---: | :---: |
| 0 | 0 | +1 |
| 0 | 1 | +16 |
| 1 | 0 | +64 |
| 1 | 1 | Master Reset |

Word Select Bits (CR2, CR3, and CR4) - The Word Select bits are used to select word length, parity, and the number of stop bits. The encoding format is as follows:

| CR4 | CR3 | CR2 | Function |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 7 Bits + Even Parity +2 Stop Bits |
| 0 | 0 | 1 | 7 Bits + Odd Parity + 2 Stop Bits |
| 0 | 1 | 0 | 7 Bits + Even Parity + 1 Stop Bit |
| 0 | 1 | 1 | 7 Bits + Odd Parity + 1 Stop Bit |
| 1 | 0 | 0 | 8 Bits + 2 Stop Bits |
| 1 | 0 | 1 | 8 Bits + Stop Bit |
| 1 | 1 | 0 | 8 Bits + Even parity + 1 Stop Bit |
| 1 | 1 | 1 | 8 Bits + Odd Parity + 1 Stop Bit |

Word length, Parity Select, and Stop Bit changes are not buffered and therefore become effective immediately.

Transmitter Control Bits (CR5 and CR6) - Two Transmitter Control bits provide for the control of the interrupt from the Transmit Data Register Empty condition, the Request-toSend ( $\overline{\mathrm{TTS}}$ ) output, and the transmission of a Break level (space). The following encoding format is used:

| CR6 | CR5 | Function |
| :---: | :---: | :--- |
| 0 | 0 | $\overline{R T S}=$ low, Transmitting Interrupt Disabled. |
| 0 | 1 | $\overline{\operatorname{RTS}}=$ low, Transmitting Interrupt Enabled. |
| 1 | 0 | $\overline{\mathrm{RTS}}=$ high, Transmitting Interrupt Disabled. |
| 1 | 1 | $\overline{\mathrm{RTS}}=$ low, Transmits a Break level on the <br> Transmit Data Output. Transmitting Inter- <br> rupt Disabled. |

Receive Interrupt Enable Bit (CR7) - The following interrupts will be enabled by a high level in bit position 7 of the Control Register (CR7): Receive Data Register Full, Overrun, or a low-to-high transition on the Data Carrier Detect ( $\overline{\mathrm{DCD}}$ ) signal line.

## STATUS REGISTER

Information on the status of the ACIA is available to the MPU by reading the ACIA Status Register. This read-only register is selected when RS is low and $R / W$ is high. Information stored in this register indicates the status of the Transmit Data Register, the Receive Data Register and error logic, and the peripheral/modem status inputs of the ACIA.

Receive Data Register Full (RDRF), Bit 0 - Receive Data Register Full indicates that received data has been transferred to the Receive Data Register. RDRF is cleared after an MPU read of the Receive Data Register or by a master reset. The cleared or empty state indicates that the contents of the Receive Data Register are not current. Data Carrier Detect being high also causes RDRF to indicate empty.

Transmit Data Register Empty (TDRE), Bit 1 - The Transmit Data Register Empty bit being set high indicates that the Transmit Data Register contents have been transferred and that new data may be entered. The low state indicates that the register is full and that transmission of a new character has not begun since the last write data command.

Data Carrier Detect ( $\overline{\mathrm{DCD}}$ ), Bit 2 - The Data Carrier Detect bit will be high when the DCD input from a modem has gone high to indicate that a carrier is not present. This bit going high causes an Interrupt Request to be generated when the Receive Interrupt Enable is set. It remains high after the $\overline{\mathrm{DCD}}$ input is returned low until cleared by first reading the Status Register and then the Data Register or until a master reset occurs. If the $\overline{\mathrm{DCD}}$ input remains high after read status and read data or master reset has occurred, the interrupt is cleared, the $\overline{\mathrm{DCD}}$ status bit remains high and will follow the $\overline{\mathrm{DCD}}$ input.

Clear-to-Send ( $\overline{\text { CTS }}$ ), Bit 3 - The Clear-to-Send bit indicates the state of the Clear-to-Send input from a modem. A low $\overline{\mathrm{CTS}}$ indicates that there is a Clear-to-Send from the modem. In the high state, the Transmit Data Register Empty bit is inhibited and the Clear-to-Send status bit will be high. Master reset does not affect the Clear-to-Send status bit.

Framing Error (FE), Bit 4 - Framing error indicates that the received character is improperly framed by a start and a stop bit and is detected by the absence of the first stop bit. This error indicates a synchronization error, faulty transmission, or a break condition. The framing error flag is set or reset during the receive data transfer time. Therefore, this error indicator is present throughout the time that the associated character is available.

Receiver Overrun (OVRN), Bit 5 - Overrun is an error flag that indicates that one or more characters in the data stream were lost. That is, a character or a number of characters were received but not read from the Receive Data Register (RDR) prior to subsequent characters being received. The overrun condition begins at the midpoint of the last bit of the second character received in succession without a read of the RDR having occurred. The Overrun does not occur in the Status Register until the valid character prior to Overrun has
been read. The RDRF bit remains set until the Overrun is reset. Character synchronization is maintained during the Overrun condition. The Overrun indication is reset after the reading of data from the Receive Data Register or by a Master Reset.

Parity Error (PE), Bit 6 - The parity error flag indicates that the number of highs (ones) in the character does not agree with the preselected odd or even parity. Odd parity is defined to be when the total number of ones is odd. The parity error indication will be present as long as the data
character is in the RDR. If no parity is selected, then both the transmitter parity generator output and the receiver partiy check results are inhibited.

Interrupt Request (IRQ), Bit 7 - The $\overline{\operatorname{RRO}}$ bit indicates the state of the IRQ output. Any interrupt condition with its ap plicable enable will be indicated in this status bit. Anytime the $\overline{\mathrm{IRO}}$ output is low the $\overline{\mathrm{IRQ}}$ bit will be high to indicate the interrupt or service request status. $\overline{\mathrm{RQ}}$ is cleared by a read operation to the Receive Data Register or a write operation to the Transmit Data Register

ORDERING INFORMATION


Examples: EF6850C, EF6850CV, EF6850CM, EF6850JM
Package : C : Ceramic DIL, J : Cerdip DIL, P : Plastic DIL, E : LCCC, FN : PLCC.
Oper. temp. : $\mathrm{L}^{*}$ : $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}:-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{M}:-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C},{ }^{*}$ : may be omitted.
Screening level : Std : (no-end suffix), D: NFC 96883 level D,
G/B : NFC 96883 level G, B/B : NFC 96883 level B and MIL-STD-883C level B.


P SUFFIX PLASTIC PACKAGE


C SUFFIX CERAMIC PACKAGE


JSUFFIX
CERDIP PACKAGE

## PHYSICAL DIMENSIONS

CB-520


FN SUFFIX
PLCC 28



The EF6854 ADLC performs the complex MPU/data communica tion link function for the "Advanced Data Communication Control Procedure" (ADCCP), High-Level Data-Link Control (HDLC) and Synchronous Data-Link Control (SDLC) standards. The ADEC provides key interface requirements with improved software efficiency. The ADLC is, designed to provide the data communications interface for both primary and secondary stations in stand-alone, polling, and loop configurations.

- 6800 Compatible
- Protocol Features
- Automatic Flag Detection and Synchronization
- Zero Insertion and Deletion
- Extendable Address, Control and Logical Control Fields (Optional)
- Variable Word Length Information Field - 5-, 6-, 7-, or 8-Bits
- Automatic Frame Check Sequence Generation and Check
- Abort Detection and Transmision
- Idle Detection and Transmission
- Loop Mode Operation
- Loop Back Self-Test Mode
- NRZ/NRZI Modes
- Quad Data Buffers for Each Rx and Tx
- Prioritized Status Register (Optional)
- MODEM/DMA/Loop Interface
- Three available versions : EF6854 (1.0 MHz)

$$
\begin{array}{ll}
\text { EF68A54 } & (1.5 \mathrm{MHz}) \\
\text { EF68B54 } & (2.0 \mathrm{MHz})
\end{array}
$$

## MOS

(N-CHANNEL, SILICON GATE)

## ADVANCED DATA-LINK <br> CONTROLLER



PIN ASSIGNMENT


MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range |  |  |  |
| EF6854, EF68A54, E F68B54 | $\mathrm{T}_{\mathrm{A}}$ | $\left(\mathrm{T}_{\mathrm{L}}\right.$ to $\left.\mathrm{T}_{\mathrm{H}}\right)$ <br> 0 to 70 <br> EF6854, EF68A54, | ${ }^{\circ} \mathrm{C}$ |
| EF68B54: V suffix |  | -40 to 85 <br> EF6854, EF68A54 : M suffix |  |
| Storage Temperature Range | $\mathrm{T}_{\text {Stg }}$ | -55 to +125 |  |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this highimpedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level le.g., either $\vee_{S S}$ or $V_{C C}$ ).

## THERMAL CHRACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Plastic | OJA | 115 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic |  | 60 |  |
| Cerdip |  | 65 |  |
| PLCC |  | 100 |  |

FIGURE 1 - ADLC GENERAL BLOCK DIAGRAM


## POWER CONSIDERATIONS

The average chip-junction temperature, $T_{J}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
T_{J}=T_{A}+\left(P_{D} \bullet \theta J A\right)
$$

Where:
$T_{A}=$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta J A=$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
$P_{D}=P$ INT + PPORT
$P_{\text {INT }}=I_{C C} \times V_{C C}$, Watts - Chip Internal Power
PPORT $=$ Port Power Dissipation, Watts - User Determined
For most applications PPORT < PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between $P_{D}$ and $T_{J}$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K+\left(T J+273^{\circ} C\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
\mathrm{K}=\mathrm{PD}^{\bullet}\left(\mathrm{T}_{\mathrm{A}}+273^{\circ} \mathrm{C}\right)+\theta \mathrm{JA} \bullet \mathrm{PD}^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Usins this value of $K$ the values of $P_{D}$ and $T J$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$ unless otherwise noted)

| Characteristic |  | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage |  | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {SS }}+2.0$ | - | -- | V |
| Input Low Voltage |  | $\mathrm{V}_{\text {IL }}$ | - | - | VSS +0.8 | V |
| Input Leakage Current $\left(\mathrm{V}_{\text {in }}=0\right.$ to 5.25 V$)$ All Inputs Except D0-D7 <br> Hi-Z (Off-State) Input Current DO-D7 <br> $\left(\mathrm{V}_{\text {in }}=0.4\right.$ to $\left.2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right)$  |  | lin | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
|  |  | İZ | - | 2.0 | 10 | $\mu \mathrm{A}$ |
| dc Output High Voltage  <br> (/Load $=-205 \mu \mathrm{~A}$ ) D0-D7 <br> (V Load $=-100 \mu \mathrm{~A}$ ) All Others |  | VOH | $\begin{aligned} & v_{S S}+2.4 \\ & v_{S S}+2.4 \end{aligned}$ | - | - | V |
| dc Output Low Voltage ( I_oad $\left.^{\text {a }} 1.6 \mathrm{~mA}\right)$ ) |  | VOL | - | - | VSS +0.4 | V |
| Output Leakage Current (Off State) $(\mathrm{V} \mathrm{OH}=2.4 \mathrm{~V}) \quad$ TRQ |  | IOZ | - | 1.0 | 10 | $\mu \mathrm{A}$ |
| Internal Power Dissipation (measured at $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ ) |  | PINT | - | - | 850* | mW |
| $\begin{aligned} & \text { Capacitance } \\ & \left(\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \end{aligned}$ | DO-D7 <br> All Other Inputs | $\mathrm{Cin}_{\text {in }}$ | - | - | $\begin{gathered} 12.5 \\ 7.5 \end{gathered}$ | pF |
|  | $\overline{\operatorname{RDO}}$ <br> All Others | $\mathrm{C}_{\text {cut }}$ | - | - | $\begin{gathered} 5.0 \\ 10 \end{gathered}$ | pF |

*For temperatures below $0^{\circ} \mathrm{C}$, PINT will increase.
AC ELECTRICAL CHARACTERISTICS $\operatorname{V} V_{C C}=5.0 \vee \pm 5 \%, V_{S S}=0, T_{A}=T_{L}$ to $T_{H}$ unless otherwise noted)

| Characteristic | Symbol | EF6854 |  | EF68A54 |  | EF68B54 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Clock Pulse Width, Low (RxC, TxC) | PW ${ }_{\text {CL }}$ | 700 | - | 450 | - | 280 | - | ns |
| Clock Pulse Width, High ( $\mathrm{AxC}, \mathrm{T} \times \mathrm{C}$ ) | PW $\mathrm{CH}^{\text {P }}$ | 700 | - | 450 | - | 280 | - | ns |
| Serial Clock Frequency ( $\mathrm{R} \times \mathrm{C}, \mathrm{T} \times \mathrm{C}$ ) | ${ }_{\text {f }} \mathrm{SC}$ | - | 0.66 | - | 1.0 | - | 1.5 | MHz |
| Receive Data Setup Time | trDSU | 150 | - | 100 | - | 50 | - | ns |
| Receive Data Hold Time | trDH | 60 | - | 60 | - | 60 | - | ns ${ }^{\text { }}$ |
| Request-to-Send Delay Time | tRTS | - | 680 | - | 460 | - | 340 | ns |
| Clock-to-Data Delay for Transmitter | tTDD | -- | 300 | - | 250 | - | 200 | ns |
| Flag Detect Delay Time | tFD | - | 680 | - | 460 | - | 340 | ns |
| DTR Delay Time | tDTR | - | 680 | - | 460 | - | 340 | ns |
| Loop On-Line Control Delay Time | toc | - | 680 | - | 460 | - | 340 | ns |
| RDSR Delay Time | trDSR | - | 540 | - | 400 | - | 340 | ns |
| TDSR Delay Time | tTDSR | - | 540 | - | 400 | - | 340 | ns |
| Interrupt Request Release Time | IR | - | 1.2 | - | 0.9 | - | 0.7 | $\mu \mathrm{S}$ |
| RESET Pulse Width | ${ }^{\text {t RESET }}$ | 1.0 | - | 0.65 | - | 0.40 | - | $\mu \mathrm{S}$ |
| Input Rise and Fall Times (Except Enable) (0.8 V to 2.0 V ) | $\mathrm{t}_{\mathrm{r}}, \mathrm{tf}_{f}$ | - | $1.0^{*}$ | - | $1.0^{*}$ | - | $1.0^{*}$ | $\mu \mathrm{S}$ |

[^32]FIGURE 2 - BUS TIMING TEST LOADS


FIGURE 3 - RECEIVER DATA SETUP/HOLD, FLAG DETECT AND LOOP ON-LINE CONTROL DELAY TIMING


FIGURE 4 - TRANSMIT DATA OUTPUT DELAY AND REQUEST-TO-SEND DELAY TIMING


NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted.

FIGURE 5 - TDSR/RDSR DELAYS, $\overline{\operatorname{Ro}}$ 人 RELEASE DELAY, $\overline{\operatorname{RTS}}$ AND $\overline{\text { DTR }}$ DELAY TIMING


NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted
BUS TIMING CHARACTERISTICS (See Notes 1 and 2)

| Ident. | Characteristics | Symbol | EF6854 |  | EF68A54 |  | EF68B54 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Number |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Cycle Time | ${ }^{\text {t }}$ cyc | 1.0 | 10 | 0.67 | 10 | 0.5 | 10 | $\mu \mathrm{S}$ |
| 2 | Pulse Width, E Low | PWEL | 430 | 9500 | 280 | 9500 | 210 | 9500 | ns |
| 3 | Pulse Width, E High | PWEH | 450 | 9500 | 280 | 9500 | 220 | 9500 | ns |
| 4 | Clock Rise and Fall Time | $\mathrm{tr}_{\mathrm{r}}, \mathrm{tf}^{\text {f }}$ | - | 25 | - | 25 | - | 20 | ns |
| 9 | Address Hold Time | ${ }_{\text {t }} \mathrm{AH}$ | 10 | - | 10 | - | 10 | - | ns |
| 13 | Address Setup Time Before E | tas | 80 | - | 60 | - | 40 | - | ns |
| 14 | Chip Select Setup Time Before E | t CS | 80 | - | 60 | - | 40 | - | ns |
| 15 | Chip Select Hold Time | ${ }^{1} \mathrm{CH}$ | 10 | - | 10 | - | 10 | - | ns |
| 18 | Read Data Hold Time | tDHR | 20 | $50^{*}$ | 20 | $50^{*}$ | 20 | $50^{\circ}$ | ns |
| 21 | Write Data Hold Time | to ${ }^{\text {d }}$ | 10 | - | 10 | - | 10 | - | ns |
| 30 | Output Data Delay Time | t DDR | - | 290 | - | 180 | - | 150 | ns |
| 31 | Input Data Setup Time | tDSW | 165 | - | 80 | - | 60 | - | ns |

- The data bus output buffers are no longer sourcing or sinking current by tDHRmax (High Impedance).

FIGURE 6 - BUS TIMING


## FRAME FORMAT

The ADLC transmits and receives data (information or control) in a format called a frame. All frames start with an opening flag ( $F$ ) and end with a closing filag ( $F$ ). Between the
opening flag and closing flag, a frame contains an address field, control field, information field (optional) and frame check sequence field.

FIGURE 7 - DATA FORMAT OF A FRAME


Flag (F) - The flag is the unique binary pattern (01111110). It provides the frame boundary and a reference for the position of each field of the frame.

The ADLC transmitter generates a flag pattern internally and the opening flag and closing flags are appended to a frame automatically. Two successive frames can share one flag for a closing flag of the first frame and for the opening flag of the next frame, if the "FF" /"F" control bit in the control register is reset.

The receiver searches for a flag on a bit-by-bit basis and recognizes a flag at any time. The receiver establishes the frame synchronization with every flag. The flags mark the frame boundary and reference for each field but they are not transferred to the Rx FIFO. The detection of a flag is indicated by the Flag Detect output and by a status bit in the status register.

Order of Bit Transmission - Address, control and information field bytes are transferred between the MPU and the , ADLC in parallel by means of the data bus. The bit on DO (data bus bit 0 , pin 22) is serially transmitted first, and the first serially received bit is transferred to the MPU on DO. The FCS field is transmitted and received MSB first.

Address (A) Field - The 8 bits following the opening flag are the address ( $A$ ) field. The $A$-field can be extendable if the Auto-Address Extend Mode is selected in control register $\$ 3$. In the Address Extend Mode, the first bit (bit 0 ) in every address octet becomes the extend control bit. When the bit is " 0 ", the ADLC assumes another address octet will follow, and when the bit is " 1 ", the address extension is terminated. A "null" address (all " 0 ' $s$ ") does not extend. In the receiver, the Address Present status bit distinguishes the address field from other fields. When an address byte is available to be read in the receive FIFO register, the Address Present status bit is set and causes an interrupt (if enabled). The Address Present bit is set for every address octet when the Address Extend Mode is used.

Control (C) Field - The 8 bits following the address field is the control (link control) field. When the Extended Control Field bit in control register $\# 3$ is selected, the C -field is extended to 16 bits.

Information (1) Field - The I-field follows the C-field and precedes the FCS field. The 1 -field contains "data" to be transferred but is not always necessarily contained in every frame. The word length of the 1 -field can be selected from 5 to 8 bits per byte by control bits in control register \#4. The $l$-field will continue until it is terminated by the FCS and closing flag. The receiver has the capability to handle a "partial" last byte. The last information byte can be any word length between 1 and 8 bits. If the last byte in the 1 -field is less than the selected word length, the receiver will right justify the received bits, fill the remaining bits of the receiver shift register with zeros, and transfer a full byte to the Rx FIFO. Regardless of selected byte iength, the ADLC will transfer 8 bits of data to the data bus. Unused bits for word lengths of 5,6 and 7 will be zeroed.

Logical Control (LCi Field - When the Logical Control Field Select bit, in control register $\# 3$, is selected the ADLC separates the $l$-field into two sub-fields. The first sub-field is the Logical Controi fieid and the following sub-field is the "data" portion of the 1 -field. The logical control field is 8 bits and follows the C-field, which is extendable by octets, if it is selected. The last bit (bit 7) is the extend control bit, and if it is a " 1 ", the LC-field is extended one octet.

## NOTE

Hereafter the word "Information field" or " $I$-field" is used as the data portion of the information field, and excludes the logical control field. This is done in order to keep the consistency of the meaning of "Information field" as specified in SDLC, HDLC, and ADCCP standards.

Frame Check Sequence (FCS) Field - The 16 bits preceding the closing flag is the FCS field. The FCS is the "cyclic redundancy check character (CRCC)." The polynomial $x^{16}+x^{12}+x^{5}+1$ is used both for the transmitter and receiver. Both the transmitter and receiver polynomial registers are initialized to all " 1 ' $s$ " prior to calculation of the FCS. The transmitter calculates the FCS on all bits of the address, control, logical control (if selected), and information fields, and transmits the complement of the resulting remainder as FCS. The receiver performs the similar computation on all bits of the address, control, logical control lif selected), information, and received FCS fields and compares the result to FOB8 (Hexadecimal). When the result matches FOB8, the Frame Valid status bit is set in the status register. If the result does not match, the Error status bit is set. The FCS generation, transmission, and checking are performed automatically by the ADLC transmitter and receiver. The FCS field is not transferred to the Rx FIFO.

Invalid Frame - Any valid frames should have at least the A-field, C-field, and FCS field between the opening flag and - the closing flag. When invalid frames are received, the ADLC handles them as follows:

1. A short frame which has less than 25 bits between flags - the ADLC ignores the short frame and its reception is not reported to the MPU.
2. A frame less than 32 bits between the flags, or a frame 32 bits or more with an extended A-field or C-field that is not completed. - This frame is transferred into the Rx FIFO. The FCS/IF Error status bit indicates the reception of the invalid frame at the end of the frame.
3. Aborted Frame - The frame which is aborted by receiving an abort or DCD failure is also an invalid frame. Refer to "Abort" and "DCD status bit".

Zero Insertion and Zero Deletion - The Zero insertion and deletion, which allows the content of the frame to be transparent, are performed by the ADLC automatically. A binary 0 is inserted by the transmitter after any succession of five " 1 's" within a frame (A, C, LC, I, and FCS field). The receiver deletes a binary 0 that follows successive five continuous " 1 ' $s$ " within a frame.

Abort - The function of prematurely terminating a data link is called "abort." The transmitter aborts a frame by sending at least eight consecutive " 1 's" immediately after the Tx Abort control bit in control register $\# 4$ is set to a " 1 ". ( Tx FIFO is also cleared by the Tx Abort control bit at the same time.) The abort can be extended up to (at least) 16 consecutive " 1 's", if the Abort Extend control bit in the control register $\# 4$ is set when an abort is sent. This feature is useful to force mark idle transmission. Reception of seven or more consecutive " 1 ' s " is interpreted as an abort by the receiver. The receiver responds to a received abort as follows:

1. An abort in an "out of frame" condition - an abort during the idle or time fill has no meaning. The abort reception is indicated in the status register as long as the abort condition continues; but neither an interrupt nor a stored condition occurs. The abort indication disappears after 15 or more consecutive " 1 's" are received (Received Idie status is set.)
2. An abort "in frame" after less than 26 bits are received after an opening flag - under this condition, any field
of the aborted frame has not transferred to the MPU yet. The ADLC clears the aborted frame data in the FIFO and clears flag synchronization. Neither an interrupt nor a stored status occurs. The status indication is the same as (1) above.
3. An abort "in frame" after 26 bits or more are received after an opening flag - under this condition, some fields of the aborted frame might have been transferred onto the data bus. The abort status is stored in the receiver status register and the data of the aborted frame in the ADLC is cleared. The synchronization is also cleared.

Idle and Time Fill - When the transmitter is in an "out of frame" condition (the transmitter is not transmitting a frame), it is in an idle state. Either a series of contiguous flags (time fill) or a mark idle (consecutive " 1 's" on a bit-by-bit basis) is selected for the transmission in an idle state by the Flag/Mark Idle control bit. When the receiver receives 15 or more consecutive " 1 ' $s$ ", the Receive Idie status bit is set and causes an interrupt. The flags and mark idle are not transferred to the RX FIFO.

## OPERATION

## INITIALIZATION

During a power-on sequence, the ADLC is reset via the RESET input and internally latched in a reset condition to prevent erroneous output transitions. The four control registers must be programmed prior to the release of the reset condition. The release of the reset condition is performed via software by writing a " 0 " into the Rx RS control bit (receiver) and/or Tx RS control bit (transmitter). The release of the reset condition must be done after the $\overline{\text { RESET }}$ input has gone high.

At any time during operation, writing a " 1 " into the Rx RS control bit or Tx RS control bit causes the reset condition of the receiver or the transmitter.

## TRANSMITTER OPERATION

The TX FIFO register cannot be pre-loaded when the transmitter is in a reset state. After the reset release, the Flag/Mark Idle control bit selects either the mark idle state (inactive ide) or the Flag "time fill" (active idle) state. This active or inactive mark idle state will continue until data is loaded into the TX FIFO.
The availability of the Tx FIFO is indicated by the TDRA status bit under the control of the 2-Byte/1-Byte control bit. TDRA status is inhibited by the Tx RS bit or CTS input being high. When the 1 -Byte mode is selected, one byte of the FIFO is available for data transfer when TDRA goes high. When the 2-Byte mode is selected, two successive bytes can be transferred when TDRA goes high.

The first byte (Address field) should be written into the TX FIFO at the "Frame Continue" address. Then the transmission of a frame automatically starts. If the transmitter is in a mark idle state, the transfer of an address causes an opening flag within two or three transmitter clock cycles. If the transmitter has been in a time fill state, the current time fill flag being transmitted is assumed as an opening flag and the address field will follow it.


$\therefore$ frame continues as long as data is written into the $T x$ FIFO, it the "Frame Continue" address. The ADLC internally kegns track of the field sequence in the frame. The frame format is described in the "FRAME FORMAT" section.

The frame is terminated by one of two methods. The most efficien: way to terminate the frames from a software standpol ${ }^{+}$is to write the last data character into the Transmit ㄷF.. "rame Terminate" address (RS1, RSO=11) rather thaI. the Transmit FIFO "Frame Continue" address (RS1, MS $C=10$ ). An alternate method is to follow the last write of Gista in the Tx FIFO "Frame Continue" address with the seting if the Transmit Last Data control bit. Either method
causes the last character to be transmitted and the FCS field to automatically be appended along with a closing flag. Data for a new frame can be loaded into the Tx FIFO immediately after the old frame data, if TDRA is high. The closing Flag can serve as the opening Flag of the next frame or separate opening and closing Flags may be transmitted. If a new frame is not ready to be transmitted, the ADLC will automatically transmit the Active (Flag) or Inactive (Mark) Idle condition.

If the Tx FIFO becomes empty at any time during frame transmission (the FIFO has no data to transfer into transmitter shift register during transmission of the last half of the
next to last bit of a word), an underrun will occur and the transmitter automatically terminates the frame by transmitting an abort. The underrun state is indicated by the Tx Underrun status bit.
Any time the Tx ABORT Control bit is set, the transmitter immediately aborts the frame (transmits at least 8 consecutive " 1 's") and clears the Tx FIFO. If the Abort Extend Control bit is set at the time, an idle lat least 16 consecutive " 1 ' $s$ ") is transmitted. An abort or idle in an "out of frame" condition can be useful to gain 8 or 16 bits of delay. (For an example, see "Programming Considerations.")

The CTS (Clear-to-Send) input and $\overline{\text { RTS }}$ (Request-toSend) output are provided for a MODEM or other hardware interface.
The TDRA/FC status bit (when selected to be Frame Complete Status) can cause an interrupt upon frame completion (i.e., a flag or abort completion).

Details regarding the inputs and outputs, status bits, control bits, and FIFO operation are described in their respective sections.

## RECEIVER OPERATION

Data and a pre-synchronized clock are provided to the ADLC receiver section by means of the Receive Data (RxD) and Receive Clock ( $\mathrm{R} \times \mathrm{C}$ ) inputs. The data is a continuous stream of binary bits with the characteristic that a maximum of five " 1 ' $s$ " can occur in succession unless Abort, Flag, or Idling condition occurs. The receiver continuously (on a bit-by-bit basis) searches for Flags and Aborts.
When a flag is detected, the receiver establishes frame synchronization to the flag timing. If a series of flags is received, the receiver resynchronizes to each flag.
If the frame is terminated before the internal buffer time expires (the frame data is less than 25 bits after an opening flag), the frame is simply ignored. Noise on the data input ( XxD ) during time fill can cause this kind of invalid frame.

The received serial data enters a 32-bit shift register (clocked by RxC ) before it is transferred into the Rx Data FIFO. Synchronization is established when a Flag is detected in the first eight locations of the shift register. Once synchronization has been achieved, data is clocked through to the last byte location of the shift register where it is transferred byte-per-byte into the Rx Data FIFO. The Rx Data FIFO is clocked by E to cause received data to move through the FIFO to the last empty register location. The Receiver Data Available status bit (RDA) indicates when data is present in the last register (Register \#3) for the 1-Byte Transfer Mode. The 2-Byte Transfer Mode causes the RDA status bit to indicate data is available when the last two FIFO register locations (Registers $\# 2$ and $\# 3$ ) are full. If the data character present in the FIFO is an address octet, the status register will exhibit an Address Present status condition. Data being available in the Rx Data FIFO causes an interrupt to be initiated (assuming the receiver interrupt is enabled, RIE=" 1 "). The MPU will read the ADLC Status Register as a result of the interrupt or in its turn in a polling sequence. RDA or Address Present will indicate that receiver data is available and the MPU should subsequently read the Rx Data FIFO register. The interrupt and status bit will then be reset automatically. If more than one character had been received and was resident in the Rx Data FIFO, subsequent E clocks will cause the FIFO to update and the RDA status bit and interrupt will again be SET. In the 2-Byte Transfer Mode both data bytes may be
read on consecutive E cycles. Address Present provides for 1 byte transfers only.
The sequence of each field in the received frame is automatically handled by the ADLC. The frame format is described in the "FRAME FORMAT" section.
When a closing flag is received, the frame is terminated. The 16 bits preceding the closing flag are regarded as the FCS and are not transferred to the MPU. Whatever data is present in the most-significant byte portion of the receiver buffer register it is right justified and transferred to the Rx FIFO. The frame boundary pointer, which is explained in the "RX FIFO REGISTER" section, is set simultaneously in the Rx FIFO. The frame boundary pointer sets the Frame Valid status bit (when the frame was completed with no error) or the FCS/IF Error Status bit (when the frame was completed with error) when the last byte of the frame appears at the last location of the Rx FIFO. As long as the Frame Valid or FCS/IF Error status bit is set, the data transfer from the second location of the Rx FIFO to the last location of the Rx FIFO is inhibited.
Any time the Frame Discontinue control bit is set, the ADLC discards the current frame data in the ADLC without dropping flag synchronization. This feature can be used to ignore a frame which is addressed to another station.
The reception of an abort or idle is explained in the "FRAME FORMAT" section. The details regarding the inputs, outputs, status bits, control bits, and Rx FIFO operation are described in their respective sections.

## LOOP MODE OPERATION

The ADLC in the loop mode, not only performs the transmission and receiving of data frames in the manner previously described, but also has additional features for gaining and relinquishing loop control. In Figure 9a, a configuration is shown which depicts loop mode operation. The system configuration shows a primary station and several secondary stations. The loop is always under control of the primary station. When the primary wants to receive data, it transmits a Poll sequence and allows frame transmission to secondary stations on the loop. Each secondary is in series and adds one bit of delay to the loop. Secondary A in the figure receives data from the primary via its Rx Data Input, delays the data 1 bit, and transmits it to secondary B via its Tx Data Output. Secondaries B, C, and D operate in a similar manner. Therefore, data passes through each secondary and is received back by the primary controller.
Certain protocol rules must be followed in the manner by which the secondary station places itself on-loop (connects its transmitter output to the loopl, goes active on the loop (starts transmitting its own station's data on the loop), and goes off the loop (disconnects its transmitter output). Otherwise loop data to other stations down loop would be interfered. The data stream always flows the same way and the order in which secondary terminals are serviced is determined by the hardware configuration. The primary controller times the delay through the loop. Should it exceed $n+1$ bit times, where $n$ is the number of secondary terminals on the loop, it will indicate a loop failure. Control is transferred to a secondary by transmitting a "Go Ahead" signal following the Glosing Flag of a polling frame (request for a response from the secondary) from the primary station. The "Go Ahead" from the primary is a " 0 " and seven " 1 ' $s$ " followed by mark


FIGURE 9 b - EXAMPLE OF EXTERNAL LOOP LOGIC

idling. The primary can abort its response request by interrupting its idle with flags. The secondary should immediately stop transmission and return control back to the primary. When the secondary completes its frame, a closing flag is transmitted followed by all " 1 's". The primary detects the final 01111111...("Go Ahead" to the primary) and control is given back to the primary. Note that, if a down-loop secondary (e.g., station D) needs to insert information following an up-loop station (e.g., station A), the go ahead to station $D$ is the last " 0 " of the closing flag from station $A$ followed by " 1 's".
The ADLC in the primary station should operate in a nonloop full-duplex mode. The ADLC in the secondaries should operate in a loop mode, monitoring up-loop data on its receiver data input. The ADLC can recognize the necessary sequences in the data stream to automatically go on/off the loop and to insert its own station data. The procedure is the following and is summarized in Table 1.
(1) Go On-Loop - When the ADLC powers up, the terminal station will be off line. The first task is to become an active terminal on the loop. The ADLC must be connected to a Loop Link via an external switch as shown in Figure 9a. After a hardware reset, the ADLC $\overline{L O C} / \overline{D T R}$ Output will be in the high state and the up-loop receive data repeated
through gate $A$ to the down Loop stations. Any Up-Loop transmission will be received by the ADLC. The Loop Mode/Non-Loop Mode Control bit (bit 5 in Control Register 3) must be set to place the ADLC in the Loop Mode. The ADLC now monitors its Rx Data input for a string of seven consecutive " 1 's" which will allow a station to go on line. The Loop operation may be monitored by use of the Loop Status bit in Status Register 1. After power up and reset, this bit is a zero. When seven consecutive " 1 's" are received by the ADLC the $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ output will go to a low level, disabling gate $A$ (refer to Figure 9b), enabling gate $B$ and connecting the ADLC Tx Data output to the down Loop stations. The up Loop data is now repeated to the down Loop stations via the ADLC. A 1-bit delay is inserted in the data (in NRZI mode, there will be a 2 -bit delay) as it circulates through the ADLC. The ADLC is now on-line and the Loop Status bit in Status Register 1 will be at a one.
(2) Go Active after Poll - The receiver section will monitor the up-link data for a general or addressed poll command and the Tx FIFO should be loaded with data so that when the go ahead sequence of a zero followed by seven " 1 's" (01111111---) is detected, transmission can be initiated immediately. When the polling frame is detected, the Go-Active-On-Poll control bit must be set (bit 6 in Control

TABLE 1 - SUMMARY OF LOOP MODE OPERATION

| state | RX SECTION | TX SECTION | LOOP STATUS BIT |
| :---: | :---: | :---: | :---: |
| OFF.LOOP | Rx section recelves data from loop and searches for 7 " 1 's" (when On-Loop Control bit set) to go ON-LOOP. | Inactive <br> 1) NRZMODE. TX data output is maintained "high" (mark). <br> 2) NRZI MODE. TX data output reflects the Rx date input state delayed by one blt time. (Not normally connected to loop.) The NRZI data is Internally decoded to provide error-free transitions to On-Loop mode. | "0" |
| ON-LOOP | 1) When Go-Active on poll bit is set, Rx section searches for 01111111 pattern (the EOP or 'Go Ahead') to become the active terminal on the loop. <br> 2) When On-Loop control blt is reset, Rx section searches for 8 " 1 's" to go OFF Loop. | Inactive <br> 1) NRZ MODE. TX data output reflects Rx data Input state delayed one bit time. <br> 2) NRZI MODE. TX data output reflects Rx data input state delayed 2 bit times. | "1" |
| Active | Rx section searches for flag (an interrupt from the loop controller) at Rx data input. Recelved flag causes $\overline{F D}$ output to go low. IRO is generated if RIE and FDSE control bits are set. | Tx data originates within ADLC until Go Active on Poll bit is reset and a flag or Abort is completed. Then returns to ON-Loop state. | "0" |

Register 3). A maximum of seven bit times are available to set this control bit after the closing flag of the poll. When the Go-Ahead is detected by the receiver, the ADLC will automatically change the seventh one to a zero so that the repeated sequence out gate B in Figure Gb is now an opening flag sequence ( 011111110 ). Transmission now continues from the TX FIFO with data (address, control, etc.) as previously described. When the ADLC has gone active-onpoll, the L.oop Status bit in Status Register 1 will go to a zero. The receiver searches for a flag, which indicates that the primary station is interrupting the current operation.
(3) Go Inactive when On-Loop - The Go-Active-On-Poll control bit may be $\overline{\text { RESET }}$ at any time during transmission. When the frame is complete (the closing Flag or abort is transmitted), the Loop is automatically released and the station reverts back to being just a 1 -bit delay in the Loop, repeating up-link data. If the Go-Active-On-Poll control bit is not reset by software and the final frame is transmitted (Flag/Mark Idle bit $=0$ ), then the transmitter wili mark ide and will not release the loop to up-loop data. A Tx Abort command would have to be used in this case in order to go inactive when on the loop. Also, if the Tx FIFO was not preloaded with data (address, control, etc.) prior to changing the "Go Ahead Character" to a Flag, the ADLC will either transmit flags (active idle character) until data is loaded (when Flag/Mark Idle Control bit is high) or will go into an underrun condition and transmit an Abort (when Flag/Mark Idle control bit is low). When an abort is transmitted, the Go-Active-on-Poll control bit is reset automatically and the ADLC reverts to its repeating mode, ( $T \times D=$ delayed RxD ). When the ADLC transmitter lets go of the loop, the Loop Status bit will return to a " 1 ", indicating normal on-loop retransmission of up-loop data.
(4) Go Off-Loop - The ADLC can drop off the Loop (go off-linel similar to the way it went on-line. When the Loop On-Line control bit is reset the ADLC receiver section looks for eight successive " 1 's" before allowing the $\overline{L O C} / \overline{D T R}$ output to return high (the inactive state). Gate A in Figure 9b will be enabled and gate B disabled allowing the loop to maintain continuity without disturbance. The Loop Status bit will show an off-line condition (logical zero).

## SIGNAL DESCRIPTIONS

All inputs of ADLC are high-impedance and TTLcompatible level inputs. All outputs of the ADLC are compatible with standard TTL. Interrupt Request (iRQ), however, is an open-drain output (no internal pullup).

## INTERFACE FOR MPU

Bidirectional Data Bus (DO-D7) - These data bus I/O ports allow the data transfer between ADLC and system bus. The data bus drivers are three-state devices that remain in the high-impedance (off) state except when the MPU performs an ADLC read operation.

Enable Clock ( $E$ ) - E activates the address inputs ( $\overline{C S}$, RSO, and RS1) and R/W input and enables the data transter on the data bus. E also moves data through the Tx FIFO and Rx FIFO. E should be a free-running clock such as the E F6800 MPU system clock.

Chip Select ( $\overline{\mathbf{C S}}$ ) - An ADLC read or write operation is enabled only when the CS input is low and the E clock input is high. ( $\mathrm{E} \cdot \overline{\mathrm{CS}}$ ).

Register Selects (RSO, RS1) - When the Register Select inputs are enabled by ( $\mathrm{E} \cdot \overline{\mathrm{CS}}$ ), they select internal registers in conjunction with the Read/Write input and Address Control bit (control register 1, bit 0 ). Register addressing is defined in Table 2.

Read/Write Control Line (R/W) - The R/W input controls the direction of data flow on the data bus when it is enabled by ( $\mathrm{E} \cdot \overline{\mathrm{CS}}$ ). When $\mathrm{R} / \overline{\mathrm{W}}$ is high, the I/O Buffer acts as an output driver and as an input buffer when low. It also selects the Read Only and Write Only registers within the ADLC.

Reset Input ( $\overline{\text { RESET }}$ ) - The $\overline{\text { RESET }}$ input provides a means of resetting the ADLC from a hardware source. In the "low state," the RESET input causes the following:
-Rx Reset and Tx Reset are SET causing both the Receiver and Transmitter sections to be held in a reset condition.
-Resets the following control bits: Transmit Abort, $\overline{\mathrm{RTS}}$, Loop Mode, and Loop On-Line/DTR.

- Clears all stored status condition of the status registers.
"Outputs: RTS and LOC/DTR go high. TxD goes to the mark state (" 1 ' s " are transmitted).
When RESET returns "high" (the inactive state) the transmitter and receiver sections will remain in the reset state until Tx Reset and Rx Reset are cleared via the data bus under software control. The Control Register bits affected by $\overline{\text { RESET }}$ cannot be changed when $\overline{\text { RESET }}$ is "low."

Interrupt Request Output ( $\overline{\mathrm{RQ}})-\overline{\mathrm{RQ}}$ will be low if an interrupt situation exists and the appropriate interrupt enable has been set. The interrupt remains as long as the cause for the interrupt is present and the enable is set. $\overline{\mathrm{RO}}$ will be low as long as the $\overline{\mathrm{IRO}}$ status bit is set and is high if the $\overline{\mathrm{RQ}}$ status bit is not set.

## CLOCK AND DATA OF TRANSMITTER AND RECEIVER

Transmitter Clock Input (TxC) - The transmitter shifts data on the negative transition of the TxC clock input. When the Loop Mode or Test Mode is selected, TxC should be the same frequency and phase as the RxC clock. The data rate of the transmitter should not exceed the E frequency.

Receiver Clock Input (RXC) - The receiver samples the data on the positive transition of the RxC clock. RxC should be synchronized with receive data externally.

Transmit Data Output (TxD) - The serial data from the transmitter is coded in NRZ or NRZI (Zero Complement) data format.

Receiver Data Input (RxD) - The serial data to be received by the ADLC can be coded in NRZ or NRZI (Zero Complement) data format. The data rate of the receiver should not exceed the E frequency. If a partial byte reception is possible at the end of a frame, the maximum data rate of the receiver is indicated by the following relationship:

$$
f_{R x C} \leq \frac{1}{2 t_{E}+300 n s}
$$

where $t E$ is the period of $E$.

## PERIPHERAL/MODEM CONTROL

Request-to-Send Output ( $\overline{\mathrm{RTS}}$ ) - The Request-to-Send output is controlled by the Request-to-Send control bit in conjunction with the state of the transmitter section. When the $\overline{\mathrm{RTS}}$ bit goes high, the $\overline{\mathrm{RTS}}$ output is forced low. When the $\overline{\text { RTS }}$ bit returns low, the RTS output remains low until the end of the frame and there is no further data in the Tx FIFO for a new frame. The positive transition of $\overline{\mathrm{RTS}}$ occurs after the completion of a Flag, an Abort, or when the RTS control bit is reset during a mark idling state. When the $\overline{\text { RESET }}$ input is low, the RTS output goes high.

Clear-to-Send Input ( $\overline{\mathrm{CTS}}$ ) -- The $\overline{\mathrm{CTS}}$ input provides a real-time inhibit to the TDRA status bit and its associated interrupt. The positive transition of CTS is stored within the ADLC to ensure its occurrence will be acknowledged by the system. The stored $\overline{\mathrm{CTS}}$ information and its associated $\overline{\mathrm{RO}}$ (if enabled) are cleared by writing a " 1 " in the Clear Tx Status bit or in the Transmitter Reset bit.

Data-Carrier-Detect Inupt ( $\overline{\mathrm{DCD}}$ ) - The $\overline{\mathrm{DCD}}$ input provides a real-time inhibit to the receiver section. A high level on the $\overline{D C D}$ input resets and inhibits the receiver register, but data in the Rx FIFO from a previous frame is not disturbed. The positive transition of $\overline{\mathrm{DCD}}$ is stored within the ADLC to ensure that its occurrence will be acknowledged by the system. The stored $\overline{D C D}$ information and its associated $\overline{\mathrm{RQ}}$ (if enabled) are cleared by means of the Clear Rx Status Control bit or by the Rx Reset bit.

Loop On-Line Control/Data Terminal Ready Output ( $\overline{\text { LOC }} / \overline{\text { DTR }})$ - The $\overline{\text { LOC }} / \overline{\text { DTR }}$ output serves as a $\overline{\text { DTR }}$ output in the non-loop mode or as a Loop Control output in the loop mode. When $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ output performs the $\overline{\mathrm{DTR}}$ function, it is turned on and off by means of the $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ control bit. When the $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ control bit is high the $\overline{\mathrm{DTR}}$ output will be low. In the loop mode the $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ output provides the means of controlling the external loop interface hardware to go On-line or Off-line. When the $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ control bit is SET and the loop has "idled" for 7 bit times or more ( $\mathrm{RxD}=01111111 \ldots$ ), the $\overline{\mathrm{LOC}} / \overline{\mathrm{DTR}}$ output will go low (on-
 output to be high.

Flag Detect Output ( $\overline{\mathrm{FD}}$ ) - An output to indicate the reception of a flag and initiate an external time-out counter for the loop mode operation. The $\overline{\text { FD }}$ output goes low for 1 bit time beginning at the last bit of the flag character, as sampled by the receiver clock ( RxC ).

## DMA INTERFACE

Receiver Data Service Request Output (RDSR) - The RDSR Output is provided primarily for use in DMA Mode operation and indicates (when high) that the Rx FIFO requests service (RSDR output reflects the RDA status bit regardless of the state of the RDSR mode control bit in CR1). If the prioritized Status Mode is selected, RDSR will be inhibited when any other receiver status conditions are present. RDSR goes low when the Rx FIFO is read.

Transmitter Data Service Request Output (TDSR) - The TDSR Output is provided for DMA mode operation and indicates (when high) that the Tx FIFO request service regardless of the state of the TDSR Mode Control bit in CR1. TDSR goes low when the Tx FIFO is loaded. TDSR is inhibited by: the Tx RS control bit being SET, $\overline{\text { RESET being }}$ low, or CTS being high. If the prioritized status mode is used, Tx Underrun also inhibits TDSR. TDSR reflects the TDRA status bit except in the FC mode. In the FC mode the TDSR line is inhibited.

## ADLC REGISTERS

Eight registers in the ADLC can be accessed by means of the MPU data and address buses. The registers are defined as read-only or write-only according to the direction of information flow. The addresses of these registers are defined in Table 2. The transitter FIFO register can be accessed by two different addresses, the "Frame Terminate" address and the "Frame Continue" address. (The function of these addresses are discussed in the FIFO section.)

TABLE 2 - REGISTER ADDRESSING

| Register Selected | R/ $\bar{W}$ | RS1 | RS0 | Address <br> Control Bit <br> $\left(C_{1} b_{0}\right)$ |
| :--- | :---: | :---: | :---: | :---: |
| Write Control Register \#1 | 0 | 0 | 0 | $\times$ |
| Write Control Register \#2 | 0 | 0 | 1 | 0 |
| Write Control Register \#3 | 0 | 0 | 1 | 1 |
| Write Transmit FIFO <br> (Frame Continue) | 0 | 1 | 0 | $\times$ |
| Write Transmit FIFO <br> (Frame Terminate) | 0 | 1 | 1 | 0 |
| Write Control Register \#4 | 0 | 1 | 1 | 1 |
| Read Status Register \#1 | 1 | 0 | 0 | X |
| Read Status Register \#2 | 1 | 0 | 1 | X |
| Read Receiver FIFO | 1 | 1 | X | X |

## RECEIVER DATA FIRST-IN FIRST-OUT REGISTER

Rx FIFO - The Rx FIFO consists of three 8-bit registers which are used for the buffer storage of received data. Data bytes are always transferred from a full register to an adjacent empty register; and both phases of the E input clock are
used for the data transfer. Each register has pointer bits which point the frame boundary. When these pointers appear at the last FIFO location, they update the Address Present, Frame Valid, or FCS/IF Error status bits.

The RDA status bit indicates the state of the Rx FIFO. When RDA status bit is " 1 ", the Rx FIFO is ready to be read. The RDA status is controlled by the 2-Byte/1-Byte control bit. When overrun occurs, the data in the first byte of the Rx FIFO are not longer valid.

Both the Rx Reset bit and $\overline{\operatorname{RESET}}$ input clear the Rx FIFO. Abort ("in Frame") and a high level on the $\overline{\mathrm{DCD}}$ input also clears the Rx FIFO, but the last bytes of the previous frame, which are separated by the frame boundary pointer, are not disturbed.

## TRANSMITTER DATA FIRST-IN FIRST-OUT REGISTER

Tx FIFO - The Tx FIFO consists of three 8-bit registers which are used for buffer storage of data to be transmitted. Data is always transferred from a full register to an empty adjacent register; the transfer occurs on both phases of the $E$ input clock. The Tx FIFO can be addressed by two different register addresses, the "Frame Continue" address and the "Frame Terminate" address. Each register has pointer bits which point to the frame boundary. When a data byte is written at the "Frame Continue" address, the pointer of the first FIFO register is set. When a data byte is written at the "Frame Terminate" address, the pointer of the first FIFO register is reset. Rx RS control bit or Tx Abort control bit resets all pointers. The pointer will shift through the FIFO. When a positive transition is detected at the third location of FIFO, the transmitter initiates a frame with an open flag. When the negative transition is detected at the third location of FIFO, the transmitter closes a frame, appending the FCS and closing Flag to the last byte.
The Tx last control bit can be used instead of using the "Frame Terminate" address. When the Tx last control bit is set with a " 1 ", the logic searches the last byte location in the FIFO and resets the pointer in the FIFO register.
The status of Tx FIFO is indicated by the TDRA status bit. When TDRA is " 1 ", the Tx FIFO is available for loading data. The TDRA status is controlled by the 2-Byte/1-Byte control bit. The Tx FIFO is reset by both Tx Reset and RESET input. During this reset condition or when CTS input is high, the TDRA status bit is suppressed and data loading is inhibited.

ADLC INTERNAL REGISTER STRUCTURE

|  |  | RS1 RS0 $=00$ | RS1 RSO $=01$ | RS1 RS0 $=10$ | RS1 RSO $=11$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Bit \# | Status Register \#1 | Status Register \#2 | Receiver Data Register |  |
|  | 0 | RDA | Address Present | Bit 0 |  |
|  | 1 | Status \#2 <br> Read Request | Frame Valid | Bit 1 |  |
|  | 2 | Loop | Inactive Idle Received | Bit 2 |  |
|  | 3 | Flag Detected (When Enabled) | Abort Received | Bit 3 | Same as RS $1, \mathrm{RSO}=10$ |
|  | 4 | $\overline{\text { CTS }}$ | FCS Error | Bit 4 |  |
|  | 5 | Tx Underrun | $\overline{\mathrm{DCD}}$ | Bit 5 |  |
|  | 6 | TDRA/Frame Complete | Rx Overrun | Bit 6 |  |
|  | 7 | IRQ Present | RDA (Receiver Data Available) | Bit 7 |  |


|  | Bit \# |  |  |  | Transmitter Data | Transmitter Data |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Control Register \#1 | Control Register \#2 $\left(C_{1} b_{0}=0\right)$ | Control Register \#3 ( $\mathrm{C}_{1} \mathrm{~b}_{0}=1$ ) | (Continue Data) | (Last Data) $\left(c_{1} b_{0}=0\right)$ | Control Register $\# 4$ ( $\mathrm{C}_{1} \mathrm{~b}_{0}=1$ ) |
|  | 0 | Address Control (AC) | Prioritized Status Enable | Logical Control Field Select | Bit 0 | Bit 0 | Double Flag/Single Flag Interframe Control |
|  | 1 | Receiver Interrupt Enable (RIE) | 2 Byte/1 Byte Transfer | Extended Control Field Select | Bit 1 | Bit 1 | Word Length Select Transmit \#1 |
|  | 2 | Transmitter Interrupt Enable (TIE) | Flag/Mark Idle | Auto, Address <br> Extension Mode | Bit 2 | Bit 2 | Word Length Select Transmit $\pm 2$ |
|  | 3 | RDSR Mode (DMA) | Frame Complete/ TDRA Select | 01/11 Idie | Bit 3 | Bit 3 | Word Length Select Receive $=1$ |
|  | 4 | TDSR Mode (DMA) | Transmit Last Data | Flag Detected Status Enable | Bit 4 | Bit 4 | Word Length Select Receive \#2 |
|  | 5 | Rx Frame Discontinue | CLR R× Status | Loop/Non-Loop Mode | Bit 5 | Bit 5 | Transmit Abort |
|  | 6 | R×RESET | CLR Tx Status | Go Active on Poll/Test | Bit 6 | Bit 6 | Abort Extend |
|  | 7 | T×RESET | RTS Control | Loop On-Line Control DTR | Bit 7 | Bit 7 | NRZI/NRZ |

## CONTROL REGISTER 1 (CR1)

| RS | RSO | R/W | AC | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | TxRS | R×RS | Discontinue | TDSR | RDSR | TIE | RIE | AC |
| 0 | 0 | 0 | $x$ |  |  |  | Mode | Mode |  |  |  |

bO - Address Control (AC) - AC provides another RS (Register Select) signal internally. The AC bit is used in conjunction with RS0, RS1, and R/W inputs to select particular registers, as shown in Table 2.
b1 - Receiver Interrupt Enable (RIE) - RIE enables/disables the interrupt request caused by the receiver section. 1...enable, 0...disable.
b2 - Transmitter Interrupt Enable (TIE) - TIE enables/disables the interrupt request caused by the transmitter. $1 . .$. enable, $0 .$. disable.
b3 - Receiver Data Service Request Mode (RDSR MODE) - The RDSR MODE bit provides the capability of operation with a bus system in the DMA mode when used in conjunction with the prioritized status mode. When RDSR MODE is set, àn interrupt request caused by RDA status is inhibited, and the ADLC does not request data transfer via the $\overline{\mathrm{RO}}$ output.
b4 - Transmitter Data Service Request Mode (TDSR MODE) - The TDSR MODE bit provides the capability of operation with a bus system in the DMA mode when used in conjunction with the prioritized status mode. When TDSR MODE is set, an interrupt request caused by TDRA status is inhibited, and the ADLC does not request a data transfer via the $\overline{R O}$ output.
b5 - Rx Frame Discontinue (DISCONTINUE) - When the DISCONTINUE bit is set, the currently received frame is ignored and the ADLC discards the data of the current frame. The DISCONTINUE bit only discontinues the currently received frame and has no affect on subsequent frames, even if a following frame has entered the receiver section. The DISCONTINUE bit is automatically reset when the last byte of the frame is discarded. When the ignored frame is aborted by receiving an Abort or DCD failure, the DISCONTINUE bit is also reset.
b6 - Receiver Reset (Rx RS) - When the Rx RS bit is " 1 ", the receiver section stays in the reset condition. All receiver sections, including the Rx FIFO register and the receiver status bits in both status registers, are reset. (During reset, the stored DCD status is reset but the DCD status bit follows the $\overline{D C D}$ input.) RxRS is set by forcing a low level on the RESET input or by writing a " 1 " into the bit from the data bus. Rx RS must be reset by writing a " 0 " from the data bus after RESET has gone high.
b7 - Transmitter Reset (Tx RS) - When the Tx RS bit is " 1 ", the transmitter section stays in the reset condition and transmits marks (" 1 's"). All transmitter sections, including the TX FIFO and the transmitter status bits, are reset (FIFO cannot be loaded). During reset, the stored CTS status is reset but the CTS status bit follows the $\overline{\mathrm{CTS}}$ input. Tx RS is set by forcing a low level on the $\overline{\text { RESET input or by writing a }}$ " 1 " from the data bus. It must be reset by writing a " 0 " after $\overline{\text { RESET }}$ has gone high.

## CONTROL REGISTER 2 (CR2)

| RS1 | RSO | R/ $\bar{W}$ | AC |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | RTS | CLR | CLR | Tx | FC/TDRA | F/M | $2 / 1$ | PSE |
|  |  | TxST | RxST | Last | Select | Idle | Byte |  |  |  |  |

b0 - Prioritized Status Enable (PSE) - When the PSE bit is SET, the status bits in both status registers are prioritized as defined in the Status Register section. When PSE is low, the status bits indicate current status without bit suppression by other status bits. The exception to this rule is the CTS status bit which always supresses the TDRA status.
b1 - 2-Byte/1-Byte Transfer (2/1 Byte) - When the 2/1 Byte bit is RESET the TDRA and RDA status bits then will indicate the availability of their respective data FIFO registers for a single-byte data transfer. Similarly, if $2 / 1$ Byte is set, the TDRA and RDA status bit indicate when two bytes of data can be moved without a second status read.
b2 - Flag/Mark Idle Select (F/M Idie) - The F/M Idle bit selects Flag characters or bit-by-bit Mark Idle for the time fill or the idle state of the transmitter. When Mark Idle is selected, Go-Ahead code can be generated for loop operation in conjunction with the 01/11 Idle control bit ( $\mathrm{C}_{3} \mathrm{~b}_{3}$ ). 1...Flag time fill, $0 . .$. Mark Idle.
b3 - Frame Complete/TDRA Select (FC/TDRA Select) - The FC/TDRA Select bit selects TDRA status or FC status for the TDRA/FC status bit indication. 1...FC status, $0 .$. TDRA status.
b4 - Transmit Last Data (Tx Last) - Tx Last bit provides another method to terminate a frame. This bit should be set
after loading the last data byte and before the Tx FIFO empties. When the Tx Last bit is set, the ADLC assumes the byte is the last byte and terminates the frame by appending CRCC and a closing Flag. This control bit is useful for DMA operation. Tx Last bit automatically returns to the " 0 " state.
b5 - Clear Receiver Status (CLR Rx ST) - When a " 1 " is written into the CLR Rx ST bit, a reset signal is generated for the receiver status bits in status registers $\# 1$ and $\# 2$ lexcept AP and RDA bits). The reset signal is enabled only for the bits which have been present during the last "read status" operation. The CLR Rx ST bit automatically returns to the " 0 " state.
b6 - Clear Transmitter Status (CLR Tx ST) - When a " 1 " is written into CLR Tx ST bit, a reset signal is generated for the transmitter status bits in status register \$1 (except TDRA). The reset signal is enabled for the bits which have been present during the last "read status" operation. The CLR Tx ST bit automatically returns to the " 0 " state.
b7 - Request-to-Send Conarol (RTS) - The RTS bit, when high, causes the RTS output to be low (the active state). When the RTS bit returns low and data is being transmitted, the RTS output remains low until the last character of the frame (the closing Flag or Abort) has been completed and the Tx FIFO is empty. If the transmitter is idling when the RTS bit returns low, the RTS output will go high (the inactive state) within two bit times.

| CONTROL REGISTER 3 (CR3) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{cccc}\text { RS1 } & \mathrm{RS} 0 & \mathrm{R} / \overline{\mathrm{W}} & \mathrm{AC} \\ 0 & 1 & 0 & 1\end{array}$ |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  |  |  | LOC/ | GAP/ | Loop | FDSE | 01/11 | AEX | CEX | LCF |
|  |  |  |  | DTR | TST |  |  | Idle |  |  |  |

b0 - Logical Control Field Select (LCF) - The LCF select bit causes the first byte(s) of data belonging to the information field to remain 8 -bit characters until the logical control field is complete. The logical control field (when selected) is an automatically extendable field which is extended when bit 7 of a logical control character is a " 1 ." When the LCF Select bit is reset the ADLC assumes no logical control field is present for either the transmit or received data channels. When the logical control field is terminated, the word length of the information data is then defined by WLS 1 and $W L S_{2}$.
b1 - Extended Control Field Select ( $C_{E X}$ ) - When the $C_{E X}$ bit is a " 1 ", the control field is extended and asusmed to be 16 bits. When $C_{E X}$ is " 0 ", the control field is assumed to be 8 bits.
b2 - Auto/Address Extend Mode (AEX) - The AEX bit when "low"' allows full 8 bits of the address octet to be utilized for addressing because address extension is inhibited. When the AEX bit is "high," bit 0 of address octet equal to " 0 " causes the Address field to be extended by one octet. The exception to this automatic address field extension is when the first address octet is all " 0 ' $s$ " (the Null Address).
b3 - 01/11 Idle (01/11 Idie) - The 01/11 Idle Control bit determines whether the inactive (Mark) idle condition begins with a " 0 " or not. If the 01/11 Idle Control is SET, the closing flag (or Abort) will be followed by a 011111 ...pattern. This is required of the controller for the "Go Ahead" character in the Loop Mode. When 01/11 is RESET, the idling condition will be all " 1 ' $s$ ".
b4 - Flag Detect Status Enable (FDSE) - The FDSE bit enables the FD status bit in Status Register $\$ 1$ to indicate the occurrence of a received Flag character. The status indication will be accompanied by an interrupt if RIE is SET. Flag
detection will cause the Flag Detect output to go low for 1 bit time regardless of the state of FDSE.
b5 - LOOP/NON-LOOP Mode (LOOP) - When the LOOP bit is set, loop mode operation is selected and the GAP/TST control bit, LOC/DTR control bit and LOC/DTR output are selected to perform the loop control functions. When LOOP is reset, the ADLC operates in the point-topoint data communications mode.
b6 - Go Active On Poll/Test (GAP/TST) - In the Loop Mode - The GAP/TST bit is used to respond to the poll sequence and to begin transmission. When GAP/TST is set, the receiver searches for the "Go Ahead" (or End of Poll, EOP). The receiver "Go ahead" is converted to an opening Flag and the ADLC starts its own transmission. When GAP/TST is reset during the transmission, the end of the frame (the completion of Flag or Abort) causes the termination of the "go-active-on-poll" operation and the Rx Data to Tx Data link is re-established. The ADLC then returns to the "loop-on-line" state.

In the Non-Loop Mode - The GAP/TST bit is used for self-test purposes. If GAP/TST bit is set, the TXD output is connected to the RxD input internally, and provides a "loopback" feature. For normal operation, the GAP/TST bit should be reset.
b7 - Loop On-Line Control/DTR Control (LOC/DTR) In the Loop Mode - The LOC/DTR bit is used to go on-line or to go off-line. When LOC/DTR is set, the ADLC goes to the on-line state after 7 consecutive " 1 's" occur at the RxD input. When LOC/DTR is reset, the ADLC goes to the "offline" state after eight consecutive " 1 ' $s$ " occur at the RXD input.

In the Non-Loop Mode - The LOC/DTR bit directly controls the Loop On-Line/DTR output state. 1... $\overline{\mathrm{DTR}}$ output goes to low level, O...DTR output goes to high level.

b0 - Double Flag/Single Flag Interframe Control ("FF" $/$ " $F$ ") - The " $F F^{\prime \prime}$ "/" $F$ " Control bit determines whether the transmitter will transmit separate closing and opening Flags when frames are transmitted successively. When the "FF"/" $F$ " control bit is low, the closing flag of the first frame will serve as the opening flag of the second frame. When the bit is high, independent opening and closing flags will be transmitted.
b1, b2 - Transmitter Word Length Select (Tx WLS1 a. id WLS2) - Tx WLS1 and WLS2 are used to select the word length of the transmitter information field. The encoding format is shown in Table 3.
b3, b4 - Receiver Word Length Select (Rx WLS1 and WLS2) - Rx WLS1 and WLS2 are used to select the word length of the receiver information field. The encoding format is shown in Table 3.

TABLE 3 - I-FIELD CHARACTER LENGTH SELECT

| WLS $_{\mathbf{1}}$ | WLS $_{\mathbf{2}}$ | I-Field Character Length |
| :---: | :---: | :---: |
| 0 | 0 | 5 bits |
| 1 | 0 | 6 bits |
| 0 | 1 | 7 bits |
| 1 | 1 | 8 bits |

b5 - Transmit Abort (ABT) - The ABT bit causes an Abort (at least 8 bits of " 1 " in succession) to be transmitted. The Abort is initiated and the Tx FIFO is cleared when the control bit goes high. Once Abort begins, the Tx Abort control bit assumes the low state.
b6 - Abort Extend (ABTEX) - If ABTEX is set, the abort code initiated by ABT is extended up to at least 16 bits of consecutive " 1 ' $s$ ", the mark Idle State.
b7 - NRZI (Zero Complement)/NRZ Select (NRZI/NRZ) - NRZI/NRZ bit selects the transmit/receive data format to be NRZI or NRZ in both Loop Mode or NonLoop mode operation. When the NRZI Mode is selected, a

1-bit delay is added to the transmitted data (TxD) to allow for NRZI encoding. 1...NRZI, O...NRZ.

NOTE
NRZ! coding - The serial data remains in the same state to send a binary " 1 " and switches to the opposite state to send a binary " 0 ".

## STATUS REGISTER

The Status Register $\# 1$ is the main status register. The IRO bit indicates whether the ADLC requests service or not. The S2RQ bit indicates whether any bits in status register $\# 2$ request any service. TDRA and RDA, because they are most often used, are located in bit positions that are more convenient to test. RDA reflects the state of the RDA bit in status register $\$ 2$.
The Status Register $\$ 2$ provides the detailed status information contained in the S2RO bit and these bits reflect receiver status. The FD bit is the only receiver status which is not indicated in status register $\$ 2$.
The prioritized status mode provides maximum efficiency in searching the status bits and indicates only the most important action required to service the ADLC. The priority trees of both status registers are provided in Figure 10.
Reading the status register is a non-destructive process. The method of clearing status depends upon the bit's function and is discussed for each bit in the register.

FIGURE 10 - STATUS REGISTER PRIORITY TREE (PSE = 1)

| Decreasing Priority | SR \#1 |  |  |
| :---: | :---: | :---: | :---: |
|  | (Tx) | (Rx) | SR\#2 (Rx) |
|  | - CTS | FD | ERR, FV, DCD, |
| \| | $\downarrow$ | $\downarrow$ | OVRN, RX ABT |
|  | 1 TXU | S2RO |  |
| $\downarrow$ | 4 TORA/FC | RDA |  |
|  |  |  | AP |
|  |  |  | RDA |

[^33]
## STATUS REGISTER 1 (SR1)

| RS1 | RSO | R/W | AC |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | $X$ |  |  |  |  |  |  |  |

b0 - Receiver Data Available (RDA) - The RDA status bit reflects the state of the RDA status bit in status register \#2. It provides the means of achieving data transfers of received data in the full Duplex Mode without having to read both status registers.
b1 - Status Register \#2 Read Request (S2RQ) - All the status bits (stored conditions) of status register \$2, (except RDA bit) are logically ORed and indicated by the S2RO status bit. Therefore, S2RQ indicates that status register \#2 needs to be read. When S2RQ is " 0 ", it is not necessary to read status register \#2. The bit is cleared when the appropriate bits in status register \#2 are cleared or when Rx Reset is used.
b2 - Loop Status (LOOP) - The LOOP status bit is used to monitor the loop operation of the ADLC. This bit does not cause an IRQ. When Non-Loop Mode is selected, LOOP bit stays " 0 ". When Loop Mode is selected, the LOOP status bit goes to " 1 " during "On-Loop" condition. When ADLC is in an "Off-Loop" condition or "Go-Active-On-Poll" condition, the LOOP status bit is a " 0 ".
b3 - Flag Detected (FD) - The FD Status bit indicates that a flag has been received if the Flag Detect Enable control bit has been set. The bit goes high at the last bit of the Flag Character received (when the Flag Detect Output goes low) and is stored until cleared by Clear Rx Status or Rx Reset.
b4 - Clear-to-Send (CTS) - The CTS input positive transition is stored in the status register and causes an IRQ (if Enabled). The stored CTS condition and its IRQ are cleared by Clear Tx Status control bit or Tx Reset bit. After the stored status is reset, the CTS status bit reflects the state of the $\overline{\mathrm{CTS}}$ input.
b5 - Transmitter Underrun (TxU) - When the transmitter runs out of data during a frame transmission, an underrun occurs and the frame is automatically terminated by transmitting an Abort. The underrun condition is indicated by the TxU status bit. TxU can be cleared by means of the Clear Tx Status Control bit or by Tx Reset.
b6 - Transmitter Data Register Available/Frame Complete (TDRA/FC) - The TDRA Status bit serves two purposes depending upon the state of the Frame Complete/TDRA Select control bit. When this bit serves as a TDRA status bit, it indicates that data (to be transmitted) can be loaded into the Tx Data FIFO register. The first register (Register 1) of the Tx Data FIFO being empty (TDRA $=$ " 1 ") will be indicated by the TDRA Status bit in the "1-Byte Transfer Mode." The first two registers (Registers \#1 and \#2) must be empty for TDRA to be high when in the "2-Byte Transfer Mode." TDRA is inhibited by Tx Reset, or $\overline{C T S}$ being high.
When the Frame Complete Mode of operation is selected, the TDRA/FC status bit goes high when an abort is transmitted or when a flag is transmitted with no data in the Tx FIFO. The bit remains high until cleared by resetting the TDRA/FC control bit or setting the Tx Reset bit.
b7 - Interrpt Request (IRQ) - The Interrupt Request status bit indicates when the $\overline{\mathrm{RO}}$ output is in the active state ( $\overline{\mathrm{RQ}}$ Output $=$ " 0 "). The IRQ status bit is subject to the same interrupt enables (RIE, TIE) as the $\overline{\mathrm{RQ}}$ output, i.e., with both transmitter and receiver interrupts enabled, the IRQ status bit is a logical ORed indication of Status Register 1 status bits. The IRO bit only reflects the set status bits which have interrupts enabled. The IRO status bit simplifies status inquiries for polling systems by providing single bit indication of service requests.
STATUS REGISTER 2 (SR2)

b0 - Address Present (AP) - The AP status bit provides the frame boundary and indicates an Address octet is available in the Rx Data FIFO register. In the Extended Addressing Mode, the AP bit continues to indicate addresses until the Address field is complete. The Address present status bit is cleared by reading data or by Rx Reset.
b1 - Frame Valid (FV) - The FV status bit provides the frame boundary indication to the MPU and also indicates that a frame is complete with no error. The FV status bit is set when the last data byte of a frame is transferred into the last location of the Rx FIFO (available to be read by MPU). Once FV status is set, the ADLC stops further data transfer into the last location of the Rx FIFO (in order to prevent the mixing of two frames) until the status bit is cleared by the Clear Rx Status bit or Rx Reset.
b2 - Inactive Idle Received (RxIdie) - The Rxidle status bit indicates that a minimum of 15 consecutive " 1 's" have been received. The event is stored within the status register and can cause an interrupt. The interrupt and stored condition are cleared by the Clear Rx Status Control bit. The Status bit is the Logical OR of the receiver idling detector (which continues to reflect idling until a " 0 " is received) and the stored inactive idle condition.
b3 - Abort Received (RxABT) - The R×ABT status bit indicates that seven or more consecutive " 1 ' $s$ " have been received. Abort has no meaning under out-of-frame conditions; therefore, no interrupt nor storing of the status will occur unless a Flag has been detected prior to the Abort. An Abort Received when "in frame" is stored in the status register and causes an IRQ. The status bit is the logical OR of the stored conditions and the Rx Abort detect logic, which is cleared after 15 consecutive " 1 's" have occurred. The stored

Abort condition is cleared by the Clear Rx Status Control bit or Rx Reset.
b4 - Frame Check Sequence/Invalid Frame Error (ERR) - When a frame is complete with a cyclic redundancy check (CRC) error or a short frame error (the frame does not have complete Address and Control fields), the ERR status bit is set instead of the Frame Valid status bit. Other functions, frame boundry indication and control function, are exactly the same as for the Frame Valid status bit. Refer to the FV status bit.
b5 - Data Carrier Detect (DCD) - A positive transition on the DCD input is stored in the status register and causes an IRO (if enabled). The stored DCD condition and its IRQ are cleared by the Clear Rx Status Control bit or RX Reset. After stored status is reset, the DCD status bit follows the state of the input. Both the stored DCD condition and the $\overline{\mathrm{DCD}}$ input cause the reset of the receiver section when they are high.
b6 - Receiver Overrun (OVRN) - OVRN status indicates that receiver data has been transferred into the Rx FIFO when it is full, resulting in data loss. The OVRN status is cleared by the Clear Rx Status bit or Rx Reset. Continued overrunning only destroys data in the first FIFO Register.
b7 - Receiver Data Available (RDA) - The Receiver Data Available status bit indicates when receiver data can be read from the Rx Data FIFO. When the prioritized status mode is used, the RDA bit indicates that non-address and non-last data are available in the Rx FIFO. The receiver data being present in the last register of the FIFO causes RDA to be high for the "1-Byte Transfer Mode." The RDA bit being high indicates that the last two registers are full when in the " 2 -Byte Transfer Mode." The RDA status bit is reset automatically when data is not available.

1. Status Priority - When the prioritized status mode is used, it is best to test for the lowest priority conditions first. The lowest priority conditions typically occur more frequently and are the most likely conditions to exist when the processor is interrupted.
2. Stored vs Present Status - Certain status bits IDCD, CTS, Rx Abort, and Rx Idle) indicate a status which is the logical OR of a stored and a present condition. It is the stored status that causes an interrupt and which is cleared by a Status Clear control bit. After being cleared, the status register will reflect the present condition of an input or a receiver input sequence.
3. Clearing Status Registers - In order to clear an interrupt with the two Status Clear control bits, a particular status condition must be read before it can be cleared. In the prioritized mode, clearing a higher priority condition might result in another IRO caused by a lower priority condition whose status was suppressed when a status register was first read. This guarantees that a status condition is never inadvertently cleared.
4. Clearing the Rx FIFO - An Rx Reset will effectively clear the contents of all three Rx FIFO bytes. However, the FIFO may contain data from two different frames when abort or DCD failure occurs. When this happens, the data from a previously closed frame (a frame whose closing flag has been received) will not be destroyed.
5. Servicing the Rx FIFO in a 2-Byte Mode - The procedure for reading the last bytes of data is the same, regardless of whether the frame contains an even or an odd number of bytes. Continue to read 2 bytes until an interrupt occurs that is caused by an end-of-frame status (FV or ERR). When this occurs, indicating the last byte either has been read or is ready to be read, switch temporarily to the 1 -byte mode with no prioritized status (control register 2 ).

Test RDA to indicate whether a 1-byte read should be performed. Then clear the frame end status.
6. Frame Complete Status and RTS Release - In many cases, a MODEM will require a delay for releasing $\overline{\mathrm{RTS}}$. An 8 -bit or 16 -bit delay can be added to the ADLC RTS output by using an Abort. At the end of a transmission, frame complete status will indicate the frame completion. After frame complete status goes high, write " 1 " into the Abt control bit land Abt Extend bit if a 16 -bit delay is required). After the Abt control bit is set, write " 0 " into the RTS control bit. The transmitter will transmit eight or sixteen " 1 's" and the RTS output will then go high (inactive).
7. Note to users not using the EF6800 - (a) Carte should be taken when performing a write followed by a read on successive E pulses at a high frequency rate. Time must be allowed for status changes to occur. If this is done, the time that E is low between successive write/read E pulses should be at least 500 ns . (b) The ADLC is a completely static part. However, the E frequency should be high enough to move data through the FIFOs and to service the peripheral requirements. Also, the period between successive E pulses should be less than the period of RxC or $T x C$ in order to maintain synchronization between the data bus and the peripherals.
8. Clear-to-Send ( $\overline{\mathrm{CTS}}$ ) - The CTS input, when high, provides a real-time inhibit to the TDRA status bit and its associated interrupt. All other status bits will be operational. Since it inhibits TDRA, $\overline{C T S}$ also inhibts the TDSR DMA request. The CTS input being high does not affect any other part of the transmitter. Information in the Tx FIFO and Tx Shift Register will, therefore, continue to be transmitted as long as the Tx CLK is running.

## ORDERING INFORMATION

| DevicePackage - Sceening levelThe table below horizontally shows all available suffix combinations for package, operating temperature and screeninglevel. Other possibilities on request. |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
| DEVICE | PACKAGE |  |  |  |  | OPER. TEMP. |  |  | SCREENING LEVEL |  |  |  |
|  | C | J | P | E | FN | L* | V | M | Std | D | G/B | B/B |
| EF6854 (1.0 MHz) | $\bullet$ |  |  |  | $\bullet$ | - |  |  | - |  |  |  |
|  | $\bullet$ | $\bullet$ |  |  |  |  | $\bullet$ |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  |  | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  | $\bullet$ | $\bullet$ |
|  |  | $\bullet$ |  |  |  |  |  | - | - |  | - |  |
| EF68A54 (1.5 MHz) | - |  |  |  |  | - |  |  | - |  |  |  |
|  | - | $\bullet$ |  |  |  |  | $\bullet$ |  | $\bullet$ |  |  |  |
|  | $\bullet$ |  |  | $\bullet$ |  |  |  | - | $\bullet$ |  | - | - |
|  |  |  | $\bullet$ |  |  |  |  | - | $\bullet$ |  | $\bullet$ |  |
| EF68B54 ( 2.0 MHz ) | $\bullet$ |  |  |  |  | $\bullet$ |  |  | $\bullet$ |  |  |  |
|  | $\bullet$ | $\bullet$ |  |  |  |  | $\bullet$ |  | $\bullet$ |  | $\bullet$ |  |
| Examples : EF6854C, EF6854CV, EF6854CM, EF6854JM |  |  |  |  |  |  |  |  |  |  |  |  |
| Package : C : Ceramic DIL, J : Cerdip DIL, P : Plastic DIL, E: LCCC, FN : PLCC. <br> Oper. temp. : $\mathrm{L}^{*}: 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}$ : $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{M}:-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$, ${ }^{*}$ : may be omitted. <br> Screening level: Std : (no-end suffix), D: NFC 96883 level D, <br> G/B : NFC 96883 level G, B/B : NFC 96883 level B and MIL-STD-883C level B. |  |  |  |  |  |  |  |  |  |  |  |  |

## PHYSICAL DIMENSIONS



CB-132


ALSO AVAILABLE

J SUFFIX
c Suffix
CERDIP PACKAGE CERAMIC PACKAGE

CB-520

Lecarabibel

FN SUFFIX
PLCC 28


E SUFFIX
LCcC 28



## CHAPTER 3-68000 MICROPROCESSORS

68000 MICROPROCESSORS SELECTION GUIDE

| Part number | Description | Technology | Alt source | CLK freq. (MHz) | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TS68000-8 | 16-bit MPU 32-bit data and address registers - | HMOS | MC68000-8 | 8 | 3-3 |
| TS68000-10 | 16 megabyte direct addressing range - |  | MC68000-10 | 10 |  |
| TS68000-12 | 56 powerful instruction pages - |  | MC68000-12 | 12,5 |  |
| TS68000-16 | Memory mapped I/O-14 addressing modes |  |  | 16 |  |
| TS68008-8 | 8-bit data bus version of TS68000 | HMOS | MC68008-8 | 8 | 3-95 |
| TS68008-10 | 1 Mbyte direct addressing space - Complete |  | MC68008-10 | 10 |  |
| TS68008-12 | code compatibility with the TS68000 |  | MC68008-12 | 12,5 |  |
| MK68201/04-4 | 16-bit MCU ROMLESS (UPC) | NMOS | - | 4 | 3-191 |
| MK68201/04-6 | 16-bit MCU ROMLESS (UPC) |  | " | 6 |  |
| MK68211/04-4 | 16-bit MCU ROMLESS (GP) | ", | " | 4 |  |
| MK68211/04-6 | 16-bit MCU ROMLESS (GP) | ", | ", | 6 |  |
| MK68E201/04-4 | 16-bit Emulator (UPC) | ", | ", | 4 |  |
| MK68E211/04-4 | 16-bit Emulator (GP) | " | " | 4 |  |
| MK68HC201/04-8 | 16-bit MCU ROMLESS (UPC) | HCMOS | " | 8 | 3-265 |
| MK68HC201/04-10 | 16-bit MCU ROMLESS (UPC) |  | " | 10 |  |
| MK68HC201/04-12 | 16-bit MCU ROMLESS (UPC) | ", | " | 12.5 |  |
| MK68HC211/04-8 | 16-bit MCU ROMLESS (GP) | ", | " | 8 |  |
| MK68HC211/04-10 | 16-bit MCU ROMLESS (GP) | " | " | 10 |  |
| MK68HC211/04-12 | 16-bit MCU ROMLESS (GP) | ", | ", | 12.5 |  |
| MK68HCE221/08-8 | 16-bit Emulator (UPC/GP) | ", | " | 8 |  |
| MK68HCE221/08-10 | 16-bit Emulator (UPC/GP) | ", | ", | 10 |  |
| MK68HCE221/08-12 | 16-bit Emulator (UPC/GP) | " | " | 12.5 |  |

## ADVANCE INFORMATION

The TS68000 is the first implementation of the 68000 16/32 microproces sor architecture. The TS68000 has a 16 -bit data bus and 24 -bit addess bus while the full architecture provides for 32 -bit address and data buses. It is completely code-compatible with the TS68008 8-bit daia bus implementation of the 68000 and is downward code-compatible with the TS68020 32 -bit implementation of the architecture. Any user-mode programs written using the TS68000 instruction set will run unchanged on the TS68008 and TS68020. This is possible because the user programming model is identical for all three processors and the instruction sets are prope, sub-sets of the complete architecture.
The resources available to the TS68000 user consist of the following :

- 1632 -bit data and address registers
- 16 megabyte direct addressing range
- 56 powerful instruction types
- Operations on five main data types
- Memory mapped I/O
- 14 addressing modes
- 4 available versions : $8 \mathrm{MHz}, 10 \mathrm{MHz}, 12.5 \mathrm{MHz}$ and 16 MHz .

As shown in the user programming model, the TS68000 offers 1632 -bit registers and a 32 -bit program counter. The first eight registers (D0-D7) are used as data registers for byte ( 8 -bit), word (16-bit), and long word ( 32 -bit) operations. The second set of seven registers (A0-A6) and the user stack pointer (USP) may be used as software stack pointers and base address registers. In addition, the registers may be used for word and long word operations. All of the 16 registers may be used as index registers.


## HMOS

high-density, N-CHANNEL, SILICON-GATE,DEPLETION LOAD

16-/32-BIT MICROPROCESSOR


CASE CB-523


FN SUFFIX PLCC 68

| PIN ASSIGNMENT |  |
| :---: | :---: |
| $\mathrm{D}_{4}{ }^{-1}$ | $64 \square 05$ |
| D3-2 | 63 ¢06 |
| $\mathrm{D} 2-3^{3}$ | 62 صD7 |
| 01.4 | 61 608 |
| DO-5 | 60 Р09 |
| $\overline{\text { AS }} 6$ | 59.010 |
| $\overline{U D S}{ }^{7}$ | 58 ص011 |
| LDS 8 | $57 \square 12$ |
| R/W̄-9 | 56 曰013 |
| DTACK 10 | 55 صD14 |
| $\overline{B G} \square^{11}$ | 54 ¢015 |
| BGACK 12 | 53 صGND |
| $\overline{B R} \square^{13}$ | 52 صA23 |
| $\mathrm{v}_{\mathrm{CC}} \mathrm{Cl}^{14}$ | 51 A222 |
| CLK-15 | 50 曰A21 |
| GND: 16 | $49 \mathrm{~m}^{\text {V } C C}$ |
| HALT 17 | 48 صA20 |
| RESET 18 | 47 صA19 |
| VMA 19 | 46 صA18 |
| E- 20 | 45 صA17 |
| VPAD 21 | 44 صA16 |
| $\overline{\text { BERR }-22 ~}$ | 43 РA15 |
| PL2 23 | 42 صA14 |
| IPLID24 | 41 DA13 |
| IPLOE 25 | 40 PA12 |
| FC2-26 | 39 РA11 |
| $\mathrm{FCl}^{-27}$ | 38 صA10 |
| FCOL 28 | 37 صА9 |
| A15 ${ }^{29}$ | 36 صА8 |
| A2 30 | 35 صА7 |
| A3 31 | 34 صа6 |
| ${ }^{4} 4$ | $33 \mathrm{Pa5}$ |

## SECTION 1 <br> INTRODUCTION

The TS68000 is the first implementation of the $6800016 / 32$ microprocessor architecture. The TS68000 has a 16 -bit data bus and 24 -bit address bus while the full architecture provides for 32 -bit address an data buses. It is completely code-compatible with the TS68008 8-bit data bus implementation of the 68000 and is downward code-compatible with the TS68020 32-bit implementation of the architecture. Any user-mode programs written using the TS68000 instruction set will run unchanged on the TS68008 and TS68020. This is possible because the user programming model is identical for all four processors and the instruction sets are proper sub-sets of the complete architecture.

The rasources available to the TS68000 user consist of the following :

- 17 32-Bit Data and Address Registers
- 16 Megabyte Direct Addressing Range
- 56 Powerful Instruction Types
- Operations on Five Main Data Types
- Memory Mapped I/O
- 14 Addressing Modes

As shown in the user programming model (Figure 1-1), the TS68000 offers 1632 -bit registers and a 32 -bit program counter. The first eight registers (D0-D7) are used as data registers for byte ( 8 -bit), word (16-bit), and long word (32-bit) operations. The second set of seven registers (A0-A6) and the user stack pointer (USP) may be used as software stack pointers and base address registers. In addition, the registers may be used for word and long word operations. All of the 16 registers may be used as index registers.

In supervisor mode, the upper byte of the status register and the supervisor stack pointer (SSP) are also available to the programmer. These registers are shown in Figure 1-2.

The status register (Figure 1-3) contains the interrupt mask (eight levels available) as well as the condition codes: extend (X), negative (N), zero (Z), overflow (V), and carry (C). Additional status bits indicate that the processor is in a trace ( $T$ ) mode and in a supervisor ( S ) or user state.

### 1.1 DATA TYPES AND ADDRESSING MODES

Five basic data types are supported. These data types are:

- Bits
- Words (16 bits)
- BCD Digits (4 bits)
- Long Words (32 bits)
- Bytes (8 bits)

In addition, operations on other data types such as memory addresses, status word data, etc., are provided in the instruction set.


Figure 1-1. User Programming Model


Figure 1-2. Supervisor Programming Model Supplement


Figure 1-3. Status Register

The 14 address modes, shown in Table 1-1, include six basic types:

- Register Direct
- Register Indirect
- Absolute
- Program Counter Relative
- Immediate
- Implied

Included in the register indirect addressing modes is the capability to do postincrementing, predecrementing, offsetting, and indexing. The program counter relative mode can also be modified via indexing and offsetting.

Table 1-1. Addressing Modes

| Addressing Modes | Syntax |
| :---: | :---: |
| Register Direct Addressing Data Register Direct <br> Address Register Direct | $\begin{aligned} & \text { Dn } \\ & \text { An } \end{aligned}$ |
| Absolute Data Addressing Absolute Short Absolute Long | $\begin{aligned} & x \times x \text { W } \\ & x \times x . L \end{aligned}$ |
| Program Counter Relative Addressing <br> Relative with Offset <br> Relative with Index Offset | $\begin{aligned} & d_{16}(\mathrm{PC}) \\ & \mathrm{d}_{8}\left(\mathrm{PC}, \mathrm{X}_{n}\right) \\ & \hline \end{aligned}$ |
| Register Indirect Addressing <br> Register Indirect <br> Postincrement Register Indirect <br> Predecrement Register Indirect <br> Register Indirect with Offset <br> Indexed Register Indirect with Offset | (An) <br> $(A n)+$ <br> - (An) <br> $d_{16}(A n)$ <br> $d g(A n, X n)$ |
| Immediate Data Addressing immediate Quick Immediate | $\begin{aligned} & \# x x x \\ & \# 1-\# 8 \end{aligned}$ |
| Implied Addressing Implied Register | SR USP SP PC |

[^34]
### 1.2 INSTRUCTION SET OVERVIEW

The TS68000 instruction set is shown in Table 1-2. Some additional instructions are variations, or subsets, of these and they appear in Table 1-3. Special emphasis has been given to the instruction set's support of structured high-level languages to facilitate ease of programming. Each instruction, with few exceptions, operates on bytes, words, and long words and most instructions can use any
of the 14 addressing modes. Combining instruction types, data types, and addressing modes, over 1000 useful instructions are provided. These instructions include signed and unsigned, multiply and divide, "quick" arithmetic operations, BCD arithmetic, and expanded operations (through traps).

Table 1-2. Instruction Set Summary

| Mnemonic | Description |
| :--- | :--- |
| ABCD | Add Decimal With Extend |
| ADD | Add |
| AND | Logical And |
| ASL | Arithmetic Shift Left |
| ASR | Arithmetic Shift Right |
| BCC | Branch Conditionally |
| BCHG | Bit Test and Change |
| BCLR | Bit Test and Clear |
| BRA | Branch Always |
| BSET | Bit Test and Set |
| BSR | Branch to Subroutine |
| BTST | Bit Test |
| CHK | Check Register Against Bounds |
| CLR | Clear Operand |
| CMP | Compare |
| DBCC | Test Condition, Decrement and Branch |
| DIVS | Signed Divide |
| DIVU | Unsigned Divide |
| EOR | Exclusive Or |
| EXG | Exchange Registers |
| EXT | Sign Extend |
| JMP | Jump |
| JSR | Jump to Subroutine |
| LEA | Load Effective Address |
| LINK | Link Stack |
| LSL | Logical Shift Left |
| LSR | Logical Shift Right |


| Mnemonic | Description |
| :--- | :--- |
| MOVE | Move |
| MULS | Signed Multiply |
| MULU | Unsigned Multiply |
| NBCD | Negate Decimal with Extend |
| NEG | Negate |
| NOP | No Operation |
| NOT | One's Complement |
| OR | Logical Or |
| PEA | Push Effective Address |
| RESET | Reset External Devices |
| ROL | Rotate Left without Extend |
| ROR | Rotate Right without Extend |
| ROXL | Rotate Left with Extend |
| ROXR | Rotate Right with Extend |
| RTE | Return from Exception |
| RTR | Return and Restore |
| RTS | Return from Subroutine |
| SBCD | Subtract Decimal with Extend |
| ScC | Set Conditional |
| STOP | Stop |
| SUB | Subtract |
| SWAP | Swap Data Register Halves |
| TAS | Test and Set Operand |
| TRAP | Trap |
| TRAPV | Trap on Overflow |
| TST | Test |
| UNLK | Unlink |
|  |  |

Table 1-3. Variations of Instruction Types

| Instruction <br> Type | Variation | ADD <br> ADDA <br> ADDQ <br> ADDI <br> ADDX |
| :--- | :--- | :--- |
| ADD | Add <br> Add Address <br> Add Quick <br> Add Immediate <br> Add with Extend |  |
| ANDI |  |  |
| ANDI to CCR | ANDI to SR <br> And Immediate <br> And Immediate to <br> Conditior Codes <br> And Immediate to <br> Status Register |  |
| CMP | CMP <br> CMPA <br> CMPM <br> CMPI | Compare <br> Compare Address <br> Compare Memory <br> Compare Immediate |
| EOR | EOR <br> EORI <br> EORI to CCR <br> EORI to SR | Exclusive Or <br> Exclusive Or Immediate <br> Exclusive Or Immediate <br> to Condition Codes <br> Exclusive Or Immediate <br> to Status Register |


| Instruction Type | Variation | Description |
| :---: | :---: | :---: |
| MOVE | MOVE MOVEA MOVEM MOVEP MOVEQ MOVE from SR MOVE to SR MOVE to CCR MOVE USP | Move <br> Move Address <br> Move Multiple Registers <br> Move Peripheral Data <br> Move Quick <br> Move from Status Register <br> Move to Status Register <br> Move to Condition Codes <br> Move User Stack Pointer |
| NEG | NEG <br> NEGX | Negate <br> Negate with Extend |
| OR | OR <br> ORI <br> ORI to CCR <br> ORI to SR | Logical Or Or Immediate Or Immediate to Condition Codes Or Immediate to Status Register |
| SUB | SUB <br> SUBA <br> SUBI <br> SUBO <br> SUBX | Subtract <br> Subtract Address <br> Subiract Immediate <br> Subtract Quick <br> Subtract with Extend |

## SECTION 2 <br> DATA ORGANIZATION AND ADDRESSING CAPABILITIES

This section contains a description of the registers and the data organization of the TS68000.

### 2.1 OPERAND SIZE

Operand sizes are defined as follows: a byte equals 8 bits, a word equals 16 bits, and a long word equals 32 bits. The operand size for each instruction is either explicitly encoded in the instruction or implicitly defined by the instruction operation. Implicit instructions support some subset of all three sizes.

### 2.2 DATA ORGANIZATION IN REGISTERS

The eight data registers support data operands of $1,8,16$, or 32 bits. The seven address registers together with the stack pointers support address operands of 32 bits.

### 2.2.1 Data Registers

Each data register is 32 bits wide. Byte operands occupy the low order 8 bits, word operands the low order 16 bits, and long word operands the entire 32 bits. The least significant bit is addressed as bit zero; the most significant bit is addressed as bit 31 .

When a data register is used as either a source or destination operand, only the appropriate low order portion is changed; the remaining high order portion is neither used nor changed.

### 2.2.2 Address Registers

Each address register and the stack pointer is 32 bits wide and holds a full 32-bit address. Address registers do not support the sized operands. Therefore, when an address register is used as a source operand, either the low order word or the entire long word operand is used depending upon the operation size. When an address register is used as the destination operand, the entire register is affected regardless of the operation size. If the operation size is word, any other operands are sign extended to 32 bits before the operation is performed.

### 2.3 DATA ORGANIZATION IN MEMORY

Bytes are individually addressable with the high order byte having an even address the same as the word, as shown in Figure 2-1. The low order byte has an odd address that is one count higher than the word address. Instructions and multibyte data are accessed only on word (even byte) boundaries. If a long word datum is located at address $n$ ( $n$ even), then the second word of that datum is located at address $n+2$.


Figure 2-1. Word Organization in Memory

The data types supported by the TS68000 are : bit data, integer data of 8,16 , or 32 bits, 32 -bit addresses and binary coded decimal data. Each of these data types is put in memory, as shown in Figure 2-2. The numbers indicate the order in which the data would be accessed from the processor.

### 2.4 ADDRESSING

Instructions for the TS68000 contain two kinds of information : the type of function to be performed and the location of the operand(s) on which to perform that function. The methods used to locate (address) the operand(s) are explained in the following paragraphs.

Instructions specify an operand location in one of three ways:
Register Specification - the number of the register is given in the register field of their instruction.

Effective Address - use of the different effective addressing modes.
Implicit Reference - the definition of certain instructions implies the use of specific registers.

### 2.5 INSTRUCTION FORMAT

Instructions are from one to five words in length as shown in Figure 2-3. The length of the instruction and the operation to be performed is specified by the first word of the instruction which is called the operation word. The remaining words further specify the operands. These words are either immediate operands or extensions to the effective address mode specified in the operation word.

### 2.6 PROGRAM/DATA REFERENCES

The TS68000 separates memory references into two classes : program references and data references. Program references, as the name implies, are references to that section of memory that contains the program being executed. Data references refer to that section of memory that contains data. Operand reads are from the data space except in the case of the program counter relative addressing mode. All operand writes are to the data space.

### 2.7 REGISTER SPECIFICATION

The register field within an instruction specifies the register to be used. Other fields within the instruction specify whether the register selected is an address or data register and how the register is to be used.

Integer Data - 1 Byte $=8$ Bits

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  | Byte 0 |  |  |  | LS8 |  |  |  | Byte 1 |  |  |  |  |
|  |  |  | Byte 2 |  |  |  |  |  |  |  | Byte 3 |  |  |  |  |

1 Word = 16 Bits
$\left.\begin{array}{|llllllllllllll|}\hline 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2\end{array}\right] 1$ 0
1 Long Word = 32 Bits

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2. | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB - | -Lon | Wor | - |  |  |  | ow |  |  |  |  |  |  |  | - |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Addresses - 1 Address $=32$ Bits

MSB $=$ Most Significant Bit $\quad$ LSB $=$ Least Significant Bit
Decımal Data -2 Binary Coded Decimal Digits $=1$ Byte

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

MSD $=$ Most Significant Digit $\quad$ LSD $=$ Least Significant Digit

Figure 2-2. Memory Data Organization


Figure 2-3. Instruction Operation Word General Format

### 2.8 EFFECTIVE ADDRESS

Most instructions specify the location of an operand by using the effective address field in the operation word. For example, Figure 2-4 shows the general format of the single-effective-address instruction operation word. The effective address is composed of two 3 -bit fields: the mode field and the register field. The value in the mode field selects the different address modes. The register field contains the number of a register.

The effective address field may require additional information to fully specify the operand. This additional information, called the effective address extension, is contained in the following word or words and is considered part of the instruction, as shown in Figure 2-3. The effective address modes are grouped into three categories: register direct, memory addressing, and special.


Figure 2-4. Single-Effective-Address Instruction Operation Word

### 2.8.1 Register Direct Modes

These effective addressing modes specify that the operand is in one of 16 multifunction registers.
2.8.1.1 DATA REGISTER DIRECT. The operand is in the data register specified by the effective address register field.
2.8.1.2 ADDRESS REGISTER DIRECT. The operand is in the address register specified by the effective address register field.

### 2.8.2 Memory Address Modes

These effective addressing modes specify that the operand is in memory and provide the specific address of the operand.
2.8.2.1 ADDRESS REGISTER INDIRECT. The address of the operand is in the address register specified by the register field. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.
2.8.2.2 ADDRESS REGISTER INDIRECT WITH POSTINCREMENT. The address of the operand is in the address register specified by the register field. After the operand address is used, it is incremented by one, two, or four depending upon whether the size of the operand is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is incremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.
2.8.2.3 ADDRESS REGISTER INDIRECT WITH PREDECREMENT. The address of the operand is in the address register specified by the register field. Before the operand address is used, it is decremented by one, two, or four depending upon whether the operand size is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is decremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.
2.8.2.4 ADDRESS REGISTER INDIRECT WITH DISPLACEMENT. This addressing mode requires one word of extension. The address of the operand is the sum of the address in the address register and the sign-extended 16 -bit displacement integer in the extension word. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine inftructions.
2.8.2.5 ADDRESS REGISTER INDIRECT WITH INDEX. This addressing mode requires one word of extension. The address of the operand is the sum of the address in the address register, the signextended displacement integer in the low order eight bits of the extension word, and the contents of the index register. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.

### 2.8.3 Special Address Modes

The special address modes use the effective address register field to specify the special addressing mode instead of a register number.
2.8.3.1 ABSOLUTE SHORT ADDRESS. This addressing mode requires one word of extension. The address of the operand is the extension word. The 16 -bit address is sign extended before it is used. The reference is classified as a data reference with the exception of the jump and jump-tosubroutine instructions.
2.8.3.2 ABSOLUTE LONG ADDRESS. This addressing mode requires two words of extension. The address of the operand is developed by the concatenation of the extension words. The high order part of the address is the first extension word; the low order part of the address is the second extension word. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.
2.8.3.3 PROGRAM COUNTER WITH DISPLACEMENT. This addressing mode requires one word of extension. The address of the operand is the sum of the address in the program counter and the sign-extended 16 -bit displacement integer in the extension word. The value in the program counter is the address of the extension word. The reference is classified as a program reference.
2.8.3.4 PROGRAM COIJNTER WITH INDEX. This addressing mode requires one word of extension. The address is the sum of the address in the program counter, the sign-extended displacement integer in the lower eight bits of the extension word, and the contents of the index register. The value in the program counter is the address of the extension word. This reference is classified as a program reference.
2.8.3.5 IMMEDIATE DATA. This addressing mode requires either one or two words of extension depending on the size of the operation.

Byte Operation - operand is low order byte of extension word
Word Operation - operand is extension word
Long Word Operation - operand is in the two extension words, high order 16 bits are in the first extension word, low order 16 bits are in the second extension word.
2.8.3.6 IMPLICIT REFERENCE. Some instructions make implicit reference to the program counter (PC), the system stack pointer (SP), the supervisor stack pointer (SSP), the user stack pointer (USP), or the status register (SR). A selected set of instructions may reference the status register by means of the effective address field. These are:

| ANDI to CCR | EORI to SR | MOVE to CCR |
| :--- | :--- | :--- |
| ANDI to SR | ORI to CCR | MOVE to SR |
| EORI to CCR | ORI to SR | MOVE from SR |

### 2.9 EFFECTIVE ADDRESS ENCODING SUMMARY

Table 2-1 is a summary of the effective addressing modes discussed in the previous paragraphs.

Table 2-1. Effective Address Encoding Summary

| Addressing Mode | Mode | Register |
| :---: | :---: | :---: |
| Data Register Direct | 000 | Register Number |
| Address Register Direct | 001 | Register Number |
| Address Register Indirect | 010 | Register Number |
| Address Register Indirect with <br> Postincrement | 011 | Register Number |
| Address Register Indirect with <br> Predecrement | 100 | Register Number |
| Address Register Indirect with <br> Displacement | 101 | Register Number |


| Addressing Mode | Mode | Register |
| :--- | :---: | :---: |
| Address Register Indirect with <br> Index | 110 | Register Number |
| Absolute Short | 111 | 000 |
| Absolute Long | 111 | 001 |
| Program Counter with <br> Displacement | 111 | 010 |
| Program Counter with Index | 111 | 011 |
| Immediate | 111 | 100 |

### 2.10 SYSTEM STACK

The system stack is used implicitly by many instructions; user stacks and queues may be created and maintained through the addressing modes. Address register seven (A7) is the system stack pointer (SP). The system stack pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), depending on the state of the $S$ bit in the status register. If the $S$ bit indicates supervisor state, SSP is the active system stack pointer and the USP cannot be referenced as an address register. If the $S$ bit indicates user state, the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory.

## SECTION 3 <br> INSTRUCTION SET SUMMARY

This section contains an overview of the form and structure of the TS68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

| Data Movement | Bit Manipulation |
| :--- | :--- |
| Integer Arithmetic | Binary Coded Decimal |
| Logical | Program Control |
| Shift and Rotate | System Control |

The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development.

### 3.1 DATA MOVEMENT OPERATIONS

The basic method of data acquisition (transfer and storage) is provided by the move (MOVE) instruction. The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to register. Address move instructions allow word and long word operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (LEA), push effective address (PEA), link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 3-1 is a summary of the data movement operations.

Table 3-1. Data Movement Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| EXG | 32 | $R x \rightarrow R y$ |
| LEA | 32 | $E A \backsim A n$ |
| LINK | - | $A n \rightarrow-(S P)$ <br> $S P \rightarrow A n$ <br> $S P$ <br> displacement $\rightarrow S P$ |
| MOVE | $8,16,32$ | $S \rightarrow d$ |
| MOVEM | 16,32 | $(E A) \rightarrow A n, D n$ <br> $A n, D n \rightarrow E A$ |


| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| MOVEP | 16,32 | $(E A) \rightarrow \mathrm{Dn}$ <br> $\mathrm{Dn} \rightarrow(\mathrm{EA})$ |
| MOVEQ | 8 | $\# \mathrm{xxx} \rightarrow \mathrm{Dn}$ |
| PEA | 32 | $E A \rightarrow-(\mathrm{SP})$ |
| SWAP | 32 | $\mathrm{Dn}[31: 16] \rightarrow \mathrm{Dn}[15: 0]$ |
| UNLK | - | $A n \rightarrow \mathrm{Sp}$ <br> $(S P) \rightarrow \rightarrow \mathrm{An}$ |

[^35]
### 3.2 INTEGER ARITHMETIC OPERATIONS

The arithmetic operations include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, with data operations accepting all operand sizes. Address operations are limited to legal address size operands (16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long word product, and a long word dividend with word divisor to produce a word quotient with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 3-2 is a summary of the integer arithmetic operations.

Table 3-2. Integer Arithmetic Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| ADD | 8, 16, 32 <br> 16, 32 | $\begin{aligned} & D_{n}+(E A) \rightarrow D_{n} \\ &(E A)+D n \rightarrow(E A) \\ &(E A)+(x \times x \rightarrow(E A) \\ & A_{n}+(E A) \rightarrow A_{n} \end{aligned}$ |
| ADDX | $\begin{gathered} 8,16,32 \\ 16,32 \end{gathered}$ | $\begin{array}{r} D x+D y+x \rightarrow D x \\ -(A x)+-(A y)+x \rightarrow(A x) \\ \hline \end{array}$ |
| CLR | 8, 16, 32 | $0 \rightarrow E A$ |
| CMP | $\begin{gathered} 8,16,32 \\ 16,32 \end{gathered}$ | $\begin{gathered} D n-(E A) \\ (E A)-A x x x \\ (A x)+-(A y)- \\ A n-(E A) \end{gathered}$ |
| DIVS | $32 \div 16$ | $\mathrm{Dn}_{n} \div(\mathrm{EA}) \rightarrow \mathrm{Dn}_{n}$ |
| DIVU | $32 \div 16$ | $D_{n} \div(E A) \rightarrow D_{n}$ |
| EXT | $\begin{aligned} \hline 8 \rightarrow 16 \\ 16 \rightarrow 32 \\ \hline \end{aligned}$ | $\begin{aligned} &\left(D_{n}\right)_{8} \rightarrow D_{16} \\ &\left(D_{n} 1_{6}\right. \rightarrow D_{32} \\ & \hline \end{aligned}$ |
| MULS | $16 \times 16 \rightarrow 32$ | $\mathrm{Dn}_{\mathrm{n} \times(E A)} \rightarrow \mathrm{Dn}^{\text {n }}$ |
| MULU | $16 \times 16 \rightarrow 32$ | $D_{n} \times(E A) \rightarrow D_{n}$ |
| NEG | 8, 16, 32 | $0-(E A) \rightarrow(E A)$ |
| NEGX | 8, 16, 32 | $0-(E A)-X \rightarrow(E A)$ |
| SUB | $\begin{gathered} 8,16,32 \\ 16,32 \end{gathered}$ | $\begin{aligned} D_{n}-(E A) & \rightarrow D_{n} \\ (E A)-D n & (E A) \\ (E A)-* \times x & \rightarrow(E A) \\ A_{n}-(E A) & \rightarrow A_{n} \end{aligned}$ |
| SUBX | 8, 16, 32 | $\begin{aligned} & D x-D y-x \rightarrow D x \\ &-(A x)--(A y)-x \rightarrow(A x) \\ & \hline \end{aligned}$ |
| TAS | 8 | $[E A]-0,1 \rightarrow E A[7]$ |
| TST | 8, 16, 32 | (EA) -0 |

NOTES:
( )= bit number
$-11=$ indirect with predecrement
( ) $+=$ indirect with postdecrement
\# = immediate data

### 3.3 LOGICAL OPERATIONS

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 3-3 is a summary of the logical operations.

Table 3-3. Logical Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| AND | $8,16,32$ | Dn $\Lambda(E A) \rightarrow \mathrm{Dn}$ <br> $(E A) \Lambda D n \rightarrow(E A)$ <br> $(E A) \Lambda \# x x x \rightarrow(E A)$ |
| OR | $8,16,32$ | Dn $\vee(E A) \rightarrow D n$ <br> $(E A) \vee D n \rightarrow(E A)$ <br> $(E A) \vee \# x x x \rightarrow(E A)$ |
| EOR | $8,16,32$ | $(E A) \oplus D y \rightarrow(E A)$ <br> $(E A) \oplus \# x \times x \rightarrow(E A)$ |
| NOT | $8,16,32$ | $\sim(E A) \rightarrow(E A)$ |

NOTES:

$$
\begin{array}{ll}
\text { ~ = invert } & V=\text { logical OR } \\
\#=\text { immediate data } & \Theta=\text { logical exclusive OR } \\
\Lambda=\text { logical AND } &
\end{array}
$$

### 3.4 SHIFT AND ROTATE OPERATIONS

Shift operations in both directions are provided by the arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand sizes and allow a shift count specified in a data register.

Memory shifts and rotates are for word operands only and allow only single-bit shifts or rotates.
Table 3-4 is a summary of the shift and rotate operations.
Table 3-4. Shift and Rotate Operations


### 3.5 BIT MANIPULATION OPERATIONS

Bit manipulation operations are accomplished using the following instructions: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 3-5 is a summary of the bit manipulation operations. ( $Z$ is bit 2 of the status register.)

Table 3-5. Bit Manipulation Operations
$\left.\begin{array}{l}\begin{array}{|c|c|c|}\hline \text { Instruction } & \text { Operand Size } & \text { Operation } \\ \hline \text { BTST } & 8,32 & \text { ~bit of }(E A) \rightarrow Z\end{array} \\ \hline \text { BSET }\end{array} 8,32 \quad \begin{array}{c}\sim \text { bit of }(E A) \rightarrow Z \\ 1 \rightarrow \text { bit of EA }\end{array}\right]$

### 3.6 BINARY CODED DECIMAL OPERATIONS

Multiprecision arithmetic operations on binary coded decimal numbers are accomplished using the following instructions: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 3-6 is a summary of the binary coded decimal operations.

Table 3-6. Binary Coded Decimal Operations

| Instruction | $\begin{aligned} & \text { Operand } \\ & \text { Size } \end{aligned}$ | Operation |
| :---: | :---: | :---: |
| ABCD | 8 | $\begin{gathered} D \times 10+\text { Dy } 10+X \rightarrow D x \\ -(\text { Ax) } 10+- \text { (Ay) } 10+x \rightarrow(\text { Ax }) \end{gathered}$ |
| SBCD | 8 | $\begin{gathered} \mathrm{D} x_{10}-\mathrm{Dy} 10^{-X} \rightarrow \mathrm{Dx} \\ -(\mathrm{Ax})_{10^{-}-(\mathrm{Ay})_{10}-\mathrm{x} \rightarrow(\mathrm{Ax})} \end{gathered}$ |
| NBCD | 8 | $0-(E A) 10-X \rightarrow$ (EA) |

NOTE: $-(1)=$ indirect with predecrement

### 3.7 PROGRAM CONTROL OPERATIONS

Program control operations are accomplished using a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 3-7.

The conditional instructions provide setting and branching for the following conditions:

| CC - carry clear | LS - low or same |
| :--- | :--- |
| CS - carry set | LT - less than |
| EQ - equal | $\mathrm{MI}-$ minus |
| $\mathrm{F}-$ never true | $\mathrm{NE}-$ not equal |
| $\mathrm{GE}-$ greater or equal | $\mathrm{PL}-$ plus |
| $\mathrm{GT}-$ greater than | $\mathrm{T}-$ always true |
| $\mathrm{HI}-$ high | $\mathrm{VC}-$ no overflow |
| LE - less or equal | $\mathrm{VS}-$ overflow |

Table 3-7. Program Control Operations


### 3.8 SYSTEM CONTROL OPERATIONS

System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 3-8.

Table 3-8. System Control Operations

| Instruction | Operation |
| :--- | :--- |
| Privileged | Logical AND to Status Register |
| ANDI to SR | Logical EOR to Status Register |
| EORI to SR | Load New Status Register |
| MOVE FA to SR | Move User Stack Ponter |
| MOVE USP | Logical OR to Siatus Register |
| ORI to SR | Reset External Devices |
| RESET | Return from Exception |
| RTE | Stop Program Execution |
| STOP |  |
| Trap Generating | Check Data Register Against Upper Bounds |
| CHK | Trap |
| TRAP | Trap on Overtlow |
| TRAPV |  |
| Status Register | Logical AND to Condition Codes |
| ANDI to CCR | Logical EOR to Condition Codes |
| EORI to CCR | Load New Condition Codes |
| MOVE EA to CCR | Store Status Register |
| MOVE SR to EA | Logical OR to Condition Codes |
| ORI to CCR |  |

## SECTION 4 SIGNAL AND BUS OPERATION DESCRIPTION

This section contains a brief description of the input and output signals. A discussion of bus operation during the various machine cycles and operations is also given.

## NOTE

The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The term assert or assertion is used to indicate that a signal is active or true, independent of whether that level is represented by a high or low voltage. The term negate or negation is used to indicate that a signal is inactive or false.

### 4.1 SIGNAL DESCRIPTION

The input and output signals can be functionally organized into the groups shown in Figure 4-1. The following paragraphs provide a brief description of the signals and a reference (if applicable) to other paragraphs that contain more detail about the function being performed.


Figure 4-1. Input and Output Signals

### 4.1.1 Address Bus (A1 through A23)

This 23-bit, unidirectional, three-state bus is capable of addressing 8 megawords of data. It provides the address for bus operation during all cycles except interrupt cycles. During interrupt cycles, address lines A1, A2, and A3 provide information about what level interrupt is being serviced while address lines A4 through A23 are all set to a logic high.

### 4.1.2 Data Bus (D0 through D15)

This 16 -bit, bidirectional, three-state bus is the general purpose data path. It can transfer and accept data in either word or byte length. During an interrupt acknowledge cycle, the external device supplies the vector number on data lines D0-D7

### 4.1.3 Asynchronous Bus Control

Asynchronous data transfers are handled using the following control signals: address strobe, read/write, upper and lower data strobes, and data transfer acknowledge. These signals are explained in the following paragraphs.
4.1.3.1 ADDRESS STROBE ( $\overline{\mathrm{AS}})$. This signal indicates that there is a valid address on the address bus.
4.1.3.2 READ/WRITE (R/ $\overline{\mathbf{W}}$ ). This signal defines the data bus transfer as a read or write cycle. The $R / \bar{W}$ signal also works in conjunction with the data strobes as explained in the following paragraph.
4.1.3.3 UPPER AND LOWER DATA STROBE ( $\overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}$ ). These signals control the flow of data on the data bus, as shown in Table 4-1. When the $R / \bar{W}$ line is high, the processor will read from the data bus as indicated. When the $R / \bar{W}$ line is iow, the processor will write to the data bus as shown

Table 4-1. Data Strobe Control of Data Bus

| $\overline{\text { UDS }}$ | $\overline{\text { LDS }}$ | R/ $\bar{W}$ | D8-D15 | D0-D7 |
| :---: | :---: | :---: | :---: | :---: |
| High | High | - | No Valid Data | No Valıd Data |
| Low | Low | High | Valid Data Bits <br> $8-15$ | Valıd Data Bits <br> 0.7 |
| High | Low | High | No Valid Data | Valıd Data Bits <br> $0-7$ |
| Low | High | High | Valid Data Bits <br> $8-15$ | No Valid Data |
| Low | Low | Low | Valid Data Bits <br> $8-15$ | Valıd Data Bits <br> $0-7$ |
| High | Low | Low | Valid Data Bits <br> $0.7 *$ | Valid Data Bits <br> 0.7 |
| Low | High | Low | Valid Data Bits <br> $8-15$ | Valıd Data Bits <br> $8-15 *$ |

* These conditions are a result of current implementation and may not appear on future devices
4.1.3.4 DATA TRANSFER ACKNOWLEDGE ( $\overline{\text { DTACK }}$ ). This input indicates that the data transfer is completed. When the processor recognizes DTACK during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle is terminated (Refer to 4.4 ASYNCHRONOUR VERSUS SYNCHRONOUS OPERATION)


### 4.1.4 Bus Arbitration Control

The three signals, bus request, bus grant, and bus grant acknowledge, form a bus arbitration circuit to determine which device will be the bus master device.
4.1.4.1 BUS REQUEST ( $\overline{B R}$ ). This input is wire ORed with all other devices that could be bus masters. This input indicates to the processor that some other device desires to become the bus master.
4.1.4.2 BUS GRANT ( $\overline{\mathrm{BG}}$ ). This output indicates to all other potential bus master devices that the processor will release bus control at the end of the current bus cycle.
4.1.4.3 BUS GRANT ACKNOWLEDGE ( $\overline{\text { BGACK }}$ ). This input indicates that some other device has become the bus master. This signal should not be asserted until the following four conditions are met:

1. a bus grant has been received,
2. address strobe is inactive which indicates that the microprocessor is not using the bus,
3. data transfer acknowledge is inactive which indicates that neither memory nor peripherals are using the bus, and
4. bus grant acknowledge is inactive which indicates that no other device is still claiming bus mastership.

### 4.1.5 Interrupt Control ( $\overline{\mathrm{PLO}}, \overline{\mathrm{PL}}, \overline{\mathrm{PL} 2}$ )

These input pins indicate the encoded priority level of the device requesting an interrupt. Level seven is the highest priority while level zero indicates that no interrupts are requested. Level seven cannot be masked. The least significant bit is given in $\overline{\mathrm{PLO}}$ and the most significant bit is contained in $\overline{P L 2}$. These lines must remain stable until the processor signals interrupt acknowledge (FC0-FC2 are all high) to insure that the interrupt is recognized.

### 4.1.6 System Control

The system control inputs are used to either reset or halt the processor and to indicate to the processor that bus errors have occurred. The three system control inputs are explained in the following paragraphs.
4.1.6.1 BUS ERROR ( $\overline{B E R R}$ ). This input informs the processor that there is a problem with the cycle currently being executed. Problems may be a result of:

1. nonresponding devices,
2. interrupt vector number acquisition failure,
3. illegal access request as determined by a memory management unit, or
4. other application dependent errors.

The bus error signal interacts with the halt signal to determine if the current bus cycle should be reexecuted or if exception processing should be performed.

Refer to 4.2.4 Bus Error and Halt Operation for additional information about the interaction of the bus error and halt signals.
4.1.6.2 RESET ( $\overline{\operatorname{RESET}}$ ). This bidirectional signal line acts to reset (start a system initialization sequence) the processor in response to an external reset signal. An internally generated reset (result
of a $\overline{\text { RESET }}$ instructioni) causes all external devices to be reset and the internal state of the processor is not affected. A total system reset (processor and external devices) is the result of external HALT and $\overline{\text { RESET }}$ signals applied at the same time. Refer to 4.2.5 Reset Operation for further information.
4.1.6.3 HALT ( $\overline{\text { HALT}})$. When this bidirectional line is driven by an external device, it will cause the processor to stop at the completion of the current bus cycle. When the processor has been halted using this input, all control signals are inactive and all three-state lines are put in their highimpedance state (refer to Table 4-3). Refer to 4.2.4 Bus Error and Halt Operation for additional information about the interaction between the HALT and bus error signals.

When the processor has stopped executing instructions, such as in a double bus fault condition (refer to 4.2.4.4 DOUBLE BUS FAULTS), the HALT line is driven by the processor to indicate to external devices that the processor has stopped.

### 4.1.7 EF6800 Peripheral Control

These control signals are used to allow the interfacing of synchronous EF6800 peripheral devices with the asynchronous TS68000. These signals are explained in the following paragraphs.
4.1.7.1 ENABLE (E). This signal is the standard enable signal common to all EF6800 type peripheral devices. The period for this output is ten TS68000 clock periods (six clocks low, four clocks high). Enable is generated by an internal ring counter which may come up in any state (i.e., at power on, it is impossible to guarantee phase relationship of $E$ to CLK). E is a free-running clock and runs regardless of the state of the bus on the MPU.
4.1.7.2 VALID PERIPHERAL ADDRESS ( $\overline{\mathrm{VPA}}$ ). This input indicates that the device or region addressed is an EF6800 Family device and that data transfer should be synchronized with the enable (E) signal. This input also indicates that the processor should use automatic vectoring for an interrupt. Refer to SECTION 6 INTERFACE WITH EF6800 PERIPHERALS.
4.1.7.3 VALID MEMORY ADDRESS ( $\overline{\mathrm{VMA}}$ ). This output is used to indicate to EF6800 peripheral devices that there is a valid address on the address bus and the processor is synchronized to enable. This signal only responds to a valid peripheral address ( $\overline{\mathrm{VPA}}$ ) input which indicates that the peripheral is an EF6800 Family device.

### 4.1.8 Processor Status (FC0, FC1, FC2)

These function code outputs indicate the state (user or supervisor) and the cycle type currently being executed, as shown in Table 4-2. The information indicated by the function code outputs is valid whenever address strobe ( $\overline{\mathrm{AS}}$ ) is active.

Table 4-2. Function Code Outputs

| Function Code Output |  | Cycle Type |  |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 |  | (Undefined, Reserved) |
| Low | Low | Low | User Data |
| Low | Low | High | User |
| Low | High | Low | User Program |
| Low | High | High | (Undefined, Reserved) |


| Function Code Output |  |  | Cycle Type |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 | FCO |  |
| High | Low | Low | (Un) |
| High | Low | High | Supervisor Data |
| High | High | Low | Supervisor Program |
| High | High | High | Interrupt Acknowledge |

### 4.1.9 Clock (CLK)

The clock input is a TTL-compatible signal that is internally buffered for development of the internal clocks needed by the processor. The clock input should not be gated off at any time and the clock signal must conform to minimum and maximum pulse width times.

### 4.1.10 Signal Summary

Table 4-3 is a summary of all the signals discussed in the previous paragraphs

Table 4-3. Signal Summary

| Signal Name | Mnemonic | Input/Output | Active State | $\mathrm{Hi}-\mathrm{Z}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | On HALT | On BGACK |
| Address Bus | A1.A23 | Outpu: | Higr | ves | ves |
| Data Bus | D0.D15 | inpu: Output | Higr | Yes | Yes |
| Address Strobe | $\overline{\mathrm{AS}}$ | Output | Lon | Nic | yes |
| Read/Write | $R \cdot \bar{W}$ | Output | Read. Higr Write-Lon | $N$ | Yes |
| Upper and Lower Data Stobes | $\overline{\overline{U S S}}, \overline{\mathrm{DS}}$ | Output | Lon | No | Yes |
| Data Transfer Acknowledge | $\overline{\text { DTACK }}$ | inpu: | Lon | No | Vc |
| Bus Request | $\overline{\mathrm{BR}}$ | input | Low | No | Vo |
| Bus Grant | BG | Output | Lon | No | Vo |
| Bus Grant Acknowledge | BGACK | Input | Low | い | $\checkmark$ |
| Interrupt Priority Level | $\overline{\mathrm{PLO}}, \overline{\mathrm{PLL1}}, \overline{\mathrm{PLL2}}$ | input | Lon | No | N0 |
| Bus Error | BERR | Input | Lon | No | No |
| Reset | RESET | Input Output | Low | Nol | vol |
| Halt | $\overline{\text { HALT }}$ | Input Output | Low | Nol | vol |
| Enable | E | Output | Higr | No | Ve |
| Valid Memory Address | $\overline{\text { VMA }}$ | Outpui | Low | No | res |
| Valıd Perıpheral Address | $\overline{\mathrm{VPA}}$ | Inpu: | Luw | No | N |
| Function Code Outpu! | FC0, FC1, FC2 | Output | High | No | Yes |
| Clock | CLK | Input | Hign | No | No |
| Power Input | $\mathrm{V}_{\text {CC }}$ | Input | - | -- | - |
| Ground | GND | Input | - | - | - |

NOTE
1 Open drain

### 4.2 BUS OPERATION

The following paragraphs explain control signal and bus operation during data transfer operations, bus arbitration, bus error and hait conditions, and reset operation.

### 4.2.1 Data Transfer Operations

Transfer of data between devices involves the following leads:

1. address bus A1 through A23,
2. data bus D0 through D15, and
3. control signals.

The address and data buses are separate parallel buses used to transfer data using an asynchronous bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. In addition, the bus master is responsible for deskewing the acknowledge and data signals from the slave device.

The following paragraphs explain the read, write, and read-modify-write cycles. The indivisible read-modify-write cycle is the method used by the TS68000 for interlocked multiprocessor communications.
4.2.1.1 READ CYCLE. During a read cycle, the processor receives data from the memory or a peripheral device. The processor reads bytes of data in all cases. If the instruction specifies a word (or double word) operation, the processor reads both upper and lower bytes simultaneously by asserting both upper and lower data strobes. When the instruction specifies byte operation, the processor uses an internal AO bit to determine which byte to read and then issues the data strobe required for that byte. For byte operations, when the AO bit equals zero, the upper data strobe is issued. When the AO bit equals one, the lower data strobe is issued. When the data is received, the processor correctly positions it internally.

A word read cycle flowchart is given in Figure 4-2. A byte read cycle flowchart is given in Figure 4-3. Read cycle timing is given in Figure 4-4. Figure 4-5 details word and byte read cycle operations.


Figure 4-2. Word Read Cycle Flowchart


Figure 4-3. Byte Read Cycle Flowchart


Figure 4-4. Read and Write Cycle Timing Diagram


Figure 4-5. Word and Byte Read Cycle Timing Diagram
4.2.1.2 WRITE CYCLE. During a write cycle, the processor sends data to either the memory or a peripheral device. The processor writes bytes of data in all cases. If the instruction specifies a word operation, the processor writes both bytes. When the instruction specifies a byte operation, the processor uses an internal A0 bit to determine which byte to write and then issues the data strobe required for that byte. For byte operations, when the A0 bit equals zero, the upper data strobe is issued. When the AO bit equals one, the lower data strobe is issued. A word write flowchart is given in Figure 4-6. A byte write cycle flowchart is given in Figure 4-7. Write cycle timing is given in Figure $4-4$. Figure 4-8 details word and byte write cycle operation.


Figure 4-6. Word Write Cycle Flowchart


Figure 4-7. Byte Write Cycle Flowchart


Figure 4-8. Word and Byte Write Cycle Timing Diagram
4.2.1.3 READ-MODIFY-WRITE CYCLE. The read-modify-write cycle performs a read, modifies the data in the arithmetic-logic unit, and writes the data back to the same address. In the TS68000, this. cycle is indivisible in that the address strobe is asserted throughout the entire cycle. The test and set (TAS) instruction uses this cycle to provide meaningful communication between processors in a multiple processor environment. This instruction is the only instruction that uses the read-modifywrite cycles and since the test and set instruction only operates on bytes, all read-modify-write cycles are byte operations. A read-modify-write flowchart is given in Figure 4-9 and a timing diagram is given in Figure 4-10.


Figure 4-9. Read-Modify-Write Cycle Flowchart


Figure 4-10. Read-Modify-Write Cycle Timing Diagram

### 4.2.2 Bus Arbitration

Bus arbitration is a technique used by master-type devices to request, be granted, and acknowledge bus mastership. In its simplest form, it consists of the following

1. asserting a bus mastership request,
2. receiving a grant that the bus is available at the end of the current cycle, and
3. acknowledging that mastership has been assumed

Figure 4-11 is a flowchart showing the detail involved in a request from a single device. Figure 4-12 is a timing diagram for the same operation. This technique allows processing of bus requests during data transfer cycles.

The timing diagram shows that the bus request is negated at the time that an acknowledge is asserted. This type of operation would be true for a system consisting of the processor and one device capable of bus mastership. In systems having a number of devices capable of bus mastership, the bus request line from each device is wire ORed to the processor. In this system, it is easy to see that there could be more than one bus request being made. The timing diagram shows that the bus grant signal is negated a few clock cycles after the transition of the acknowledge ( $\overline{\mathrm{BGACK}}$ ) signal.

However, if the bus requests are still pending, the processor will assert another bus grant within a few clock cycles after it was negated. This additional assertion of bus grant allows external arbitration circuitry to select the next bus master before the current bus master has completed its requirements. The following paragraphs provide additional information about the three steps in the arbitration process.

| Request the Bus |
| :--- |
|  |
|  |
|  |


| Grant Bus Arbitration |
| :--- |
| 1) Assert Bus Grant $(\overline{\mathrm{BG}})$ |


| Terminate Arbitration |
| :--- |
| 1)Negate $\overline{B G}$ (and Wait for $\overline{\mathrm{BGACK}}$ to be <br> Negated) Acknowledge $(\overline{\mathrm{BGACK}})$ to Become New <br> Master <br> 4) <br> Bus Master Negates $\overline{\mathrm{BR}}$ |

1) External Arbitration Determines Next Bus Master
2) Next Bus Master Waits for Current Cycle to Complete
3) Next Bus Master Asserts Bus Grant Acknowledge (BGACK) to Become New 4) Bus Master Negates $\overline{B R}$ Negated)

## Acknowledge Bus Mastership

 Complete$\qquad$


Release Bus Mastership

1) Negate $\overrightarrow{\text { BGACK }}$

Figure 4-11. Bus Arbitration Cycle Flowchart


Figure 4-12. Bus Arbitration Cycle Timing Diagram
4.2.2.1 REQUESTING THE BUS. External devices capable of becoming bus masters request the bus by asserting the bus request ( $\overline{\mathrm{BR}}$ ) signal. This is a wire-ORed signal (although it need not be constructed from open-collector devices) that indicates to the processor that some external device requires control of the external bus. The processor is effectively at a lower bus priority level than the external device and will relinquish the bus after it has completed the last bus cycle it has started.

When no acknowledge is received before the bus request signal goes inactive, the processor will continue processing when it detects that the bus request is inactive. This allows ordinary processing to continue if the arbitration circuitry responded to noise inadvertently.
4.2.2.2 RECEIVING THE BUS GRANT. The processor asserts bus grant ( $\overline{\mathrm{BG}}$ ) as soon as possible. Normally this is immediately after internal synchronization. The only exception to this occurs when the processor has made an internal decision to execute the next bus cycle but has not progressed far enough into the cycle to have asserted the address strobe ( $\overline{\mathrm{AS}}$ ) signal. In this case, bus grant will be delayed until $\overline{\mathrm{AS}}$ is asserted to indicate to external devices that a bus cycle is being executed.

The bus grant signal may be routed through a daisy chained network or through a specific priorityencoded network. The processor is not affected by the external method of arbitration as long as the protocol is obeyed.
4.2.2.3 ACKNOWLEDGEMENT OF MASTERSHIP. Upon receiving a bus grant, the requesting device waits until address strobe, data transfer acknowledge, and bus grant acknowledge are negated before issuing its own BGACK. The negation of the address strobe indicates that the previous master hås completed its cycle; the negation of bus grant acknowledge indicates that the previous master has released the bus. (While address strobe is asserted, no device is allowed to "break into" a cycle.) The negation of data transfer acknowledge indicates the previous slave has terminated its connection to the previous master. Note that in some applications data transfer acknowledge might not enter into this function. General purpose devices would then be connected such that they were only dependent on address strobe. When bus grant acknowledge is issued, the
device is a bus master until it negates bus grant acknowledge. Bus grant acknowledge should not be negated until after the bus cycle(s) is (are) completed. Bus mastership is terminated at the negation of bus grant acknowledge.

The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still pending, another bus grant will be asserted within a few clocks of the negation of the bus grant. Refer to 4.2.3 Bus Arbitration Control. Note that the processor does not perform any external bus cycles before it re-asserts bus grant

### 4.2.3 Bus Arbitration Control

The bus arbitration control unit in the TS68000 is implemented with a finite state machine. A state diagram of this machine is shown in Figure 4-13. All asynchronous signals to the TS68000 are synchronized before being used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time ( \#47) has been met (see Figure 4-14). The input signal is sampled on the falling edge of the clock and is valid internally after the next falling edge.

As shown in Figure 4-13, input signals labeled $R$ and $A$ are internally synchronized on the bus request and bus grant acknowledge pins respectively. The bus grant output is labeled $G$ and the internal three-state control signal $T$. If $T$ is true, the address, data, and control buses are placed in a high-impedance state when $\overline{\mathrm{AS}}$ is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level. State changes (valid outputs) occur on the next rising edge after the internal signal is valid.

A timing diagram of the bus arbitration sequence during a processor bus cycle is shown in Figure 4-15. The bus arbitration sequence while the bus is inactive (i.e., executing internal operations such as a multiply instruction) is show in Figure 4-16.

If a bus request is made at a time when the MPU has already begun a bus cycle but $\overline{\mathrm{AS}}$ has not been asserted (bus state SO ), $\overline{\mathrm{BG}}$ will not be asserted on the next rising edge. Instead, $\overline{\mathrm{BG}}$ will be delayed until the second rising edge following its internal assertion. This sequence is shown in Figure 4-17.

### 4.2.4 Bus Error and Halt Operation

In a bus architecture that requires a handshake from an external device, the possibility exists that the handshake might not occur. Since different systems will require a different maximum response time, a bus error input is provided. External circuitry must be used to determine the duration between address strobe and data transfer acknowledge before issuing a bus error signal. When a bus error signal is received, the processor has two options: initiate a bus error exception sequence or try running the bus cycle again.


Figure 4-13. TS68000 Bus Arbitration Unit State Diagram


Figure 4-14. Timing Relationship of External Asynchronous Inputs to Internal Signals


Figure 4-15. Bus Arbitration Timing Diagram - Processor Active


Figure 4-16. Bus Arbitration Timing Diagram - Bus Inactive


Figure 4-17. Bus Arbitration Timing Diagram - Special Case
4.2.4.1 BUS ERROR OPERATION. When the bus error signal is asserted, the current bus cycle is terminated. If $\overline{B E R R}$ is asserted before the falling edge of $\mathrm{S} 2, \overline{\mathrm{AS}}$ will be negated in S 7 in either a read or write cycle. As long as $\overline{B E R R}$ remains asserted, the data and address buses will be in the high-impedence state. When $\overline{B E R R}$ is negated, the processor will begin stacking for exception processing. Figure $4-18$ is a timing diagram for the exception sequence. The sequence is composed of the following elements:

1. stacking the program counter and status register,
2. stacking the error information,
3. reading the bus error vector table entry, and
4. executing the bus error handler routine.

The stacking of the program counter and the status register is the same as if an interrupt had occurred. Several additional items are stacked when a bus error occurs. These items are used to determine the nature of the error and correct it, if possible. The bus error vector is vector number two located at address $\$ 000008$. The processor loads the new program counter from this location. A software bus error handler routine is then executed by the processor. Refer to 5.2 EXCEPTION PROCESSING for additional information.


Figure 4-18. Bus Error Timing Diagram
4.2.4.2 RE-RUN OPERATION. When, during a bus cycle, the processor receives a bus error signal and the halt pin is being driven by an external device, the processor enters the re-run sequence. Figure $4-19$ is a timing diagram for re-running the bus cycle.

The processor terminates the bus cycle, then puts the address and data output lines in the highimpedence state. The processor remains "halted", and will not run another bus cycle until the halt signal is removed by external logic. Then the processor will re-run the previous cycle using the same function codes, the same data (for a write operation), and the same controls. The bus error signal should be removed at least one clock cycle before the halt signal is removed.

## NOTE

The processor will not re-run a read-modify-write cycle. This restriction is made to guarantee that the entire cycle runs correctly and that the write operation of a test-andset operation is performed without ever releasing $\overline{A S}$. If $\overline{B E R R}$ and $\overline{\text { HALT }}$ are asserted during a read-modify-write bus cycle, a bus error operation results.


Figure 4-19. Re-Run Bus Cycle Timing Diagram
4.2.4.3 HALT OPERATION. The halt input signal to the TS68000 performs a halt/run/single-step function in a similar fashion to the EF6800 halt function. The halt and run modes are somewhat self explanatory in that when the halt signal is constantly active the processor "halts" (does nothing) and when the halt signal is constantly inactive the processor "runs" (does something).

This single-step mode is derived from correctly timed transitions on the halt signal input. It forces the processor to execute a single bus cycle by entering the run mode until the processor starts a bus cycle then changing to the halt mode. Thus, the single-step mode allows the were to procert through (and therefore debug.) processor operations one bus cycle at a time.

Figure 4-20 details the timing required for correct single-step operations. Some care must be exercised to avoid harmful interactions between the bus error signal and the halt pin when using the single-cycle mode as a debugging tool. This is also true of interactions between the halt and reset lines since these can reset the machine.


Figure 4-20. Halt Processor Timing Diagram

When the processor completes a bus cycle after recognizing that the halt signal is active, most three-state signals are put in the high-impedence state, these include:

1. address lines, and
2. data lines.

This is required for correct performance of the re-run bus cycle operation.
While the processor is honoring the halt request, bus arbitration performs as usual. That is, halting has no effect on bus arbitration. It is the bus arbitration function that removes the control signals from the bus.

The halt function and the hardware trace capability allow the hardware debugger to trace single bus cycles or single instructions at a time. These processor capabilities, along with a software debugging package, give total debugging flexibility.
4.2.4.4 DOUBLE BUS FAULTS. When a bus error exception occurs, the processor will attempt to stack several words containing information about the state of the machine. If a bus error exception occurs during the stacking operation, there have been two bus errors in a row. This is commonly referred to as a double bus fault. When a double bus fault occurs, the processor will halt. Once a bus error exception has occurred, any bus error exception occurring before the execution of the next instruction constitutes a double bus fault.

Note that a bus cycle which is re-run does not constitute a bus error exception and does not contribute to a double bus fault. Note also that this means that as long as the external hardware requests it, the processor will continue to re-run the same bus cycle.

The bus error pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor.

### 4.2.5 Reset Operation

The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure $4-21$ is a timing diagram for the reset operation. Both the halt and reset lines must be asserted to ensure total reset of the processor.

When the reset and halt lines are driven by an external device, it is recognized as an entire system reset, including the processor. The processor responds by reading the reset vector table entry ivector number zero, address $\$ 000000$ ) and loads it into the supervisor stack pointer (SSP). Vector table entry number one at address $\$ 000004$ is read next and loaded into the program counter. The processor initializes the status register to an interrupt level of seven. No other registers are affected by the reset sequence.

When a reset instruction is executed, the processor drives the reset pin for 124 clock periods. In this case, the processor is trying to reset the rest of the system. Therefore, there is no effect on the
internal state of the processor. All of the processor's internal registers and the status register are unaffected by the execution of a reset instruction. All external devices connected to the reset line will be reset at the completion of the reset instruction.

Asserting the reset and halt lines for ten clock cycles will cause a processor reset, except when VCC is initially applied to the processor. In this case, an external reset must be applied for at least 100 milliseconds.



NOTES

1) Internal start-up time
2) SSP High read in here
3) SSP Low read in here
4) $P C$ High read in here
5) PC Low read in here
6) First instruction fetched here

Bus State Unknown:
All Control Signals Inactive. Data Bus in Read Mode $>$

Figure 4-21. Reset Operation Timing Diagram

### 4.3 THE RELATIONSHIP OF $\overline{\text { DTACK, }} \overline{B E R R}$, AND $\overline{\text { HALT }}$

In order to properly control termination of a bus cycle for a re-run or a bus error condition, DIACM, $\overline{B E R R}$, and HALT should be asserted and negated on the rising edge of the TS68000 clock. Whi: will assure that when two signals are asserted simultaneously, the required setup time (\#47) for both of them will be met during the same bus state.

This, or some equivalent precaution, should be designed external to the TS68000. Parameter \#48 is intended to ensure this operation in a totally asynchronous system, and may be ignored if the above conditions are met.

The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 4-4):

| Normal Termination: | $\overline{\text { DTACK }}$ occurs first (case 1). |
| :---: | :---: |
| Halt Termination: | $\overline{\text { HALT }}$ is asserted at the same time or before $\overline{\text { DTACK }}$ and $\overline{\mathrm{BERR}}$ remains negated (cases 2 and 3 ). |
| Bus Error Termination: | $\overline{B E R R}$ is asserted in lieu of, at the same time, or before $\overline{D T A C K}$ (case 4); $\overline{B E R R}$ is negated the same time or after $\overline{\text { DTACK }}$. |
| Re-Run Termination: | $\overline{\mathrm{HALT}}$ and $\overline{\mathrm{BERR}}$ are asserted in lieu of, at the same time, or before $\overline{\text { DTACK }}$ (cases 6 and 7); पALT must be held at least one cycle after $\overline{\mathrm{BERR}}$. Case 5 indicates $\overline{\mathrm{BERR}}$ may precede $\overline{\text { HALT }}$ on all mask sets which allows fully asynchronous assertion. |

Table 4-4 details the resulting bus cycle termination under various combinations of control signal sequences. The negation of these same control signals under several conditions is shown in Table 4-5 ( $\overline{T T A C K}$ is assumed to be negated normally in all cases; for best results, both DTACK and $\overline{B E R R}$ should be negated when address strobe is negated).

Table 4-4. $\overline{\text { DTACK }}, \overline{B E R R}$, and $\overline{\text { HALT }}$ Assertion Results

| $\begin{aligned} & \text { Case } \\ & \text { No. } \end{aligned}$ | Control Signal | Asserted on Rising Edge of State |  | Result |
| :---: | :---: | :---: | :---: | :---: |
|  |  | N | $\mathrm{N}+2$ |  |
| 1 | $\begin{aligned} & \overline{\overline{\text { DTACK }}} \\ & \frac{\text { BERR }}{\text { HALT }} \end{aligned}$ | $\begin{aligned} & \hline A \\ & \text { NA } \\ & \text { NA } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline s \\ & x \\ & x \\ & \hline \end{aligned}$ | Normal cycle terminate and continue. |
| 2 | $\frac{\overline{\overline{O T A C K}}}{\frac{\text { BERR }}{\mathrm{HALT}}}$ | $\begin{gathered} \text { A } \\ \text { NA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \hline s \\ & x \\ & s \end{aligned}$ | Normal cycle terminate and halt. Continue when $\overline{\mathrm{HALT}}$ removed. |
| 3 | $\begin{aligned} & \overline{\overline{\text { DTACK }}} \\ & \overline{\overline{B E R R}} \\ & \overline{\text { HALT}} \end{aligned}$ | $\begin{gathered} \text { NA } \\ \text { NA } \\ \text { A } \end{gathered}$ | $\begin{gathered} \hline A \\ N A \\ S \end{gathered}$ | Normal cycle terminate and halt. Continue when $\overline{\text { HALT }}$ removed |
| 4 | $\begin{aligned} & \overline{\overline{D T A C K}} \\ & \overline{\overline{B E R R}} \\ & \overline{\text { HALT }} \end{aligned}$ | $\begin{gathered} X \\ A \\ \text { NA } \\ \hline \end{gathered}$ | $\begin{gathered} \hline x \\ S \\ \text { NA } \\ \hline \end{gathered}$ | Terminate and take bus error trap |
| 5 | $\begin{aligned} & \overline{\text { DTACK }} \\ & \frac{\text { BERR }}{\text { HALT }} \end{aligned}$ | $\begin{gathered} \text { NA } \\ \text { A } \\ \text { NA } \end{gathered}$ | $\begin{aligned} & \hline X \\ & S \\ & A \\ & \hline \end{aligned}$ | Terminate and re-run. |
| 6 | $\begin{aligned} & \frac{\overline{\mathrm{DTACK}}}{\frac{\text { BERR }}{\mathrm{HALT}}} \end{aligned}$ | $\begin{aligned} & \hline X \\ & A \\ & A \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & s \\ & s \end{aligned}$ | Terminate and re-run when $\overline{\text { HALT }}$ removed. |
| 7 | $\begin{aligned} & \frac{\overline{\text { TTACK }}}{\text { BERR }} \\ & \hline \text { HALT } \end{aligned}$ | $\begin{gathered} \text { NA } \\ \text { NA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & X \\ & A \\ & S \\ & \hline \end{aligned}$ | Terminate and re-run when $\overline{\mathrm{HALT}}$ removed |
| $\begin{aligned} & \text { Legend: } \\ & \mathrm{N}- \\ & \mathrm{A}- \\ & \mathrm{NA}- \\ & \mathrm{X}- \\ & \mathrm{S}-\mathrm{s} \end{aligned}$ | the number signal is a signal is don't care signal was | of the sserted in riot asser asserted | rent eve his bus st in this previous | bus state !e g. S4, S6. etc ! <br> te <br> tate <br> state and remains asserted in this state |

Table 4-5. $\overline{\mathrm{BERR}}$ and $\overline{\text { HALT }}$ Negation Results

| Conditions of Termination in Table 4-4 | Contro Signal | Negated on Rising Edge of State |  |  | Results - Next Cycle |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | N |  | $\mathrm{N}+2$ |  |
| Bus Error | $\begin{aligned} & \overline{\text { BERR }} \\ & \hline \text { HALT } \end{aligned}$ | $\bullet$ | or <br> or |  | Takes bus error trap. |
| Re-run | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | $\stackrel{\bullet}{\bullet}$ |  | - | Illegal sequẹnce; usually traps to vector number 0 . |
| Re-run | $\overline{\overline{\text { BERR }}}$ | $\bullet$ |  | - | Re-runs the bus cycle |
| Normal | $\frac{\overline{\text { BERA }}}{\text { HALT }}$ |  |  | $\bullet$ | May lengthen next cycle. |
| Normal | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | $\bullet$ | or | none | if next cycle is started it will be terminated as a bus error |

$\bullet$ = Signal is negated in this bus state.

EXAMPLE A:
A system uses a watch-dog timer to terminate accesses to unpopulated address space. The timer asserts $\overline{\text { DTACK }}$ and $\overline{B E R R}$ simultaneousty after time out (case 4).
EXAMPLE B:
A system uses error detection on RAM contents. Designer may (a) delay $\overline{\text { DTACK }}$ untll data verified and return $\overline{B E R R}$ and HALT simultaneously to re-run error cycle (case 6), or if valid, return $\overline{\text { DTACK }}$ (case 1); (b) delay $\overline{\text { DTACK }}$ until data verified and return $\overline{B E R R}$ at same time as $\overline{\text { DTACK }}$ if data in error (case 4).

### 4.4 ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION

### 4.4.1 Asynchronous Operation

To achieve clock frequency independence at a system level, the TS68000 can be used in an asynchronous manner. This entails using only the bus handshake lines ( $\overline{A S}, \overline{U D S}, \overline{L D S}, \overline{D T A C K}, \overline{B E R R}$, HALT, and $\overline{V P A}$ ) to control the data transfer. Using this method, $\overline{A S}$ signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle. The slave device (memory or peripheral) then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowlege signal ( $\overline{\text { DTACK }}$ ) to terminate the bus cycle. If no slave responds or the access is invalid, external control logic asserts the $\overline{B E R R}$, or $\overline{B E R R}$ and $\overline{H A L T}$, signal to abort or rerun the bus cycle.

The DTACK signal is allowed to be asserted before the data from a slave device is valid on a read cycle. The length of time that DTACK may precede data is given as parameter \#31 and it must bu met in any asynchronous system to insure that valid data is latched into the processor. Notice th.t there is no maximum time specified from the assertion of $\overline{\mathrm{AS}}$ to the assertion of $\overline{\text { DTACK. Ihis in }}$ because the MPU will insert wait cycles of one clock period each until $\overline{\text { DTACK }}$ is recognized

### 4.4.2 Synchronous Operation

To allow for those systems which use the system clock as a signal to generate DTACK and other asynchronous inputs, the asynchronous input setup time is given as parameter \#47. If this setup is met on an input, such as $\overline{\text { DTACK, the processor is guaranteed to recognize that signal on the next }}$ falling edge of the system clock. However, the converse is not true - if the input signal does not meet the setup time it is not guaranteed not to be recognized. In addition, if DTACK is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter \#27. Given this, parameter \#31 may be ignored. Note that if $\overline{\text { DTACK }}$ is asserted, with the required setup time, before the falling edge of $S 4$, no wait states will be incurred and the bus cycle will run at its maximum speed of four clock periods.

## NOTE

During an active bus cycle, $\overline{B E R R}$ is sampled on every falling edge of the clock starting with S2. $\overline{\text { DTACK }}$ is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S 6 during a read. The bus cycle will then be terminated in S7 except when $\overline{B E R R}$ is asserted in the absence of DTACK, in which case it will terminate one clock cycle later in S9. $\overline{\mathrm{VPA}}$ is sampled only on the third falling edge of the system clock before the rising edge of the E clock.

## SECTION 5 PROCESSING STATES

This section describes the actions of the TS68000 which are outside the normal processing associated with the execution of instructions. The functions ot the bits in the supervisor portion of the status register are covered: the supervisor/user bit, the trace enable bit, and the processor interrupt priority mask. Finally, the sequence of memory references and actions taken by the processor on exception conditions are detailed.

The TS68000 is always in one of three processing states : normal, exception, or halted. The normal processing state is that associated with instruction execution; the memory references are to fetch instructions and operands, and to store results. A special case of the normal state is the stopped state which the processor enters when a stop instruction is executed. In this state, no further references are made.

The exception processing state is associated with interrupts, trap instructions, tracing, and other exceptional conditions. The exception may be internally generated by an instruction or by an unusual condition arising during the execution of an instruction. Externally, exception processing can be forced by an interrupt, by a bus error, or by a reset. Exception processing is design vide an efficient context switch so that the processor may handle unusual conditions.

The halted processing state is an indication of catastrophic hardware failure. For example, if during the exception processing of a bus error another bus error occurs, the processor assumes that the system is unusable and halts. Only an external reset can restart a halted processor. Note that a processor in the stopped state is not in the halted state, nor vice versa.

### 5.1 PRIVILEGE STATES

The processor operates in one of two states of privilege: the "supervisor" state or the "user" state. The privilege state determines which operations are legal, are used to choose between the supervisor stack pointer and the user stack pointer in instruction references, and may by used by an external memory management device to control and translate accesses.

The privilege state is a mechanism for providing security in a computer system. Programs should access only their own code and data areas, and ought to be restricted from accessing information which they do not need and must not modify.

The privilege mechanism provides security by allowing most programs to execute in user state. In this state, the accesses are controlled, and the effects on other parts of the system are limited. The operating system executes in the supervisor state, has access to all resources, and performs the overhead tasks for the user state programs.

### 5.1.1 Supervisor State

The supervisor state is the higher state of privilege. For instruction execution, the supervisor state is determined by the $S$ bit of the status register; if the $S$ bit is asserted (high), the processor is in the supervisor state. All instructions can be executed in the supervisor state. The bus cycles generated by instructions executed in the supervisor state are classified as supervisor references. While the processor is in the supervisor privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly access the supervisor stack pointer

All exception processing is done in the supervisor state, regardless of the setting of the S bit. The bus cycles generated during exception processing are classified as supervisor references. All stacking operations during exception processing use the supervisor stack pointer.

### 5.1.2 User State

The user state is the lower state of privilege. For instruction execution, the user state is determined by the $S$ bit of the status register; if the $S$ bit is negated (low), the processor is executing instructions in the user state.

Most instructions execute the same in user state as in the supervisor state. However, some instructions which have important system effects are made privileged. User programs are not permitted to execute the stop instruction or the reset instruction. To ensure that a user program cannot enter the supervisor state except in a controlled manner, the instructions which modify the whole state register are privileged. To aid in debugging programs which are to be used as operatıng systems, the move to user stack pointer (MOVE to USP) and move from user stack pointer (MOVE from USP) instructions are also privileged.

The bus cycles generated by an instruction executed in the user state are classified as user state references. This allows an external memory management device to translate the address and to control access to protected portions of the address space. While the processor is in the user privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly, access the user stack pointer.

### 5.1.3 Privilege State Changes

Once the processor is in the user state and executing instructions, only exception processing can change the privilege state. During exception processing, the current setting of the $S$ bit of the status register is saved and the $S$ bit is asserted, putting the processor in the supervisor state. Therefore, when instruction execution resumes at the address specified to process the exception, the processor is in the supervisor privilege state.

### 5.1.4 Reference Classification

When the processor makes a reference, it classifies the kind of reference being made, using the encoding on the three function code output lines. This allows external translation of addresses, control of access, and differentiation of special processor state, such as interrupt acknowledge. Table $5-1$ lists the classification of references.

Table 5-1. Bus Cycle Classification

| Function Code Output |  |  | Reference Class |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 | FC0 |  |
| 0 | 0 | 0 | Unassigned) |
| 0 | 0 | 1 | User Data |
| 0 | 1 | 0 | User Program |
| 0 | 1 | 1 | (Unassigned) |


| Function Code Output |  |  | Reference Class |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 | FC0 |  |
| 1 | 0 | 0 | (Unassigned) |
| 1 | 0 | 1 | Supervisor Data |
| 1 | 1 | 0 | Supervisor Program |
| 1 | 1 | 1 | Interrupt Acknowledge |

### 5.2 EXCEPTION PROCESSING

Before discussing the details of interrupts, traps, and tracing, a general description of exception processing is in order. The processing of an exception occurs in four steps, with variations for different exception causes. During the first step, a temporary copy of the status register is made and the status register is set for exception processing. In the second step the exception vector is determined and the third step is the saving of the current processor context. In the fourth step a new context is obtained and the processor switches to instruction processing.

### 5.2.1 Exception Vectors

Exception vectors are memory locations from which the processor fetches the address of a routine which will handle that exception. All exception vectors are two words in length (Figure 5-1), except for the reset vector which is four words. All exception vectors lie in the supervisor data space, except for the reset vector which is in the supervisor program space. A vector number is an 8 -bit number which, when multiplied by four, gives the address of an exception vector. Vector numbers are generated internally or externally, depending on the cause of the exception. In the case of interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8 -bit vector number (Figure 5-2) to the processor on data bus lines D0 through D7. The processor translates the vector number into a full 24 -bit address, shown in Figure 5-3. The memory layout for exception vectors is given in Table 5-2.


Figure 5-1. Format of Vector Table Entries


Where
$v 7$ is the MSB of the Vector Number $v 0$ is the LSB of the Vector Number

Figure 5-2. Vector Number Format


Figure 5-3. Exception Vector Address Calculation

As shown in Table 5-2, the memory layout is 512 words long (1024 bytes). It starts at address 0 and proceeds through address 1023. This provides 255 unique vectors; some of these are reserved for TRAPS and other system functions. Of the 255, there are 192 reserved for user interrupt vectors. However, there is no protection on the first 64 entries, so user interrupt vectors mav overlap at the discretion of the systems designer.

### 5.2.2 Kinds of Exceptions

Exceptions can be generated by either internal or external causes. The externally generated exceptions are the interrupts and the bus error and reset, requests. The interrupts are requests from

Table 5-2. Exception Vector Table

| Vector <br> Number(s) | Address |  |  | Assignment |
| :---: | :---: | :---: | :---: | :---: |
|  | Dec | Hex | Space |  |
| 0 | 0 | 000 | SP | Reset: Initial SSP |
| - | 4 | 004 | SP | Reset: Initial PC |
| 2 | 8 | 008 | SD | Bus Error |
| 3 | 12 | 00C | SD | Address Error |
| 4 | 16 | 010 | SD | Illegal Instruction |
| 5 | 20 | 014 | SD | Zero Divide |
| 6 | 24 | 018 | SD | CHK instruction |
| 7 | 28 | 010 | SD | TRAPV instruction |
| 8 | 32 | 020 | SD | Privilege Violation |
| 9 | 36 | 024 | SD | Trace |
| 10 | 40 | 028 | SD | Line 1010 Emulator |
| 11 | 44 | 02C | SD | Line 1111 Emulator |
| 12* | 48 | 030 | SD | (Unassigned, Reserved) |
| 13* | 52 | 034 | SD | (Unassigned, Reserved) |
| 14* | 56 | 038 | SD | (Unassigned, Reserved) |
| 15 | 60 | 03C | SD | Uninitialized Interrupt Vector |
| 16.23* | 64 | 04C | SD | (Unassigned, Reserved) |
|  | 95 | 05F |  | - |
| 24 | 96 | 060 | SD | Spurious Interrupt |
| 25 | 100 | 064 | SD | Level 1 Interrupt Autovector |
| 26 | 104 | 068 | SD | Level 2 Interrupt Autovector |
| 27 | 108 | 06C | SD | Level 3 Interrupt Autovector |
| 28 | 112 | 070 | SD | Level 4 Interrupt Autovector |
| 29 | 116 | 074 | SD | Level 5 Interrupt Autovector |
| 30 | 120 | 078 | SD | Level 6 Interrupt Autovector |
| 31 | 124 | 07C | SD | Level 7 Interrupt Autovector |
| 32.47 | 128 | 080 | SD | TRAP Instruction Vectors |
|  | 191 | OBF |  | - |
| 48-63* | 192 | OCO | SD | (Unassigned, Reserved) |
|  | 255 | OFF |  | - |
| 64-255 | 256 | 100 | SD | User Interrupt Vectors |
|  | 1023 | 3FF |  | - |

*Vector numbers 12131416 through 23, and 48 through 63 are reserved for future enhancements by THOMSON SEMICONDUCTEURS. No user peripheral devices should be assigned these numbers.
peripheral devices for processor action while the bus error and reset inputs are used for access control and processor restart. The internally generated exceptions come from instructions, or from address errors or tracing. The trap (TRAP), trap on overflow (TRAPV), check data register against upper bounds (CHK), and divide (DIV) instructions all can generate exceptions as part of their instruction execution. In addition, illegal instructions, word fetches from odd addresses, and privilege violations cause exceptions. Tracing behaves like a very high-priority internally-generated interrupt after each instruction execution.

### 5.2.3 Exception Processing Sequence

Exception processing occurs in four identifiable steps. In the first step, an internal copy is made of the status register. After the copy is made, the $S$ bit is asserted, putting the processor into the supervisor privilege state. Also, the $T$ bit is negated which will allow the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated.

In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor fetch and classified as an interrupt acknowledge. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector.

The third step is to save the current processor status, except for the reset exception. The current program counter value and the saved copy of the status register are stacked using the supervisor stack pointer as shown in Figure 5-4. The program counter value stacked usually points to the next unexecuted instruction; however, for bus error and address error, the value stacked for the program counter is unpredictable, and may be incremented from the address of the instruction which caused the error. Additional information defining the current context is stacked for the bus error and add dress error exceptions.

The last step is the same for all exceptions. The new program counter value is fetched from the exception vector. The processor then resumes instruction execution. The instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started.


Figure 5-4. Exception Stack Order (Groups 1 and 2)

### 5.2.4 Multiple Exceptions

These paragraphs describe the processing which occurs when multiple exceptions arise simultaneously. Exceptions can be grouped according to their occurrence and priority. The group 0 exceptions are reset, bus error, and address error. These exceptions cause the instruction currently being executed to be aborted and the exception processing to commence within two clock cycles.

The group 1 exceptions are trace and interrupt, as well as the privilege violations and illegal instructions. These exceptions allow the current instruction to execute to completion, but pre-empt the execution of the next instruction by forcing exception processing to occur (privilege violations and illegal instructions are detected when they are the next instruction to be executed). The group 2 exceptions occur as part of the normal processing of instructions. The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these exceptions, the normal execution of an instruction may lead to exception processing.

Group 0 exceptions have highest priority, while group 2 exceptions have lowest priority. Within group 0 , reset has highest priority, followed by bus error and then address error. Within group 1, trace has priority over external interrupts, which in turn takes priority over illegal instruction and privilege violation. Since only one instruction can be executed at a time, there is no priority relation within group 2 .

The priority relation between two exceptions determines which is taken, or taken first, if the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the $T$ bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. A summary of exception grouping and priority is given in Table 5-3.

Table 5-3. Exception Grouping and Priority

| Group | Exception | Processing |
| :---: | :---: | :---: |
| 0 | Reset <br> Address Error <br> Bus Error | Exception processing begins <br> within two clock cycles |
| 1 | Trace <br> Interrupt <br> lilegal <br> Privilege | Exception processing begins before <br> the next instruction |
| 2 | TRAP. TRAPV <br> CHK. <br> Zero Divide | Exception processing is siarted by <br> normai instruction execution |

### 5.3 EXCEPTION PROCESSING DETAILED DISCUSSION

Exceptions have a number of sources and each exception has processing which is peculiar to it. The following paragraphs detail the sources of exceptions, how each arises, and how each is processed.

### 5.3.1 Reset

The reset input provides the highest exception level. The processing of the reset signal is designed for system initiation and recovery from catastrophic failure. Any processing in progress at the time of the reset is aborted and cannot be recovered. The processor is forced into the supervisor state and the trace state is forced off. The processor interrupt priority mask is set at level seven. The vector number is internally generated to reference the reset exception vector at location 0 in the supervisor program space. Because no assumptions can be made about the validity of register contents,
in particular the supervisor stack pointer, neither the program counter nor the status register is saved. The address contained in the first two words of the reset exception vector is fetched as the initial supervisor stack pointer, and the address in the last two words of the reset exception vector is fetched as the initial program counter. Finally, instruction execution is started at the address in the program counter.. The power-up/restart code should be pointed to by the initial program counter.

The reset instruction does not cause loading of the reset vector, but does assert the reset line to reset external devices. This allows the software to reset the system to a known state and then continue processing with the next instruction.

### 5.3.2 Interrupts

Seven levels of interrupt priorities are provided. Devices may be chained externally within interrupt priority levels, allowing an unlimited number of peripheral devices to interrupt the processor. Interrupt priority levels are numbered from one to seven, with level seven being the highest priority. The status register contains a 3-bit mask which indicates the current processor priority, and interrupts are inhibited for all priority levels less than or equal to the current processor priority.

An interrupt request is made to the processor by encoding the interrupt request level on the interrupt request lines; a zero indicates no interrupt request. Interrupt requests arriving at the processor do not force immediate exception processing, but are made pending. Pending interrupts are detected between instruction executions. If the priority of the pending interrupt is lower than or equal to the current processor priority, execution continues with the next instruction and the interrupt exception processing is postponed. (The recognition of level seven is slightly different, as explained in the following paragraph.)

If the priority of the pending interrupt is greater than the current processor priority, the exception processing sequence is started. A copy of the status register is saved, the privilege state is sent to the supervisor stack, tracing is suppressed, and the processor priority level is set to the level of the interrupt acknowledged. The processor fetches the vector number from the interrupting device, classifying the reference as an interrupt acknowledge and displaying the level number of the interrupt being acknowledged on the address bus. If external logic requests an automatic vectoring, the processor internally generates a vector number which is determined by the interrupt level number. If external logic indicates a bus error, the interrupt is taken to be spurious, and the generated vector number references the spurious interrupt vector. The processor then proceeds with the usual exception processing, saving the program counter and status register on the supervisor stack. The saved value of the program counter is the address of the instruction which would have been executed had the interrupt not been present. The content of the interrupt vector whose vector number was previously obtained is fetched and loaded into the program counter, and normal instruction execution commences in the interrupt handling routine. A flowchart for the interrupt acknowledge sequence is given in Figure 5-5, a timing diagram is given in Figure 5-6, and the interrupt processing sequence is shown in Figure 5-7.

Priority level seven is a special case. Level seven interrupts cannot be inhibited by the interrupt priority mask, thus providing a "non-maskable interrupt" capability. An interrupt is generated each time the interrupt request level changes from some lower level to level seven. Note that a level seven interrupt may still be caused by the level comparison if the request level is a seven and the processor priority is set to a lower level by an instruction.

PROCESSOR
INTERRUPTING DEVICE

| Grant the Interrupt | Request the Interrupt |
| :---: | :---: |
| 1) Compare Interrupt Level in Status Register and Wait for Current Instruction to Complete <br> 2) Assert Address Strobe ( $\overline{\mathrm{AS}}$ ) <br> 3) Place Interrupt Level on A1, A2, A3 |  |
| 4) Set Function Code to Interrupt Acknowledge | Provide the Vector Number |
| 6) Assert Data Strobes ( $\overline{\mathrm{UDS}}$ * and $\overline{\mathrm{LDS}}$ ) | 1) Place Vector Number on DO-D7 <br> 2) Assert Data Transter Acknowledge $\cdot \overline{\text { DTACK }}$, |
| Acquire the Vector Number |  |
| 1) Latch Vector Number <br> 2) Negate $\overline{U D S}$ and $\overline{\mathrm{LDS}}$ |  |
| 3) Negate AS | Release |
|  | 11 Negate $\overline{\text { DTACK }}$ |
| Start Interrupt Processing |  |

* Although a vector number is one byte, both data strobes are asserted due to the microcode used or exception processing ithe processor does not recognize anything on data lines D8 through D15 at this time

Figure 5-5. Vector Acquisition Flowchart


* Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing The pro cessor does not recognize anything on data lines D8 through D15 at this time.

Figure 5-6. Interrupt Acknowledge Cycle Timing Diagram


NOTE SSP reters to the value of the supervisor stack pointer before the interrupt occurs
Figure 5-7. Interrupt Processing Sequence

### 5.3.3 Uninitialized Interrupt

An interrupting device asserts $\overline{\mathrm{VPA}}$ or provides an interrupt during an interrupt acknowledge cycle to the TS68000. If the vector register has not been initialized, the responding TS68000 Family peripheral will provide vector 15 , the uninitialized interrupt vector. This provides a uniform way to recover from a programming error.

### 5.3.4 Spurious Interrupt

If during-the interrupt acknowledge cycle no device responds by asserting $\overline{\mathrm{DTACK}}$ or $\overline{\mathrm{VPA}}$, the bus error line should be asserted to terminate the vector acquisition. The processor separates the processing of this error from bus error by fetching the spurious interrupt vector instead of the bus error vector. The processor then proceeds with the usual exception processing.

### 5.3.5 Instruction Traps

Traps are exceptions caused by instructions. They arise either from processor recognition of abnormal conditions during instruction execution, or from use of instructions whose normal behavior is trapping.

Some instructions are used specifically to generate traps. The TRAP instruction always forces an exception and is useful for implementing system calls for user programs. The TRAPV and CHK instructions force an exception if the user program detects a runtime error, which may be an arithemetic overflow or a subscript out of bounds.

The signed divide (DIVS) and unsigned (DIVU) instructions will force an exception if a division operation is attempted with a divisor of zero.

### 5.3.6 Illegal and Unimplemented Instructions

"Illegal instruction" is the term used to refer to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is
fetched, an illegal instruction exception occurs. THOMSON SEMICONDUCTEURS reserves the right to define instructions whose opcodes may be any of the illegal instructions. Three bit patterns will always force an illegal instruction trap on all TS68000 Family compatible microprocessors. They are : \$4AFA, \$4AFB, and \$4AFC. Two of the patterns, \$4AFA and \$4AFB, are reserved for THOMSON SEMICONDUCTEURS system products. The third pattern, S4AFC, is reserved for customer use.

Word patterns with bits 15 through 12 equaling 1010 or 1111 are distinguished as unimplemented instructions and separate exception vectors are given to these patterns to permit efficient emulation. This facility allows the operating system to detect program errors, or to emulate unimplemented instructions in software.

### 5.3.7 Privilege Violations

In order to provide system security, various instructions are privileged. An attempt to execute one of the privileged instructions while in the user state will cause an exception. The privileged instructions are:

| STOP | AND Immediate to SR |
| :--- | :--- |
| RESET | EOR Immediate to SR |
| RTE | OR Immediate to SR |
| MOVE to SR | MOVE USP |

### 5.3.8 Tracing

To aid in program development, the TS68000 includes a facility to allow instruction-by-instruction tracing. In the trace state, after each instruction is executed an exception is forced, allowing a debugging program to monitor the execution of the program under test.

The trace facility uses the $T$ bit in the supervisor portion of the status register. If the $T$ bit is negated (off), tracing is disabled, and instruction execution proceeds from instruction to instruction as normal. If the $T$ bit is asserted (on) at the beginning of the execution of an instruction, a trace exception will be generated after the execution of that instruction is completed. If the instruction is not executed, either because an interrupt is taken, or the instruction is illegal or privileged, the trace exception does not occur. The trace exception also does not occur if the instruction is aborted by a reset, bus error, or address error exception. If the instruction is indeed executed and an interrupt is pending on completion, the trace exception is processed before the interrupt exception. If, during the execution of the instruction an exception is forced by that instruction, the forced exception is processed before the trace exception.

As an extreme illustration of the above rules, consider the arrival of an interrupt during the execution of a TRAP instruction while tracing is enabled. First the trap exception is processed, then the trace exception, and finally the interrupt exception. Instruction execution resumes in the interrupt handler routine.

### 5.3.9 Bus Error

Bus error exceptions occur when the external logic requests that a bus error be processed by an exception. The current bus cycle which the processor is making is then aborted. Whether the processor was doing instruction or exception processing, that processing is terminated, and the processor immediately begins exception processing.

Exception processing for the bus error follows the usual sequence of steps. The status register is copied, the supervisor state is entered, and the trace state is turned off. The vector number is generated to refer to the bus error vector. Since the processor was not between instructions when the bus error exception request was made, the context of the processor is more detailed. To save more of this context, additional information is saved on the supervisor stack. The program counter and the copy of the status register are of course saved. The value saved for the program counter is advanced by some amount, one to five words beyond the address of the first word of the instruction which made the reference causing the bus error. If the bus error occurred during the fetch of the next instruction, the saved program counter has a value in the vicinity of the current instruction, even if the current instruction is a branch, a jump, or a return instruction. Besides the usual information, the processor saves its internal copy of the first word of the instruction being processed and the address which was being accessed by the aborted bus cycle. Specific information about the access is also saved: whether it was a read or a write, whether or not the processor was processing an instruction, and the classification displayed on the function code outputs when the bus error occurred. The processor is processing an instruction if it is in the normal state or processing a group 2 exception; the processor is not processing an instruction if it is processing a group 0 or a group 1 ex ception. Figure $5-8$ illustrates how this information is organized on the supervisor stack. Although this information is not sufficient in general to effect full recovery from the bus error, it does allow software diagnosis. Finally, the processor commences instruction processing at the address contained in vector number two. It is the responsibility of the error handler routine to clean up the stack and determine where to continue execution.

$R / \bar{W}$ (read/write) write $=0$, read $=1 \quad 1 / N$ (instruction/not) instruction $=0$, not $=1$
Figure 5-8. Exception Stack Order (Group 0)

If a bus error occurs during the exception processing for a bus error, address error, or reset, the processor is halted and all processing ceases. This simplifies the detection of catastrophic system failure, since the processor removes itself from the system rather than destroy any memory contents. Only the $\overline{\mathrm{RESET}}$ pin can restart a halted processor.

### 5.3.10 Address Error

Address error exceptions occur when the processor attempts to access a word or a long word operand or an instruction at an odd address. The effect is much like an internally generated bus
error, so that the bus cycle is aborted and the processor ceases whatever processing it is currently doing and begins exception processing. After the exception processing commences, the sequence is the same as that for bus error including the information that is stacked, except that the vector number refers to the address error vector instead. Likewise, if an address error occurs during the exception processing for a bus error, address error, or reset, the processor is halted. As shown in Figure 5-9, an address error will execute a short bus cycle followed by exception processing.


Figure 5-9. Address Error Timing Diagram

## SECTION 6 INTERFACE WITH EF6800 PERIPHERALS

THOMSON SEMICONDUCTEURS' extensive line of EF6800 peripherals are directly compatible with the TS68000. Some of these devices that are particularly useful are :

EF6821 Peripheral Interface Adapter
EF6840 Programmable Timer Module
EF9345, EF9367 CRT Controllers
EF6850 Asynchronous Communications Interface Adapter
EF6852 Synchronous Serial Data Adapter
EF6854 Advanced Data Link Controller
To interface the synchronous EF6800 peripherals with the asynchronous TS68000, the processor modifies its bus cycle to meet the EF6800 cycle requirements whenever an EF6800 device address is detected. This is possible since both processors use memory mapped I/O. Figure 6-1 is a flowchart of the interface operation between the processor and EF6800 devices.


Figure 6-1. EF6800 Interfacing Flowchart

### 6.1 DATA TRANSFER OPERATION

Three signals on the processor provide the EF6800 interface. They are : enable (E), valid memory address ( $\overline{\mathrm{VMA}}$ ), and valid peripheral address ( $\overline{\mathrm{VPA}}$ ). Enable corresponds to the E or phase 2 signal in existing 6800 systems. The bus frequency in one tenth of the incoming TS68000 clock frequency. The timing of E allows 1 megahertz peripherals to be used with 8 megahertz TS68000s. Enable has a $60 / 40$ duty cycle ; that is, it is low for six input clocks and high for four input clocks. This duty cycle allows the processor to do successive $\overline{\mathrm{VPA}}$ accesses on successive $E$ pulses.

EF6800 cycle timing is given in Figures 6-2, 6-3, 8-7, and 8-8. At state zero (SO) in the cycle, the address bus is in the high-impedence state. A function code is asserted on the function code output lines. One-half clock later, in state 1, the address bus is released from the higtr-impedence state.


Figure 6-2. TS68000 to EF6800 Peripheral Timing - Best Case


Figure 6-3. TS68000 to EF6800 Peripheral Timing - Worst Case

During state 2 , the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the upper and/or lower data strobes are also asserted in state 2. If the bus cycle is a write cycle, the read/write ( $R / \bar{W}$ ) signal is switched to low (write) during state 2 . One-half clock later, in state 3, the write data is placed on the data bus, and in state 4 the data strobes are issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of $\overline{\mathrm{VPA}}$.

The VPA input signals the processor that the address on the bus is the address of an EF6800 device (or an area reserved for EF6800 devices) and that the bus should conform to the phase 2 transfer characteristics of the EF6800 bus. Valid peripheral address is derived by decoding the address bus, conditioned by the address strobe. Chip select for the EF6800 peripherals should be derived by decoding the address bus conditioned by $\overline{\mathrm{VMA}}$.

After recognition of $\overline{\mathrm{VPA}}$, the processor assures that the enable ( $E$ ) is low, by waitıng if necessary, and subsequently asserts $\overline{\mathrm{VMA}}$. Valid memory address is then used as part of the chip select equation of the peripheral. This ensures that the EF6800 peripherals are selected and deselected at the correct time. The peripheral now runs its cycle during the high portion of the E signal. Figures 6-2 and $6-3$ depict the best and worst case EF6800 cycle timing. This cycle length is dependent strictly upon when $\overline{\mathrm{VPA}}$ is asserted in relationship to the E clock.

If we assume that external circuitry asserts $\overline{V P A}$ as soon as possible after the assertion of $\overline{\mathrm{AS}}$, then $\overline{V P A}$ will be recognized as being asserted on the falling edge of $\$ 4$ In this case, no "extra" watt cycles will be inserted prior to the recognition of $\overline{V P A}$ asserted and only the wait cycles inserted to synchronize with the E clock will determine the total length of the cycle. In any case, the synchronization delay will be some integral number of clock cycles within the following two extremes:

1. Best Case $-\overline{\mathrm{VPA}}$ is recognized as being asserted on the falling edge three clock cycles before E rises (or three clock cycles after E falls).
2. Worst Case $-\overline{\mathrm{VPA}}$ is recognızed as berng asserted on the falling edge two clock cycles before E rises (or four clock cycles after $E$ falls)

During a read cycle, the processor latches the peripheral data in state 6 . For all cycles, the processor negates the address and data strobes one-half clock cycle later in state 7 and the enable signal goes low at this time. Another half clock later, the address bus is put in the high-impedence state. During a write cycle, the data bus is put in the high-impedence state and the read/write signal is switched high. The peripheral logic must remove $\overline{\mathrm{VPA}}$ within one clock afier the address strobe is negated
$\overline{\mathrm{DTACK}}$ should not be asserted while $\overline{\mathrm{VPA}}$ is asserted. Notice that the TS68000 $\overline{\mathrm{VMA}}$ is active low, contrasted with the active high EF6800 VMA. This allows the processor to put its buses in the high impedence state on DMA requests without inadvertently selecting the peripherals.

### 6.2 INTERRUPT INTERFACE OPERATION

During an interrupt acknowledge cycle while the processor is fetching the vector, the VPA is asserted, the TS68000 will assert VMA and comicte a normal EF6800 read cycle as shown in Figure $6-4$. The processor will then use an internally generated vector that is a function of the interrupt being serviced. This process is known as autovectoring. The seven autovectors are vector numbers 25 through 31 (decimal).

Autovectoring operates in the same fashion (but is not restricted to) the EF6800 interrupt sequence The basic difference is that there are six normalinterrupt vectors and one NMI type vector. As with both the EF6800 and the TS68000's normal vectored interrupt, the interrupt service routine can be located anywhere in the address space. This is due to the fact that while the vector numbers are fixed, the contents of the vector table entries are assigned by the user.

Since $\overline{\mathrm{VMA}}$ is asserted during autovectoring, care should be taken to insure that the 6800 peripheral address decoding prevents unintended accesses.

*Although $\overline{U D S}$ and $\overline{\mathrm{LDS}}$ are asserted, no data is read from the bus during the autovector cycle The vector number is generated internally.

Figure 6-4. Autovector Operation Timing Diagram

## SECTION 7 <br> INSTRUCTION SET AND EXECUTION TIMES

### 7.1 INSTRUCTION SET

The following paragraphs provide information about the addressing categories and instruction set of the TS68000.

### 7.1.1 Addressing Categories

Effective address modes may be categorized by the ways in which they may be used. The following classifications will be used in the instruction definitions.

Data If an effective address mode may be used to refer to data operands, it is considered a data addressing effective address mode.
Memory If an effective address mode may be used to refer to memory operands, it is considered a memory addressing effective address mode.
Alterable If an effective address mode may be used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode.
Control If an effective address mode may be used to refer to memory operands without an associated size, it is considered a control addressing effective address mode.
These categories may be combined, so that additional, more restrictive, classifications may be defined. For example, the instruction descriptions use such classifications as alterable memory or data alterable. The former refers to those addressing modes which are both alterable and memory addresses, and the latter refers to addressing modes which are both data and alterable.

Table 7-1 shows the various categories to which each of the effective address modes belong. Table $7-2$ is the instruction set summary.

Table 7-1. Effective Addressing Mode Categories

| Effective Address Modes | Mode | Register | Addressing Categories |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Data | Memory | Control | Atterable |
| Dn | 000 | Register Number | X | - | - | X |
| An | 001 | Register Number | - | - | - | x |
| (An) | 010 | Register Number | $x$ | $x$ | X | $x$ |
| (An) + | 011 | Register Number | x | X | - | X |
| - (An) | 100 | Register Number | x | x | - | $x$ |
| d(An) | 101 | Register Number | X | x | $x$ | X |
| d(An, ix) | 110 | Register Number | X | X | X | X |
| xxx.W | 111 | 000 | X | X | X | $\times$ |
| x×x.L | 111 | 001 | x | x | $\times$ | X |
| d(PC) | 111 | 010 | x | X | X | - |
| d(PC, ix) | 111 | 011 | X | x | X | - |
| *xxx | 111 | X | $\times$ | $\times$ | - | - |

Table 7-2. Instruction Set (Sheet 1 of 2)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | Z | V | C |
| ABCD | Add Decimal with Extend | (Destination) $10+$ (Source) ${ }_{10}+\mathrm{X} \rightarrow$ Destination | * | U | * | U | * |
| ADD | Add Binary | (Destination) + (Source) $\rightarrow$ Destination | * | * | * | * | * |
| ADDA | Add Address | $($ Destination $)+($ Source ) $\rightarrow$ Destination | - | - | - | - | - |
| ADDI | Add Immediate | $($ Destination + Immediate Data $\rightarrow$ Destination | * |  | * | * | * |
| ADDQ | Add Quick | (Destination) + Immediate Data $\rightarrow$ Destination | * | * | * | * | * |
| ADDX | Add Extended | (Destination) + (Source) $+X \rightarrow$ Destination |  | * | * | * | * |
| AND | AND Logical | (Destination) $\Lambda$ (Source) $\rightarrow$ Destination | - |  |  | 0 | 0 |
| ANDI | AND Immediate | (Destination) $\boldsymbol{\Lambda}$ Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ANDI to CCR | AND Immediate to Condition Codes | (Source) $\Lambda$ CCR $\rightarrow$ CCR | * | * | * |  |  |
| ANDI to SR | AND Immediate to Status Register | (Source) $\Lambda$ SR $\rightarrow$ SR | * | * | * | * | * |
| ASL, ASR | Arithmetic Shift | (Destination) Shifted by <count> $\rightarrow$ Destination | * | * | * | * | * |
| ${ }^{\text {BCC }}$ | Branch Conditionally | If CC then PC + d $\rightarrow$ PC | - | - | - | - | - |
| BCHG | Test a Bit and Change | $\begin{aligned} & - \text { < }<\text { bit number }>\text { ) OF Destination } \rightarrow z \\ & \sim \text { bit number }>) \text { OF Destination } \rightarrow \\ & <\text { bit number }>\text { OF Destination } \end{aligned}$ | - | - | * | - | - |
| BCLR | Test a Bit and Clear | $\begin{aligned} & \sim(<\text { bit number }>) \text { OF Destination } \rightarrow z \\ & 0 \rightarrow<\text { bit number }>\rightarrow \text { OF Destination } \end{aligned}$ | - | - | * | - | - |
| BRA | Branch Always | $P C+d \rightarrow P C$ | - | - | - | - | - |
| BSET | Test a Bit and Set | $\begin{aligned} & \sim(<\text { bit number }>) \text { OF Destination } \rightarrow Z \\ & 1 \rightarrow<\text { bit number }>\text { OF Destination } \\ & \hline \end{aligned}$ | - | - | * | - | - |
| BSR | Branch to Subroutine | $P C \rightarrow-(S P) ; P C+d \rightarrow P C$ | - | - | - | - | - |
| BTST | Test a Bit | $\sim$ ( bit number $>$ ) OF Destination $\rightarrow z$ | - | - | * | - |  |
| CHK | Check Register Against Bounds | If $\mathrm{Dn}<0$ or $\mathrm{Dn}>$ (<ea>) then TRAP | - | * | U | U | U |
| CLR | Clear and Operand | $0 \rightarrow$ Destination | - | 0 | 1 | 0 | 0 |
| CMP | Compare | (Destination) - (Source) | - | * | * | * |  |
| CMPA | Compare Address | (Destination) -- (Source) | - | * | * | * | * |
| CMPI | Compare Immediate | (Destination) - Immediate Data | - | * | * | * | * |
| CMPM | Compare Memory | (Destination) - (Source) | - | * | * | * | * |
| ${ }^{\text {DBCC }}$ | Test Condition, Decrement and Branch | If $\sim$ CC then $\mathrm{Dn}-1 \rightarrow \mathrm{Dn}$; if $\mathrm{Dn} \neq-1$ then PC $+\mathrm{d} \rightarrow \mathrm{PC}$ | - | - | - | - | - |
| DIVS | Signed Divide | (Destination)/ (Source) $\rightarrow$ Destination | - | * | * | * | 0 |
| DIVU | Unsigned Divide | (Destination)/(Source) $\rightarrow$ Destination | - | * | * | * | 0 |
| EOR | Exclusive OR Logical | (Destination) $\oplus$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| EORI | Exclusive OR Immediate | (Destination) $\oplus$ Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| EORI to CCR | Exclusive OR Immediate to Condition Codes | (Source) $\oplus$ CCR $\rightarrow$ CCR | * | * | * | * | * |
| EORI to SR | Exclusive OR Immediate to Status Register | (Source) $\oplus$ SR $\rightarrow$ SR | * | * | * | * | * |
| EXG | Exchange Register | $\mathrm{R}_{\mathrm{x}} \rightarrow \mathrm{R}_{\mathrm{y}}$ | - | - | - | - | - |
| EXT | Sign Extend | (Destination) Sign-Extended $\rightarrow$ Destination | - | * | * | 0 | 0 |
| JMP | Jump | Destination $\rightarrow$ PC | - | - | - | - | - |
| JSR | Jump to Subroutine | $\mathrm{PC} \rightarrow-(\mathrm{SP})$; Destination $\rightarrow \mathrm{PC}$ | - | - | - | - | - |
| LEA | Load Effective Address | $\langle\mathrm{ea}\rangle \rightarrow \mathrm{An}$ | - | - | - | - | - |
| LINK | Link and Allocate | $A n \rightarrow-(S P) ; S P \rightarrow A n ; S P+$ Displacement $\rightarrow$ SP | - | - | - | - | - |
| LSL, LSR | Logical Shift | (Destination) Shifted by <count> $\rightarrow$ Destination | * | * | * | 0 | * |
| MOVE | Move Data from Source to Destination | ( Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MOVE to CCR | Move to Condition Code | (Source) $\rightarrow$ CCR | * | * | * | * | * |
| MOVE to SR | Move to the Status Register | (Source) $\rightarrow$ SR | * | * | * | * | * |

$\Lambda$ logical AND
$\checkmark$ logical OR
$\oplus$ logical exclusive OR
~ logical complement

* affected
- unaffected

0 cleared
1 set
U undefined

Table 7-2. Instruction Set (Sheet 2 of 2)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | Z | V | C |
| MOVE from SR | Move from the Status Register | $S R \rightarrow$ Destination |  | .. | - |  | - |
| MOVE USP | Move User Stack Pointer | USP $\rightarrow$ An, An $\rightarrow$ USP | - | - | -- | -- | - |
| MOVEA | Move Address | (Source) $\rightarrow$ Destination | - | - | - | -- | $\cdots$ |
| MOVEM | Move Multiple Registers | $\begin{aligned} & \text { Registers } \rightarrow \text { Destination } \\ & \text { (Sourcel } \rightarrow \text { Registers } \end{aligned}$ | - | - | -- | - |  |
| MOVEP | Move Peripheral Data | (Sourcel $\rightarrow$ Destination | -- | - | - | - | - |
| MOVEQ | Move Quick | Immediate Dạta $\rightarrow$ Destınation | - | * | * | 0 | 0 |
| MULS | Signed Multiply | (Destinat:on) $\times$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MULU | Unsigned Multıply | (Destination) $\times$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| NBCD | Negate Decimal with Extend | $0-$ (Destination) $10^{-X} \rightarrow$ Destination | * | U | * | U | * |
| NEG | Negate | $0-$ (Destination) $\rightarrow$ Destination | * | * | * | * | * |
| NEGX | Negate with Extend | $0-($ Destination $)-x \rightarrow$ Destination | * | * | * | * | * |
| NOP | No Operation | - | - | - | -- | --- | - |
| NOT | Logical Complement | $\sim$ (Destination) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| OR | Inclusive OR Logical | (Destination) v (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ORI | Inclusive OR Immediate | (Destınationi v Immediate Data $\rightarrow$ Destınation | - | * | * | 0 | 0 |
| ORI to CCR | Inclusive OR Immediate to Condition Codes | (Source) $\vee$ CCR $\rightarrow$ CCR | * | * | * | * | * |
| ORI to SR | Inclusive OR Immediate to Status Register | (Source) $\vee$ SR $\rightarrow$ SR | * | * | * | * | * |
| PEA | Push Effective Address | $\langle\mathrm{ea}\rangle \rightarrow-(\mathrm{SP} \mid$ | - | - | - | - | -- |
| RESET | Reset External Device | - | - | - | - | - | - |
| ROL, ROR | Rotate (Without Extend) | (Destination) Rotated by <count $>\rightarrow$ Destination | - | * | * | 0 | * |
| ROXL, ROXR | Rotate with Extend | (Destination) Rotated by $<$ count $\rangle \rightarrow$ Destination | * | * | * | 0 | * |
| RTE | Return from Exception | $(S P)+\rightarrow S R ;(S P)+\rightarrow P C$ | * | * | * | * | * |
| RTR | Return and Restore Condition Codes | $(\mathrm{SP})+\rightarrow \mathrm{CC} ;(\mathrm{SP})+\rightarrow \mathrm{PC}$ | * | * | * | * | * |
| RTS | Return from Subroutine | $(\mathrm{SP})+\rightarrow \mathrm{PC}$ | - | - | - | - | $\sim$ |
| SBCD | Subtract Decimal with Extend | (Destination) $10-$ (Source) $10-\mathrm{X} \rightarrow$ Destination | * | U | * | U | * |
| ${ }^{\text {S CC }}$ | Set According to Condition | If CC then 1's $\rightarrow$ Destination else 0's $\rightarrow$ Destınation | - | - | - | - | - |
| STOP | Load Status Regıster and Stop | Immediate Data $\rightarrow$ SR; STOP | * | * | * | * | * |
| SUB | Subtract Binary | (Destınation) - (Source) $\rightarrow$ Destination | * | * | * | * | * |
| SUBA | Subtract Address | (Destination) - (Source) $\rightarrow$ Destination | - | - | -- | -- | - |
| SUBI | Subtract Immediate | (Destination) - Immedıate Data $\rightarrow$ Destination | * | * | * | * | * |
| SUBQ | Subtract Quick | (Destination) - Immediate Data $\rightarrow$ Destination | * | * | * | * | * |
| SUBX | Subtract with Extend | (Destınation) - (Source) - $x \rightarrow$ Destination | * | * | * | * | * |
| SWAP | Swap Register Halves | Register [31:16] $\rightarrow$ Register [15:0] | - | * | * | 0 | 0 |
| TAS | Test and Set an Operand | (Destınation) Tested $\rightarrow$ CC, $1 \rightarrow$ [7] OF Destınation | - | * | * | 0 | 0 |
| TRAP | Trap | $\mathrm{PC} \rightarrow-$ (SSP); SR $\rightarrow-$ (SSP). (Vector) $\rightarrow$ PC | - | - | - | - | - |
| TRAPV | Trap on Overflow | If $V$ then TRAP | - | - | - | -- | - |
| TST | Test and Operand | (Destinatıon) Tested $\rightarrow$ CC | - | * | * | 0 | 0 |
| UNLK | Unlink | $\mathrm{A}_{n} \rightarrow \mathrm{SP},(\mathrm{SP})+\rightarrow \mathrm{An}^{\prime}$ | - | - | - | - | - |
|  |  | \| $1=$ bit number <br> A logical AND <br> $\checkmark$ logical OR <br> $\oplus$ logical exclusive OR <br> - logical complement | * affected <br> - unaffected <br> 0 cleared <br> 1 set <br> U undefined |  |  |  |  |

### 7.1.2 Instruction Prefetch

The TS68000 uses a two-word tightly-coupled instruction prefetch mechanism to enhance performance. This mechanism is described in terms of the microcode operations involved. If the execution of an instruction is defined to begin when the microroutine for that instruction is entered, some features of the prefetch mechanism can be described.

1. When execution of an instruction begins, the operation word and the word following have already been fetched. The operation word is in the instruction decoder.
2. In the case of multi-word instructions, as each additional word of the instruction is used internally, a fetch is made to the instruction stream to replace it.
3. The last fetch for an instruction from the instruction stream is made when the operation word is discarded and decoding is started on the next instruction.
4. If the instruction is a single-word instruction causing a branch, the second word is not used. But because this word is fetched by the preceding instruction, it is impossible to avoid this superfluous fetch.
5. In the case of an interrupt or trace exception, both words are not used
6. The program counter usually points to the last word fetched from the instruction stream.

### 7.2 INSTRUCTION EXECUTION TIMES

The following paragraphs contain listings of the instruction execution times in terms of external clock (CLK) periods. In this timing data, it is assumed that both memory read and write cycle times are four clock periods. Any wait states caused by a longer memory cycle must be added to the total instruction time. The number of bus read and write cycles for each instruction is also included with the timing data. This timing data is enclosed in parenthesis following the execution periods and is shown as ( $r / w$ ) where $r$ is the number of read cycles and $w$ is the number of write cycles.

## NOTE

The number of periods includes instruction fetch and all applicable operand fetches and stores.

### 7.2.1 Effective Address Operand Calculation Timing

Table 7-3 lists the number of clock periods required to compute an instruction's effective address. It includes fetching of any extension words, the address computation, and fetching of the memory operand. The number of bus read and write cycles is shown in parenthesis as (r/w). Note there are no write cycles involved in processing the effective address.

### 7.2.2 Move Instruction Execution Times

Tables 7-4 and 7-5 indicate the number of clock periods for the move instruction. This data includes instruction fetch, operand reads, and operand writes. The number of bus read and write cycles is shown in parenthesis as (r/w).

Table 7-3. Effective Address Calculation Times

| Addressing Mode |  | Byte, Word | Long |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Dn } \\ & \text { An } \end{aligned}$ |   <br> Data Register Direct Register <br> Address Register Direct  | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ |
| $\begin{aligned} & (A n) \\ & (A n)+ \\ & \hline \end{aligned}$ | Address Register Indirect Memory Address Register Indirect with Postincrement | $\begin{aligned} & 4(1 / 0) \\ & 4(1 / 0) \end{aligned}$ | $\begin{aligned} & 8(2 / 0) \\ & 8(2 / 0) \end{aligned}$ |
| $\begin{aligned} & -(A \dot{n}) \mid \\ & d\left(A_{n}\right) \end{aligned}$ | Address Register Indirect with Predecrement Address Register Indirect with Displacement | $\begin{aligned} & \hline 6(1 / 0) \\ & 8(2 / 0) \end{aligned}$ | $\begin{aligned} & \hline 10(2 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & d(A n, 1 x)^{*} \\ & x \times x W W \end{aligned}$ | Address Register Indirect with Index Absolute Short | $\begin{array}{r} \hline 10(2 / 0) \\ 8(2 / 0) \\ \hline \end{array}$ | $\begin{aligned} & 14(3 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & x \times x \mathrm{~L} \\ & \mathrm{~d}(\mathrm{PC}) \end{aligned}$ | Absolute Long <br> Program Counter with Displacement | $\begin{array}{r} \hline 12(3 / 0) \\ 8(2 / 0) \end{array}$ | $\begin{aligned} & \hline 16(4 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & \text { diPC, }\|x\|^{*} \\ & \# x x x \end{aligned}$ | Program Counter with Index Immediate | $\begin{gathered} 10(2 / 0) \\ 4(1 / 0) \end{gathered}$ | $\begin{gathered} \hline 14(3 / 0) \\ 8(2 / 0) \end{gathered}$ |

*The size of the index register (ix) does not affect execution time.

Table 7-4. Move Byte and Word Instruction Execution Times

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | (An) + | - (An) | d(An) | d(An, ix)* | xxx.W | xxx.L |
| Dn | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) |
| $A_{n}$ | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) |
| (An) | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |
| $(A n)+$ | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |
| - (An) | 10(2/0) | 10(2/0) | 14(2/1) | 14(2/1) | 14(2/1) | 18(3/1) | 20(3/1) | 18(3/1) | 22(4/1) |
| $d(A n)$ | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| d(An, $(x) *$ | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) |
| $x \times x$ W | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| $x \times x$ L | 16(4/0) | 16(4/0) | 20(4/1) | 20(4/1) | 20(4/1) | 24(5/1) | 26(5/1) | 24(5/1) | 28(6/1) |
| d(PC) | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| d(PC, $1 x)^{*}$ | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) |
| \# $\times$ x ${ }^{\text {a }}$ | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |

* The size of the index register (ix) does not affeci execution tume.

Table 7-5. Move Long Instruction Execution Times

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | (An) + | - (An) | d(An) | d(An, ix)* | xxx.W | xux.L |
| Dn | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) |
| An | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) |
| ( $A_{n}$ ) | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |
| $\left(A_{n}\right)+$ | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |
| (An) | 14(3/0) | 14!3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 26(4/2) | 28(4/2) | 26(4/2) | 30(5/2) |
| $d(A n)$ | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| d(An, ix)* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 3015/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| $x \times x$ W | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 2815/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| $x \times x$ L | 20(5/0) | 20(5/0) | 28(5/2) | 28(5/2) | 28(5/2) | 3216/2) | 346/2) | 32(6/2) | 36(7/2) |
| d(PC) | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(5/2) |
| d(PC, \|x)* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| *xxx | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |

[^36]
### 7.2.3 Standard Instruction Execution Times

The number of clock periods shown in Table 7-6 indicates the time required to perform the operations, store the results, and read the next instruction. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

In Table 7-6 the headings have the following meanings: $\mathrm{An}=$ address register operand, $\mathrm{Dn}=\mathrm{data}$ register operand, ea = an operand specified by an effective address, and $M=$ memory effective address operand.

Table 7-6. Standard Instruction Execution Times

| Instruction | Size | op<ea>, Ant | op<ea>, Dn | op Dn, <M> |
| :---: | :---: | :---: | :---: | :---: |
| ADD | Byte, Word | $8(1 / 0)+$ | 4(1/0) + | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)+$ * | $6(1 / 0)+$ ** | 12(1/2)+ |
| AND | Byte, Word | - | 4(1/0)+ | $8(1 / 1)+$ |
|  | Long | - | $6(1 / 0)+$ ** | 12(1/2)+ |
| CMP | Byte, Word | $6(1 / 0)+$ | $4(1 / 0)+$ | - |
|  | Long | $6(1 / 0)+$ | $6(1 / 0)+$ | - |
| DIVS | - | - | 158(1/0) + * | - |
| DIVU | - | - | 140(1/0) +* | - |
| EOR | Byte, Word | - | 4(1/0)*** | $8(1 / 1)+$ |
|  | Long | - | 8(1/0)*** | 12(1/2)+ |
| MULS | - | - | 70(1/0) + * | - |
| MULU | - | - | 70(1/0) + * | - |
| OR | Byte, Word | - . | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | - | $6(1 / 0)+* *$ | 12(1/2)+ |
| SUB | Byte, Word | $8(1 / 0)+$ | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)+$ ** | $6(1 / 0)+* *$ | 12(1/2) + |

> NOTES:
> + add effective address calculation time
> $\dagger$ word or long only
> * indicates maximum value
> * * The base time of six clock periods is increased to eight if the effective address mode is register direct or immediate (effective address time should also be added)
> * * Only available effective address mode is data register direct.
> DIVS, DIVU - The divide algorithm used by the TS68000 provides less than $10 \%$ difference between the best and worst case timings.
> MULS, MULU - The multiply algorithm requires $38+2 n$ clocks where $n$ is defined as:
> MULU: $n=$ the number of ones in the <ea>
> MULU: $n=$ concatanate the <ea> with a zero as the LSB; $n$ is the resultant number of 10 or 01 patterns in the 17 -bit source; i.e., worst case happens when the source is $\$ 5555$.

### 7.2.4 Immediate Instruction Execution Times

The number of clock periods shown in Table 7-7 includes the time to fetch immediate operands, perform the operations, store the results, and read the next operation. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

In Table 7-7, the headings have the following meanings: \# = immediate operand, $\mathrm{Dn}=$ data register operand, $A n=$ address register operand, $M=$ memory operand, and $S R=s t a t u s$ register.

Table 7-7. Immediate Instruction Execution Times

| Instruction | Size | op \#, Dn | op \#, An | op \#, M |
| :---: | :---: | :---: | :---: | :---: |
| ADDI | Byte, Word | 8(2/0) | - | 12(2/1) + |
|  | Long | 16(3/0) | - | 20(3/2) + |
| ADDQ | Byte, Word | 4(1/0) | 8(1/0)* | $8(1 ; 1)+$ |
|  | Long | 8(1/0) | $8(1 / 0)$ | $12(1 \cdot 2)+$ |
| ANDI | Byte, Word | 8(2/0) | - | $12(2) 1)+$ |
|  | Long | 16(3/0) | - | $201311+$ |
| CMPI | Byte, Word | 812/0) | - | $812.01+$ |
|  | Long | 14(3/0) | - | 12(3:0) + |
| EORI | Byte, Word | 8(2/0) | -- | 12(2) ${ }^{\text {( }}$ + |
|  | Long | 16(3/0) | - | 20(3:2) + |
| MOVEQ | Long | 4(1/0) | - | - |
| ORI | Byte, Word | 812/0) | - | 12(2) 1) + |
|  | Long | 16(3/0) | - | $201321+$ |
| SUBI | Byte, Word | 8(2/0) | - | $12(2 \cdot 1)+$ |
|  | Long | 16(3/0) | - | 2013.2) + |
| SUBQ | Byte, Word | 4(1/0) | 8(1/0)* | $8111)+$ |
|  | Long | 8(1/0) | 8(1)0) | 12(1.2) + |

+ add effective address calculation time
* word only


### 7.2.5 Single Operand Instruction Execution Times

Table 7-8 indicates the number of clock periods for the single operand instructions. The number of bus read and write cycles is shown in parenthesis as (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-8. Single Operand Instruction Execution Times

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| CLR | Byte, Word | 4(1/0) | 8(1/1) + |
|  | Long | 6(1/0) | 12(1/2) + |
| NBCD | Byte | 6(1/0) | $8(1,1)+$ |
| NEG | Byte, Word | 4(1/0) | $8(1,1)+$ |
|  | Long | 6(1/0) | 12(1/2) + |
| NEGX | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
|  | Long | 6(1/0) | 12(1/2)+ |
| NOT | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
|  | Long | 6(1/0) | 12(1/2) + |
| $\mathrm{S}_{\mathrm{CC}}$ | Byte, False | 4(1/0) | $8(1 / 1)+$ |
|  | Byte, True | 6(1/0 4 | $8(1 / 1)+$ |
| TAS | Byte | 4(1/0) | 10(1/1) + |
| TST | Byte, Word | 4(1/0) | $4(1 / 0)+$ |
|  | Long | 4(1/0) | $4(1 / 0)+$ |

[^37]
### 7.2.6 Shift/Rotate Instruction Execution Times

Table 7-9 indicates the number of clock periods for the shift and rotate instructions. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-9. Shift/Rotate Instruction Execution Times

| Instruction | Size | Register | Memory |
| :--- | :---: | :---: | :---: |
| ASR, ASL | Byte, Word | $6+2 \mathbf{n}(1 / 0)$ | $\mathbf{8}(1 / 1)+$ |
|  | Long | $8+2 \mathbf{n}(1 / 0)$ | - |
| LSR, LSL | Byte, Word | $6+2 \mathbf{n}(1 / 0)$ | $\mathbf{8 ( 1 / 1 ) +}$ |
|  | Long | $\mathbf{8 + 2 n}(1 / 0)$ | - |
| ROR, ROL | Byte, Word | $6+2 \mathbf{n}(1 / 0)$ | $\mathbf{8}(1 / 1)+$ |
|  | Long | $\mathbf{8 + 2 n}(1 / 0)$ | - |
|  | Byte, Word | $6+2 \mathbf{n}(1 / 0)$ | $\mathbf{8 ( 1 / 1 ) +}$ |
|  | Long | $\mathbf{8 + 2 n}(1 / 0)$ | - |

+ add effective address calculation time
$n$ is the shift or rotate count


### 7.2.7 Bit Manipulation Instruction Execution Times

Table 7-10 indicates the number of clock periods required for the bit manipulation instructions. The number of bus read and write cycles is shown in parenthesis as ( $r / w$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-10. Bit Manipulation Instruction Execution Times

| Instruction | Size | Dynamic |  | Static |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Register | Memory | Register | Memory |
| BCHG | Byte | - | $8(1 / 1)+$ | - | 12(2/1) + |
|  | Long | 8(1/0)* | - | 12(2/0)* | - |
| BCLR | Byte | - | $8(1 / 1)+$ | - | 12(2/1) + |
|  | Long | 10(1/0)* | - | 14(2/0)* | - |
| BSET | Byte | -- | $8(1 / 1)+$ | - | 12(2/1) + |
|  | Long | 8(1/0)* | - | 12(2/0)* | - |
| BTST | Byte | - | 4(1/0)+ | - | $8(2 / 0)+$ |
|  | Long | 6(1/0) | - | 10(2/0) | - |

+ add effective address calculation time
* indicates maxımum value


### 7.2.8 Conditional Instruction Execution Times

Table 7-11 indicates the number of clock periods required for the conditional instructions. The number of bus read and write cycles is indicated in parenthesis as ( $r / w$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-11. Conditional Instruction Execution Times

| Instruction | Displacement | Branch <br> Taken | Branch <br> Not Taken |
| :--- | :---: | :---: | :---: |
| BCC | Byte | $10(2 / 0)$ | $8(1 / 0)$ |
|  | Word | $10(2 / 0)$ | $12(2 / 0)$ |
| BSR | Byte | $10(2 / 0)$ | - |
|  | Word | $10(2 / 0)$ | - |
| DBCC | Byte | $18(2 / 2)$ | - |
|  | Word | $18(2 / 2)$ | - |

+ add effective address calculation time
* indicates maximum value


### 7.2.9 JMP, JSR, LEA, PEA, and MOVEM Instruction Execution Times

Table 7- 12 indicates the number of clock periods required for the jump, jump-to-subroutine, load effective address, push effective address, and move multiple registers instructions. The number of bus read and write cycles is shown in parenthesis as (r/w).

Table 7-12. JMP, JSR, LEA, PEA, and MOVEM Instruction Execution Times

| Instr | Size | (An) | (An) + | -(An) | d(An) | d(An, ix) + | xxx.W | xxx.L | d(PC) | d(PC, ix)* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | - | 8(2/0) | - | - | 10(2/0) | 14(3/0) | 10(2/0) | 12(3/0) | 10(2/0) | 14/3/0) |
| JSR | - | 16(2/2) | - | - | 18(2/2) | 22(2/2) | 18(2/2) | 2013/2) | 18(2/2) | 22(2/2) |
| LEA | - | 4(1/0) | - | - | 8(2/0) | 12(2/0) | 8(2/0) | 12(3/0) | 8(2/0) | 12(2/0) |
| PEA | - | 12(1/2) | - | - | 16/2/2) | 20(2/2) | 1612/2) | 20(3/2) | 16(2/2) | 2012/2) |
| MOVEM | Word | $\begin{array}{r} 12+4 n \\ (3+n / 0) \end{array}$ | $\begin{gathered} 12+4 n \\ (3+n / 0) \end{gathered}$ | - | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 18+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 20+4 n \\ (5+n / 0) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 18+4 n \\ (4+n / 0) \end{array}$ |
| $M \rightarrow R$ | Long | $\begin{array}{r} 12+8 n \\ (3+2 n / 0) \end{array}$ | $\begin{array}{r} 12+8 n \\ (3+2 n / 0) \end{array}$ | - | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 18+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 20+8 n \\ (5+2 n / 0) \end{array}$ | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \end{array}$ | $\begin{array}{r} 18+8 n \\ (4+2 n / 0) \end{array}$ |
| MOVEM | Word | $\begin{aligned} & \hline 8+4 n \\ & (2 / n) \end{aligned}$ | - | $\begin{aligned} & \hline 8+4 n \\ & (2 / n) \end{aligned}$ | $\begin{array}{r} 12+4 n \\ (3 / n) \\ \hline \end{array}$ | $\begin{array}{r} 14+4 n \\ (3 / n) \end{array}$ | $\begin{array}{r} \hline 12+4 n \\ (3 / n) \\ \hline \end{array}$ | $\begin{array}{r} 16+4 n \\ (4 / n) \end{array}$ | $-$ | -- |
| $R \rightarrow M$ | Long | $\begin{aligned} & 8+8 n \\ & (2 / 2 n) \end{aligned}$ |  | $\begin{aligned} & \hline 8+8 n \\ & (2 / 2 n) \end{aligned}$ | $\begin{aligned} & \hline 12+8 n \\ & (3 / 2 n) \end{aligned}$ | $\begin{aligned} & 14+8 n \\ & (3 / 2 n) \end{aligned}$ | $\begin{gathered} 12+8 n \\ (3 / 2 n) \end{gathered}$ | $\begin{aligned} & 16+8 n \\ & (4 / 2 n) \end{aligned}$ | - | -- |

$n$ is the number of registers to move
*is the size of the index register (ix) does not affect the instruction's execution time

### 7.2.10 Multi-Precision Instruction Execution Times

Table 7-13 indicates the number of clock periods for the multi-precision instructions. The number of clock periods includes the time to fetch both operands, perform the operations, store the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as (r/w).

In Table 7-13, the headings have the following meanings: $\mathrm{Dn}=$ data register operand and $\mathrm{M}=$ memory operand.

Table 7-13. Multi-Precision Instruction Execution Times

| Instruction | Size | op Dn, Dn | op M, M |
| :---: | :---: | :---: | :---: |
| ADDX | Byte, Word | 41101 | 181311 |
|  | Long | 81101 | 301521 |
| CMPM | Byte, Word |  | 121301 |
|  | Long |  | 201501 |
| SUBX | Byte, Word | $4!10$ | 181311 |
|  | Long | 81101 | 30152 |
| ABCD | Byte | $6!101$ | 181311 |
| SBCD | Byte | $6!101$ | 18131 |

### 7.2.11 Miscellaneous Instruction Execution Times

Tables 7-14 and 7-15 indicate the number of clock periods for the following miscellaneous instructions. The number of bus read and write cycles is shown in parenthesis as ( $r$. w). The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

Table 7-14. Miscellaneous Instruction Execution Times

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| ANDI to CCR | Byte | 201301 |  |
| ANDI to SR | Word | 201301 | - |
| CHK | - | $10110)+$ | . |
| EORI to CCR | Byte | 201301 |  |
| EORI to SR | Word | 201301 | - |
| ORI to CCR | Byte | 201301 |  |
| ORI to SR | Word | 201301 |  |
| MOVE from SR | - | 61101 | $81111+$ |
| MOVE to CCR | - | 12.201 | 1220) + |
| MOVE to SR | - | 121201 | 12201 - |
| EXG | - | 61101 | . |
| EXT | Word | 41100 | - |
|  | Long | $4(1.0)$ |  |
| LINK | - | 161221 | $\cdots$ |
| MOVE from USP | - | $4110)$ | - |
| MOVE to USP | - | $4110)$ | - |
| NOP | - | 411.01 | - |
| RESET | $-$ | $132(10)$ |  |
| RTE | - | 201501 | - |
| RTR | - | 2015 0) | - |
| RTS | - | 16/4.0) |  |
| STOP | - | 4(0)0) | $\cdots$ |
| SWAP | - | 4(1/0) |  |
| TRAPV | - | 4(1/0) | - |
| UNL.K | - | 1213/0) | $-$ |

+ add effective address calculation time

Table 7-15. Move Peripheral Instruction Execution Times

| Instruction | Size | Register $\rightarrow$ Memory | Memory $\rightarrow$ Register |
| :---: | :---: | :---: | :---: |
| MOVEP | Word | $16(2 / 2)$ | $16(4 / 0)$ |
|  | Long | $24(2 / 4)$ | $24(6 / 0)$ |

### 7.2.12 Exception Processing Execution Times

Table 7-16 indicates the number of clock periods for exception processing. The number of clock periods includes the time for all stacking, the vector fetch, and the fetch of the first two instruction words of the handler routine. The number of bus read and write cycles is shown in parenthesis as (r/w).

Table 7-16. Exception Processing Execution Times

| Exception | Periods |
| :--- | :--- |
| Address Error | $50(4 / 7)$ |
| Bus Error | $50(4 / 7)$ |
| CHK Instruction | $\mathbf{4 4 ( 5 / 4 ) +}$ |
| Divide by Zero | $\mathbf{4 2 ( 5 / 4 )}$ |
| Illegal Instruction | $34(4 / 3)$ |
| Interrupt | $44(5 / 3) *$ |
| Privilege Violation | $34(4 / 3)$ |
| $\overline{\text { RESET }} \boldsymbol{*} *$ | $\mathbf{4 0 ( 6 / 0 )}$ |
| Trace | $\mathbf{3 4 ( 4 / 3 )}$ |
| TRAP Instruction | $\mathbf{3 8 ( 4 / 4 )}$ |
| TRAPV Instruction | $\mathbf{3 4 ( 4 / 3 )}$ |

+ add effective address calculation time
* The interrupt acknowledge cycle is assumed to take four clock periods
*     * Indicates the time from when $\overline{\operatorname{RESET}}$ and $\overline{\text { HALT }}$ are first sampled as negated to when instruction execution starts.


## SECTION 8 ELECTRICAL SPECIFICATIONS

This section contains electrical specifications and associated timing information for the TS68000

### 8.1 MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -03 to + 70 | V |
| Input Voltage | $V_{\text {in }}$ | -0.3 to +7.0 | $\checkmark$ |
| $\begin{aligned} & \text { Operating Temperature Range } \\ & \text { TS68000C } \\ & \text { TS68000V } \\ & \text { TS68000M } \end{aligned}$ | ${ }^{T}$ A | $\begin{gathered} T T_{L} \text { to } T H \\ 0 \text { to } 70 \\ -40 \text { to } 85 \\ -55 \text { to } 125 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | ${ }^{\text {stg }}$ | - 55 to 150 | ${ }^{\circ} \mathrm{C}$ |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields, however, it is ad. vised that normal precautions be taken to avord application of any voltage higher than maximum-rated voltages to this high. impedance circuit Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level le 9 , either GND or $\mathrm{V}_{\mathrm{CC}}$

### 8.2 THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Symbol | Value | Rating |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Thermal Resistance (Stıll Aır) |  |  |  |  |  |
| Ceramic DIL |  | 30 |  | $15^{*}$ |  |
| Ceramic PGA |  | 33 |  | 15 |  |
| LCCC | JJA | 50 | $\theta J \mathrm{C}$ | 25 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic DIL |  | 35 |  | $15^{*}$ |  |
| PLCC |  | 60 |  | $25^{*}$ |  |

* Estimated


### 8.3 DC ELECTRICAL CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \% ; G N D=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to TH ; see Figures 8-1, 8-2, and 8-3)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 | $\mathrm{V}_{\text {CC }}$ | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | GND-0.3 | 0.8 | V |
| Input Leakage Current @ 5.25 V $\overline{B E R R}, \overline{\mathrm{BGACK}}, \overline{\mathrm{BR}}, \overline{\mathrm{DTACK}}$. <br> CLK, $\overline{\text { IPLO }} \overline{\mathrm{PLL}}, \overline{\mathrm{VPA}}$  <br> HALT, $\overline{\mathrm{RESET}}$  | $\mathrm{l}_{\text {in }}$ | - | $\begin{aligned} & 2.5 \\ & 20 \end{aligned}$ | $\mu \mathrm{A}$ |
|  | ITSI | - | 20 | $\mu \mathrm{A}$, |
| Output High Voltage $(1 \mathrm{OH}=-400 \mu \mathrm{~A})$ <br> $E, \overline{A S}, A 1-A 23, \overline{B G}, D 0-D 15$, FCO-FC2, $\overline{\mathrm{DS}}, \mathrm{R} / \bar{W}, \overline{U D S}, \overline{V M A}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}-0.75 \\ 2.4 \end{gathered}$ |  | V |
| $\begin{gathered} \text { Output Low Voltage } \\ (1 \mathrm{OL}=1.6 \mathrm{~mA}) \\ (1 \mathrm{OL}=3.2 \mathrm{~mA}) \\ (1 \mathrm{OL}=5.0 \mathrm{~mA}) \\ (1 \mathrm{OL}=5.3 \mathrm{~mA}) \end{gathered}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & - \\ & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & 0.5 \\ & 0.5 \\ & 0.5 \\ & 05 \end{aligned}$ | V |
| Power Dissipation (See 8.4 POWER CONSIDERATIONS) | $\mathrm{PD}^{* * *}$ | - | - | W |
| Capacitance ( $\mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{~T}^{\prime}=25^{\circ} \mathrm{C}$; Frequency $\left.=1 \mathrm{MHz}\right)^{* *}$ | $\mathrm{C}_{\text {in }}$ | - | 20.0 | pF |

* With external pullup resistor of $1.1 \mathrm{k} \mathrm{\Omega}$.
*     * Capacitance is periodically sampled rather than $100 \%$ tested.
***During normal operation instantaneous $V_{C C}$ current requirements may be as high as 1.5 A


Figure 8-1. $\overline{\text { RESET Test Load }}$


Figure 8-2. HALT Test Load


Figure 8-3. Test Loads

### 8.4 POWER CONSIDERATIONS

The average chip-junction temperature, $T_{J}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{aligned}
& T_{J}=T_{A}+\left(P_{D} \bullet \theta J A\right) \\
& \text { Where: }
\end{aligned}
$$

$$
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=\text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
& \theta J A=\text { Package Thermal Resistance, Junction-to-Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
& \text { PD }=\mathrm{PINT}^{2}+\mathrm{PI}_{\mathrm{I}} \mathrm{O} \\
& \text { PINT }=\text { ICC } \times \text { VCC }_{\text {C }} \text {, Watts - Chip Internal Power } \\
& \mathrm{P}_{\mathrm{I} / \mathrm{O}}=\text { Power Dissipation on Input and Output Pins - User Determined }
\end{aligned}
$$

For most applications $\mathrm{PI} / \mathrm{O}<$ PINT and can be neglected.
An approximate relationship between $P_{D}$ and $T_{J}$ (if $P_{I / O}$ is neglected) is:

$$
\begin{equation*}
P D=K \div\left(T J+273^{\circ} C\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \cdot\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \bullet P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P_{D}$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of TA.

Figure 8-4 illustrates the graphic solution to the equations, given above, for the specification power dissipations of 1.50 and 1.75 watts over the ambient temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ using an average $\theta \mathrm{JA}$ of $40^{\circ} \mathrm{C} /$ watt to represent the various TS68000 packages. However, actual $\theta \mathrm{JA}{ }^{\prime} \mathrm{s}$ in the range of $30^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C} /$ watt only change the curves slightly.


Figure 8-4. TS68000 Power Dissipation (PD) vs Ambient Temperature ( $T_{A}$ )

The total thermal resistance of a package $(\theta J A)$ can be separated into two components, $\theta J C$ and $\theta$ CA, representing the barrier to heat flow from the semiconductor junction to the package (case) surface ( $\theta J C$ ) and from the case to the outside ambient ( $\theta$ CA) . These terms are related by the equation:

$$
\begin{equation*}
\theta \mathrm{JA}=\theta \mathrm{JC}+\theta \mathrm{CA} \tag{4}
\end{equation*}
$$

$\theta \mathrm{JC}$ is device related and cannot be influenced by the user. However, $\theta \mathrm{CA}$ is user dependent and can be minimized by such thermal management techniques as heat sinks, ambient air cooling and thermal convention. Thus, good thermal management on the part of the user can significantly reduce $\theta$ CA so that $\theta$ JA approximately equals $\theta$ JC. Substitution of $\theta$ JC for $\theta$ JA in equation (1) will result in a lower semiconductor junction temperature.
8.5 AC ELECTRICAL SPECIFICATIONS - CLOCK TIMING (See Figure 8-5)

| Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $f$ | 4.0 | 8.0 | 4.0 | 10.0 | 4.0 | 12.5 | 4.0 | 16 | $\mathrm{MH}_{2}$ |
| Cyele Time | ${ }_{\text {ceyc }}$ | 125 | 250 | 100 | 250 | 80 | 250 | 60 | 250 | ns |
| Clock Pulse Width | $\begin{aligned} & { }^{\circ} \mathrm{CL} \\ & \\ & \\ & \mathrm{H} \mathrm{CH} \end{aligned}$ | $\begin{aligned} & 55 \\ & 55 \end{aligned}$ | $\begin{aligned} & 125 \\ & 125 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 126 \\ & 125 \end{aligned}$ | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ | $\begin{aligned} & 125 \\ & 125 \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | $\begin{aligned} & 125 \\ & 125 \end{aligned}$ | ns |
| Rise and Fall Times | $\begin{aligned} & \mathrm{C}_{\mathrm{Cr}} \\ & \mathrm{t}_{\mathrm{t}} \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \\ & \hline \end{aligned}$ | - | 10 <br> 10 | - | 5 5 | - | 5 5 | ns |



NOTE:
Timing measurements are referenced to and from a low voltage of 0.8 volt and high a voltage of 2.0 volts, unless otherwise noted.
The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between
0.8 volt and 2.0 volts.
Figure 8-5. Clock Input Timing Diagram

### 8.6 AC ELECTRICAL SPECIFICATIONS - READ CYCLES

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \% ; \mathrm{GND}=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; see Figure 8-6)

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 1 | Clock Period | ${ }^{\text {t }} \mathrm{CYC}$ | 125 | 250 | 100 | 250 | 80 | 250 | 60 | 250 | ns |
| 2 | Clock Width Low | ${ }^{\text {t }} \mathrm{CL}$ | 55 | 125 | 45 | 125 | 35 | 125 | 25 | 125 | ns |
| 3 | Clock Width High | ${ }^{\text {t }} \mathrm{CH}$ | 55 | 125 | 45 | 125 | 35 | 125 | 25 | 125 | ns |
| 4 | Clock Fall Time | ${ }^{1} \mathrm{Cf}$ | - | 10 | - | 10 | - | 5 | - | 5 | ns |
| 5 | Clock Rise Time | ${ }^{\text {t }} \mathrm{Cr}$ | - | 10 | - | 10 | - | 5 | - | 5 | ns |
| 6 | Clock Low to Address Valid | ${ }^{\text {' }}$ CLAV | - | 70 | - | 60 | - | 55 | - | 50 | ns |
| 6 A | Clock High to FC Valid | ${ }^{\text {t }}$ CHFCV | - | 70 | - | 60 | - | 55 | - | 50 | ns |
| 7 | Clock High to Address, Data Bus High Impedance (Maximum) | ${ }^{\text {t }}$ CHADZ | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 8 | Clock High to Address, FC Invalid (Minimum) | ${ }^{\text {t }}$ CHAFI | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }} \mathrm{CHSL}$ | 0 | 60 | 0 | 55 | 0 | 55 | 0 | 55 | ns |
| $11^{2}$ | Address Valid to $\overline{\mathrm{AS}}$, $\overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ AVSL | 30 | - | 20 | - | 0 | - | 0 | - | ns |
| $11 \mathrm{~A}^{2}$ | FC Valid to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ CCVSL | 60 | - | 50 | - | 40 | - | 30 | - | ns |
| $12^{1}$ | Clock Low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High | ${ }^{\text {' }}$ LLSH | - | 70 | - | 55 | - | 50 | - | 45 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Address/FC Invalid | ${ }^{\text {T}}$ SHAFI | 30 | - | 20 | - | 10 | - | 10 | - | ns |
| $14^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width Low | ${ }^{\text {'SL }}$ | 240 | - | 195 | - | 160 | - | 120 | - | ns |
| $15^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width High | ${ }^{\text {t }}$ SH | 150 | - | 105 | - | 65 | - | 50 | - | ns |
| $17^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to R/W High | ${ }^{\text {t }}$ SHRH | 40 | - | 20 | - | 10 | - | 10 | - | ns |
| $18^{1}$ | Clock High to R/W High | ${ }^{\text {t }} \mathrm{CHRH}$ | 0 | 70 | 0 | 60 | 0 | 60 | 0 | 55 | ns |
| $27^{5}$ | Data In to Clock Low (Setup Time) | ${ }^{\text {t }}$ IICL | 15 | - | 10 | - | 10 | - | 10 | - | ns |
| $28^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\text { DTACK }}$ High | ${ }^{\text {'SHDAH }}$ | 0 | 245 | 0 | 190 | 0 | 150 | 0 | 110 | ns |
| 29 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data In Invalid (Hold Time) | ${ }^{\text {'SHDII }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 30 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{BERR}}$ High | ${ }^{\text {t }}$ SHBEH | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $31^{2.5}$ | $\overline{\text { DTACK Low to Data In (Setup Time) }}$ | ${ }^{\text {t }}$ ALLDI | - | 90 | - | 65 | - | 50 | - | 30 | ns |
| 32 | $\overline{\text { HALT }}$ and $\overline{\text { RESET }}$ Input Transition Time | ${ }^{\text {tRHr, }}$ ¢ | 0 | 200 | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| $47^{5}$ | Asynchronous Input Setup Time | ${ }^{\text {t }} \mathrm{ASI}$ | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| $48^{3}$ | $\overline{\text { BERR }}$ Low to DTTACK Low | ${ }^{\text {t }}$ BELDAL | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| $56^{4}$ | $\overline{\text { HALT }} / \overline{\text { RESET }}$ Pulse Width | tHRPW | 10 | - | 10 | - | 10 | - | 10 | - | Clk.Per. |

## NOTES :

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the value given in the maximum columns.
2. Actual value depends on clock period
3. If 47 is satisfied for both $\overline{\text { DTACK }}$ and $\overline{B E R R}, 48$ may be 0 nanosecond.
4. For power up, the MPU must be held in RESET state for 100 milliseconds to allow stabilization of on-chip circuitry. After the system is powered up, 56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (47) requirements are satisfied, the $\overline{\text { DTACK }}$ low-to-data setup time (31) requirement can be ignored. The data must only satisfy the data-in to clock-low setup time (27) for the following cycle.

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation.


NOTES:

1. Setup time for the synchronous inputs $\overline{B G A C K}, \overline{\mathrm{PLO}-2}$, and $\overline{\mathrm{VPA}}$ guarantees their recogrition at the next taling edge of the clock
2. $\overline{B R}$ need fall at this time only in order to insure being recognized at the end of this bus cycle.
3. Timing measurements are referenced to and from a iow voltage of 08 volt and a high voltage 2.0 volts, unless otherwise noted The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 08 volt and 2.0 volis.

Figure 8-6. Read Cycle Timing Diagram

### 8.6 AC ELECTRICAL SPECIFICATIONS - WRITE CYCLES

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \% ; G N D=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; see Figure 8-7)

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 1 | Clock Period | ${ }^{\text {t }}$ cyc | 125 | 250 | 100 | 250 | 80 | 250 | 60 | 250 | ns |
| 2 | Clock Width Low | ${ }^{\text {'CL }}$ | 55 | 125 | 45 | 125 | 35 | 125 | 25 | 125 | ns |
| 3 | Clock Width High | ${ }^{\text {c }} \mathrm{CH}$ | 55 | 125 | 45 | 125 | 35 | 125 | 25 | 125 | ns |
| 4 | Clock Fall Time | ${ }^{\text {t }} \mathrm{C} f$ | - | 10 | - | 10 | - | 5 | - | 5 | ns |
| 5 | Clock Rise Time | ${ }^{\text {t }} \mathrm{Cr}$ | - | 10 | - | 10 | - | 5 | - | 5 | ns |
| 6 | Clock Low to Address Valid | ${ }^{\text {t }}$ CLAV | - | 70 | - | 60 | - | 55 | - | 50 | ns |
| 6A | Clock High to FC Valid | ${ }^{\text {t }} \mathrm{CHFCV}$ | - | 70 | - | 60 | - | 55 | - | 50 | ns |
| 7 | Clock High to Address, Data Bus High Impedance (Maximum) | ${ }^{\text {t }}$ CHADZ | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 8 | Clock High to Address, FC Invalid (Minimum) | ${ }^{\text {t }} \mathrm{CHAFI}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ CHSL | 0 | 60 | 0 | 55 | 0 | 55 | 0 | 55 | ns |
| $11^{2}$ | Address Valid to AS Low | ${ }^{\text {t }}$ AVSL | 30 | - | 20 | - | 0 | - | 5 | - | ns |
| $11 \mathrm{~A}^{2}$ | FC Valid to $\overline{\mathrm{AS}}$ Low | ${ }^{\text {tFCVSL }}$ | 60 | - | 50 | - | 40 | - | 30 | - | ns |
| $12^{1}$ | Clock Low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High | ${ }^{\text {t }}$ CLSH | - | 70 | - | 55 | - | 50 | - | 45 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Address/FC Invalid | tSHAFI | 30 | - | 20 | - | 10 | - | 10 | - | ns |
| $14^{2}$ | $\overline{\text { AS Low }}$ | ${ }^{\text {t }}$ SL | 240 | - | 195 | - | 160 | - | 120 | - | ns |
| $14 \mathrm{~A}^{2}$ | $\overline{\mathrm{DS}}$ Width Low | ${ }^{\text {T }}$ DSL | 115 | - | 95 | - | 80 | - | 60 | - | ns |
| $15^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width High | ${ }^{\text {t }}$ SH | 150 | - | 105 | - | 65 | - | 50 | - | ns |
| $18^{1}$ | Clock High to R/W High | ${ }^{\text {t }}$ CHRH | 0 | 70 | 0 | 60 | 0 | 60 | 0 | 55 | ns |
| $20^{1}$ | Clock High to R/W Low | ${ }^{\text {t }}$ CHRL | - | 70 | - | 60 | - | 60 | - | 55 | ns |
| $20 A^{6}$ | $\overline{\mathrm{AS}}$, Low to R/ $\bar{W}$ Valid | ${ }^{\text {'ASRV }}$ | - | 20 | - | 20 | - | 20 | - | 20 | ns |
| $21^{2}$ | Address Valid to R/̄W Low | ${ }^{\text {t }}$ AVRL | 20 | - | 0 | - | 0 | - | 0 | - | ns |
| $21 \mathrm{~A}^{2}$ | FC Valid to R/W Low | ${ }^{\text {'FCCVRL }}$ | 60 | - | 50 | - | 30 | - | 20 | - | ns |
| $22^{2}$ | R/W Low to $\overline{\mathrm{DS}}$ Low | tRLSL | 80 | - | 50 | - | 30 | - | 20 | - | ns |
| 23 | Clock Low to Data Out Valid | ${ }^{\text {t }}$ CLDO | - | 70 | - | 55 | - | 55 | - | 50 | ns |
| $25^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data Out Invalid | ${ }^{\text {t }}$ SHDOI | 30 | - | 20 | - | 15 | - | 10 | - | ns |
| $26^{2}$ | Data Out Valid to $\overline{\text { DS }}$ Low | tDOSL | 30 | - | 20 | - | 15 | - | 15 | - | ns |
| $28^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\text { DTACK }}$ High | ${ }^{\text {T }}$ SHDAH | . 0 | 245 | 0 | 190 | 0 | 150 | 0 | 110 | ns |
| 30 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{BERR}}$ High | ${ }^{\text {'SHBEH }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 32 | $\overline{\text { HALT }}$ and $\overline{\text { RESET }}$ Input Transition Time | ${ }^{\text {tRHr }}$, $f$ | 0 | 200 | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| $47^{5}$ | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| $48^{3}$ | $\overline{\text { BERR }}$ Low to DTTACK Low | ${ }^{\text {'BELDAL }}$ | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| 53 | Clock High to Data Out Invalid | ${ }^{\text {t }} \mathrm{CHDOI}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 55 | R/ $\bar{W}$ to Data Bus Driven | tRLDBD | 30 | - | 20 | - | 10 | - | 10 | - | ns |
| $56^{4}$ | $\overline{\text { HALT }}$ / $\overline{\text { RESET }}$ Pulse Width | thRPW | 10 | - | 10 | - | 10 | - | 10 | - | Clk.Per |

## NOTES :

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the value given in the maximum columns
2. Actual value depends on clock period.
3. If 47 is satisfied for both $\overline{D T A C K}$ and $\overline{B E R R}, 48$ may be 0 nanoseconds.
4. For power up, the MPU must be held in RESET state for 100 milliseconds to allow stabilization of on-chip circuitry. After the syster is powered up, 56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (47) requirements are satisfied, the DTACK low-to-data setup time (31) requirement can be ignorec The data must only satisfy the data-in to clock-low setup time (27) for the following cycle.
6. When $\overline{A S}$, and $R / \bar{W}$ are equally loaded ( $\pm 20 \%$ ), Subtract 10 nanoseconds from the values in these columns.

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation.


NOTES:

1. Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts.
2. Because of loading variations, $R / \bar{W}$ may be valid after $\overline{A S}$ even though both are initiated by the rising edge of $S 2$ (Specification 20A).

Figure 8-7. Write Cycle Timing Diagram

### 8.7 AC ELECTRICAL SPECIFICATIONS - TS 68000 to 6800 PERIPHERAL

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \% ; G N D=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; refer to Figures $8-8$ and $\left.8-9\right)$

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $12^{1}$ | Clock Low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High | ${ }^{\text {' CLSH }}$ | - | 70 | - | 55 | - | 50 | - | 45 | ns |
| $18^{1}$ | Clock High to R/W High | ${ }^{\text {t }} \mathrm{CHRH}$ | 0 | 70 | 0 | 60 | 0 | 60 | 0 | 55 | ns |
| $20^{1}$ | Clock High to R $\bar{W} \cdot$ Low (Write) | ${ }^{\text {t }}$ CHRL | - | 70 | - | 60 | - | 60 | - | 55 | ns |
| 23 | Clock Low to Data Out Valid (Write) | ${ }^{\text {² ClDO }}$ | - | 70 | - | 55 | - | 55 | - | 50 | ns |
| $27^{2}$ | Data In to Clock Low (Setup Time on Read) | ${ }^{1} \mathrm{CLDO}$ | 15 | - | 10 | - | 10 | - | 10 | - | ns |
| 29 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data In Invalid (Hold Time on Read) | ${ }^{\text {'SHDII }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 40 | Clock Low to VMA Low | ${ }^{\text {c }}$ CLVML | - | 70 | - | 70 | - | 70 | - | 70 | ns |
| 41 | Clock Low to E Transition | ${ }^{\text {t CLET }}$ | - | 70 | - | 55 | - | 45 | - | 45 | ns |
| 42 | E Output Rise and Fall Time | ${ }^{1} \mathrm{Er}, \mathrm{f}$ | - | 25 | - | 25 | - | 25 | - | 25 | ns |
| 43 | $\overline{\mathrm{VMA}}$ Low to E High | ${ }^{\text {T VMLEH }}$ | 200 | - | 150 | - | 90 | - | 70 | - | ns |
| 44 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{VPA}}$ High | ${ }^{\text {t }}$ SHVPH | 0 | 120 | 0 | 90 | 0 | 70 | 0 | 50 | ns |
| 45 | E Low to Control, Address Bus Invalid (Address Hold Time) | ${ }^{\text {t }}$ LCAI | 30 | - | 10 | - | 10 | - | 10 | - | ns |
| $47^{2}$ | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| $49^{3}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to E Low | ${ }^{\text { }}$ SHEL | -70 | 70 | -55 | 55 | -45 | 45 | -45 | +45 | ns |
| 50 | E Width High | ${ }^{\prime} \mathrm{EH}$ | 450 | - | 350 | - | 280 | - | 210 | - | ns |
| 51 | E Width Low | ${ }^{\text {tel }}$ | 700 | - | 550 | - | 440 | - | 330 | - | ns |
| 54 | E Low to Data Out Invalid | 'ELDO! | 30 | - | 20 | - | 15 | - | 10 | - | ns |

## NOTES :

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the value given in the maximum columns. 2. If the asynchronous setup time (47) requirements are satisfied, the DTACK low-to-data setup time (31) requirement can be ignored. The data must only satisfy the date-in clock-low setup time (27) for the following cycle.
2. The falling edge of $S 6$ triggers both the negation of the strobes $(\overline{\mathrm{AS}}$, and $\times \overline{\mathrm{DS}})$ and the falling edge of $E$. Either of these events can occur first, depending upon the loading on each signal. Specification 49 indicates the absolute maximum skew that will occur between the rising edge of the strobes and the falling edge of the E clock.


This timing diagram is included for those who wish to design their own circuit to generate $\overline{\mathrm{VMA}}$ it shows the best case possibly attainable
Figure 8-8. TS 68000 to $\mathbf{6 8 0 0}$ Peripheral Timing Diagram - Best Case


NOTE This timing diagram is included for those who wish to design their own circuit to generate VMA. It shows the worst case possibly attainable.
Figure 8-9. TS68000 to 6800 Peripheral Timing Diagram - Worst Case

### 8.8 AC ELECTRICAL SPECIFICATIONS - BUS ARBITRATION

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \% ; \mathrm{GND}=0 \mathrm{Vdc} ; \mathrm{T}_{A}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; see Figures 8-10, 8-11, and 8-12)

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | 16 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 7 | Clock High to Address, Data Bus High Impedance | ${ }^{\text {² }}$ CHADZ | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 16 | Clock High to Control Bus High Impedance | ${ }^{\text {' }} \mathrm{CHCZ}$ | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 33 | Clock High to $\overline{\mathrm{BG}}$ Low | ${ }^{\text {t }}$ CHGL | - | 70 | - | 60 | - | 50 | - | 45 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | ${ }^{\text {' }}$ CHGH | - | 70 | - | 60 | - | 50 | - | 45 | ns |
| 35 | $\overline{\mathrm{BR}}$, Low to $\overline{\mathrm{BG}}$ Low | ${ }^{\text {'BRLGL }}$ | 1.5 | $\begin{array}{\|r\|} \hline 90 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|r\|} \hline 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{r} 70 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|c\|} \hline 65 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | Clk. Per. |
| $36^{1}$ | $\overline{\mathrm{BR}}$ High to $\overline{\mathrm{BG}}$ High | 'BKHGH | 1.5 | $\begin{array}{\|r\|} \hline 90 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|r\|} \hline 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{r} 70 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|c\|} \hline 65 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | Clk. Per. |
| 37 | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BG}}$ High | 'GALGH | 1.5 | $\begin{array}{\|l\|} \hline 90 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|l\|} \hline 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|r\|} \hline 70 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|c\|} \hline 65 \mathrm{~ns} \\ -3.5 \\ \hline \end{array}$ | Clk. Per. |
| $37 A^{2}$ | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BR}}$ High | ${ }^{\text {'GALBRH }}$ | 20 | $\begin{array}{\|r\|} \hline 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | 20 | $\begin{array}{\|c} 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | 20 | $\begin{array}{\|c\|} \hline 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | 20 | $\begin{array}{\|c} 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | ns |
| 38 | $\overline{\mathrm{BG}}$ Low to Control, Address, Data Bus High Impedance ( $\overline{\mathrm{AS}}$ High) | 'GLZ | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 39 | $\overline{\mathrm{BG}}$ Width High | ${ }^{\text {t GH }}$ | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| 46 | BGACK Width Low | ${ }^{\text {t }}$ AAL | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| $47^{3}$ | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| 57 | $\overline{\mathrm{BGACK}}$ High to Control Bus Driven $\overline{\mathrm{AS}}, \overline{\mathrm{UDS}, \overline{\mathrm{LDS}}}$$F C_{x}, R / \bar{W}, \overline{V M A} \mid$ | ${ }^{\text {'GABD }}$ | 1.5 | - | 1.5 | - | 1.5 | - | - | 1.5 | Clk.Per. |
|  |  |  | 1 |  | 1 |  | 1 |  |  | 1 |  |
| $58^{1}$ | $\overline{\text { BR High to Control Bus Driven }}$ | ${ }^{\prime}$ ¢ंHBD | 15 | - | 1.5 | - | 1.5 | - | - | 1.5 | Clk.Per |

NOTES :

1. The processor will negate $\overline{\mathrm{BG}}$ and begin driving the bus again if external arbitration logic negates $\overline{B R}$ before asserting $\overline{\mathrm{BGACK}}$
2. The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, $\overline{\mathrm{BG}}$ may be reasserted.
3. If the asynchronous setup time (47) requirements are satisfied, the DTACK low-to-data setup time (31) requirement can ban ignored. The data must only satisfy the date-in clock-low setup time (27) for the following cycle.

Figures $8-10,8-11$, and $8-12$ depict the three bus arbitration cases that can arise. Figure $8-10$ shows the timing where $\overline{\mathrm{AS}}$ is negated when the processor asserts $\overline{\mathrm{BG}}$ (Idle Bus Case). Figure $8-11$ shows the timing where $\overline{\mathrm{AS}}$ is asserted when the processor asserts $\overline{\mathrm{BG}}$ (Active Bus Case). Figure 8-12 shows the timing where more than one bus master are requesting the bus. Refer to 4.2.2 Bus Arbitration for a complete discussion of bus arbitration.

The waveforms shown in Figures $8-10,8-11$, and $8-12$ should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation.


Figure 8-10. Bus Arbitration Timing Diagram - Idle Bus Case


Figure 8-11. Bus Arbitration Timing Diagram - Active Bus Case


Figure 8-12. Bus Arbitration Timing Diagram - Multiple Rus Requests

## SECTION 9

ORDERING INFORMATION
This section contains detailed information to be used as a guide when ordering the TS 68000 9.1. STANDARD VERSIONS

| Package Type | Frequency (MHz) | Temperature | Order Number |
| :---: | :---: | :---: | :---: |
| Ceramic DIL | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CC8 |
| C Suffix | 8.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS 68000 VC8 |
|  | 8.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 MC8 |
|  | 10.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CC10 |
|  | 10.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS 68000 VC10 |
|  | 10.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 MC10 |
|  | 12.5 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CC12 |
|  | 12.5 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS 68000 VC12 |
|  | 12.5 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 MC12 |
|  | 16.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CC16 |
| Plastic DIL | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CP8 |
| P Suffix | 10.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CP10 |
|  | 12.5 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CP12 |
|  | 16.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CP16 |
| PLCC | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CFN8 |
| FN Suffix | 10.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CFN10 |
|  | 12.5 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CFN12 |
|  | 16.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CFN16 |
| LCCC | 8.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 ME8 |
| E Suffix | 10.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 ME10 |
|  | 12.5 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 ME 12 |
| Pin Grid Array | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CR8 |  |
| R Suffix | 8.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 MR8 |
|  | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CR10 |  |
|  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 MR10 |  |
|  | 10.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CR12 |
|  | 10.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS 68000 MR12 |
|  | 12.5 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68000 CR16 |

### 9.2. HI-REL VERSIONS

In order to fit more closely to customer specific requirements, THOMSON SEMICONDUCTEURS is proposing different screening levels for its HI-REL ranges.
G/B screening : Available only from THOMSON SEMICONDUCTEURS, this quality level, very close to the MIL-STD-883, is a cost effective alternative for customers who want to buy HI-REL devices (low guaranteed AQL). The G/B level is in full accordance with the NFC 96883 class G.
B/B screening: Full accordance with the MIL-STD-883 Rev.C, class B (US), the CECC 90.000, class B (European) and with the NFC 96883 class B (French).
Details on screening procedures for these levels of selection are available on request (please contact our sales representatives).

| Package Type | Frequency ( MHz ) | Temperature | Order Number |
| :---: | :---: | :---: | :---: |
| Ceramic DIL C Suffix | $\begin{array}{r} 8.0 \\ 8.0 \\ 10.0 \\ 10.0 \\ 12.5 \\ 12.5 \\ \hline \end{array}$ | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \end{aligned}$ | TS 68000 MC G/B8 TS 68000 MC B/B8 TS 68000 MC G/B10 TS 68000 MC B/B10 TS 68000 MC G/B12 TS 68000 MC B/B12 |
| LCCC E Suffix | $\begin{array}{r} 8.0 \\ 8.0 \\ 10.0 \\ 10.0 \\ 12.5 \\ 12.5 \\ \hline \end{array}$ | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+1256 \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \end{aligned}$ | TS 68000 MEG/B8 TS 68000 ME B/B8 TS 68000 ME G/B10 TS 68000 ME B/B10 TS 68000 ME G/B12 TS 68000 ME B/B12 |
| Pin Grid Array R Suffix | $\begin{array}{r} 8.0 \\ 8.0 \\ 10.0 \\ 10.0 \\ 12.5 \\ 12.5 \\ \hline \end{array}$ | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \end{aligned}$ | TS 68000 MR G/B8 TS 68000 MR B/B8 TS 68000 MR G/B10 TS 68000 MR B/B10 TS 68000 MR G/B12 TS 68000 MR B/B12 |

## SECTION 10 <br> MECHANICAL DATA

This section contains the pin assignments and package dimensions for the 64-pin dual-in-line, the 68 -terminal chip carrier (LCCC), the 68-pin grid array, and the 68 -pin quad pack (PLCC), versions of the TS68000.
10.1 PIN ASSIGNMENTS

64-Pin Dual-in-Line Package


68-Terminal Chip Carrier (LCCC)


68-Pin Quad Pack (PLCC)


68-Pin Grid Array


### 10.2 PACKAGE DIMENSIONS



PSUFFIX PLASTIC PACKAGE

C SUFFIX CERAMIC PACKAGE



E SUFFIX LCCC 68


## ADVANCE INFORMATION

The TS 68008 is a member of the TS 68000 family of advanced microprocessors. This device allows the design of cost effective systems using 8 -bit data buses while providing the benefits of a 32 -bit microprocessor architecture. The performance of the TS68008 is greater than any 8 -bit microprocessor and superior to several 16 -bit microprocessors.

- 17 32-Bit Data and Address Registers
- 56 Basic Instruction Types
- Extensive Exception Processing
- Memory Mapped I/O
- 14 Addressing Modes
- 1 Mbyte Linear Addressing Space
- Complete Code Compatibility with the TS68000.

A system implementation based on an 8-bit data bus reduces system cost in comparison to 16 -bit systems due to a more effective use of components and the fact that byte-wide memories and peripherals can be used much more effectively. In addition, the non-multiplexed address and data buses eliminate the need for external demultiplexers, thus further simplifying the system.

## PROGRAMMING MODEL



## HMOS

HIGH-DENSITY, N-CHANNEL, SILICON-GATE, DEPLETION LOAD

## 8-/32-BIT MICROPROCESSOR WITH 8-BIT DATA BUS



## SECTION 1 <br> INTRODUCTION

The TS68008 is a member of the 68000 Family of advanced microprocessors. This device allows the design of cost effective systems using 8-bit data buses while providing the benefits of a 32-bit microprocessor architecture. The performance of the TS68008 is greater than any 8-bit microprocessor and superior to several 16 -bit microprocessors.

The resources available to the TS68008 user consist of the following:

- 17 32-Bit Data and Address Registers
- 56 Basic Instruction Types
- Extensive Exception Processing
- Memory Mapped I/O
- 14 Addressing Modes
- Complete Code Compatibility with the TS68000

A system implementation based on an 8 -bit data bus reduces system cost in comparison to 16 -bit systems due to a more effective use of components and the fact that byte-wide memories and peripherals can be used much more effectively. In addition, the non-multiplexed address and data buses eliminate the need for external demultiplexers, thus further simplifying the system.

The TS68008 has full code compatibility (source and object) with the TS68000 which allows programs to be run on either MPU, depending on performance requirements and cost objectives.

The TS68008 is available in a 48-pin dual-in-line package (plastic or ceramic) and a 52 -pin quad plastic package. Among the four additional pins of the 52 -pin package, two additional address lines are included beyond the 20 address lines of the 48-pin package. The address range of the TS68008 is one or four megabytes with the 48 - or 52 -pin package, respectively.

The large non-segmented linear address space of the TS68008 allows large modular programs to be developed and executed efficiently. A large linear address space allows program segment sizes to be determined by the application rather than forcing the designer to adopt an arbitrary segment size without regard to the application's individual requirements.

The programmer's model is identical to that of the TS68000, as shown in Figure 1-1, with seventeen 32 -bit registers, a 32 -bit program counter, and a 16 -bit status register. The first eight registers (D0-D7) are used as data registers for byte ( 8 -bit), word ( 16 -bit), and long word (32-bit) operations. The second set of seven registers (A0-A6), the user stack pointer (A7), and the system stack pointer ( $\mathrm{A} 7^{\prime}$ ) may be used as software stack pointers and base address registers. In addition, the registers may be used for some simple word and long word data operations. All of the 17 registers may be used as index registers.


Figure 1-1. Programming Model
While all of the address registers can be used to create stacks and queues, the A7 address register, by convention, is used as the system stack pointer. Supplementing this convention is another address register, A7', also referred to as the system stack pointer. This powerful concept allows the supervisor mode and user mode of the TS68008 to each have their own system stack pointer (consistently referred to as SP) without needing to move pointers for each context of use when the mode is switched.

The system stack pointer (SP) is either the supervisor stack pointer ( $A 7^{\prime} \equiv$ SSP) or the user stack point ( $A 7 \equiv U S P$ ), depending on the state of the $S$ bit in the status register. If the $S$ bit is set, indicating that the processor is in the supervisor state, when the SSP is the active system stack pointer and the USP is not used. If the S bit is clear, indicating that the processor is in the user state, then the USP is the active system stack pointer and the SSP is protected from user modification.

The status register, shown in Figure 1-2, may be considered as two bytes: the user byte and the system byte. The user byte contains five bits defining the overflow (V), zero (Z), negative ( N ), carry $(C)$, and extended ( X ) condition codes. The system byte contains five defined bits. Three bits are used to define the current interrupt priority; any interrupt level higher than the current mask level will be recognized. (Note that level 7 interrupts are non-maskable - that is, level 7 interrupts are always processed.I Two additional bits indicate whether the processor is in the trace ( $T$ ) mode and/or in the supervisor (S) state.


Figure 1-2. Status Register

### 1.1 DATA TYPES AND ADDRESSING MODES

Five basic data types are supported. These data types are:

- Bits
- BCD Digits (4 bits)
- Bytes (8 bits)
- Words (16 bits)
- Long Words (32 bits)

In addition, operations on other data types such as memory addresses, status word data, etc., are provided in the instruction set.

Most instructions can use any of the 14 addressing modes which are listed in Table 1-1. These addressing modes consist of six basic types:

- Register Direct
- Register Indirect
- Absolute
- Program Counter Relative
- Immediate
- Implied

Table 1-1. Addressing Modes

| Addressing Modes | Syntax |
| :---: | :---: |
| Register Direct Addressing Data Register Direct Address Register Direct | $\begin{aligned} & \mathrm{Dn} \\ & \mathrm{An} \end{aligned}$ |
| Absolute Data Addressing Absolute Short Absolute Long | $\begin{aligned} & x \times x \times W \\ & x \times x L^{2} \end{aligned}$ |
| Program Counter Relative Addressing Relative with Oftset Re'ative with Index Ottset | $\begin{aligned} & d_{16}(P C) \\ & d_{8}\left(P C, x_{n}\right) \end{aligned}$ |
| Register Indirect Addressing <br> Register Indirect <br> Postincrement Register Indirect Predecrement Register Indirect Register Incirect with Oftset Indexed Regegter Indirect with Ottset | (An) <br> (An) + <br> - (An) <br> $d_{16}(A n)$ <br> $d_{8}(A n, X n)$ |
| Immedrate. Data Addessing Immeddide <br> () atick Immediate | $\begin{aligned} & \# x \times x \\ & \# 1 \cdot \# 8 \end{aligned}$ |
| Impleed Addre'sing Impleed Re'giste. | SR/USP, SP:PC |

NOTES:
Dn = Data Register
An = Address Register
$\mathrm{X}_{\mathrm{n}}=$ Address or Data Register used as Index Register
SR $=$ Status Register
$P C=$ Program Counter
$S P=$ Stack Pointer
USP $=$ User Stack Pointer
() = Contents of
$\mathrm{d}_{8}=8$-Bit Offset (Displacement)
$d_{16}=16$-Bit Offset (Displacement)
*xxx = Immediate Data

The register indirect addressing modes also have the capability to perform postincrementing, predecrementing, offsetting, and indexing. The program counter relative mode may be used in combination with indexing and offsetting for writing relocatable programs.

### 1.2 INSTRUCTION SET OVERVIEW

The TS68008 is completely code compatible with the TS68000. This means that programs developed for the TS68000 will run on the TS68008 and vice versa. This applies equally to either source code or object code.

The instruction set was designed to minimize the number of mnemonics remembered by the programmer. To further reduce the programmer's burden, the addressing modes are orthogonal.

The instruction set, shown in Table 1-2, forms a set of programming tools that include all processor functions to perform data movement, integer arithmetic, logical operations, shift and rotate operations, bit manipulation, BCD operations, and both program and system control. Some additional instructions are variations or subsets of these and appear in Table 1-3.

Table 1-2. Instruction Set

| Mnemonic | Description |
| :--- | :--- |
| ABCD | Add Decimal With Extend |
| ADD | Add |
| AND | Logical And |
| ASL | Arithmetic Shift Left |
| ASR | Arithmetic Shift Right |
| Bcc | Branch Conditionally |
| BCHG | Bit Test and Change |
| BCLR | Bit Test and Clear |
| BRA | Branch Always |
| BSET | Bit Test and Set |
| BSR | Branch to Subroutine |
| BTST | Bit Test |
| CHK | Check Register Against Bounds |
| CLR | Clear Operand |
| CMP | Compare |
| DBCC | Test Condition, Decrement and Branch |
| DIVS | Signed Divide |
| DIVU | Unsigned Divide |
| EOR | Exclusive Or |
| EXG | Exchange Registers |
| EXT | Sign Extend |
| JMP | Jump |
| JSR | Jump to Subroutine |
| LEA | Load Effective Address |
| LINK | Link Stack |
| LSL | Logical Shift Left |
| LSR | Logical Shift Right |
|  |  |


| Mnemonic | Description |
| :--- | :--- |
| MOVE | Move |
| MULS | Signed Multiply |
| MULU | Unsigned Multiply |
| NBCD | Negate Decimal with Extend |
| NEG | Negate |
| NOP | No Operation |
| NOT | One's Complement |
| OR | Logical Or |
| PEA | Push Effective Address |
| RESET | Reset External Devices |
| ROL | Rotate Left without Extend |
| ROR | Rotate Right without Extend |
| ROXL | Rotate Left with Extend |
| ROXR | Rotate Right with Extend |
| RTE | Return from Exception |
| RTR | Return and Restore |
| RTS | Return from Subroutine |
| SBCD | Subtract Decimal :vith Extend |
| ScC | Set Conditional |
| STOP | Stop |
| SUB | Subtract |
| SWAP | Swap Data Register Halves |
| TAS | Test and Set Operand |
| TRAP | Trap |
| TRAPV | Trap on Overflow |
| TST | Test |
| UNLK | Unlink |
|  |  |

Table 1-3. Variations of Instruction Types

| Instruction Type | Variation | Description |
| :---: | :---: | :---: |
| ADD | $\begin{aligned} & \text { ADD } \\ & \text { ADDA } \\ & \text { ADDO } \\ & \text { ADDI } \\ & \text { ADDX } \end{aligned}$ | Add <br> Add Address <br> Add Quick <br> Add Immediate <br> Add with Extend |
| AND | AND <br> ANDI <br> ANDI to CCR <br> ANDI to SR | Logical And <br> And Immediate <br> And Immediate to Condition Codes And Immediate to Status Register |
| CMP | CMP <br> CMPA <br> CMPM <br> CMPI | Compare <br> Compare Address <br> Compare Memory <br> Compare Immediate |
| EOR | EOR <br> EORI <br> EORI to CCR <br> EORI to SR | Exclusive Or <br> Exclusive Or Immediate Exclusive Or Immediate to Condition Codes Exclusive Or Immediate to Status Register |


| Instruction Type | Variation | Description |
| :---: | :---: | :---: |
| MOVE | MOVE <br> MOVEA <br> MOVEC <br> MOVEM <br> MOVEP <br> MOVEO <br> MOVES <br> MOVE from SR <br> MORE to SR <br> MOVE from CCR <br> MOVE to CCR <br> MOVE USP | Move <br> Move Address <br> Move Control Register <br> Move Multiple Registers <br> Move Peripheral Data <br> Move Quick <br> Move Alternate Address Space <br> Move from Status Register <br> Move to Status Register <br> Move from Condition Codes <br> Move to Condition Codes <br> Move User Stack Pointer |
| NEG | $\begin{array}{\|l\|} \hline \text { NEG } \\ \text { NEGX } \end{array}$ | Negate <br> Nexgate with Extend |
| OR | OR <br> ORI <br> ORI to CCR <br> ORI to SR | Logical Or <br> Or Immediate <br> Or Immediate to <br> Condition Codes <br> Or Immediate to <br> Status Register |
| SUB | $\begin{aligned} & \text { SUB } \\ & \text { SUBA } \\ & \text { SUBI } \\ & \text { SUBQ } \\ & \text { SUBX } \end{aligned}$ | Subtract <br> Subtract Address <br> Subtract Immediate <br> Subtract Quick <br> Subtract with Extend |

# SECTION 2 DATA ORGANIZATION AND ADDRESSING CAPABILITIES 

This section describes the registers and data organization of the TS68008.

### 2.1 OPERAND SIZE

Operand sizes are defined as follows: a byte equals eight bits, a word equals 16 bits (two bytes), and a long word equals 32 bits (four bytes). The operand size for each instruction is either explicitly encoded in the instruction or implicitly defined by the instruction operation. Implicit instructions support some subset of all three sizes. When fetching instructions, the TS68008 always fetches pairs of bytes (words) thus guaranteeing compatibility with the TS68000.

### 2.2 DATA ORGANIZATION IN REGISTERS

The eight data registers support data operands of $1,8,16$, or 32 bits. The seven address registers together with the stack pointers support address operands of 32 bits.

### 2.2.1 Data Registers

Each data register is 32 bits wide. Byte operands occupy the low order eight bits, word operands the low order 16 bits, and long word operands the entire 32 bits. The least significant bit is addressed as bit zero; the most significant bit is addressed as bit 31 .

When a data register is used as either a source or destination operand, only the appropriate low order portion is changed; the remaining high order portion is neither used nor changed.

### 2.2.2 Address Registers

Each address register and the stack pointer is 32 bits wide and holds a full 32 -bit address. Address registers do not support the byte sized operand. Therefore, when an address register is used as a source operand, either the low order word or the entire long word operand is used depending upon the operation size. When an address register is used as the destination operand, the entire register is affected regardless of the operation size. If the operation size is word, any other operands are sign extended to 32 bits before the operation is performed.

### 2.3 DATA ORGANIZATION IN MEMORY

The data types supported by the TS68008 are: bit data, integer data of 8,16 , or 32 bits, and 32 -bit addresses. Figure 2-1 shows the organization of these data types in memory.


| 1 Word $=2$ Bytes $=16$ Bits |  |
| :--- | :--- |
| Byte 0 (MS Byte) | Word 0 |
| Byte 1 (LS Byte) |  |
| Byte 0 (MS Byte) | Word 1 |
| Byte 1 (LS Byte) |  |



Figure 2-1. Memory Data Organization

### 2.4 ADDRESSING

Instructions for the TS68008 contain two kinds of information: the type of function to be performed, and the location of the operand(s) on which to perform that function. The methods used to locate (address) the operand(s) are explained in the following paragraphs.

Instructions specify an operand location in one of three ways:
Register Specification - the number of the register is given in the register field of the instruction.
Effective Address - use of the different effective address modes.
Implicit Reference - the definition of certain instructions implies the use of specific registers.

### 2.5 INSTRUCTION FORMAT

Instructions are from one to five words (two to ten bytes) in length as shown in Figure 2-2. Instructions always start on a word boundary thus guaranteeing compatibility with the TS68000. The length of the instruction and the operation to be performed is specified by the tirst word of the instruction which is called the operation word. The remaining words further specify the operands. These words are either immediate operands or extensions to the effective adaress mode specified in the operation word.

| Even Byte ( $\mathrm{A} 0=0$ ) |  |  |  |  |  |  |  | Odd Byte ( $\mathrm{A} 0=11$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  | Operation Word (First Word Specifies Operation and Modes) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Immediate Operand (If Any. One or Two Words) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Source Effective Address Extension (If Any, One or Two Words) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Destination Effective Address Extension (If Any, One or Two Words) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 2-2. Instruction Operation Word General Format

### 2.6 PROGRAM/DATA REFERENCES

The TS68008 separates memory references into two classes: program references, and data references. Program references, as the name implies, are references to that section of memory containing the program being executed. Data references refer to that section of memory containing data. Operand reads are from the data space except in the case of the program counter relative addressing mode. All operand writes are to the data space. The function codes are used to indicate the address space being accessed during a bus cycle.

### 2.7 REGISTER SPECIFICATION

The register field within an instruction specifies the register to be used. Other fields within the instruction specify whether the register selected is an address or data register and how the register is to be used.

### 2.8 EFFECTIVE ADDRESS

Most instructions specify the location of an operand by using the effective address field in the operation word. For example, Figure 2-3 shows the general format of the single-effective-address instruction operation word. The effective address is composed of two 3 -bit fields: the mode field, and the register field. The value in the mode field selects the different address modes. The register field contains the number of a register.


Figure 2-3. Single-Effective-Address Instruction Operation Word

The effective address field may require additional information to fully specify the operand. This additional information, called the effective address extension, is contained in the following word or words and is considered part of the instruction, as shown in Figure 2-2. The effective address modes are grouped into three categories: register direct, memory addressing, and speciai.

### 2.8.1 Register Direct Modes

These effective addressing modes specify that the operand is in one of sixteen multifunction registers.
2.8.1.1 DATA REGISTER DIRECT. The operand is in the data register specified by the effective address register field.
2.8.1.2 ADDRESS REGISTER DIRECT. The operand is in the address register specified by the effective address register field.

### 2.8.2 Memory Address Modes

These effective addressing modes specify that the operand is in memory and provide the specific address of the operand.
2.8.2.1 ADDRESS REGISTER INDIRECT. The address of the operand is in the address register specified by the register field. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.
2.8.2.2 ADDRESS REGISTER INDIRECT WITH POSTINCREMENT. The address of the operand is in the address register specified by the register field. After the operand address is used, it is incremented by one, two, or four depending upon whether the size of the operand is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is incremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.
2.8.2.3 ADDRESS REGISTER INDIRECT WITH PREDECREMENT. The address of the operand will be in the address register specified by the register field. Before the address register is used for operand access, it is decremented by one, two, or four depending upon whether the operand size is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is decremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.
2.8.2.4 ADDRESS REGISTER INDIRECT WITH DISPLACEMENT. This address mode requires one word of extension. The address of the operand is the sum of the address in the address register and the sign-extended 16 -bit displacement integer in the extension word. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.
2.8.2.5 ADDRESS REGISTER INDIRECT WITH INDEX. This address mode requires one word of extension. The address of the operand is the sum of the address in the address register, the signextended displacement integer in the low order eight bits of the extension word, and the contents of the index register. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.

### 2.8.3 Special Address Modes

The special address modes use the effective address register field to specify the special addressing mode instead of a register number.
2.8.3.1 ABSOLUTE SHORT ADDRESS. This address mode requires one word of extension. The address of the operand is the extension word. The 16 -bit address is sign extended before it is used. The reference is classified as a data reference with the exception of the jump and jump-tosubroutine instructions.
2.8.3.2 ABSOLUTE LONG ADDRESS. This address mode requires two words of extension. The address of the operand is developed by the concatenation of the extension words. The high order part of the address is the first extension word; the low order part of the address is the second extension word. The reference is classified as a data reference with the exception of the jump and jump-to-subroutine instructions.
2.8.3.3 PROGRAM COUNTER WITH DISPLACEMENT. This address mode requires one word of extension. The address of the operand is the sum of the address in the program counter and the sign-extended 16 -bit displacement integer in the extension word. The value in the program counter is the address of the extension word. The reference is classified as a program reference.
2.8.3.4 PROGRAM COUNTER WITH INDEX. This address mode requires one word of extension. This address is the sum of the address in the program counter, the sign-extended displacement integer in the lower eight bits of the extension word, and the contents of the index register. The value in the program counter is the address of the extension word. This reference is classified as a program reference.
2.8.3.5 IMMEDIATE DATA. This address mode requires either one or two words of extension depending on the size of the operation.

Byte Operation - operand is low order byte of extension word
Word Operation - operand is extension word
Long Word Operation - operand is in the two extension words, high order 16 bits are in the first extension word, low order 16 bits are in the second extension word.
2.8.3.6 IMPLICIT REFERENCE. Some instructions make implicit reference to the program counter (PC), the system stack pointer (SP), the supervisor stack pointer (SSP), the user stack pointer (USP), or the status register (SR). A selected set of instructions may reference the status register by means of the effective address field. These are:

| ANDI to CCR | EORI to SR | MOVE to CCR |
| :--- | :--- | :--- |
| ANDI to SR | ORI to CCR | MOVE to SR |
| EORI to CCR | ORI to SR | MOVE from SR |

### 2.9 EFFECTIVE ADDRESS ENCODING SUMMARY

Table 2-1 is a summary of the effective addressing modes discussed in the previous paragraphs.

Table 2-1. Effective Address Encoding Summary

| Addressing Mode | Mode | Register |
| :--- | :---: | :---: |
| Data Register Direct | 000 | Register Number |
| Address Register Direct | 001 | Register Number |
| Address Register Indirect | 010 | Register Number |
| Address Register Indirect with <br> Postincrement | 011 | Register Number |
| Address Register Indirect with <br> Predecrement | 100 | Register Number |
| Address Register Indirect with <br> Displacement | 101 | Register Number |
| Address Register Indirect with <br> Index | 110 | Register Number |
| Absolute Short | 111 | 000 |
| Absolute Long | 111 | 001 |
| Program Counter with | 111 | 010 |
| Displacement |  |  |

### 2.10 SYSTEM STACK

The system stack is used implicitly by many instructions; user stacks and queues may be created and maintained through the addressing modes. Address register seven (A7) is the system stack pointer (SP). The system stack pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), depending on the state of the $S$ bit in the status register. If the $S$ bit indicates supervisor state, SSP is the active system stack pointer and the USP is not used. If the S bit indicates user state, the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory.

## SECTION 3 INSTRUCTION SET SUMMARY

This section contains an overview of the form and structure of the TS68008 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

Data Movement<br>Integer Arithmetic<br>Logical<br>Shift and Rotate

Bit Manipulation<br>Binary Coded Decimal<br>Program Control<br>System Control

The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development.

### 3.1 DATA MOVEMENT OPERATIONS

The basic method of data acquisition (transfer and storage) is provided by the move (MOVE) instruction. The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to register. Address move instructions allow word and long word operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (LEA), push effective address (PEA), link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 3-1 is a summary of the data movement operations.

Table 3-1. Data Movement Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| EXG | 32 | $R \mathrm{x} \rightarrow \mathrm{Ry}^{\text {l }}$ |
| LEA | 32 | $E A \rightarrow A n$ |
| LINK | - | $\begin{gathered} \mathrm{AN} \rightarrow-(\mathrm{SP}) \\ \mathrm{SP} \rightarrow \mathrm{An} \\ \mathrm{SP}+\mathrm{displacement} \rightarrow \mathrm{SP} \end{gathered}$ |
| MOVE | 8, 26, 32 | $(E A) s \rightarrow(E A) d$ |
| MOVEM | 16, 32 | $(E A) \rightarrow A n, D n$ <br> $A n, D n \rightarrow(E A)$ |
| MOVEP | 16, 32 | $\begin{aligned} & (E A) \rightarrow D n \\ & D_{n} \rightarrow(E A) \end{aligned}$ |
| MOVEQ | 8 | $\# x x x \rightarrow D n$ |
| PEA | 32 | $E A \rightarrow-(S P)$ |
| SWAP | 32 | Dn(31:16] $\rightarrow$ Dn[15:0] |
| UNLK | - | $\begin{gathered} A n \rightarrow S P \\ (S P)+\rightarrow A n \end{gathered}$ |

NOTES:
s= source
$d=$ destination
[ ] = bit number
$-=$ indirect with predecrement
$+=$ indirect with postdecrement
\# = immediate data

### 3.2 INTEGER ARITHMETIC OPERATIONS

The arithmetic operations include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, with data operations accepting all operand sizes. Address operations are limited to legal address size operands (16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long word product, and a long word dividend with word divisor to produce a word quotient with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 3-2 is a summary of the integer arithmetic operations.

Table 3-2. Integer Arithmetic Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| ADD | $8,16,32$ $16,32$ | $\begin{gathered} D n+(E A) \rightarrow D n \\ (E A)+D n \rightarrow(E A) \\ (E A)+\# x x x \rightarrow(E A) \\ A n+(E A) \rightarrow A n \end{gathered}$ |
| ADDX | $\begin{gathered} 8,16,32 \\ 16,32 \end{gathered}$ | $\left\lvert\, \begin{gathered} D x+D y+x \rightarrow D x \\ -(A x)+-(A y)+X \rightarrow(A x) \end{gathered}\right.$ |
| CLR | 8, 16, 32 | $0 \rightarrow$ (EA) |
| CMP | $8,16,32$ $16,32$ | $\begin{gathered} D n-(E A) \\ (E A)-\# x x x x \\ (A x)+-(A y)+ \\ A n-(E A) \end{gathered}$ |
| DIVS | $32 \div 16$ | $D n \div(E A) \rightarrow$ nn |
| DIVU | $32 \div 16$ | $D n \div(E A) \rightarrow$ nn |


| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| EXT | $\begin{gathered} 8 \rightarrow 16 \\ 16 \rightarrow 32 \end{gathered}$ | $(\mathrm{Dn})_{8} \rightarrow \mathrm{Dn}_{16}$ $\left(\mathrm{Dn}_{16} \rightarrow \mathrm{Dn}_{32}\right.$ |
| MULS | $16 \times 16 \rightarrow 32$ | $D n \times(E A) \rightarrow$ nn |
| MULU | $16 \times 16 \rightarrow 32$ | Dn $\times(E A) \rightarrow$ Dn |
| NEG | 8, 16, 32 | $0-(E A) \rightarrow(E A)$ |
| NEGX | 8, 16, 32 | $0-(E A)-X \rightarrow$ (EA) |
| SUB | 8, 16, 32 | $\begin{gathered} D n-(E A) \rightarrow D n \\ (E A)-D n \rightarrow(E A) \\ (E A)-\# x \times x \rightarrow(E A) \\ A n-(E A) \rightarrow A n \end{gathered}$ |
| SUBX | 8, 16, 32 | $\begin{gathered} D x-D y-x \rightarrow D x \\ -(A x)--(A y)-x \rightarrow(A x) \end{gathered}$ |
| TAS | 8 | (EA) $-0,1 \rightarrow$ EA [7] |
| TST | 8, 16, 32 | (EA) - 0 |

[^38]
### 3.3 LOGICAL OPERATIONS

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 3-3 is a summary of the logical operations.

Table 3-3. Logical Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| AND | 8, 16, 32 | Dn $\Lambda(E A) \rightarrow$ Dn (EA) $\Lambda D n \rightarrow(E A)$ (EA) $\Lambda * \times x x \rightarrow$ (EA) |
| OR | 8, 16, 32 | $D n \vee(E A) \rightarrow D n$ $(E A) \vee D_{n} \rightarrow(E A)$ $(E A) \vee \# x \times x \rightarrow(E A)$ |
| EOR | 8, 16, 32 | $\begin{aligned} & (E A) \oplus D y \rightarrow(E A) \\ & (E A) \oplus \# x x x \rightarrow(E A) . \end{aligned}$ |
| NOT | 8, 16, 32 | $\sim(E A) \rightarrow E A$ |

NOTES:

$$
\begin{array}{ll}
\#=\text { immediate data } & V=\text { logical OR } \\
\sim=\text { invert } & \oplus=\text { logical exclusive OR } \\
\Lambda=\text { logical AND } &
\end{array}
$$

### 3.4 SHIFT AND ROTATE OPERATIONS

Shift operations in both directions are provided by the arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand sizes and allow a shift count specified in a data register.

Memory shifts and rotates are for word operands and provide single-bit shifts or rotates.
Table 3-4 is a summary of the shift and rotate operations.
Table 3-4. Shift and Rotate Operations

| Instruction |  | Operation |
| :---: | :---: | :---: |
| ASL | 8, 16, 32 | $x / C \leftarrow \leftarrow$ |
| ASR | 8, 16, 32 | $\longrightarrow \longrightarrow x / C$ |
| LSL | 8, 16, 32 | $\mathrm{X} / \mathrm{C} \leftarrow \leftarrow \leftarrow 0$ |
| LSR | 8, 16, 32 | $0 \rightarrow \longrightarrow x / c$ |
| ROL | 8, 16, 32 | $\mathrm{C}, \sqrt{4}$ |
| ROR | 8, 16, 32 |  |
| ROXL | 8, 16, 32 | $\mathrm{C}$ |
| ROXR | 8, 16, 32 | $\square x \rightarrow C$ |

### 3.5 BIT MANIPULATION OPERATIONS

Bit manipulation operations are accomplished using the following instructions: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 3-5 is a summary of the bit manipulation operations. ( $Z$ is bit 2 of the status register.)

Table 3-5. Bit Manipulation Operations
$\begin{array}{l}\begin{array}{|c|c|c|}\hline \text { Instruction } & \text { Operand Size } & \text { Operation } \\ \hline \text { BTST } & 8,32 & \sim \text { bit of }(E A) \rightarrow Z\end{array} \\ \hline \text { BSET }\end{array}$ 8,32 $\left.\quad \begin{array}{c}\sim \text { bit of }(E A) \rightarrow Z \\ 1 \rightarrow \text { bit of EA }\end{array}\right]$

### 3.6 BINARY CODED DECIMAL OPERATIONS

Multiprecision arithmetic operations on binary coded decimal numbers are accomplished using the following instructions: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 3-6 is a summary of the binary coded decimal operations.

Table 3-6. Binary Coded Decimal Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| $A B C D$ | 8 | $D x_{10}+D y_{10}+X \rightarrow D x$ <br> $-(A x)_{10}+-(A y)_{10}+X \rightarrow(A x)$ |
| $S B C D$ | 8 | $D x_{10}-D y_{10}-X \rightarrow D x$ <br> $-(A x)_{10}--(A y)_{10}-X \rightarrow(A x)$ |
| NBCD | 8 | $0-(E A)_{10}-X \rightarrow(E A)$ |

### 3.7 PROGRAM CONTROL OPERATIONS

Program control operations are accomplished using a series of conditional and unconditional branch instructions, jump instructions, and return instructions. These instructions are summarized in Table 3-7.

The conditional instructions provide setting and branching for the following conditions:

| CC - carry clear | GE - greater or equal | LS - low or same | PL - plus |
| :--- | :--- | :--- | :--- |
| CS - carry set | $G T$ - greater than | LT - less than | $T$ - always true |
| EQ - equal | HI - high | MI - minus | VC - no overflow |
| F - never true | LE - less or equal | NE - not equal | VS - overflow |

Table 3-7. Program Control Operations

| Instruction | Operation |
| :---: | :---: |
| Conditional |  |
| BCC | Branch Conditionally (14 conditions) |
|  | 8- and 16-Bit Displacement |
| DBCC | Test Condition, Decrement, and Branch |
|  | 16-Bit Displacement |
| SCC | Set Byte Conditionally (16 Conditions) |
| Unconditional | Branch Always |
| BRA | 8- and 16-Bit Displacement |
|  | Branch to Subroutine |
| BSR | 8- and 16-Bit Displacement |
|  | Jump |
| JMP | Jump to Subroutine |
| JSR |  |
| Returns | Return and Restore Condition Codes |
| RTR | Return from Subroutine |
| RTS |  |

### 3.8 SYSTEM CONTROL OPERATIONS

System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 3-8.

Table 3-8. System Control Operations

| Instruction |  |
| :--- | :--- |
| Privileged | Operation |
| ANDI to SR | Logical AND to Status Register |
| EORI to SR | Logical EOR to Status Register |
| MOVE EA to SR | Load New Status Register |
| MOVE USP | Move User Stack Pointer |
| ORI to SR | Logical OR to Status Register |
| RESET | Reset External Devices |
| RTE | Return from Exception |
| STOP | Stop Program Execution |
| Trap Generating |  |
| CHK |  |
| TRAP | Check Data Register Against Upper Bounds |
| TRAPV | Trap on Overflow |
| Status Register |  |
| ANDI to CCR | Logical AND to Condition Codes |
| EORI to CCR | Logical EOR to Condition Codes |
| MOVE EA to CCR | Load New Condition Codes |
| MOVE SR to EA | Store Status Register |
| ORI to CCR | Logical OR to Condition Codes |

## SECTION 4 <br> SIGNAL AND BUS OPERATION DESCRIPTION

This section contains a brief description of the input and output signals. A discussion of bus operation during the various machine cycles and operations is also given.

### 4.1 SIGNAL DESCRIPTION

The TS68008 is available in two package sizes (48-pin and 52 -pin). The additional four pins of the 52 -pin quad package allow for additional signals: A20, A21, $\overline{\mathrm{BGACK}}$, and $\overline{\mathrm{PL} 2}$.

Throughout this document, references to the address bus pins (AO-A19) and the interrupt priority level pins $(\overline{\mathrm{PLO}} / \overline{\mathrm{PL} 2}, \overline{\mathrm{PL}})$ refer to $\mathrm{A} 0-\mathrm{A} 21$ and $\overline{\mathrm{PLO}}, \overline{\mathrm{PLL}}$, and $\overline{\mathrm{PL} 2}$ for the 52 -pin version of the TS68008.

The input and output signals can be functionally organized into the groups shown in Figure 4-1(a) for the 48-pin version and in Figure 4-1 (b) for the 52-pin version. The following paragraphs provide a brief description of the signals and a reference (if applicable) to other paragraphs that contain more information about the function being performed.
(a) 48-Pin Version


Figure 4-1. Input and Output Signals


Figure 4-1. Input and Output Signals (Continued)

### 4.1.1 Address Bus (48-Pin: A0 through A19 <br> 52-Pin: A0 through A21)

This unidirectional three-state bus provides the address for bus operation during all cycles except interrupt acknowledge cycles. During interrupt acknowledge cycles, address lines A1, A2, and A3 provide information about what level interrupt is being serviced while address lines A0 and A4 through A19 (A21) are all driven high.

### 4.1.2 Data Bus (D0 through D7)

This 8 -bit, bidirectional, three-state bus is the general purpose data path. During an interrupt acknowledge cycle, the external device supplies the vector number on data lines D0-D7.

### 4.1.3 Asynchronous Bus Control

Asynchronous data transfers are handled using the following control signals: address strobe, read/write, data strobe, and data transfer acknowledge. These signals are explained in the following paragraphs.
4.1.3.1 ADDRESS STROBE ( $\overline{\mathrm{AS}})$. This three-state signal indicates that there is a valid address on the address bus. It is also used to "lock" the bus during the read-modify-write cycle used by the test and set (TAS) instruction.
4.1.3.2 READ/WRITE (R/W). This three-state signal defines the data bus transfer as a read or write cycle. The R/ $\bar{W}$ signal also works in conjunction with the data strobe as explained in the following paragraph.
4.1.3.3 DATA STROBE ( $\overline{\mathrm{SS}}$ ). This three-state signal controls the flow of data on the data bus as shown in Table 4-1. When the $R / \bar{W}$ line is high, the processor will read from the data bus as indicated. When the R/W line is low, the processor will write to the data bus as shown.

Table 4-1. Data Strobe Control of Data Bus

| $\overline{\text { DS }}$ | R/信 | D0-D7 |
| :---: | :---: | :---: |
| 1 | - | No Valid Data |
| 0 | 1 | Valid Data Bits 0.7 (Read Cycle) |
| 0 | 0 | Valid Data Bits 0.7 (Write Cycle) |

4.1.3.4 DATA TRANSFER ACKNOWLEDGE ( $\overline{\text { DTACK }}$ ). This input indicates that the data transfer is completed. When the processor recognizes $\overline{\text { DTACK }}$ during a read cycle, data is latched and the bus cycle is terminated. When DTACK is recognized during a write cycle, the bus cycle is terminated. (Refer to 4.4 ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION.)

### 4.1.4 Bus Arbitration Control

The 48-pin TS68008 contains a simple two-wire arbitration circuit and the 52 -pin TS68008 contains the full three-wire TS68000 bus arbitration control. Both versions are designed to work with daisychained networks, priority encoded networks, or a combination of these techniques. This circuit is used in determining which device will be the bus master device.
4.1.4.1 BUS REQUEST $(\overline{B R})$. This input is wire ORed with all other devices that could be bus masters. This device indicates to the processor that some other device desires to become the bus master. Bus requests may be issued at any time in a cycle or even if no eycle is being performed.
4.1.4.2 BUS GRANT ( $\overline{\mathrm{BG}}$ ). This output indicates to all other potential bus master devices that the processor will release bus control at the end of the current bus cycle.
4.1.4.3 BUS GRANT ACKNOWLEDGE ( $\overline{B G A C K}$ ). This input, available on the 52 -pin version only, indicates that some other device has become the bus master. This signal should not be asserted until the following four conditions are met:

1. a bus grant has been received,
2. address strobe is inactive which indicates that the microprocessor is not using the bus,
3. data transfer acknowledge is inactive which indicates that neither memory nor peripherals are using the bus, and
4. bus grant acknowledge is inactive which indicates that no other device is still claiming bus mastership.

## NOTES

1) There is a two-clock interval straddling the transition of $\overline{A S}$ from the inactive state to the active state during which $\overline{\mathrm{BG}}$ cannot be issued.
2) If an existing $T S 68000$ system is retrofitted to use the TS68008, 48-pin version (using $\overline{B R}$ and $\overline{B G}$ only), the existing $\overline{B R}$ and $\overline{B G A C K}$ signals should be ANDed and the resultant signal connected to the TS68008's $\overline{\mathrm{BR}}$.

### 4.1.5 Interrupt Control (48-Pin: $\overline{\mathrm{PLO}} / \overline{\mathrm{PL}}, \overline{\mathrm{IPL}}$ <br> 52-Pin: $\overline{\mathrm{PL}}, \overline{\mathrm{PL}}, \overline{\mathrm{P}} \mathbf{1}$ )

These input pins indicate the encoded priority level of the device requesting an interrupt. The TS68000 and the 52 -pin TS68008 MPUs use three pins to encode a range of $0-7$ but, for the 48 -pin TS68008 only two pins are available. By connecting the $\overline{\mathrm{PLO}} / \overline{\mathrm{PL} 2}$ pin to both the $\overline{\mathrm{PLO}}$ and $\overline{\mathrm{PL} 2}$ inputs internally, the 48 -pin encodes values of $0,2,5$, and 7 . Level zero is used to indicate that there are no interrupts pending and level seven is a non-maskable edge-triggered interrupt. Except for level seven, the requesting level must be greater than the interrupt mask level contained in the processor status register before the processor will acknowledge the request.

The level presented to these inputs is continually monitored to allow for the case of a requesting level that is less than or equal to the processor status register level to be followed by a request that is greater than the processor status register level. A satisfactory interrupt condition must exist for two successive clocks before triggering an internal interrupt request. An interrupt acknowledge sequence is indicated by the function codes.

### 4.1.6 System Control

The system control inputs are used to either reset or halt the processor and to indicate to the processor that bus errors have occurred. The three system control signals are explained in the following paragraphs.
4.1.6.1 BUS ERROR ( $\overline{B E R R}$ ). This input informs the processor that there is a problem with the cycle currently being executed. Problems may be a result of:

1. nonresponding devices,
2. interrupt vector number acquisition failure,
3. illegal access request as determined by a memory management unit, or
4. various other application dependent errors.

The bus error signal interacts with the halt signal to determine if the current bus cycle should be reexecuted or if exception processing should be performed. Refer to 4.2.3 Bus Error and Halt Operation for a detailed description of the interaction which is summarized below.

| $\overline{\text { BERR }}$ | $\overline{\text { HALT }}$ | Resulting Operation |
| :--- | :--- | :--- |
| High | High | Normal operation |
| High | Low | Single bus cycle operation |
| Low | High | Bus error - exception processing |
| Low | Low | Bus error - re-run current cycle |

4.1.6.2 RESET ( $\overline{\operatorname{RESET}}$ ). This bidirectional signal line acts to reset (start a system initialization sequence) the processor in response to an external $\overline{\operatorname{RESET}}$ signal. An internally generated reset (result of a reset instruction) causes all external devices to be reset and the internal state of the processor is not affected. A total system reset (processor and external devices) is the result of external HALT and $\overline{\mathrm{RESET}}$ signals applied at the same time. Refer to 4.2.4 Reset Operation for further information.
4.1.6.3 HALT ( $\overline{\text { HALT }}$ ). When this bidirectional line is driven by an external device, it will cause the processor to stop at the completion of the current bus cycle. When the processor has been halted
using this input, all control signals are inactive and all three-state lines are put in their highimpedance state. Refer to 4.2.3 Bus Error and Halt Operation for additional information about the interaction between the halt and bus error signals.

When the processor has stopped executing instructions, such as in a double bus fault condition, the halt line is driven by the processor to indicate to external devices that the processor has stopped.

### 4.1.7 $\mathbf{6 8 0 0}$ Peripheral Control

These control signals are used to allow the interfacing of synchronous 6800 peripheral devices with the asynchronous TS68008. These signals are explained in the following paragraphs.

The TS68008 does not supply a valid memory address ( $\overline{\mathrm{VMA}}$ ) signal like that of the TS68000. The $\overline{\mathrm{VMA}}$ signal indicates to the 6800 peripheral devices that there is a valid address on the address bus and that the processor is synchronized to the enable clock. This signal can be produced by a TTL circuit (see a sample circuit in Figure 4-2). The VMA signal, in this circuit, only responds to a valid peripheral address (VPA) input which indicates that the peripheral is an 6800 Family device. Timing for this circuit is shown in Figure 6-2.


Figure 4-2. External $\overline{\mathrm{VMA}}$ Generation
The VPA decode shown in Figure 4-2 is an active high decode indicating that address strobe ( $\overline{\mathrm{AS}}$ ) has been asserted and the address bus is addressing an 6800 peripheral. The VPA output of the circuit is used to indicate to the TS68008 that the data transfer should be synchronized with the enable ( $E$ ) signal.
4.1.7.1 ENABLE (E). This signal is the standard enable signal common to all 6800 type peripheral devices. The period for this output is 10 TS68008 clock periods (six clocks low, four clocks high).
4.1.7.2 VALID PERIPHERAL ADDRESS ( $\overline{\mathrm{VPA}}$ ). This input indicates that the device or region addressed is a 6800 Family device and that data transfer should be synchronized with the enable (E) signal. This input also indicates that the processor should use automatic vectoring for an interrupt. Refer to 6.0 INTERFACE WITH 6800 PERIPHERALS.

### 4.1.8 Processor Status (FC0, FC1, FC2)

These function code outputs indicate the state (user or supervisor) and the cycle type currently being executed, as shown in Table 4-2. The information indicated by the function code outputs is valid whenever address strobe ( $\overline{\mathrm{AS}}$ ) is active.

Table 4-2. Function Code Outputs

| Function Code Output |  | Cycle Type |  |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 |  |  |
| Low | Low | Low | (Undefined, Reserved) |
| Low | Low | High | User Data |
| Low | High | Low | User Program |
| Low | High | High | (Undefined, Reserved) |
| High | Low | Low | (Undefined, Reserved) |
| High | Low | High | Supervisor Data |
| High | High | Low | Supervisor Program |
| High | High | High | Interrupt Acknowledge |

### 4.1.9 Clock (CLK)

The clock input is a TTL-compatible signal that is internally buffered for development of the internal clocks needed by the processor. The clock input shall be a constant frequency.

### 4.1.10 VCC and GND

Power is supplied to the processor using these two signals. $V_{C C}$ is power and GND is the ground connection.

### 4.1.11 Signal Summary

Table 4-3 is a summary of all the signals discussed in the previous paragraphs.

Table 4-3. Signal Summary

| Signal Name | Mnemnoic | Input/Output | Active State | Hi-Z |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | on $\overline{\text { HALT }}$ | on $\overline{\text { BGACK }}$ |
| Address Bus | A0.A19 | Output | High | Yes | Yes |
| Data Bus | D0-D7 | Input/ Output | High | Yes | Yes |
| Address Strobe | $\overline{\mathrm{AS}}$ | Output | Low | No | Yes |
| Read/Write | R/ $\bar{W}$ | Output | Read.High Write-Low | $\begin{aligned} & \text { No } \\ & \text { No } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { Yes } \\ & \text { Yes } \end{aligned}$ |
| Data Strobes | $\overline{\mathrm{DS}}$ | Output | Low | No | Yes |
| Data Transfer Acknowledge | DTACK | Input | Low | No | No |
| Bus Request | $\overline{B R}$ | Input | Low | No | No |
| Bus Grant | $\stackrel{\rightharpoonup}{B G}$ | Output | Low | No | No |
| Bus Grant Acknowledge* * | BGACK | Input | Low | No | No |
| Interrupt Priority Level | $\overline{\text { IPL }} \times$ | Input | Low | No | No |
| Bus Error | BERR | Input | Low | No | No |
| Reset | $\overline{\text { RESET }}$ | Input/Output | Low | No* | No* |
| Halt | $\overline{\mathrm{HALT}}$ | Input/Output | Low | No* | No* |
| Enable | E | Output | High | No | No |
| Valid Peripheral Address | $\overline{\mathrm{VPA}}$ | Input | Low | No | No |
| Function Code Output | FC0, FC1, FC2 | Output | High | No | Yes |
| Clock | CLK | Input | High | No | No |
| Power Input | $\mathrm{V}_{\mathrm{CC}}$ | Input | - | - | - |
| Ground | GND | Input | - | - | - |

[^39]* *52-Pin Version Only


### 4.2 BUS OPERATION

The following paragraphs explain control signal and bus operation during data transfer operations, bus arbitration, bus error and halt conditions, and reset operation.

### 4.2.1 Data Transfer Operations

Transfer of data between devices involves the following leads:

- Address bus A0 through A19
- Data bus D0 through D7
- Control signals

The address and data buses are separate non-multiplexed parallel buses. Data transfer is accomplished with an asynchronous bus structure that uses handshakes to ensure the correct movement of data. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. In addition, the bus master is responsible for deskewing the acknowledge and data signals from the slave device.

The following paragraphs explain the read, write, and read-modify-write cycles. The indivisible read-modify-write cycle is the method used by the TS68008 for interlocked multiprocessor communications.

## NOTE

The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The term assert or assertion is used to indicate that a signal is active or true independent of whether that voltage is low or high. The term negate or negation is used to indicate that a signal is inactive or false.
4.2.1.1 READ CYCLE. During a read cycle, the processor receives data from the memory or a peripheral device. The processor reads bytes of data in all cases. If the instruction specifies a word (or double word) operation, the processor reads both bytes. When the instruction specifies byte operation, the processor uses A0 to determine which byte to read and then issues data strobe.

A word read cycle flowchart is given in Figure 4-3. A byte read cycle flowchart is given in Figure 4-4. Read cycle timing is given in Figure 4-5. Figure 4-6 details words and byte read cycle operations.
4.2.1.2 WRITE CYCLE. During a write cycle, the processor sends data to either the memory or a peripheral device. The processor writes bytes of data in all cases. If the instruction specifies a word operation, the processor writes both bytes. When the instruction specifies a byte operation, the processor uses A0 to determine which byte to write and then issues the data strobe. A word write cycle flowchart is given in Figure 4-7. A byte write cycle flowchart is given in Figure 4-8. Write cycle timing is given in Figure 4-5. Figure 4-9 details word and byte write cycle operation.
4.2.1.3 READ-MODIFY-WRITE CYCLE. The read-modify-write cycle performs a byte read, modifies the data in the arithmetic-logic unit, and writes the data back to the same address. In the TS68008, this cycle is indivisible in that the address strobe is asserted throughout the entire cycle. The test and set (TAS) instruction uses this cycle to provide meaningful communication between processors in a multiple processor environment. This instruction is the only instruction that uses the read-modify-write cycle and since the test and set instruction only operates on bytes, all read-modify-write cycles are byte operations. A read-modify-write cycle flowchart is given in Figure 4-10 and a timing diagram is given in Figure 4-11.


Figure 4-3. Word Read Cycle Flowchart


Figure 4-4. Byte Read Cycle Flowchart


Figure 4-5. Read and Write Cycle Timing Diagram


Figure 4-6. Word and Byte Read Cycle Timing

### 4.2.2 Bus Arbitration

Bus arbitration on the 52 -pin version of the TS68008 is identical to that on the TS68000.
Bus arbitration on the 48 -pin version of the TS68008 has been modified from that on the TS68000. It is controlled by the same finite state machine as on the TS68000, but because the BGACK input signal is not bonded out to a pin and is, instead, permanently negated internally, the bus arbitration becomes a two-wire handshake circuit. Therefore, in reading the following paragraphs for a description of bus arbitration on the 48 -pin version of the TS68008, the BGACK signal should be considered permanently negated.

Bus arbitration is a technique used by master-type devices to request, be granted, and acknowledge bus mastership. In its simplest form, it consists of the following:

1. asserting a bus mastership request,
2. receiving a grant that the bus is available at the end of the current cycle, and
3. on the 52 -pin version of the TS68008 only, acknowledging that mastership has been assumed.


Figure 4-7. Word Write Cycle Flowchart


Figure 4-8. Byte Write Cycle Flowchart


Figure 4-9. Word and Byte Write Cycle Timing


Figure 4-10. Read-Modify-Write Cycle Flowchart


Figure 4-11. Read-Modify-Write Cycle Timing

Flowcharts showing the detail involved in a request from a single device are illustrated in Figure 4-12 for the 48 -pin version and Figure $4-13$ for the 52 -pin version. Timing diagrams for the same operation are given in Figure 4-14 and Figure 4-15. This technique allows processing of bus requests during data transfer cycles.

The timing diagram shows that the bus request is negated at the time that an acknowledge is asserted. This type of operation would be true for a system consisting of the processor and one device capable of bus mastership. In systems having a number of devices capable of bus mastership, the bus request line from each device is wire ORed to the processor. In this system, it is easy to see that there could be more than one bus request being made. The timing diagram shows that the bus grant signal is negated a few clock cycles after the transition of the acknowledge ( $\overline{\mathrm{BGACK}}$ ) signal.

However, if the bus requests are still pending, the processor will assert another bus grant within a few clock cycles after it was negated. This additional assertion of bus grant allows external arbitration circuitry to select the next bus master before the current bus master has completed its requirements. The following paragraphs provide additional information about the three steps in the arbitration process.
4.2.2.1 REQUESTING THE BUS. External devices capable of becoming bus masters request the bus by asserting the bus request ( $\overline{\mathrm{BR}}$ ) signal. This is a wire-ORed signal (although it need not be constructed from open-collector devices) that indicates to the processor that some external device requires control of the external bus. The processor is effectively at a lower bus priority level than the external device and will relinquish the bus after it has completed the last bus cycle it has started.

On the 52 -pin version, when no acknowledge is received before the bus request signal goes inactive, the processor will continue processing when it detects that the bus request is inactive. This allows ordinary processing to continue if the arbitration circuitry responded to noise inadvertently.


Figure 4-12. Bus Arbitration Cycle Flowchart for the 48-Pin Version

1) Assert Bus Request $(\overline{\mathrm{BR}})$


Figure 4-13. Bus Arbitration Cycle Flowchart for the 52 -Pin Version


Figure 4-14. Bus Arbitration Timing for the 48-Pin Version


Figure 4-15. Bus Arbitration Timing for the 52-Pin Version
4.2.2.2 RECEIVING THE BUS GRANT. The processor asserts bus grant ( $\overline{B G}$ ) as soon as possible Normally this is immediately after internal synchronization. The only exception to this occurs when the processor has made an internal decision to execute the next bus cycle but has not progressed far enough into the cycle to have asserted the address strobe ( $\overline{\mathrm{AS}}$ ) signal. In this case, bus grant will be delayed until $\overline{\mathrm{AS}}$ is asserted to indicate to external devices that a bus cycle is being executed.

The bus grant signal may be routed through a daisy-chained network or through a specific priorityencoded network. The processor is not affected by the external method of arbitration as long as the protocol is obeyed

### 4.2.2.3 ACKNOWLEDGEMENT OF MASTERSHIP (52-PIN VERSION OF TS68008 ONLY). Upon

 receiving a bus grant, the requesting device waits until address strobe, data transfer acknowledge, and bus grant acknowledge are negated before issuing its own $\overline{B G A C K}$. The negation of the address strobe indicates that the previous master has completed its cycle; the negation of bus grant acknowledge indicates that the previous master has released the bus. (While address strobe is asserted, no device is allowed to "break into" a cycle.) The negation of data transfer acknowledge indicates the previous slave has terminated its connection to the previous master. Note that in some applications data transfer acknowledge might not enter into this function. General purpose devices would then be connected such that they were only dependent on address strobe. When bus grant acknowledge is issued, the device is a bus master until it negates bus grant acknowledge. Bus grant acknowledge should not be negated until after the bus cycle(s) is (are) completed. Bus mastership is terminated at the negation of bus grant acknowledge.The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still pending, another bus grant will be asserted within a few clocks of the negation of the bus grant. Refer to 4.2.3 Bus Arbitration Control Unit. Note that the processor does not perform any external bus cycles before it re-asserts bus grant.

### 4.2.3 Bus Arbitration Control

The bus arbitration control unit in the TS68008 is implemented with a finite state machine. A state diagram of this machine is shown in Figure 4-16 for both pin versions of the TS68008. All asynchronous signals to the TS68008 are synchronized before being used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time (\#47) has been met (see Figure 4-17). The input signal is sampled on the falling edge of the clock and is valid internally after the next falling edge.

As shown in Figure 4-16, input signals labeled $R$ and $A$ are internally synchronized on the bus request and bus grant acknowledge pins respectively. The bus grant output is labeled $G$ and the internal three-state control signal T . If T is true, the address, data, and control buses are placed in a high-impedance state when $\overline{\mathrm{AS}}$ is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level. State changes (valid outputs) occur on the next rising edge after the internal signal is valid.
(a) State Diagram for the 48 -Pin Version of TS68008

(b) State Diagram for the 52 -Pin Version of TS68008

$R=$ Bus Request Internal
$A=$ Bus Grant Acknowledge Internal $G=$ Bus Grant
$T=$ Three-State Control to Bus Control Logic ${ }^{2}$
$X=$ Don't Care

1. State machine will not change if the bus is S0 or S1. Refer to 4.2.3 Bus Arbitration Contol.
2. The address bus will be placed in the highimpedance state if $T$ is asserted and $\overline{A S}$ is negated.
Figure 4-16. TS68008 Bus Arbitration Unit State Diagram


Figure 4-17. Timing Relationship of External Asynchronous Inputs to Internal Signals

A timing diagram of the bus arbitration sequence during a processor bus cycle is shown in Figure $4-18$. The bus arbitration sequence while the bus is inactive (i.e., executing internal operations such as a multiply instruction) is shown in Figure 4-19.


Figure 4-18. Bus Arbitration Timing Diagram—Processor Active


Figure 4-19. Bus Arbitration Timing Diagram-Bus Inactive

If a bus request is made at a time when the MPU has already begun as bus cycle but $\overline{\mathrm{AS}}$ has not been asserted (bus state $S 0$ ), $\overline{\mathrm{BG}}$ will not be asserted on the next rising edge. Instead, $\overline{\mathrm{BG}}$ will be delayed until the second rising edge following its internal assertion. This sequence is shown in Figure 4-20.

### 4.2.4 Bus Error and Halt Operation

In a bus architecture that requires a handshake from an external device, the possibility exists that the handshake might not occur. Since different systems will require a different maximum response time, a bus error input is provided. External circuitry must be used to determine the duration between address strobe and data transfer acknowledge before issuing a bus error signal. When a bus error signal is received, the processor has two options: initiate a bus error exception sequence or try running the bus cycle again.


Figure 4-20. Bus Arbitration Timing Diagram-Special Case
4.2.4.1 EXCEPTION SEQUENCE. When the bus error signal is asserted, the current bus cycle is terminated. $\overline{\mathrm{AS}}$ will be negated 2.5 clock periods after $\overline{\mathrm{BERR}}$ is recognized. See 4.4 ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION for more information. As long as $\overline{B E R R}$ remains asserted, the data and address buses will be in the high-impedance state. When $\overline{B E R R}$ is negated, the processor will begin stacking for exception processing. The sequence is composed of the following elements:

1. Stacking the program counter and status register.
2. Stacking the error information.
3. Reading the bus error vector table entry.
4. Executing the bus error handler routine.

The stacking of the program counter and the status register is the same as if an interrupt had occurred. Several additional items are stacked when a bus error occurs. These items are used to determine the nature of the error and correct it, if possible. The processor loads the new program counter from the bus error vector. A software bus error handler routine is then executed by the processor. Refer to 5.2 EXCEPTION PROCESSING for additional information.
4.2.4.2 RE-RUNNING THE BUS CYCLE. When the processor receives a bus error signal during a bus cycle and the $\overline{H A L T}$ pin is being driven by an external device, the processor enters the re-run sequence. Figure $4-21$ is a timing diagram for re-running the bus cycle.

The processor terminates the bus cycle, then puts the address and data output lines in the highimpedance state. The processor remains "halted," and will not run another bus cycle until the halt signal is removed by external logic. Then the processor will re-run the previous cycle using the same function codes, the same data (for a write operation), and the same controls. The bus error signal should be removed at least one clock cycle before the halt signal is removed.

## NOTE

The processor will not re-run a read-modify-write cycle. This restriction is made to guarantee that the entire cycle runs correctly and that the write operation of a test-and-set operation is performed without ever releasing $\overline{\mathrm{AS}}$. If $\overline{\mathrm{BERR}}$ and $\overline{\mathrm{HALT}}$ are asserted during a read-modify-write bus cycle, a bus error operation results.
4.2.4.3 HALT OPERATION WITH NO BUS ERROR. The halt input signal to the TS68008 performs a halt/run/single-step function in a similar fashion to the 6800 halt function. The halt and run modes are somewhat self explanatory in that when the halt signal is constantly active the processor "halts" (does nothing) and when the halt signal is constantly inactive the processor "runs" (does something). HALT operation timing is shown in Figure 4-22.


Figure 4-21. Re-Run Bus Cycle Timing Information


Figure 4-22. $\overline{\text { HALT }}$ Operation Timing Diagram

The single-step mode is derived from correctly timed transitions on the halt signal input. It forces the processor to execute a single bus cycle by entering the "run" mode until the processor starts a bus cycle then changing to the "halt" mode. Thus, the single-step mode allows the user to proceed through (and therefore debug) processsor operations one bus cycle at a time.

Figure 4-23 details the timing required for correct single-step operations. Some care must be exercised to avoid harmful interactions between the bus error signal and the HALT pin when using the single-cycle mode as a debugging tool. This is also true of interactions between the halt and reset lines since these can reset the machine (see 4.2.4 Reset Operation).

When the processor completes a bus cycle after recognizing that the halt signal is active, the address and data bus signals are put in the high-impedance state.

While the processor is honoring the halt request, bus arbitration performs as usual. That is, halting has no effect on bus arbitration. It is the bus arbitration function that removes (i.e., three-states) the control signals from the bus.

The halt function and the hardware trace capability allow the hardware debugger to trace single bus cycles or single instructions at a time. These processor capabilities, along with a software debugging package, give total debugging flexibility.


Figure 4-23. $\overline{\text { HALT }}$ Signal Single-Step Operation Timing Characteristics
4.2.4.4 DOUBLE BUS FAULTS. When a bus error exception occurs, the processor will attempt to stack several words containing information about the state of the machine. If a bus error exception occurs during the stacking operation, there have been two bus errors in a row. This is commonly referred to as a double bus fault. When a double bus fault occurs, the processor will halt. Once a bus error exception has occurred, any bus error exception occurring before the execution of the next instruction constitutes a double bus fault. Figure $4-24$ is a diagram of the bus error timing.

Note that a bus cycle which is re-run does not constitute a bus error exception, and does not contr!bute to a double bus fault. Note also that this means that as long as the external hardware requests it, the processor will continue to re-run the same bus cycle.

The bus error pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor.

### 4.2.5 Reset Operation

The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure $4-25$ is a timing diagram for processor generated reset operation.


Figure 4-24. Bus Error Timing Diagram


Figure 4-25. Reset Operation Timing Diagram

When the reset and halt lines are driven it is recognized as an entire system reset, including the processor. For an external reset, both the HALT and RESET lines must be asserted to ensure total reset of the processor. Timing diagram for system reset is shown in Figure 4-26 The processor responds by reading the reset vector table entry (vector number zero, address $\$ 000000$ ) and loads it into the supervisor stack pointer (SSP). Vector table entry number one at address $\$ 000004$ is read next and loaded into the program counter. The processor initializes the status register to an interrupt level of seven. No other registers are affected by the reset sequence

When a reset instruction is executed, the processor drives the reset pin for 124 clock periods In this case, the processor is trying to reset the rest of the system. Therefore, there is no effect on the internal state of the processor. All of the processor's internal registers and the status register are unaffected by the execution of a reset instruction. All external devices connected to the reset line will be reset at the completion of the reset instruction.

Asserting the reset and halt lines for 10 clock cycles will cause a processor reset, except when VCC is initially applied to the processor. In this case, an external reset must be applied for at least 100 milliseconds allowing stabilization of the on-chip circuitry and system clock.


Figure 4-26. System Reset Timing Diagram

### 4.3 THE RELATIONSHIP OF DTACK, BERR, AND HALT

In order to properly control termination of a bus cycle for a re-run or a bus error condition, DTACK, $\overline{B E R R}$, and HALT should be asserted and negated on the rising edge of the TS68008 clock. This will assure that when two signals are asserted simultaneously, the required setup time (\#47) for both of them will be met during the same bus state.

This, or some equivalent precaution, should be designed external to the TS68008. Parameter \#48 is intended to ensure this operation in a totally asynchronous system, and may be ignored if the above conditions are met.

The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 4-4):

| Normal Termination: | $\overline{\overline{D T A C K}}$ occurs tirst (case 1 ). |
| :--- | :--- |
| Halt Termination: | $\overline{H A L T}$ is asserted at same time, or precedes $\overline{\text { DTACK (no } \overline{B E R R} \text { ) cases } 2}$ |
| Bus Error Termination: | $\overline{\text { BER }} 3$ |
| Re-Run is asserted in lieu of, at same time, or preceding $\overline{\text { DTACK }}$ (Case |  |

Table 4-4 details the resulting bus cycle termination under various combinations of control signal sequences. The negation of these same control signals under several conditions is shown in Table 4-5 ( $\overline{\text { DTACK }}$ is assumed to be negated normally in all cases; for correct results, both $\overline{\text { DTACK }}$ and $\overline{\mathrm{BERR}}$ should be negated when address strobe is negated).

## EXAMPLE A:

A system uses a watch-dog timer to terminate accesses to unpopulated address space.
The timer asserts $\overline{\mathrm{DTACK}}$ and $\overline{\mathrm{BERR}}$ simultaneously after time out (case 4 ).

## EXAMPLE B:

A system uses error detection on RAM contents. Designer may (a) delay $\overline{\text { TTACK }}$ until data verified, and return $\overline{B E R R}$ and $\overline{\text { HALT }}$ simultaneously to re-run error cycle (case 5), or If valid, return $\overline{D T A C K}$; (b) delay $\overline{D T A C K}$ until data verified, and return $\overline{B E R R}$ at same time as $\overline{\text { DTACK }}$ if data in error (case 4); (c) return $\overline{\text { DTACK }}$ prior to data verification, as described in previous section. If data invalid, $\overline{B E R R}$ is asserted (case 1) in next cycle. Error-handling software must know how to recover error cycle.

### 4.4 ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION

### 4.4.1 Asynchronous Operation

To achieve clock frequency independence at a system level, the TS68008 can be used in an asynchronous manner. This entails using only the bus handshake lines ( $\overline{A S}, \overline{D S}, \overline{D T A C K}, \overline{B E R R}, \overline{H A L T}$, and $\overline{\mathrm{VPA}}$ ) to control the data transfer. Using this method, $\overline{\mathrm{AS}}$ signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle. The slave device (memory or peripherall then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowledge signal (DTACK) to terminate the bus cycle. If no slave responds or the access is invalid, external control logic asserts the $\overline{B E R R}$, or BERR and HALT signal to abort or rerun the bus cycle.

The $\overline{\text { DTACK }}$ signal is allowed to be asserted before the data from a slave device is valid on a read cycle. The length of time that DTACK may precede data is given as parameter \#31 and it must be met in any asynchronous system to insure that valid data is latched into the processor. Notice that there is no maximum time specified from the assertion of $\overline{\mathrm{AS}}$ to the assertion of $\overline{\mathrm{DTACK}}$. This is because the MPU will insert wait cycles of one clock period each until DTACK is recognized.

Table 4-4. $\overline{\text { DTACK }}, \overline{B E R R}$, and $\overline{\text { HALT }}$ Assertion Results

| $\begin{aligned} & \text { Case } \\ & \text { No. } \end{aligned}$ | Control Signal | Asserted on Rising Edge of State |  | Result |
| :---: | :---: | :---: | :---: | :---: |
|  |  | N | N+2 |  |
| 1 | $\begin{array}{\|c} \hline \overline{\text { DTACK }} \\ \text { BERR } \\ \hline \text { HALT } \\ \hline \end{array}$ | $\begin{gathered} \hline A \\ N A \\ N A \end{gathered}$ | $\begin{aligned} & \hline s \\ & x \\ & x \end{aligned}$ | Normal cycle terminate and continue |
| 2 | $\begin{array}{\|l} \overline{\overline{D T A C K}} \\ \overline{\text { BERR }} \\ \overline{\text { HALT }} \end{array}$ | $\begin{gathered} \hline A \\ N A \\ A \end{gathered}$ | $\begin{aligned} & \hline \mathrm{S} \\ & \mathrm{x} \\ & \mathrm{~S} \end{aligned}$ | Normal cycle terminate and halt. Continue when HALT removed. |
| 3 | $\begin{array}{\|l} \hline \overline{\text { DTACK }} \\ \overline{\text { BERR }} \\ \hline \text { HALT } \\ \hline \end{array}$ | $\begin{gathered} \hline N A \\ N A \\ A \end{gathered}$ | $\begin{gathered} \hline \text { A } \\ \text { NA } \\ S \end{gathered}$ | Normal cyćle terminate and halt Continue when HALT removed |
| 4 | $\begin{array}{\|l} \hline \frac{\mathrm{BTACK}}{\text { BERR }} \\ \frac{\text { HALT }}{} \end{array}$ | $\begin{gathered} X \\ A \\ N A \end{gathered}$ | $\begin{gathered} \hline X \\ S \\ N A \end{gathered}$ | Terminate and re-run. |
| 5 | $\begin{array}{\|c} \hline \overline{\text { DTACK }} \\ \text { BERR } \\ \hline \text { HALT } \\ \hline \end{array}$ | $\begin{aligned} & \hline X \\ & A \\ & A \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & s \\ & s \\ & \hline \end{aligned}$ | Terminate and re-run. |
| 6 | $\begin{array}{\|l} \hline \overline{\text { DTACK }} \\ \overline{\text { BERR }} \\ \overline{\text { HALT }} \end{array}$ | NA NA A | $\begin{aligned} & \hline X \\ & A \\ & S \end{aligned}$ | Terminate and re-run when $\overline{\text { HALT }}$ removed. |

Legend:
$N$ - the number of the current even bus state (e.g.. S4, S6, etc.)
A - signal is asserted in this bus state
NA - signal is not asserted in this state
X - don't care
S - signal was asserted in previous state and remains asserted in this state

Table 4-5. $\overline{\text { BERR }}$ and $\overline{\text { HALT }}$ Negation Results

| Conditions of Termination in Table 4-4 | Control Signal | Negated on Rising Edge of State |  |  | Results - Next Cycle |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | N |  | $N+2$ |  |
| Bus Error | $\overline{\overline{B E R R}}$ |  | or or | $\bullet$ | Takes bus error trap |
| Re-run | $\overline{\overline{B E R R}}$ | $\bullet$ |  | $\bullet$ | Illegal sequence, usually traps to vector number 0 |
| Re-run | BERR | - |  | $\bullet$ | Re-runs the bus cycle |
| Normal | $\frac{\overline{B E R R}}{\text { HALT }}$ |  |  | $\bullet$ | May lengthen next cycle |
| Normal | $\overline{\overline{B E R R}} \overline{\overline{H A L T}}$ | $\bullet$ |  | $\begin{gathered} \bullet \\ \text { none } \end{gathered}$ | If next cycle is started it will be terminated as a bus error |

[^40]
### 4.4.2 Synchronous Operation

To allow for those systems which use the system clock as a signal to generate $\overline{\text { DTACK }}$ and other asynchronous inputs, the asynchronous input setup time is given as parameter \#47. If this setup is met on an input, such as DTACK, the processor is guaranteed to recognize that signal on the next falling edge of the system clock. However, the converse is not true-if the input signal does not meet the setup time it is not guaranteed not to be recognized. In addition, if $\overline{D T A C K}$ is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter \#27. Given this, parameter \#31 may be ignored. Note that if DTACK is asserted, with the required setup time, before the falling edge of S4, no wait states will be incurred and the bus cycle will run at its maximum speed of four clock periods.

## NOTE

During an active bus cycle, $\overline{V P A}$ and $\overline{B E R R}$ are sampled on every falling edge of the clock starting with SO. $\overline{\text { DTACK }}$ is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S 6 during a read. The bus cycle will then be terminated in 57 except when $\overline{B E R R}$ is asserted in the absence of $\overline{D T A C K}$, in which case it will terminate one clock cycle later in S9.

## SECTION 5 PROCESSING STATES

This section describes the actions of the TS68008 which are outside the normal processing associated with the execution of instructions. The functions of the bits in the supervisor portion of the status register are covered: the supervisor/user bit, the trace enable bit, and the processor interrupt priority mask. Finally, the sequence of memory references and actions taken by the processor on exception conditions is detailed.

The TS68008 is always in one of three processing states: normal, exception, or halted. The normal processing state is that associated with instruction execution; the memory references are to fetch instructions and operands, and to store results. A special case of the normal state is the stopped state which the processor enters when a STOP instruction is executed. In this state, no further memory references are made.

The exception processing state is associated with interrupts, trap instructions, tracing, and other exceptional conditions. The exception may be internally generated by an instruction or by an unusual condition arising during the execution of an instruction. Externally, exception processing can be forced by an interrupt, by a bus error, or by a reset. Exception processing is designed to provide an efficient context switch so that the processor may handle unusual conditions.

The halted processing state is an indication of catastrophic hardware failure. For example, if during the exception processing of a bus error another bus error occurs, the processor assumes that the system is unusable and halts. Only an external reset can restart a halted processor. Note that a processor in the stopped state is not in the halted state, nor vice versa.

### 5.1 PRIVILEGE STATES

The processor operates in one of two states of privilege: the "user" state or the "supervisor" state. The privilege state determines which operations are legal, is used by the external memory management device to control and translate accesses, and is used to choose between the supervisor stack pointer and the user stack pointer in instruction references.

The privilege state is a mechanism for providing security in a computer system. Programs should access only their own code and data areas, and ought to be restricted from accessing information which they do not need and must not modify.

The privilege mechanism provides security by allowing most programs to execute in user state. In this state, the accesses are controlled, and the effects on other parts of the system are limited. The operating system executes in the supervisor state, has access to all resources, and performs the overhead tasks for the user state programs.

### 5.1.1 Supervisor State

The supervisor state is the higher state of privilege. For instruction execution, the supervisor state is determined by the $S$ bit of the status register; if the $S$ bit is asserted (high) or exception processing is invoked, the processor is in the supervisor state. All instructions can be executed in the supervisor state. The bus cycles generated by instructions executed in the supervisor state are classified as supervisor references. While the processor is in the supervisor privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly access the supervisor stack pointer.

### 5.1.2 User State

The user state is the lower state of privilege and is controlled by the $S$ bit of the status register. If the $S$ bit is negated (low), the processor is executing instructions in the user state. The bus cycles generated by an instruction executed in the user state are classified as user state references. This allows an external memory management device to translate the address and to control access to protected portions of the address space. While the processor is in the user privilege state, those instructions which use either the system stack pointer implicitly, or address register seven explicitly, access the user stack pointer.

Most instructions execute the same in user state as in the supervisor state. However, some instructions which have important system effects are made privileged. User programs are not permitted to execute the STOP instruction, or the RESET instruction. To ensure that a user program cannot enter the supervisor state except in a controlled manner, the instructions which modify the whole status register are privileged. To aid in debugging programs which are to be used as operating systems, the move to user stack pointer (MOVE USP) and move from user stack pointer (MOVE from USP) instructions are also privileged.

### 5.1.3 Privilege State Changes

Once the processor is in the user state and executing instructions, only exception processing can change the privilege state. During exception processing, the current setting of the $S$ bit of the status register is saved and the $S$ bit is asserted, putting the processor in the supervisor state. Therefore, when instruction execution resumes at the address specified to process the exception, the processor is in the supervisor privilege state.

### 5.1.4 Reference Classification

When the processor makes a reference, it classifies the kind of reference being made, using the encoding on the three function code output lines. This allows external translation of addresses, control of access, and differentiation of special processor states, such as interrupt acknowledge. Table 5-1 lists the classification of references.

### 5.2 EXCEPTION PROCESSING

Before discussing the details of interrupts, traps, and tracing, a general description of exception processing is in order. The processing of an exception occurs in four steps, with variations for different exception causes. During the first step, a temporary copy of the status register is made, and the status register is set for exception processing. In the second step the exception vector is determined, and the third step is the saving of the current processor context. In the fourth step a new context is obtained, and the processor switches to instruction processing.

Table 5-1. Reference Classification

| Function Code Output |  | Reterence Class |  |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 |  |  |
| 0 | 0 | 0 | Unassigned) |
| 0 | 0 | 1 | User Data |
| 0 | 1 | 0 | User Program |
| 0 | 1 | 1 | Unassigned |
| 1 | 0 | 0 | Unassigned |
| 1 | 0 | 1 | Supervisor Data |
| 1 | 1 | 0 | Supervisor Program |
| 1 | 1 | 1 | Interrupi Acknowledge |

### 5.2.1 Exception Vectors

Exception vectors are memory locations from which the processor fetches the address of a routine which will handle that exception. All exception vectors are two words in length (Figure 5-1), except for the reset vector, which is four words. All exception vectors lie in the supervisor data space, except for the reset vector which is in the supervisor program space. A vector number is an 8 -bit number which, when multiplied by four, gives the address of an exception vector. Vector numbers are generated internally or externally, depending on the cause of the exception. In the case of vectored interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8 -bit vector number (Figure 5-2) to the processor on data bus lines D0 through D7. The processor translates the vector number into a full 32-bit address, as shown in Figure 5-3. The memory layout for exception vectors is given in Table 5-2.


Figure 5-1. Format of Vector Table Entries


Where $v 7$ is the MSB of the Vector Number $v 0$ is the LSB of the Vector Number

Figure 5-2. Vector Number Format


Figure 5-3. Vector Number Translated to an Address

Table 5-2. Vector Table

| Vector <br> Number(s) | Address |  |  | Assignment |
| :---: | :---: | :---: | :---: | :---: |
|  | Dec | Hex | Space |  |
| 0 | 0 | 000 | SP | Reset: Initial SSP |
| - | 4 | 004 | SP | Reset: Initial PC |
| 2 | 8 | 008 | SD | Bus Error |
| 3 | 12 | 00 C | SD | Address Error |
| 4 | 16 | 010 | SD | Iliegal Instruction |
| 5 | 20 | 014 | SD | Zero Divide |
| 6 | 24 | 018 | SD | CHK Instruction |
| 7 | 28 | 01 C | SD | TRAPV Instruction |
| 8 | 32 | 020 | SD | Privilege Violation |
| 9 | 36 | 024 | SD | Trace |
| 10 | 40 | 028 | SD | Line 1010 Emulator |
| 11 | 44 | 02C | SD | Line 1111 Emulator |
| 12* | 48 | 030 | SD | (Unassigned, Reserved) |
| 13* | 52 | 034 | SD | (Unassigned, Reserved) |
| $14^{*}$ | 56 | 038 | SD | (Unassigned, Reserved) |
| 15 | 60 | 03C | SD | Uninitialized Interrupt Vector |
| 16-23* | 64 | 04C | SD | (Unassigned, Reserved) |
|  | 95 | 05F |  | - |
| 24 | 96 | 060 | SD | Spurious Interrupt |
| 25 | 100 | 064 | SD | Level 1 Interrupt Autovector |
| 26 | 104 | 068 | SD | Level 2 interrupt Autovector |
| 27 | 108 | 06C | SD | Level 3 Interrupt Autovector |
| 28 | 112 | 070 | SD | Level 4 Interrupt Autovector |
| 29 | 116 | 074 | SD | Level 5 Interrupt Autovector |
| 30 | 120 | 078 | SD | Level 6 Interrupt Autovector |
| 31 | 124 | 07C | SD | Level 7 Interrupt Autovector |
| 32-47 | 128 | 080 | SD | TRAP Instruction Vectors |
|  | 191 | OBF |  | - |
| 48-63** | 192 | OCO | SD | (Unassigned, Reserved) |
|  | 255 | OFF |  | - |
| 64-255 | 256 | 100 | SD | User Interrupt Vectors |
|  | 1023 | 3FF |  | - |

*Vector numbers 12, 13, 14, 16 through 23, and 48 through 63 are reserved for future enhancements by THOMSON SEMICONDUCTEURS. No user peripheral devices should be assigned these numbers.

As shown in Table 5-2, the memory layout is 512 words long. ( 1024 bytes). It starts at address 0 and proceeds through address 1023. This provides 255 unique vectors; some of these are reserved for TRAPS and other system functions. Of the 255, there are 192 reserved for user interrupt vectors. However, there is no protection on the first 64 entries, so user interrupt vectors may overlap at the discretion of the systems designer.

### 5.2.2 Kinds of Exceptions

Exceptions can be generated by either internal or external causes. The externally generated exceptions are the interrupts and the bus error and reset requests. The interrupts are requests from peripheral devices for processor action while the bus error and reset inputs are used for access control and processor restart. The internally generated exceptions come from instructions, or from address errors or tracing. The trap (TRAP), trap on overflow (TRAPV), check register against
bounds (CHK), and divide (DIV) instructions all can generate exceptions as part of their instruction execution. In addition, illegal instructions, word fetches from odd addresses and privilege violations cause exceptions. Tracing behaves like a very high priority, internally generated interrupt after each instruction execution.

### 5.2.3 Exception Processing Sequence

Exception processing occurs in four identifiable steps. In the first step, an internal copy is made of the status register. After the copy is made, the $S$ bit is asserted, putting the processor into the supervisor privilege state. Also, the $T$ bit is negated which will allow the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated.

In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor fetch, classified as an interrupt acknowledge. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector.

The third step is to save the current processor status, except for the reset exception. The current program counter value and the saved copy of the status register are stacked using the supervisor stack pointer. The program counter value stacked usually points to the next unexecuted instruction, however, for bus error and address error, the value stacked for the program counter is unpredictable, and may be incremented from the address of the instruction which caused the error. Additional information defining the current context is stacked for the bus error and address error exceptions.

The last step is the same for all exceptions. The new program counter value is fetched from the exception vector. The processor then resumes instruction execution. The instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started.

### 5.2.4 Multiple Exceptions

These paragraphs describe the processing which occurs when multiple exceptions arise simultaneously. Exceptions can be grouped according to their occurrence and priority. The group 0 exceptions are reset, address error, and bus error. These exceptions cause the instruction currently being executed to be aborted, and the exception processing to commence within two clock cycles.

The group 1 exceptions are trace and interrupt, as well as the privilege violations and illegal instructions. The trace and interrupt exceptions allow the current instruction to execute to completion, but pre-empt the execution of the next instruction by forcing exception processing to occur (privilege violations and illegal instructions are detected when they are the next instruction to be executed). The group 2 exceptions occur as part of the normal processing of instructions. The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these exceptions, the normal execution of an instruction may lead to exception processing.

Group 0 exceptions have highest priority, while group 2 exceptions have lowest priority. Within group 0, reset has highest priority, followed by address error and then bus error. Within group 1, trace has priority over external interrupts, which in turn takes priority over illegal instruction and privilege violation. Since only one instruction can be executed at a time, there is no priority relation within group 2.

The priority relation between two exceptions determines which is taken, or taken first, it the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the $T$ bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. A surnmary of exception grouping and priority is given in Table 5-3.,

Table 5-3. Exception Grouping and Priority

| Group | Exception | Processing |
| :---: | :---: | :---: |
| 0 | Reset <br> Address Error <br> Bus Error | Exception processing begins <br> within two clock cycles |
| 1 | Trace <br> Interrupt <br> Illegal <br> Privilege | Exception processing begins before <br> the next instruction |
| 2 | TRAP, TRAPV, <br> CHK, <br> Zero Divide | Exception processing is started by <br> normal instruction execution |

### 5.3 EXCEPTION PROCESSING DETAILED DISCUSSION

Exceptions have a number of sources, and each exception has processing which is peculiar to it. The following paragraphs detail the sources of exceptions, how each arises, and how each is processed.

### 5.3.1 Reset

The reset input provides the highest exception level. The processing of the reset signal is designed for system initiation, and recovery from catastrophic failure. Any processing in progress at the time of the reset is aborted and cannot be recovered. The processor is forced into the supervisor state, and the trace state is forced off. The processor interrupt priority mask is set at level seven. The vector number is internally generated to reference the reset exception vector at location 0 in the supervisor program space. Because no assumptions can be made about the validity of register contents, in particular the supervisor stack pointer, neither the program counter nor the status register is saved. The address contained in the first two words of the reset exception vector is fetched as the initial supervisor stack pointer, and the address in the last two words of the reset exception vector is fetched as the initial program counter. Finally, instruction execution is started at the address in the program counter. The power-up/restart code should be pointed to by the initial program counter.

The reset instruction does not cause loading of the reset vector, but does assert the reset line to reset external devices. This allows the software to reset the system to a known state and then continue processing with the next instruction.

### 5.3.2 Interrupts

Seven levels of interrupts are provided by the 68000 architecture. The TS68008 supports three interrupt levels: two, five, and seven, level seven being the highest. Devices may be chained externally within interrupt priority levels, allowing an unlimited number of peripheral devices to interrupt
the processor. The status register contains a 3-bit mask which indicates the current processor priority, and interrupts are inhibited for all priority levels less than or equal to the current processor priority.

An interrupt request is made to the processor by encoding the interrupt request level on the interrupt request lines; a zero indicates no interrupt request. Interrupt requests arriving at the processor do not force immediate exception processing, but are made pending. Pending interrupts are detected between instruction executions. If the priority of the pending interrupt is lower than or equal to the current processor priority, execution continues with the next instruction and the interrupt exception processing is postponed. (The recognition of level seven is slightly different, as explained in the following paragraph.)

If the priority of the pending interrupt is greater than the current processor priority, the exception processing sequence is started. First a copy of the status register is saved, and the privilege state is set to supervisor, tracing is suppressed, and the processor priority level is set to the level of the interrupt being acknowledged. The processor fetches the vector number from the interrupting device, classifying the reference as an interrupt acknowledge and displaying the level number of the interrupt being acknowledged on the address bus. If external logic requests an automatic vectoring, the processor internally generates a vector number which is determined by the interrupt level number. If external logic indicates a bus error, the interrupt is taken to be spurious, and the generated vector number references the spurious interrupt vector. The processor then proceeds with the usual exception processing, saving the program counter and status register on the supervisor stack. The saved value of the program counter is the address of the instruction which would have been executed had the interrupt not been present. The content of the interrupt vector whose vector number was previously obtained is fetched and loaded into the program counter, and normal instruction execution commences in the interrupt handling routine. A flowchart for the interrupt acknowledge sequence is given in Figure 5-4, a timing diagram is given in Figure 5-5, and the interrupt processing sequence is shown in Figure 5-6.

PROCESSOR
INTERRUPTING DEVICE

| Grant the Interrupt | Request the Interrupt |
| :---: | :---: |
| 1) Compare Interrupt Level in Processor Status Register and Wait for Current Instruction to Complete <br> 2) Place Interrupt Level on A1, A2, and A3 <br> 3) Drive A0, A4-A19 High |  |
| 4) Set R/W to Read <br> 5) Set Function Code to Interrupt | Provide the Vector Number |
| Acknowledge <br> 6) Assert Address Strobe ( $\overline{\mathrm{AS}}$ ) <br> 7) Assert Data Strobe ( $\overline{\mathrm{DS}}$ ) | 1) Place Vector Number on DO-D7 <br> 2) Assert Data Transfer Acknowledge |
| Acquire the Vector Number |  |
| 1) Latch Vector Number <br> 2) Negate $\overline{D S}$ <br> 3) Negate $\overline{A S}$ |  |
|  | Release |
|  | 1) Negate $\overline{\text { DTACK }}$ |
| Start Interrupt Processing |  |

Figure 5-4. Vector Acquisition Flowchart


Figure 5-5. Interrupt Acknowledge Cycle

1. Acquire vector number via interrupt acknowledge.
2. Convert vector number to a full 32 -bit address.
3. Stack the SR and PC by successive write cycles. Refer to Figure 4-7 for word write cycle operation.
4. Place vector table address on AO-A19. Refer to Figure 5-3 for address translation.
5. Read upper half of program counter $(\mathrm{PC})$. Refer to Figure 4-3 for word read cycle operation.
6. Increment vector table address by 2 and place it on A0-A19.
7. Read lower half of program counter (PC).
8. Load new program counter (PC).
9. Place contents of PC on A0-A19.
10. Read first instruction of service routine.

Figure 5-6. Interrupt Processing Sequence

Priority level seven is a special case. Level seven interrupts cannot be inhibited by the interrupt priority mask, thus providing a "non-maskable interrupt" capability. An interrupt is generated each time the interrupt request level changes from some lower level to level seven. Note that a level seven interrupt may still be caused by the level comparison if the request level is a seven and the processor priority is set to a lower level by an instruction.

### 5.3.3 Uninitialized Interrupt

An interrupting device asserts $\overline{\mathrm{VPA}}$ or provides an interrupt vector during an interrupt acknowledge cycle to the TS68008. If the vector register of the peripheral has not been initialized, the responding 68000 Family peripheral will provide vector 15 ( $\$ 0 \mathrm{~F}$ ), the uninitialized interrupt vector. This provides a uniform way to recover from a programming error.

### 5.3.4 Spurious Interrupt

If during the interrupt acknowledge cycle no device responds by asserting $\overline{\text { TTACK }}$ or $\overline{\mathrm{VPA}}$, the bus error line should be asserted to terminate the vector acquisition. The processor separates the processing of this error from bus error by fetching the spurious interrupt vector instead of the bus error vector. The processor then proceeds with the usual exception processing.

### 5.3.5 Instruction Traps

Traps are exceptions caused by instructions. They arise either from processor recognition of abnormal conditions during instruction execution. or from use of instructions whose normal behavior is trapping. The TRAP instruction always forces an exception, and is useful for implementing system calls for user programs. The TRAPV and CHK instructions force an exception if the user program detects a runtime error, which may be an arithmetic overflow or a subscript out of bounds. The signed divide (DIVS) and unsigned divide (DIVU) instructions will force an exception if a division operation is attempted with a divisor of zero.

### 5.3.6 Illegal and Unimplemented Instructions

"Illegal instruction" is the term used to refer to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is fetched, an illegal instruction exception occurs. THOMSON SEMICONDUCTEURS reserves the right to define instructions whose opcodes may be any of the illegal instructions. Three bit patterns will always force an illegal instruction trap on all 68000 Family compatible microprocessors. They are : \$ $4 A F A, \$ 4 A F B$ and $\$ 4 A F C$. Two of the patterns, $\$ 4 A F A$ and $\$ 4 A F B$, are reserved for THOMSON SEMICONDUCTEURS system products. The third pattern, \$4AFC, is reserved for customer use.

Word patterns with bits 15 through 12 equaling 1010 or 1111 are distinguished as unimplemented instructions and separate exception vectors are given to these patterns to permit efficient emulation. This facility allows the operating system to detect program errors, or to emulate unimplemented instructions in software.

### 5.3.7 Privilege Violations

In order to provide system security, various instructions are privileged. An attempt to execute one of the privileged instructions while in the user state will cause an exception. The privileged instructions are:

| STOP | AND Immediate to SR |
| :--- | :--- |
| RESET | EOR Immediate to SR |
| RTE | OR Immediate to SR |
| MOVE to SR | MOVE USP |

### 5.3.8 Tracing

To aid in program development, the TS68008 includes a tacility to allow instruction-by-instruction tracing. In the trace state, after each instruction is executed an exception is forced, allowing a debugging program to monitor the execution of the program under test.

The trace facility uses the $T$ bit in the supervisor portion of the status register. If the $T$ bit is negated (off), tracing is disabled, and instruction execution proceeds from instruction to instruction as normal. If the $T$ bit is asserted (on) at the beginning of the execution of an instruction, a trace exception will be generated after the execution of that instruction is completed. If the instruction is not executed, either because an interrupt is taken, or the instruction is illegal or privileged, the trace exception does not occur. The trace exception also does not occur if the instruction is aborted by a reset, bus error, or address error exception. If the instruction is indeed executed and an interrupt is pending on completion, the trace exception is processed before the interrupt exception. If, during the execution of the instruction, an exception is forced by that instruction, the forced exception is processed before the trace exception.

As an extreme illustration of the above rules, consider the arrival of an interrupt during the execution of a TRAP instruction while tracing is enabled. First the trap exception is processed, then the trace exception, and finally the interrupt exception. Instruction execution resumes in the interrupt handler routine.

### 5.3.9 Bus Error

Bus error exceptions occur when the external logic requests that a bus error be processed by an exception. The current bus cycle which the processor is making is then aborted. Regardless of whether the processor was doing instruction or exception processing, that processing is terminated, and the processor immediately begins exception processing.

Exception processing for bus error follows the usual sequence of steps. The status register is copied, the supervisor state is entered, and the trace state is turned off. The vector number is generated to refer to the bus error vector. Since the processor was not between instructions when the bus error exception request was made, the context of the processor is more detailed. To save more of this context, additional information is saved on the supervisor stack (refer to Figure 5-7). The program counter and the copy of the status register are of course saved. The value saved for the program counter is advanced by some amount, two to ten bytes beyond the address of the first word of the instruction which made the reference causing the bus error. If the bus error occurred during the fetch of the next instruction, the saved program counter has a value in the vicinity of the current instruction, even if the current instruction is a branch, a jump, or a return instruction. Besides the usual information, the processor saves its internal copy of the first word of the instruction being processed, and the address which was being accessed by the aborted bus cycle. Specific information about the access is also saved: whether it was a read or a write, whether the processor was processing an instruction or not, and the classification displayed on the function code outputs when the bus error occurred. The processor is processing an instruction if it is in the normal state or processing a group 2 exception; the processor is not processing an instruction if it is processing a group 0 or a group 1 exception. Figure 5-7 illustrates how this information is organized on the supervisor stack. Although this information is not sufficient in general to effect full recovery from the bus error, it does allow software diagnosis. Finally, the processor commences instruction processing at the address contained in the vector. It is the responsibility of the error handler routine to clean up the stack and determine where to continue execution.

If a bus error occurs during the exception processing for a bus error, address error, or reset, the processor is halted, and all processing ceases. This simplifies the detection of catastrophic system failure, since the processor removes itself from the system rather than destroy all memory contents. Only the RESET pin can restart a halted processor.


R/W (read/write): write $=0$, read $=1.1 / N$ (instruction/not): instruction $=0$, not $=1$
Figure 5-7. Supervisor Stack Order (Group 0)

### 5.3.10 Address Error

Address error exceptions occur when the processor attempts to access a word or a long word operand or an instruction at an odd address. When the TS68008 detects an address error it prevents assertion of $\overline{\mathrm{DS}}$ but asserts $\overline{\mathrm{AS}}$ to provide proper bus arbitration support. The effect is much like an internally generated bus error, in that the bus cycle is aborted, and the processor ceases whatever processing it is currently doing and begins exception processing. After exception processing commences, the sequence is the same as that for bus error including the information that is stacked, except that the vector number refers to the address error vector instead. Likewise, if an address error occurs during the exception processing for a bus error, address error, or reset, the processor is halted. As shown in Figure 5-8, an address error will execute a short bus cycle followed by exception processing.


Figure 5-8. Address Error Timing

## SECTION 6 INTERFACE WITH 6800 PERIPHERALS

THOMSON SEMICONDUCTEURS' extensive line of 6800 peripherals are compatible with the TS68008. Some of these devices that are particularly useful are :

EF6821 Peripheral Interface Adapter EF6850 Asynchronous Communications Interface Adapter
EF6840 Programmable Timer Module
EF9345,EF9367 CRT Controllers
EF6852 Synchronous Serial Data Adapter
EF6854 Advanced Data Link Controller

To interface the synchronous 6800 peripherals with the asynchronous TS68008, the processor modifies its bus cycle to meet the 6800 cycle requirements whenever an 6800 device address is detected. This is possible since both processors use memory mapped I/O. Figure 6-1 is a flowchart of the interface operation between the processor and 6800 devices.

### 6.1 DATA TRANSFER OPERATION

Two signals on the processor provide the 6800 interface. They are : enable ( $E$ ) , and valid peripheral address (VPA). In addition, a valid memory address (VMA) signal must be provided (see 4.1 .7 6800 Peripheral Control). Enable corresponds to the E signal in existing 6800 systems. The $E$ clock frequency is one tenth of the incoming TS68008 clock frequency. The timing of E allows 1 megahertz peripherals to be used with an 8 megahertz TS68008. Enable has a 60/40 duty cycle ; that is, it is low for six input clocks and high for four input clocks.

6800 cycle timing is given in Section 8. At state zero in the cycle, the address bus is in the highimpedance state. A function code is asserted on the function code output lines. One-half clock later, in state one, the address bus is released from the high-impedance state.

During state two, the addres: strobe $(\overline{\mathrm{AS}})$ is asserted. to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the data strobe is also asserted in state two. If the bus cycle is a write cycle the read/write ( $R / \bar{W}$ ) signal is switched to low (write) during state two. One half clock later, in state three, the write data is placed on the data bus, and in state four the data strobe is issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of $\overline{\mathrm{VPA}}$.

The $\overline{V P A}$ input signals the processor that the address on the bus is the address of an 6800 device (or an area reserved for 6800 devices) and that the bus should conform to the transfer characteristics of the 6800 bus. Valid peripheral address is derived by decoding the address bus, conditioned by address strobe. Chip select for the 6800 peripherals should be derived by decoding the address bus conditioned by $\overline{\mathrm{VMA}}$ ( $n$ ot $\overline{\mathrm{AS}}$ ).


Figure 6-1.6800 Cycle Flowchart

After recognition of $\overline{\mathrm{VPA}}$, the processor assures that the enable ( E ) is low, by waiting if necessary. Valid memory address (provided by an external circuit similar to that of Figure 4-2) is then used as part of the chip select equation of the peripheral. This ensures that the 6800 peripherals are selected and deselected at the correct time. The peripheral now runs its cycle during the high portion of the E signal. Figure $6-2$ depicts the 6800 cycle timing using the VMA generation circuit shown in Figure 4-2. This cycle length is dependent strictly upon when $\overline{\mathrm{VPA}}$ is asserted in relationship to the E clock.


Figure 6-2. 6800 Cycle Timing

During a read cycle, the processor latches the peripheral data in state six. For all cycles, the processor negates the address and data strobes one half clock cycle later in state seven, and the enable signal goes low at this time. Another half clock later, the address bus is put in the high-impedance state. During a write cycle, the data bus is put in the high-impedance state and the read/write signal is switched high. The peripheral logic must remove $\overline{V P A}$ within one clock after address strobe is negated.
$\overline{\text { DTACK }}$ should not be asserted while $\overline{\mathrm{VPA}}$ is asserted. Notice that $\overline{\mathrm{VMA}}$ is active low, contrasted with the active high 6800 VMA. Refer to Figure 4-2.

### 6.2 AC ELECTRICAL SPECIFICATIONS

The electrical specifications for interfacing the TS68008 to 6800 Family peripherals are located in Section 8.

### 6.3 INTERRUPT INTERFACE OPERATION

During an interrupt acknowledge cycle while the processor is fetching the vector, the VPA is asserted, the TS68008 will complete a normal 6800 read cycle as shown in Figure 6-3. The processor will then use an internally generated vector that is a function of the interrupt being serviced. This process is known as autovectoring. The seven autovectors are vector numbers 25 through 31 (decimal).


Figure 6-3. Autovector Operation Timing Diagram
Autovectoring operates in the same fashion (but is not restricted to) the 6800 interrupt sequence. The basic difference is that there are six normal interrupt vectors and one NMI type vector. As with both the 6800 and the TS68008's normal vectored interrupt, the interrupt service routine can be located anywhere in the address space. This is due to the fact that while the vector numbers are fixed, the contents of the vector table entries are assigned by the user.

Since $\overline{\mathrm{VMA}}$ is asserted during autovectoring, the 6800 peripheral address decoding should prevent unintended accesses.

## SECTION 7 <br> INSTRUCTION SET AND EXECUTION TIMES

### 7.1 INSTRUCTION SET

The following paragraphs provide information about the addressing categories and instruction set of the TS68008.

### 7.1.1 Addressing Categories

Effective address modes may be categorized by the ways in which they may be used. The following classifications will be used in the instruction definitions.

Data If an effective address mode by be used to refer to data operands, it is considered a data addressing effective address mode.
Memory If an effective address mode may be used to refer to memory operands, it is considered a memory addressing effective address mode.
Alterable If an effective address mode may be used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode. Control If an effective address mode may be used to refer to memory operands without an associated size, it is considered a control addressing effective address mode.
These categories may be combined, so that additional, more restrictive, classifications may be defined. For example, the instruction descriptions use such classifications as alterable memory or data alterable. The former refers to those addressing modes which are both alterable and memory addresses, and the latter refers to addressing modes which are both data and alterable. Table 7-1 shows the various categories to which each of the effective address modes belong. Table 7-2 is the instruction set summary.

Table 7-1. Effective Addressing Mode Categories

| Effective <br> Address Modes | Mode | Register | Data | Addressing Categories |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Memory | Control | Alterable |
| Dn | 000 | Register Number | X | - | - | $X$ |
| An | 001 | Register Number | - | - | - | X |
| (An) | 010 | Register Number | $X$ | $X$ | X | $X$ |
| $(A n)+$ | 011 | Register Number | X | X | - | $x$ |
| - (An) | 100 | Register Number | $x$ | X | - | $x$ |
| $d(A n)$ | 101 | Register Number | $X$ | $x$ | $x$ | $x$ |
| $d(A n, i x)$ | 110 | Register Number | X | X | X | $x$ |
| $x \times x . W$ | 111 | 000 | X | $x$ | X | X |
| $x \times x . L$ | 111 | 001 | X | $x$ | $x$ | X |
| $\mathrm{d}(\mathrm{PC})$ | 111 | 010 | X | X | X | - |
| d(PC, ix) | 111 | 011 | X | $x$ | X | - |
| \# $\mathrm{x} \times \mathrm{x}$ | 111 | 100 | X | X | - | - |

Table 7-2. Instruction Set (Sheet 1 of 2)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | z | $v$ | C |
| ABCD | Add Decimal with Extend | (Destination) $10+$ (Source) $10+x \rightarrow$ Destination | * | $\cup$ | * | U | * |
| ADD | Add Binary | (Destination) + (Source) $\rightarrow$ Destination | * | * | * | * | * |
| ADDA | Add Address | $($ Destination $)+($ Source $) \rightarrow$ Destination | - | - | - | - | - |
| ADDI | Add Immediate | (Destination) + Immediate Data $\rightarrow$ Destination | * | * | * | * | * |
| ADDO | Add Quick | (Destination) + Immediate Data $\rightarrow$ Destınation | * | * | * | * | * |
| ADDX | Add Extended | (Destination) + (Source) $+x \rightarrow$ Destination | * | * | * | * | * |
| AND | AND Logical | (Destınation) $\boldsymbol{\Lambda}$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ANDI | AND Immediate | (Destination) $\Lambda$ Immediate Data $\rightarrow$ Destınation | - | * | * | 0 | 0 |
| ASL, ASR | Arithmetic Shift | (Destination) Shifted by $\langle$ count $\rangle \rightarrow$ Destination | * | * | * | * | * |
| ${ }^{\text {CCC }}$ | Branch Conditionally | If CC then $\mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}$ | - | - | - | - | - |
| BCHG | Test a Bit and Change | $\begin{gathered} \sim(<\text { bit number }>) \text { OF Destination } \rightarrow z \\ \sim(<\text { bit number }>) \text { OF Destination } \rightarrow \\ <\text { bit number }>\text { OF Destination } \\ \hline \end{gathered}$ | - | - | * | - | - |
| BCLR | Test a Bit and Clear | $\begin{aligned} & -(<\text { bit number }>) \text { OF Destination } \rightarrow Z \\ & 0 \rightarrow<\text { bit number }>\rightarrow \text { OF Destination } \end{aligned}$ | - | - | * | - | - |
| BRA | Branch Always | PC + displacement $\rightarrow$ PC | - | - | - | - | - |
| BSET | Test a Bit and Set | $\begin{aligned} & -(<\text { bit number }>) \text { OF Destination } \rightarrow z \\ & 1 \rightarrow<\text { bit number }>\text { OF Destination } \end{aligned}$ | - | - | * | - | - |
| BSR | Branch to Subroutine | $\mathrm{PC} \rightarrow-(\mathrm{SP}), \mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}$ | - | - | - | - | - |
| BTST | Test a Bit | $\sim(<$ bit number $>1$ OF Destination $\rightarrow Z$ | - | - | * | - | - |
| CHK | Check Register against Bounds | If Dn <0 or Dn> (<ea>) then TRAP | - | * | U | $\cup$ | U |
| CLR | Clear an Operand | $0 \rightarrow$ Destination | - | 0 | 1 | 0 | 0 |
| CMP | Compare | (Destination) - (Source) | - | * | * | * | * |
| CMPA | Compare Address | (Destination) - (Source) | - | * | * | * | * |
| CMPI | Compare Immediate | (Destination) - Immediate Data | - | * | * | * | * |
| CMPM | Compare Memory | (Destination) - (Source) | - | * | * | * | * |
| DBCC | Test Condition, Decrement and Branch | If $\sim \mathrm{CC}$ then $\mathrm{Dn}-1 \rightarrow \mathrm{Dn}$; if $\mathrm{Dn} \neq-1$ then $P C+d \rightarrow P C$ | - | - | - | - | - |
| DIVS | Signed Divide | (Destination)/(Source) $\rightarrow$ Destination | - | * | * | * | 0 |
| DIVU | Unsigned Divide | (Destination)/(Source) $\rightarrow$ Destination | - | * | * | * | 0 |
| EOR | Exclusive OR Logical | (Destination) $\oplus$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| EORI | Exclusive OR Immediate | (Destination) $\oplus$ Immediate Data: Destination | - | * | * | 0 | 0 |
| EXG | Exchange Register | $\mathrm{Rx} \longleftrightarrow \mathrm{Ry}$ | - | - | - | - | - |
| EXT | Sign Extend | (Destination) Sign-extended $\rightarrow$ Destination | - | * | * | 0 | 0 |
| JMP | Jump | Destination $\rightarrow$ PC | - | - | - | - | - |
| JSR | Jump to Subroutine | $P C \rightarrow-$ (SP); Destination $\rightarrow$ PC | - | - | - | - | - |
| LEA | Load Effective Address | Destination $\rightarrow$ An | - | - | - | - | - |
| LINK | Link and Allocate | $A n \rightarrow-(S P) ; S P \rightarrow A n ; S P+$ displacement $\rightarrow$ SP | - | - | - | - | - |
| LSL, LSR | Logical Shift | (Destination) Shifted by $<$ count $>\rightarrow$ Destination | * | * | * | 0 | * |
| MOVE | Move Data from Source to Destination | (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MOVE to CCR | Move to Condition Code | (Source) $\rightarrow$ CCR | * | * | * | * | * |
| MOVE to SR | Move to the Status Register | (Source) $\rightarrow$ SR | * | * | * | * | * |
| MOVE from SR | Move from the Status Register | $S R \rightarrow$ Destination | - | - | - | - | - |
| MOVE USP | Move User Stack Pointer | $U S P \rightarrow A n ; A n \rightarrow$ USP | - | - | - | - | - |
| MOVEA | Move Address | (Source) $\rightarrow$ Destination | - | - | - | - | - |
| MOVEM | Move Multiple Registers | Registers $\rightarrow$ Destination (Source) $\rightarrow$ Registers | - | - | - | - | - |
| MOVEP | Move Peripheral Data | (Source) $\rightarrow$ Destination | - | - | - | - | - |

Table 7-2. Instruction Sheet (Sheet 2 of 2)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | Z | V | C |
| MOVEQ | Move Quick | Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MULS | Signed Multiply | (Destination) $\times$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MULU | Unsigned Multiply | (Destination) $\times$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| NBCD | Negate Decimal with Extend | $0-$ (Destination) $10-\mathrm{x} \rightarrow$ Destination | * | U | * | U | * |
| NEG | Negate | $0-$ (Destination) $\rightarrow$ Destination | * | * | * | * | * |
| NEGX | Negate with Extend | $0-$ (Destination) $-x \rightarrow$ Destination | * | * | * | * | * |
| NOP | No Operation | - | - | - | - | - | - |
| NOT | Logical Complement | $\sim$ (Destination) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| OR | Inclusive OR Logical | (Destination) $\vee$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ORI | Inclusive OR Immediate | (Destination) v Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| PEA | Push Effective Address | Destination $\rightarrow$ - (SP) | - | - | - | - | - |
| RESET | Reset External Devices | - | - | - | - | - | - |
| ROL, ROR | Rotate (Without Extend) | (Destination) Rotated by <count $>\rightarrow$ Destination | - | * | * | 0 | * |
| ROXL, ROXR | Rotate with Extend | (Destination) Rotated by $<$ count $>\rightarrow$ Destination | * | * | * | 0 | * |
| RTE | Return from Exception | $(S P)+\rightarrow S R ;(S P)+\rightarrow P C$ | * | * | * | * | * |
| RTR | Return and Restore Condition Codes | $(S P)+\rightarrow \mathrm{CC} ;(\mathrm{SP})+\rightarrow \mathrm{PC}$ | * | * | * | * | * |
| RTS | Return from Subroutine | $(\mathrm{SP})+\rightarrow \mathrm{PC}$ | - | - | - | - | - |
| SBCD | Subtract Decimal with Extend | (Destination) $10-$ (Source) $10-x \rightarrow$ Destination | * | U | * | U | * |
| SCC | Set According to Condition | If CC then 1's $\rightarrow$ Destination else 0's $\rightarrow$ Destination | - | - | - | - | - |
| STOP | Load Status Register and Stop | Immediate Data $\rightarrow$ SR; STOP | * | * | * | * | * |
| SUB | Subtract Binary | (Destination) - (Source) $\rightarrow$ Destination | * | * | * | * | * |
| SUBA | Subtract Address | (Destination) - (Source) $\rightarrow$ Destination | - | - | - | - | - |
| SUBI | Subtract Immediate | (Destination) - Immediate Data $\rightarrow$ Destination | * | * | * | * | * |
| SUBQ | Subtract Quick | (Destination) - Immediate Data $\rightarrow$ Destination | * | * | * | * | * |
| SUBX | Subtract with Extend | (Destination) - (Source) - $x \rightarrow$ Destination | * | * | * | * | * |
| SWAP | Swap Register Halves | Register [31:16] $\longleftrightarrow$ Register [15:0] | - | * | * | 0 | 0 |
| TAS | Test and Set an Operand | (Destination) Tested $\rightarrow$ CC; $1 \rightarrow$ [7] OF Destination | - | * | * | 0 | 0 |
| TRAP | Trap | $\mathrm{PC} \rightarrow$ - SSP); SR $\rightarrow$ - (SSP); (Vector) $\rightarrow$ PC | - | - | - | - | - |
| TRAPV | Trap on Overflow | If $V$ then TRAP | - | - | - | - | - |
| TST | Test an Operand | (Destination) Tested $\rightarrow$ CC | - | * | * | 0 | 0 |
| UNLK | Unlink | $\mathrm{An} \rightarrow \mathrm{SP} ;(\mathrm{SP})+\rightarrow \mathrm{An}$ | - | - | - | - | - |
|  |  | - logical exclusive OR <br> $\Lambda$ logical AND <br> $\checkmark$ logical OR <br> ~ logical complement | * affected <br> - unaffected <br> 0 cleared <br> 1 set <br> $\cup$ undefined |  |  |  |  |

### 7.1.2 Instruction Prefetch

The TS68008 uses a two-word tightly-coupled instruction prefetch mechanism to enhance performance. This mechanism is described in terms of the microcode operations involved. If the execution of an instruction is defined to begin when the microroutine for that instruction is entered, some features of the prefetch mechanism can be described.

1) When execution of an instruction begins, the operation word and the word following have already been fetched. The operation word is in the instruction decoder.
2) In the case of multiword instructions, as each additional word of the instruction is used internally, a fetch is made to the instruction stream to replace it.
3) The last fetch from the instruction stream is made when the operation word is discarded and decoding is started on the next instruction.
4) If the instruction is a single-word instruction causing a branch, the second word is not used. But because this word is fetched by the preceding instruction, it is impossible to avoid this superfluous fetch. In the case of an interrupt or trace exception, neither word is used.
5) The program counter usually points to the last word fetched from the instruction stream.

### 7.2 INSTRUCTION EXECUTION TIMES

The following paragraphs contain listings of the instruction execution times in terms of external clock (CLK) periods. In this timing data, it is assumed that both memory read and write cycle times are four clock periods. Any wait states caused by a longer memory cycle must be added to the total instruction time. The number of bus read and write cycles for each instruction is also included with the timing data. This data is enclosed in parenthesis following the execution periods and is shown as: $(r / w)$ where $r$ is the number of read cycles and $w$ is the number of write cycles. The number of periods includes instruction fetch and all applicable operand fetches and stores.

### 7.2.1 Operand Effective Address Calculation Times

Table 7-3 lists the number of clock periods required to compute an instruction's effective address. It includes fetching of any extension words, the address computation, and fetching of the memory operand. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). Note there are no write cycles involved in processing the effective address.

Table 7-3. Effective Address Calculation Times

| Addressing Mode |  | Byte | Word | Long |
| :---: | :---: | :---: | :---: | :---: |
| Dn An | Data Register Direct Register <br> Address Register Direct  | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ |
| (An) $\mid(A n)+$ |  Memory <br> Address Register Indirect  <br> Address Register Indirect with Postincrement  | $\begin{aligned} & 4(1 / 0) \\ & 4(1 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & 8(2 / 0) \\ & 8(2 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & 16(4 / 0) \\ & 16(4 / 0) \\ & \hline \end{aligned}$ |
| $\begin{aligned} & -(A n) \\ & d(A n) \end{aligned}$ | Address Register Indirect with Predecrement Address Register Indirect with Displacement | $\begin{array}{r} \hline 6(1 / 0) \\ 12(3 / 0) \end{array}$ | $\begin{aligned} & \hline 10(2 / 0) \\ & 16(4 / 0) \end{aligned}$ | $\begin{aligned} & \hline 18(4 / 0) \\ & 24(6 / 0) \end{aligned}$ |
| $\begin{aligned} & \mathrm{d}(\mathrm{An}, \mathrm{ix})^{*} \\ & \mathrm{xxx} . \mathrm{W} \end{aligned}$ | Address Register Indirect with Index Absolute Short | $\begin{aligned} & 14(3 / 0) \\ & 12(3 / 0) \end{aligned}$ | $\begin{aligned} & 18(4 / 0) \\ & 16(4 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & 26(6 / 0) \\ & 24(6 / 0) \end{aligned}$ |
| $\begin{aligned} & \mathrm{xxx} \times \mathrm{L} \\ & \mathrm{~d}(\mathrm{PC}) \end{aligned}$ | Absolute Long <br> Program Counter with Displacement | $\begin{aligned} & 20(5 / 0) \\ & 12(3 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 24(6 / 0) \\ & 16(4 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & 32(8 / 0) \\ & 24(6 / 0) \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \mathrm{d}(\mathrm{PC}, \mathrm{ix}) \\ & \# \times x x \end{aligned}$ | Program Counter with Index Immediate | $\begin{gathered} \hline 14(3 / 0) \\ 8(2 / 0) \end{gathered}$ | $\begin{array}{r} \hline 18(4 / 0) \\ 8(2 / 0) \\ \hline \end{array}$ | $\begin{aligned} & \hline 26(6 / 0) \\ & 16(4 / 0) \end{aligned}$ |

* The size of the index register (ix) does not affect execution time.


### 7.2.2 Move Instruction Execution Times

Tables 7-4, 7-5, and 7-6 indicate the number of clock periods for the move instruction. This data includes instruction fetch, operand reads, and operand writes. The number of bus read and write cycles is shown in parenthesis as: $(r / w)$.

Table 7-4. Move Byte Instruction Execution Times

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | (An) + | -(An) | d(An) | d(An, $)^{*}$ | xxx.W | xxx. 1 |
| Dn | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 20(4/1) | 22(4/1) | 2014/1) | 28(6/1) |
| An | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 20(4/1) | 22(4/1) | 2014/1) | 28(6/1) |
| (An) | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 24/5/1) | 26(5/1) | 24/5/11 | $32(7 / 1)$ |
| (An) + | 12(3/0) | 12(3/0) | 16(3/1) | 16/3/1) | 16(3/1) | 24(5/1) | 26(5/1) | 24(5/1) | $32(7 / 1)$ |
| - (An) | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 26(5/1) | 28(5/1) | 26(5/1) | 34(7/1) |
| d(An) | 20(5/0) | 2015/0) | 24(5/1) | 24(5/1) | 24/5/1) | 32(7/1) | 34(7/1) | 32(7/1) | 4019/1) |
| d(An, ix)* | 22(5/0) | 22(5/0) | 26(5/1) | 26(5/1) | 26(5/1) | 3417/1) | 36(7/1) | 3417/11 | 42(9/1) |
| xxx.W | 20(5/0) | 20(5/0) | 24/5/1) | 24(5/1) | 24/5/1) | 3217/1) | 34(7/1) | 32(7/1) | 40(9/1) |
| xxx.L. | 28(7/0) | 28(7/0) | 32(7/1) | 32(7/1) | 32(7/1) | 4019/1) | 42(9/1) | 4019/1) | 48(11/1) |
| d(PC) | 20(5/0) | 2015/0) | 24(5/1) | 24(5/1) | 24/5/1) | 32(7/1) | 34(7/1) | 3217/11 | 40(9/1) |
| d(PC, ix )* | 22(5/0) | 22(5/0) | 26(5/1) | 26(5/1) | 26(5/1) | 34(7/1) | 36(7/1) | 3417/11 | 42(9/1) |
| *xxx | 16/4/0) | 16(4/0) | 20(4/1) | 20(4/1) | 20(4/1) | 28(6/1) | 30(6/1) | 286/6/11 | 36/8/11 |

*The size of the index register (ix) does not affect execution time.

Table 7-5. Move Word Instruction Execution Times

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | $(A n)+$ | - (An) | d(An) | d(An, ix)* | xxx.W | xxx.L |
| Dn | 8(2/0) | 8(2/0) | 16(2/2) | 16(2/2) | 16(2/2) | 24(4/2) | 26(4/2) | 20(4/2) | 32(6/2) |
| An | 8(2/0) | $8(2 / 0)$ | 16(2/2) | 16(2/2) | 16(2/2) | 24(4/2) | 26(4/2) | 20(4/2) | 32(6/2) |
| (An) | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 32(6/2) | 34(6/2) | 32(6/2) | 40(8/2) |
| $\left(A_{n}\right)+$ | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 32(6/2) | -34(6/2) | 32(6/2) | 40(8/2) |
| - (An) | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 34(6/2) | 32(6/2) | 34(6/2) | 42(8/2) |
| d(An) | 24(6/0) | 24(6/0) | 32(6/2) | 32(6/2) | 32(6/2) | 40(8/2) | 42(8/2) | 40(8/2) | 48(10/2) |
| d(An, ix)* | 26(6/0) | 26(6/0) | 34(6/2) | 34(6/2) | 34(6/2) | 42(8/2) | 44(8/2) | 42(8/2) | 50(10/2) |
| $x \times x . W$ | 24(6/0) | 24(6/0) | 32(6/2) | $32(6 / 2)$ | 32(6/2) | 40(8/2) | 42(8/2) | 40(8/2) | 48(10/2) |
| $x \times x . L$ | 32(8/0) | 32(8/0) | 40(8/2) | 40(8/2) | 40(8/2) | 48(10/2) | 50(10/2) | 48(10/2) | 56(12/2) |
| d(PC) | 24(6/0) | 24(6/0) | 32(6/2) | 32(6/2) | 32(6/2) | 40(8/2) | 42(8/2) | 40(8/2) | 48(10/2) |
| d(PC, ix)* | 26(6/0) | 26(6/0) | 34(6/2) | 34(6/2) | 34(6/2) | 42(8/2) | 44(8/2) | 42(8/2) | 50(10/2) |
| \#xxx | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 32(6/2) | 34(6/2) | 32(6/2) | 40(8/2) |

* The size of the index register ( ix ) does not affect execution time.

Table 7-6. Move Long Instruction Execution Times

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | $(\mathrm{An})+$ | - (An) | d(An) | d(An, ix)* | xxx.W | xxx.L |
| Dn | 8(2/0) | 8(2/0) | 24(2/4) | 24(2/4) | 24(2/4) | 32(4/4) | 34(4/4) | 32(4/4) | 40(6/4) |
| An | 8(2/0) | 8(2/0) | 24(2/4) | 24(2/4) | 24(2/4) | 32(4/4) | 34(4/4) | 32(4/4) | 40(6/4) |
| (An) | 24(6/0) | 24(6/0) | 40(6/4) | 40(6/4) | 40(6/4) | 48(8/4) | 50(8/4) | 48(8/4) | 56(10/4) |
| $(A n)+$ | 24(6/0) | 24(6/0) | 40(6/4) | 40(6/4) | 40(6/4) | 48(8/4) | 50(8/4) | 48(8/4) | 56(10/4) |
| - (An) | 26(6/0) | 26(6/0) | 42(6/4) | 42(6/4) | 42(6/4) | 50(8/4) | 52(8/4) | 50(8/4) | 58(10/4) |
| $d(A n)$ | 32(8/0) | 32(8/0) | 48(8/4) | 48(8/4) | 48(8/4) | 56(10/4) | $58(10 / 4)$ | 56(10/4) | 64(12/4) |
| d(An, ix)* | 34(8/0) | 34(8/0) | 50(8/4) | 50(8/4) | 50(8/4) | 58(10/4) | 60(10/4) | 58(10/4) | 66(12/4) |
| xxx.W | $32(8 / 0)$ | 32(8/0) | 48(8/4) | 48(8/4) | 48(8/4) | 56(10/4) | 58(10/4) | 56(10/4) | 64(12/4) |
| $x \times x . L$ | 40(10/0) | 40(10/0) | 56(10/4) | 56(10/4) | 56(10/4) | 64(12/4) | 66(12/4) | 64(12/4) | 72(14/4) |
| d(PC) | 32(8/0) | 32(8/0) | 48(8/4) | 48(8/4) | 48(8/4) | 56(10/4) | 58(10/4) | 56(10/4) | 64(12/4) |
| $d(P C, i x)^{*}$ | 34(8/0) | 34(8/0) | 50(8/4) | 50(8/4) | 50(8/4) | 58(10/4) | 60(10/4) | 58(10/4) | 66(12/4) |
| \#xxx | 24(6/0) | 24(6/0) | 40(6/4) | 40(6/4) | 40(6/4) | 48(8/4) | 50(8/4) | 48(8/4) | 56(10/4) |

[^41]
### 7.2.3 Standard Instruction Execution Times

The number of clock periods shown in Table 7-7 indicates the time required to perform the operations, store the results, and read the next instruction. The number of bus read and write cycles is shown in parenthesis as: ( $r / w$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. In Table 7-7 the headings have the following meanings: $\mathrm{An}=$ address register operand, $\mathrm{Dn}=$ data register operand, ea $=$ an operand specified by an effective address, and $M=$ memory effective address operand.

Table 7-7. Standard Instruction Execution Times

| Instruction | Size | op <ea>, An | op <ea>, Dn | op Dn, <M> |
| :---: | :---: | :---: | :---: | :---: |
| ADD | Byte <br> Word <br> Long | $\begin{aligned} & \overline{-} \\ & 12(2 / 0)+ \\ & 10(2 / 0)+* * \end{aligned}$ | $\begin{gathered} 8(2 / 0)+ \\ 8(2 / 0)+ \\ 10(2 / 0)+* * \end{gathered}$ | $\begin{aligned} & \hline 12(2 / 1)+ \\ & 16(2 / 2)+ \\ & 24(2 / 4)+ \end{aligned}$ |
| AND | $\begin{aligned} & \text { Byte } \\ & \text { Word } \\ & \text { Long } \end{aligned}$ |  | $\begin{aligned} & \hline 8(2 / 0)+ \\ & 8(2 / 0)+ \\ & 10(2 / 0)+{ }^{* *} \end{aligned}$ | $\begin{aligned} & 12(2 / 1)+ \\ & 16(2 / 2)+ \\ & 24(2 / 4)+ \end{aligned}$ |
| CMP | $\begin{aligned} & \hline \text { Byte } \\ & \text { Word } \\ & \text { Long } \end{aligned}$ | $10(2 / 0)+$ $10(2 / 0)+$ | $\begin{array}{r} \hline 8(2 / 0)+ \\ 8(2 / 0)+ \\ 10(2 / 0)+ \\ \hline \end{array}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ |
| DIVS DIVU |  | - | $\begin{aligned} & 162(2 / 0)+{ }^{*} \\ & 144(2 / 0)+^{*} \end{aligned}$ | $\begin{aligned} & - \\ & - \end{aligned}$ |
| EOR | Byte <br> Word <br> Long |  | $\begin{array}{r} 8(2 / 0)+{ }^{* * *} \\ 8(2 / 0)+{ }^{* * *} \\ 12(2 / 0)+{ }^{* * *} \\ \hline \end{array}$ | $\begin{aligned} & 12(2 / 1)+ \\ & 16(2 / 2)+ \\ & 24(2 / 4)+ \\ & \hline \end{aligned}$ |
| MULS <br> MULU |  | - | $\begin{aligned} & 74(2 / 0)+{ }^{*} \\ & 74(2 / 0)+* \end{aligned}$ | $\begin{aligned} & - \\ & - \end{aligned}$ |
| OR | Byte Word Long | - | $\begin{gathered} \hline 8(2 / 0)+ \\ 8(2 / 0)+ \\ 10(2 / 0)+* * \\ \hline \end{gathered}$ | $\begin{aligned} & \hline 12(2 / 1)+ \\ & 16(2 / 2)+ \\ & 24(2 / 4)+ \\ & \hline \end{aligned}$ |
| SUB | Byte <br> Word <br> Long | $\begin{aligned} & 12(2 / 0)+ \\ & 10(2 / 0)+* * \end{aligned}$ | $\begin{gathered} \hline 8(2 / 0)+ \\ 8(2 / 0)+ \\ 10(2 / 0)+* * \end{gathered}$ | $\begin{aligned} & \hline 12(2 / 1)+ \\ & 16(2 / 2)+ \\ & 24(2 / 4)+ \end{aligned}$ |

NOTES:

+ Add effective address calculation time
* Indicates maximum value
*     * The base time of 10 clock periods is increased to 12 if the effective address mode is register direct or immediate (effective address time should also be added).
*     *         * Only available effective address mode is data register direct

DIVS. DIVU - The divide algorithm used by the TS68008 provides less than $10 \%$ difference between the best and worst case timings.
MULS, MULU - The multiply algorithm requires $42+2 n$ clocks where $n$ is defined as:
MULS: $n=\operatorname{tag}$ the <ea> with a zero as the MSB; $n$ is the resultant number of 10 or 01 patterns in the 17 -bit source, i.e., worst case happens when the source is $\$ 5555$.
MULU: $n=$ the number of ones in the <ea>

### 7.2.4 Immediate Instruction Execution Times

The number of clock periods shown in Table 7-8 includes the time to fetch immediate operands, perform the operations, store the results, and read the next operation. The number of bus read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. In Table 7-8, the headings have the following meanings: \# = immediate operand, $D n=$ data register operand, $A n=$ address register operand, and $M=$ memory operand.

Table 7-8. Immediate Instruction Clock Periods

| Instruction | Size | op\#, Dn | op\#, An | op\#, M |
| :---: | :---: | :---: | :---: | :---: |
| ADDI | Byte Word Long | 16(4/0) 16(4/0) <br> 28(6/0) | $\begin{aligned} & - \\ & \text { - } \end{aligned}$ | $\begin{aligned} & 20(4 / 1)+ \\ & 24(4 / 2)+ \\ & 40(6 / 4)+ \end{aligned}$ |
| ADDQ | Byte Word Long | $\begin{array}{r} \hline 8(2 / 0) \\ 8(2 / 0) \\ 12(2 / 0) \end{array}$ | $\begin{aligned} & 12(2 / 0) \\ & 12(2 / 0) \end{aligned}$ | 12(2/1) + $16(2 / 2)+$ $24(2 / 4)+$ |
| ANDI | Byte Word Long | 16(4/0) <br> 16(4/0) <br> 28(6/0) |  | $\begin{aligned} & 20(4 / 1)+ \\ & 24(4 / 2)+ \\ & 40(6 / 4)+ \end{aligned}$ |
| CMPI | Byte <br> Word <br> Long | $\begin{aligned} & \hline 16(4 / 0) \\ & 16(4 / 0) \\ & 26(6 / 0) \\ & \hline \end{aligned}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $16(4 / 0)+$ $16(4 / 0)+$ 24(6/0) + |
| EORI | Byte Word Long | 16(4/0) 16(4/0) 28(6/0) | - | $\begin{aligned} & 20(4 / 1)+ \\ & 24(4 / 2)+ \\ & 40(6 / 4)+ \end{aligned}$ |
| MOVEQ | Long | 8(2/0) | - | - |
| ORI | Byte Word Long | 16(4/0) 16(4/0) 28(6/0) | - | $\begin{aligned} & 20(4 / 1)+ \\ & 24(4 / 2)+ \\ & 40(6 / 4)+ \end{aligned}$ |
| SUBI | Byte <br> Word <br> Long | $\begin{aligned} & \hline 16(4 / 0) \\ & 16(4 / 0) \\ & 28(6 / 0) \end{aligned}$ | $\begin{aligned} & - \\ & \text { - } \end{aligned}$ | $\begin{aligned} & \hline 12(2 / 1)+ \\ & 16(2 / 2)+ \\ & 24(2 / 4)+ \end{aligned}$ |
| SUBQ | Byte <br> Word <br> Long | $\begin{gathered} \hline 8(2 / 0) \\ 8(2 / 0) \\ 12(2 / 0) \end{gathered}$ | $\begin{aligned} & 12(2 / 0) \\ & 12(2 / 0) \end{aligned}$ | $\begin{aligned} & 20(4 / 1)+ \\ & 24(4 / 2)+ \\ & 40(6 / 4)+ \end{aligned}$ |

+ add effective address calculation time


### 7.2.5 Single Operand Instruction Execution Times

Table 7-9 indicates the number of clock periods for the single operand instructions. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-9. Single Operand Instruction Execution Times

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| CLR | Byte | $8(2 / 0)$ | $12(2 / 1)+$ |
|  | Word | $8(2 / 0)$ | $16(2 / 2)+$ |
|  | Long | $10(2 / 0)$ | $24(2 / 4)+$ |
| NEG | Byte | $10(2 / 0)$ | $12(2 / 1)+$ |
|  | Byte | $8(2 / 0)$ | $12(2 / 1)+$ |
|  | Word | $8(2 / 0)$ | $16(2 / 2)+$ |
|  | Long | $10(2 / 0)$ | $24(2 / 4)+$ |
| NEGX | Byte | $8(2 / 0)$ | $12(2 / 1)+$ |
|  | Word | $8(2 / 0)$ | $16(2 / 2)+$ |
| NOT | Long | $10(2 / 0)$ | $24(2 / 4)+$ |
|  | Byte | $8(2 / 0)$ | $12(2 / 1)+$ |
|  | Word | $8(2 / 0)$ | $16(2 / 2)+$ |
| TAS | Long | $10(2 / 0)$ | $24(2 / 4)+$ |
| TSI | Byte, False | $8(2 / 0)$ | $12(2 / 1)+$ |
|  | Byte, True | $10(2 / 0)$ | $12(2 / 1)+$ |
|  | Byte | $8(2 / 0)$ | $14(2 / 1)+$ |
|  | Byte | $8(2 / 0)$ | $8(2 / 0)+$ |
|  | Word | $8(2 / 0)$ | $8(2 / 0)+$ |
|  | Long | $8(2 / 0)$ | $8(2 / 0)+$ |

+ add effective address calculation time.


### 7.2.6 Shift/Rotate Instruction Execution Times

Table 7-10 indicates the number of clock periods for the shift and rotate instructions. The number of bus read and write cycles is shown in parenthesis as: ( $r / w$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-10. Shift/Rotate Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| ASR, ASL | Byte | $10+2 n(2 / 0)$ | - |
|  | Word | $10+2 n(2 / 0)$ | $16(2 / 2)+$ |
| LSR, LSL | Long | $12+2 n(2 / 0)$ | - |
|  | Byte | $10+2 n(2 / 0)$ | - |
|  | Word | $10+2 n(2 / 0)$ | $16\left(22^{2}\right)+$ |
| ROR, ROL | Long | $12+2 n(2 / 0)$ | - |
|  | Byte | $10+2 n(2 / 0)$ | - |
|  | Word | $10+2 n(2 / 0)$ | $16(2: 2)+$ |
| ROXR, ROXL | Long | $12+2 n(2 / 0)$ | - |
|  | Byte | $10+2 n(2 / 0)$ | - |
|  | Word | $10+2 n(2 / 0)$ | $16(2 / 2)+$ |

+ add effective address calculation time
n is the shift count


### 7.2.7 Bit Manipulation Instruction Execution Times

Table 7-11 indicates the number of clock periods required for the bit manipulation instructions. The number of bus read and write cycles is shown in parenthesis as: $(r / w)$. The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 7-11. Bit Manipulation Instruction Execution Times

| Instruction | Size | Dynamic |  | Static |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Register | Memory | Register | Memory |
| BCHG | Byte <br> Long | $12(2 / 0)^{*}$ | $12(2 / 1)+$ | $2 \overline{-}$ | $20(4 / 11+$ |
| BCLR | Byte Long | $14(2 / 0) *$ | $12(2 / 1)+$ | $\frac{-}{22(4 / 0)}$ | $20(4 / 1)+$ |
| BSET | Byte Long | $12(2 / 0)^{*}$ | $12(2 / 1)+$ | $20(4 / 0)$ | $20(4 / 1)+$ |
| BTST | Byte Long | $10(2 / 0)$ | $8(2 / 0)+$ | $\overline{-}$ | $16(4 / 0)+$ |

+ add effective address calculation time
* indicates maximum value


### 7.2.8 Conditional Instruction Execution Times

Table 7-12 indicates the number of clock periods required for the conditional instructions. The number of bus read and write cycles is indicated in parenthesis as: ( $r / w$ ). The number of clock period's and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated

Table 7-12. Conditional Instruction Execution Times

| Instruction | Displacement | Trap or Branch <br> Taken | Trap or Branch <br> Not Taken |
| :--- | :---: | :---: | :---: |
| BCC | Brie | $18(4 / 0)$ | $12(2 / 0)$ <br> $20(4 / 0)$ |
|  | Word | $18(4 / 0)$ | - |
| BSR | Wrte | $18(4 / 0)$ | $18(4 / 0)$ |

+ add effective address calculation time
*indicates maximum value


### 7.2.9 JMP, JSR, LEA, PEA, and MOVEM Instruction Execution Times

Table 7-13 indicates the number of clock periods required for the jump, jump-to-subroutine, load ef fective address, push effective address, and move multiple registers instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w).

Table 7-13. JMP, JSR, LEA, PEA, and MOVEM Instruction Execution Times

| Instruction | Size | (An) | $(A n)+$ | - (An) | d(An) | $d(A n, i x) *$ | xxx.W | xxx.L | d(PC) | d(PC, ix)* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | - | 16(4/0) | - | - | 18(4/0) | 22(4/0) | 18/4/0) | 24(6/0) | 1814/0) | 22(4/0) |
| JSR | - | 32(4/4) | - | - | 34(4/4) | 38(4/4) | 34(4/4) | 40(6/4) | 34/4/4) | 38(4/4) |
| LEA | - | 8(2/0) | - | - | 16(4/0) | 2014/0) | 16/4/0) | 24(6/0) | 16(4/0) | 20(4/0) |
| PEA | - | 24/2;4) | - | - | $32(4 / 4)$ | 3614/4) | 32(4/4) | 4016/4) | 32(4/4) | 36(4/4) |
| MOVEM | Word | $\begin{array}{r} 24+8 n \\ (6+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{\|r\|} \hline 24+8 n \\ (6+2 n / 0) \\ \hline \end{array}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{array}{r} 32+8 n \\ (8+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{\|r\|} \hline 34+8 n \\ (8+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 32+8 n \\ (10+n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 40+8 n \\ 110+2 n / 01 \\ \hline \end{array}$ | $\begin{array}{r} 32+8 n \\ (8+2 n / 0) \end{array}$ | $\begin{array}{\|r\|} \hline 34+8 n \\ (8+2 n / 0) \\ \hline \end{array}$ |
| $M \rightarrow R$ | Long | $\begin{array}{r} 24+16 n \\ (6+4 n / 0) \end{array}$ | $\begin{array}{r} 24+16 n \\ \left(6+4 n^{\prime} 0\right) \end{array}$ |  | $\begin{array}{r} 32+16 n \\ (8+4 n / 0) \end{array}$ | $\begin{array}{\|r\|} \hline 34+16 n \\ 18+4 n / 01 \\ \hline \end{array}$ | $\begin{array}{r} 32+16 n \\ 18+4 n / 01 \\ \hline \end{array}$ | $\begin{gathered} 40+16 n \\ (8+4 n / 0) \end{gathered}$ | $\begin{array}{r} 32+16 n \\ (8+4 n / 0) \end{array}$ | $\begin{array}{\|c\|} \hline 34+16 n \\ (8+4 n / 0) \end{array}$ |
| MOVEM | Word | $\begin{aligned} & 16+8 n \\ & (4.2 n) \end{aligned}$ |  | $\begin{gathered} 16+8 n \\ (4: 2 n) \end{gathered}$ | $\begin{gathered} 24+8 n \\ (6 / 2 n) \end{gathered}$ | $\begin{gathered} 26+8 n \\ (6 / 2 n) \end{gathered}$ | $\begin{gathered} 24+8 n \\ (6 / 2 n) \end{gathered}$ | $\begin{gathered} 32+8 n \\ (8 / 2 n) \end{gathered}$ |  |  |
| $R \rightarrow M$ | long | $\begin{gathered} 16+16 n \\ (44 n) \end{gathered}$ |  | $\begin{array}{r} 16+16 n \\ (4,4 n) \end{array}$ | $\begin{array}{r} 24+16 n \\ (6 / 4 n) \end{array}$ | $\begin{array}{r} 26+16 n \\ (6 / 4 n) \end{array}$ | $\begin{array}{r} 24+16 n \\ (8 / 4 n) \end{array}$ | $\begin{array}{r} 32+16 n \\ (6 / 4 n) \end{array}$ |  |  |

[^42]
### 7.2.10 Multi-Precision Instruction Execution Times

Table 7-14 indicates the number of clock periods for the multi-precision instructions. The number of clock periods includes the time to fetch both operands, perform the operations, store the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as: (r/w).

In Table 7-14, the headings have the following meanings: $\mathrm{Dn}=$ data register operand and $M=$ memory operand.

Table 7-14. Multi-Precision Instruction Execution Times

| Instruction | Size | op Dn, Dn | op M, M |
| :--- | :---: | :---: | :---: |
| ADDX | Byte | $8(2 / 0)$ | $22(4 / 1)$ |
|  | Word | $8(2 / 0)$ | $50(6 / 2)$ |
|  | Long | $12(2 / 0)$ | $58(10 / 4)$ |
| CMPM | Byte | - | $16(4 / 0)$ |
|  | Word | - | $24(6 / 0)$ |
|  | Long | - | $40(10 / 0)$ |
| SUBX | Byte | $8(2 / 0)$ | $22(4 / 1)$ |
|  | Word | $8(2 / 0)$ | $50(6 / 2)$ |
|  | Long | $12(2 / 0)$ | $58(10 / 4)$ |
| SBCD | Byte | $10(2 / 0)$ | $20(4 / 1)$ |

### 7.2.11 Miscellaneous Instruction Execution Times

Tables 7-15 and 7-16 indicate the number of clock periods for the following miscellaneous instructions. The number of bus read and write cycles is shown in parenthesis as: ( $r / w$ ). The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

### 7.2.12 Exception Processing Execution Times

Table 7-17 indicates the number of clock periods for exception processing. The number of clock periods includes the time for all stacking, the vector fetch, and the fetch of the first instruction of the handler routine. The number of bus read and write cycles is shown in parenthesis as: (r/w).

Table 7-15. Miscellaneous Instruction Execution Times

| Instruction | Register | Memory |
| :---: | :---: | :---: |
| ANDI to CCR | 321601 |  |
| ANDI to SR | 321601 | . |
| EORI 10 CCR | $32(60)$ |  |
| EOR1 10 SR | 321601 |  |
| EXG | 10(2.0) | - |
| EXT | 81201 |  |
| LINK | 321441 | $\checkmark$ |
| MOVE to CCR | $18140)$ | $18,401+$ |
| MOVE to SR | $18140)$ | $18.401+$ |
| MOVE from SR | 101201 | $16122^{1}+$ |
| MOVE to USP | $812.0)$ | . |
| MOVE from USP | 812.01 | - |
| NOP | 81201 | - |
| ORI to CCR | 321601 | , |
| ORI to SR | 3216/01 | - |
| RESET | 136(2;0) | $\cdots$ |
| RTE | 40(10.0) | $-$ |
| RTR | 40(10/0) | - |
| RTS | 32(8;0) | - |
| STOP | 410/0) | - |
| SWAP | 812/0) | - |
| UNLK | 24(6/0) | -- |

+ add effective address calculation time

Table 7-16. Move Peripheral Instruction Execution Times

| Instruction | Size | Register $\rightarrow$ Memory | Memory $\rightarrow$ Register |
| :---: | :---: | :---: | :---: |
| MOVEP | Word | $24(4 / 2)$ | $24(6.0)$ |
|  | Long | $32(4 / 4)$ | $32(8.0)$ |

+ add effective address calculation time

Table 7-17. Exception Processing Execution Times

| Exception | Periods |
| :--- | :---: |
| Address Error | $94(8 / 14)$ |
| Bus Error | $94(8 / 14)$ |
| CHK Instruction | $68(8 / 6)+$ |
| Interrupt | $72(9 / 16)$ |
| Illegal Instruction | $62(8 / 6)$ |
| Privileged Instruction | $62(8 / 6)$ |
| Trace | $62(8 / 6)$ |
| TRAP Instruction | $62(8 / 6)$ |
| TRAPV Instruction | $\mathbf{6 6 ( 1 0 / 6 )}$ |
| Divide by Zero | $\mathbf{6 6 ( 8 / 6 ) +}$ |
| RESET * | $\mathbf{6 4 ( 1 2 / 0 )}$ |

+ add effective address calculation time
* The interrupt acknowledge bus cycle is assumed to take four external clock periods
* Indicates the time from when $\overline{R E S E T}$ and $\overline{H A L T}$ are first sampled as negated to when instruction execution starts.


## SECTION 8 <br> ELECTRICAL SPECIFICATIONS

This section contains the electrical specifications and associated timing information for the MC68008.

### 8.1 MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +70 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +70 | ${ }^{\circ}$ |
| Operating Temperature Range | $\mathrm{T}^{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| TS68008C |  | 0 to 70 |  |
| TS68008V |  | -40 to 85 |  |
| Storage Temperature | $\mathrm{T}_{\text {Stg }}$ | -55 to 150 | ${ }^{\circ} \mathrm{C}$ |

This device contains circuitry to protect the inputs against damage due to high statio voltages or electric tields, however, it is ad vised that normal precautions be taken to avoid application of any voltages higher than maximum-rated voltages to this high. impedance circuit Reliability of operation is enhanced if unused inputs are tied to an ap propriate logic voltage level le g, either ground or $\mathrm{V}_{\mathrm{CC}}$ l

### 8.2 THERMAL CHARACTERISTICS

| Characteristic | Value |  |  |
| :--- | :---: | :---: | :---: |
|  | $\theta$ JA | $\theta$ JC |  |
| Thermal Resistance |  |  |  |
| Ceramic DIL. | 40 | $15^{*}$ |  |
| Plastic DIL | 40 | $20^{*}$ | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| PLCC | 50 | $30^{*}$ |  |

* Estimated


### 8.3 POWER CONSIDERATIONS

The average chip-junction temperature, $\mathrm{T}_{\mathrm{J}}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T J=T A+(P D \bullet \theta J A) \tag{1}
\end{equation*}
$$

Where:
$T_{A}=$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta$ JA $=$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
PD $=\mathrm{PINT}^{2}+\mathrm{P}_{\mathrm{I}} / \mathrm{O}$
PINT $=I_{C C} \times$ VCC, Watts - Chip Internal Power
$\mathrm{P}_{\mathrm{I} / \mathrm{O}}=$ Power Dissipation on Input and Output Pins - User Determined
For most applications PI/O<PINT and can be neglected.
An approximate relationship between PD and TJ (if $\mathrm{PI} / \mathrm{O}$ is neglected) is:

$$
\begin{equation*}
P D=K \div\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \bullet P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P_{D}$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of TA.

The curve shown in Figure 8-1 gives the graphic solution to these equations for the specification power dissipation of 1.50 watts over the ambient temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ using a $\theta J \mathrm{~A}$ of $45^{\circ} \mathrm{C} / \mathrm{W}$, a typical value for packages specified.


Figure 8-1. TS68008 Power Dissipation (PD) vs Ambient Temperature (TA)

The total thermal resistance of a package ( $\theta \mathrm{JA}$ ) can be separated into two components, $\theta \mathrm{JC}$ and $\theta$ CA, representing the barrier to heat flow from the semiconductor junction to the package (case) surface $(\theta J C)$ and from the case to the outside ambient ( $\theta$ CA) . These terms are related by the equation:

$$
\begin{equation*}
\theta J A=\theta J C+\theta C A \tag{4}
\end{equation*}
$$

$\theta \mathrm{JC}$ is device related and cannot be influenced by the user. However, $\theta \mathrm{CA}$ is user dependent and can be minimized by such thermal management techniques as heat sinks, ambient air cooling and thermal convention. Thus good thermal management on the part of the user can significantly reduce $\theta$ CA so that $\theta J A=\theta J C$. Substitution of $\theta J C$ for $\theta J A$ in equation 1 will result in a lower semiconductor junction temperature.

### 8.4 DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V} C \mathrm{C}=5.0 \mathrm{Vdc} \pm 5 \% ; \mathrm{GND}=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$; see Figures $8-2,8-3$, and 8-4)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 20 | $V_{\text {CC }}$ | $\checkmark$ |
| Input Low Voltage | $V_{\text {IL }}$ | GND-03 | 0.8 | V |
| Input Leakage Current @ 5.25 V <br> $\overline{B E R R}, \overline{B R}, \overline{D T A C K}, C L K, \overline{I P L O} / \overline{2}, \overline{I P L 1}, \overline{V P A}, \overline{H A L T}, \overline{R E S E T}, \overline{B G A C K}$ | $1{ }_{\text {in }}$ | - | 20 | $\mu \mathrm{A}$ |
| HI.Z (Off State) Input Current @ $24 \mathrm{~V} / 0.4 \mathrm{~V}$ A0-A19, $\overline{\mathrm{AS}}, ~ D 0 ~ D 7, ~ F C 0 \cdot F C 2, \overline{D S}, R / \bar{W}$ | ITSI | -- | 20 | $\mu \mathrm{A}$ |
| Output High Voltage $(1 \mathrm{OH}=-400 \mu \mathrm{~A}) \quad$ E, AO.A19, AS, BG, DO-D7, FCO.FC2. | $\mathrm{V}_{\mathrm{OH}}$ | 24 | - | V |
| Output Low Voltage $\begin{array}{lr} \left({ }^{(O L}=16 \mathrm{~mA}\right) & \overline{\mathrm{HALT}} \\ \left.{ }^{(1 \mathrm{OL}}=32 \mathrm{~mA}\right) & \mathrm{AO} \cdot \mathrm{~A} 19, \overline{\mathrm{BG}}, \mathrm{FCO}-\mathrm{FC} 2 \\ (\mathrm{IOL}=50 \mathrm{~mA}) & \mathrm{E}, \overline{\mathrm{AS}}, \mathrm{DO}-\mathrm{D} 7, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}} \\ \left.{ }^{(1 \mathrm{OL}}=53 \mathrm{~mA}\right) & \end{array}$ | $\mathrm{V}_{\text {OL }}$ | - | $\begin{aligned} & 05 \\ & 0.5 \\ & 0.5 \\ & 05 \end{aligned}$ | V |
| Power Dissipation.* ${ }^{\text {T }}$ A $=0^{\circ} \mathrm{C}$ | $\mathrm{PD}_{\text {D }}$ | - | 1.5 | W |
| Capacitance ( $\mathrm{V}_{\text {in }}=0 \mathrm{~V}, \top_{A}=25^{\circ} \mathrm{C}$. Frequency $\left.=1 \mathrm{MHz}\right)^{* *}$ | $\mathrm{C}_{\text {in }}$ | - | 200 | pF |

* During normal operation instantaneous $V_{C C}$ current requirements may be as high as 15 A
* *Capacitance is periodically sampled rather than $100 \%$ tested.


Figure 8-2. $\overline{\text { RESET }}$ Test Load
Figure 8-3. $\overline{\text { HALT }}$ Test Load


Figure 8-4. Test Loads

### 8.5 CLOCK TIMING (See Figure 8-5)

| Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $f$ | 2.0 | 8.0 | 2.0 | 10.0 | 4.0 | 12.5 | MHz |
| Cycle Time | $\mathrm{t}_{\text {cyc }}$ | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| Clock Pulse Width | $\begin{aligned} & { }^{\mathrm{t}} \mathrm{CL} \\ & { }^{\mathrm{t}} \mathrm{CH} \end{aligned}$ | $\begin{aligned} & 55 \\ & 55 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ | $\begin{aligned} & 125 \\ & 125 \end{aligned}$ | ns |
| Rise and Fall Times | $\begin{aligned} & { }^{\mathrm{t}} \mathrm{Cr} \\ & { }^{\mathrm{t}} \mathrm{~F} \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | 10 10 | - | 5 | ns |



Figure 8-5. Input Clock Waveform

### 8.6 AC ELECTRICAL SPECIFICATIONS - READ CYCLES

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \% ; G N D=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; see Figure 8-6)

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Clock Period | ${ }^{\text {t }} \mathrm{CYC}$ | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| 2 | Clock Width Low | ${ }^{\text {t }} \mathrm{CL}$ | 55 | 250 | 45 | 250 | 35 | 125 | ns |
| 3 | Clock Width High | ${ }^{\text {t }} \mathrm{CH}$ | 55 | 250 | 45 | 250 | 35 | 125 | ns |
| 4 | Clock Fall Time | ${ }^{\text {t }} \mathrm{Ct}$ | - | 10 | - | 10 | - | 5 | ns |
| 5 | Clock Rise Time | ${ }^{\mathrm{t}} \mathrm{Cr}$ | - | 10 | - | 10 | - | 5 | ns |
| 6 | Clock Low to Address Valid | ${ }^{\text {t }}$ CLAV | - | 70 | - | 60 | - | 55 | ns |
| 6A | Clock High to FC Valid | ${ }^{\text {t }}$ CHFCV | - | 70 | - | 60 | - | 55 | Ns |
| 7 | Clock High to Address, Data Bus High Impedance (Maximum) | ${ }^{\text {t }}$ CHADZ | - | 80 | - | 70 | - | 60 | ns |
| 8 | Clock High to Address, FC Invalid (Minimum) | ${ }^{\text {t }} \mathrm{CHAFI}$ | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ CHSL | 0 | 60 | 0 | 55 | 0 | 55 | ns |
| $11^{2}$ | Address Valid to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ AVSL | 30 | - | 20 | - | 0 | - | ns |
| $11 \mathrm{~A}^{2,6}$ | FC Valid to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ FCVSL | 60 | - | 50 | - | 40 | - | ns |
| $12^{1}$ | Clock Low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High | ${ }^{\text {t }} \mathrm{CLSH}$ | - | 35 | - | 35 | - | 35 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Address/FC Invalid | ${ }^{\text {t }}$ SHARI | 30 | - | 20 | - | 10 | - | ns |
| $14^{2,5}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width Low | ${ }^{\text {t }}$ SL | 270 | - | 195 | - | 160 | - | ns |
| $15^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width High | ${ }^{\text {t }} \mathrm{SH}$ | 150 | - | 105 | - | 65 | - | ns |
| $17^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to R/W High | ${ }^{\text {t }}$ SHRH | 40 | - | 20 | - | 10 | - | ns |
| 181 | Clock High to R/W High | ${ }^{\text {t }} \mathrm{CHRH}$ | 0 | 40 | 0 | 40 | 0 | 40 | ns |
| $27^{5}$ | Data In to Clock Low (Setup Time) | ${ }^{\text {D }}$ IICL | 15 | - | 10 | - | 10 | - | ns |
| $28^{2,5}$ | $\overline{\text { AS }}, \overline{\mathrm{DS}}$ High to $\overline{\text { DTACK }}$ High | ${ }^{\text {t }}$ SHDAH | 0 | 245 | 0 | 190 | 0 | 150 | ns |
| 29 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data In Invalid (Hold Time) | ${ }^{\text {t }}$ SHDII | 0 | - | 0 | - | 0 | - | ns |
| 30 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{BERR}}$ High | ${ }^{\text {t }}$ SHBEH | 0 | - | 0 | - | 0 | - | ns |
| 312.5 | $\overline{\text { DTACK }}$ Low to Data Valid (Asynchronous Setup Time on Read) | ${ }^{\text {' DALD }}$ | - | 90 | - | 65 | - | 50 | ns |
| 32 | $\overline{\text { HALT }}$ and $\overline{\text { RESET }}$ Input Transition Time | ${ }^{\text {tr }}$, ${ }^{\text {r }}$, f | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| $47^{5}$ | Asynchronous Input Setup Time | 'ASI | 10 | - | 10 | - | 10 | - | ns |
| $48^{3}$ | $\overline{\text { BERR }}$ Low to DTACK Low | ${ }^{\text {t }}$ BELDAL | 20 | - | 20 | - | 20 | - | ns |
| $56^{4}$ | $\overline{\text { HALT / }} \overline{\text { RESET }}$ Pulse Width | tHRPW | 10 | - | 10 | - | 10 | - | Clk.Per. |

## NOTES :

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the values given in these columns.
2. Actual value depends on clock period.
3. If 47 is satisfied for both $\overline{\text { DTACK }}$ and $\overline{B E R R}, 48$ may be 0 nanoseconds.
4. For power up the MPU must be held in RESET state for 100 milliseconds to allow stabilization of on-chip circuitry. After the system is powered up, 56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (47) requirements are satisfied, the $\overline{\mathrm{DTACK}}$ low-to-data setup time (31) requirement can be ignored. The data must only satisfy the data-in to clock-low setup time (27) for the following cycle.
6. Setup time to guarantee recognition on next falling edge of clock.

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals Refer to other functional descriptions and their related diagrams for device operation


## NOTES

1 Setup time for the asynchronous inputs $\overline{P L O 2}, ~ \overline{P L 1}$, and $\overline{V P A}$ guarantees their recognition at the next talling tedget of the tock
$2 \overline{B R}$ need fall at this time only in order to insure being recognized at the end of this bus cucte
3 Timing measurements are referenced to and from a !ow voltage of 08 volt and a high voltar, of 20 wolts. unless otherwise noted
Figure 8-6. Read Cycle Timing Diagram

### 8.6 AC ELECTRICAL SPECIFICATIONS - WRITE CYCLES

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \% ; G N D=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; see Figure 8-7)

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Clock Period | ${ }^{\text {t }} \mathrm{CYC}$ | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| 2 | Clock Width Low | ${ }^{\text {t }} \mathrm{CL}$ | 55 | 250 | 45 | 250 | 35 | 125 | ns |
| 3 | Clock Width High | ${ }^{\text {t }} \mathrm{CH}$ | 55 | 250 | 45 | 250 | 35 | 125 | ns |
| 4 | Clock Fall Time | ${ }^{\text {t }} \mathrm{Ct}$ | - | 10 | - | 10 | - | 5 | ns |
| 5 | Clock Rise Time | ${ }^{t} \mathrm{Cr}$ | - | 10 | - | 10 | - | 5 | ns |
| 6 | Clock Low to Address Valid | ${ }^{\text {t }}$ CLAV | - | 70 | - | 60 | - | 55 | ns |
| 6 A | Clock High to FC Valid | ${ }^{\text {t }}$ CHFCV | - | 70 | - | 60 | - | 55 | Ns |
| 7 | Clock High to Address, Data Bus High Impedance (Maximum) | ${ }^{\text {t }}$ CHADZ | - | 80 | - | 70 | - | 60 | ns |
| 8 | Clock High to Address, FC Invalid (Minimum) | ${ }^{\text { }}$ CHAFI | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low | ${ }^{\text {t }}$ CHSL | 0 | 60 | 0 | 55 | 0 | 55 | ns |
| $11^{2}$ | Address Valid to $\overline{\mathrm{AS}}$ Low | ${ }^{\text {t }}$ +VSL | 30 | - | 20 | - | 0 | - | ns |
| $11 \mathrm{~A}^{2.7}$ | FC Valid to $\overline{\mathrm{AS}}$ Low | ${ }^{\text {t }}$ FCVSL | 60 | - | 50 | - | 40 | - | ns |
| $12^{1}$ | Clock Low to $\overline{\text { AS }}, \overline{\mathrm{DS}}$ High | ${ }^{\text {t }}$ CLSH | - | 35 | - | 35. | - | 35 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Address/FC Invalid | ${ }^{\text {t }}$ SHARI | 30 | - | 20 | - | 10 | - | ns |
| $14^{2.5}$ | $\overline{\text { AS Low }}$ | ${ }^{\text {'SL }}$ | 270 | - | 195 | - | 160 | - | ns |
| $14 \mathrm{~A}^{2}$ | $\overline{\text { DS Width Low }}$ | ${ }^{\text {' DSL }}$ | 140 | - | 95 | - | 80 | - | ns |
| $15^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width High | ${ }^{\text {t }}$ SH | 150 | - | 105 | - | 65 | - | ns |
| $18^{1}$ | Clock High to R/W High | ${ }^{\text {t }} \mathrm{CHRH}$ | 0 | 40 | 0 | 40 | 0 | 40 | ns |
| $20^{1}$ | Clock High to R/W Low | ${ }^{\text {t }}$ CHRL | - | 40 | - | 40 | - | 40 | ns |
| $20 A^{6}$ | $\overline{\mathrm{AS}}$, Low to R/W valid | ${ }^{\text {t }}$ ASRV | - | 20 | - | 20 | - | 20 | ns |
| $21^{2}$ | Address Valid to R/W Low | ${ }^{\text {t }}$ AVRL | 20 | - | 0 | - | 0 | - | ns |
| $21 \mathrm{~A}^{2.7}$ | FC Valid to R/W Low | ${ }^{\text {t }}$ FCVRL | 60 | - | 50 | - | 30 | - | ns |
| $22^{2}$ | R/W Low to $\overline{\text { DS }}$ Low | tRLSL | 80 | - | 50 | - | 30 | - | ns |
| 23 | Clock Low to Data Out Valid | ${ }^{\text {t }}$ CLDO | - | 70 | - | 55 | - | 55 | ns |
| $25^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Data Out Invalid | ${ }^{\text {t }}$ SHDOI | 50 | - | 20 | - | 20 | - | ns |
| $26^{2}$ | Data Out Valid to $\overline{\text { DS }}$ Low | ${ }^{\text {t DOSL }}$ | 35 | - | 20 | - | 20 | - | ns |
| 282.5 | $\overline{\text { AS, }} \overline{\text { DS }}$ High to DTACK High | ${ }^{\text {T }}$ SHDAH | 0 | 245 | 0 | 190 | 0 | 150 | ns |
| 30 | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{BERR}}$ High | ${ }^{\text {t }}$ SHBEH | 0 | - | 0 | - | 0 | - | ns |
| 32 | $\overline{\text { HALT }}$ and $\overline{\text { RESET }}$ Input Transition Time | ${ }^{\text {tRHr }}$, ${ }^{\text {c }}$ | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| 475 | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 10 | - | 10 | - | 10 | - | Ns |
| $48^{3}$ | BERR Low to DTACK Low | tBELDAL | 20 | - | 20 | - | 20 | - | ns |
| 53 | Clock High to Data Out Invalid | ${ }^{\text {t }} \mathrm{CHDOI}$ | 0 | - | 0 | - | 0 | - | ns |
| 55 | R/W to Data Bus Impedance Driven | tRLDBD | 30 | - | 20 | - | 10 | - | ns |
| $56^{4}$ | HALT / RESET Pulse Width | tHRPW | 10 | - | 10 | - | 10 | - | Clk.Per. |

## NOTES :

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the values given in these columns.
2. Actual value depends on clock period
3. If 47 is safisfied for both DTACK and $\overline{B E R R}, 48$ may be 0 nanoseconds.
4. For power up the MPU must be held in RESET state for 100 milliseconds to allow stabilization of on-chip circuitry. After the system is powered up 56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (47) requirements are satisfied, the $\overline{\text { DTACK }}$ low-to-data setup time (31) requirement can be ignored. The data must only satisfy the data-in to clock-low setup time (27) for the following cycle.
6. When $\overline{\mathrm{AS}}$, and $\mathrm{R} / \mathrm{W}$ are equally haded ( $\pm 20 \%$ ), subtract 10 nanoseconds from the values in these columns.
7. Setup time to guarantee recognition on next falling edge of clock.

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation


Figure 8-7. Write Cycle Timing Diagram

### 8.7 AC ELECTRICAL SPECIFICATIONS - TS 68008 to 6800 PERIPHERAL

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \% ; \mathrm{GND}=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.$ to $70^{\circ} \mathrm{C}$; see Figures $8-8$ and $8-9$ )


## NOTES :

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the values given in these columns.
2. Actual value depends on clock period.
3. The falling edge of S 6 triggers both the negation of the strobes ( $\overline{\mathrm{AS}}$, and $\times \overline{\mathrm{DS}}$ ) and the falling edge of E . Either of these events can occur first, depending upon the loading on each signal. Specification 49 indicates the absolute maximum skew that will occur between the rising edge of the strobes and the falling edge of the Eclock.


Figure 8-8. TS68008 to $\mathbf{6 8 0 0}$ Peripheral Timing Diagram - Best Case


NOTE: This timing diagram is included for those who wish to design their own circuit to generate $\overline{\mathrm{VMA}}$. It shows the worst case possibly attanable.
Figure 8-9. TS68008 to 6800 Peripheral Timing Diagram - Worst Case

### 8.8 AC ELECTRICAL SPECIFICATIONS - BUS ARBITRATION

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \% ; G N D=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$; see Figures 8-10, 8-11, and 8-12)

| Num. | Characteristic | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 7 | Clock High to Address, Data Bus High Impedance | ${ }^{\text {t }}$ +HADZ | - | 80 | - | 70 | - | 60 | ns |
| 16 | Clock High to Control Bus High Impedance | ${ }^{\text {t }} \mathrm{CHCZ}$ | - | 80 | - | 70 | - | 60 | ns |
| 33 | Clock High to $\overline{\mathrm{BG}}$ Low | ${ }^{\text {t }} \mathrm{CHGL}$ | - | 40 | - | 40 | - | 40 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | ${ }^{\text {t }} \mathrm{CHGH}{ }^{\text {\% }}$ | - | 40 | - | 40 | - | 40 | ns |
| 35 | $\overline{\mathrm{BR}}$, Low to $\overline{\mathrm{BG}}$ Low | ${ }^{\text {t BRLGL }}$ | 1.5 | $\begin{gathered} 90 \mathrm{~ns} \\ +3.5 \end{gathered}$ | 1.5 | $\begin{aligned} & 80 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | 1.5 | $\begin{aligned} & 80 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | Clk.Per. |
| $36^{1}$ | $\overline{\mathrm{BR}}$ High to $\overline{\mathrm{BG}}$ High | tBRHGH | 1.5 | $\begin{array}{r} 90 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{aligned} & 80 \mathrm{~ns} \\ & +3.5 \end{aligned}$ | 1.5 | $\begin{array}{\|r\|} \hline 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | Clk. Per. |
| 37 | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BG}}$ High (52-Pin Version Only) | ${ }^{\text {t }}$ GALGH | 1.5 | $\begin{array}{r} 90 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{\|l\|} \hline 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | 1.5 | $\begin{array}{r} 80 \mathrm{~ns} \\ +3.5 \\ \hline \end{array}$ | Clk.Per. |
| $37 A^{2}$ | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BR}}$ High (52-Pin Version Only) | ${ }^{\text {t }}$ GALBRH | 20 | $\begin{array}{\|c\|} \hline 1.5 \\ \text { Clocks } \\ \hline \end{array}$ | 20 | $\begin{gathered} 1.5 \\ \text { Clocks } \end{gathered}$ | 20 | $\begin{gathered} 1.5 \\ \text { Clocks } \end{gathered}$ | ns |
| 38 | $\overline{\mathrm{BG}}$ Low to Control, Address, Data Bus High Impedance ( $\overline{\mathrm{AS}}$ High) | ${ }^{\text {t }}$ LIZ | - | 80 | - | 70 | - | 60 | ns |
| 39 | $\overline{\mathrm{BG}}$ Width High | ${ }^{\text {t }} \mathrm{GH}$ | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| 46 | $\overline{\text { BGACK }}$ Width Low (52-Pin Version Only) | ${ }^{\text {t }}$ GAL | 1.5 | - | 1.5 | - | 1.5 | - | Clk.Per. |
| 47 | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 10 | - | 10 | - | 10 | - | ns |
| 57 | BGACK High to Control Bus Driven (52-Pin Version Only) | ${ }^{\text {t }}$ GABD | 1.5 | - | 1.5 | - | 1.5 | - | Cik.Per. |
| $58^{1}$ | BG High to Control Bus Driven | ${ }^{\text {t }}$ GHBD | 1.5 | - | $1.5{ }^{\circ}$ | - | 1.5 | - | Clk.Per. |

## NOTES :

1. For processor will negate $\overline{\mathrm{BG}}$ and begin driving the bus again if external arbitration logic negates $\overline{\mathrm{BR}}$ before asserting $\overline{\mathrm{BGACK}}$.
2. The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, $\overline{B G}$ may be reasserted.

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals Refer to other functional descriptions and their related diagrams for device operation


NOTE

1. 52-Pin Version of TS68008 Only.

Figure 8-10. Bus Arbitration Timing - Idie Bus Case

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation.


Figure 8-11. Bus Arbitration Timing - Active Bus Case

These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation.


NOTE

1. 52-Pin Version of TS68008 Only.

Figure 8-12. Bus Arbitration Timing - Multiple Bus Requests (52-Pin Version Only)

## SECTION 9 <br> ORDERING INFORMATION

This section contains detailed information to be used as a guide when ordering the TS 680008

### 9.1. STANDARD VERSIONS

| Package Type | Frequency <br> (MHz) | Temperature <br> Range | Part Number |
| :---: | :---: | :---: | :---: |
| Ceramic DIL | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS $68008 \mathrm{CC8}$ |
| C Suffix | 8.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VC8}$ |
|  | 10.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS 68008 CC 10 |
|  | 10.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VC10}$ |
|  | 12.5 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VC12}$ |
| Plastic DIL | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS $68008 \mathrm{CP8}$ |
| P. Suffix | 8.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VP8}$ |
|  | 10.0 | $-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS $68008 \mathrm{CP10}$ |
|  | 10.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VP10}$ |
|  | 12.5 | $-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS $68008 \mathrm{CP12}$ |
| PLCC | 8.0 | $-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS $68008 \mathrm{CFN8}$ |
| FN Suffix |  |  |  |

### 9.2. HI-REL VERSIONS

In order to fit more closely to customer specific requirements, THOMSON SEMICONDUCTEURS is proposing different screening levels for its HI-REL ranges.
G/B screening : Available only from THOMSON SEMICONDUCTEURS, this quality level, very close to the MIL-STD-883, is a cost effective alternative for customers who want to buy HI-REL devices (low guaranteed AQL). The G/B level is in full accordance with the NFC 96883 class G.

B/B screening: Full accordance with the MIL-STD-883 Rev.C, class B (US), the CECC 90.000 , class B (European) and with the NFC 96883 class B (French).

Details on screening procedures for these levels of selection are available on request (please contact ou sales representatives).

| Package Type | Frequency <br> (MHz) | Temperature <br> Range | Part Number |
| :---: | :---: | :---: | :---: |
| Ceramic DIL | 8.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VCG} / \mathrm{B} 8$ |
| C Suffix | 10.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VCG} / \mathrm{B} 10$ |
|  | 12.5 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS $68008 \mathrm{VCG} / \mathrm{B} 12$ |

## SECTION 10 <br> MECHANICAL DATA

This section contains the pin assignments and package dimensions for the TS68008.

### 10.1 PIN ASSIGNMENTS

## 48-Pin Dual-in-Line

 (Top View)|  | $48 \text { A2 }$ |
| :---: | :---: |
| A4 $\square^{2}$ | 47 ${ }^{\text {a }}$ |
| $A^{\prime} 50$ | 46 AO |
| A6 44 | 45 FCO |
| A7 $0^{5}$ | 44 FCl |
| A8 6 | $43 \mathrm{FCC2}$ |
| A9 7 | $42 \mathrm{~T} \overline{\mathrm{PL} 2} / \overline{0}$ |
| A10 8 | 41 PIL |
| A1109 | 40 BERR |
| A12 10 | 39 VPA |
| A13 11 | 38 E |
| A14 12 | 37 RESET |
| $v_{\text {CC }} 13$ | $36]$ HALT |
| A15 14 | 35 GND |
| GND 15 | 34 CLK |
| A 1616 | $33 \mathrm{D} \overline{\mathrm{BR}}$ |
| A17 17 | 32 BG |
| A18 18 | $31 \square$ DTACK |
| A19 19 | $307 \mathrm{R} / \overline{\mathrm{W}}$ |
| D7 20 | $29 . \overline{\mathrm{DS}}$ |
| D6 21 | $28 . \overline{A S}$ |
| D5 22 | 2700 |
| 04023 | 2601 |
| D3 24 | 2502 |

52-Pin Quad Pack (PLCC)
(Top View)



CB-522



FN SUFFIX PLCC 52

MK68200 16-BIT
SINGLE-CHIP MICROCOMPUTERS
MK68201/MK68E201/MK68211/MK68E211/MK68E221
MICROCOMPUTER COMPONENTS

## FEATURES

$\square$ 16-bit, high performance, single-chip microcomputer
$\square 14$ address and data registers

- Eight 16-bit or sixteen 8-bit data registers
- Six 16-bit address registers
$\square$ Advanced 16-bit instruction set
- Bit, byte, and word operands
- Nine addressing modes
- Byte and word BCD arithmetic
$\square$ High performance ( 6 MHz instruction clock)
- 500 ns register-to-register move or add
$-3.5 \mu \mathrm{~s} 16 \times 16$ multiply
$-4.0 \mu \mathrm{~s} 32 / 16$ divide
$\square$ Available with $0,4 \mathrm{~K}(2 \mathrm{~K} \times 16)$ of ROM
$\square 256(128 \times 16)$ or $512(256 \times 16)$ byte RAM
$\square$ Up to 1 K byte RAM on MK68E221
$\square$ Three 16-bit timers
- Interval modes
- Event modes
- One-shot modes
- Pulse and period measurement modes
- Two input and two output pins

Serial channel

- Double-buffered receive and transmit
- Asynchronous to 375 Kbps
- Synchronous to 1.5 Mbps
- Address wake-up recognition and generation
- Internal/external baud rate generation
$\square$ Parallel I/O
- Up to 40 pins
- Direction programmable by bit
— One 16 -bit or two 8 -bit port(s) with handshaking
$\square$ Interrupt controller
- 16 independent vectors
- Eight external interrupt sources
- One non-maskable interrupt
- Individual interrupt masking
$\square$ Optional external bus
- 16-bit, multiplexed address/data bus
- Automatic bus request/grant arbitration


Figure 1. MK68200

- Two control bus versions:
- 68000-compatible bus (UPC)
- General Purpose Bus (GP)8 and 12 MHz time base versions produce 4 and 6 MHz instruction clock rates, respectively.
- Crystal or external TTL clock
$\square$ Single +5 volt power supply
$\square$ DIP, chip carrier or pin-grid packaging


## GENERAL DESCRIPTION

MK68200 designates a series of new, high-performance, 16-bit, single-chip microcomputers from Thomson Mostek. Implemented in Scaled Poly-5 NMOS, they incorporate an architecture designed for superior performance in computation-intensive control applications. A modern, comprehensive instruction set (which features both high speed execution and code space efficiency) is combined on-chip with extensive, flexible I/O capabilities. On-chip RAM and optional on-chip ROM are provided within a full 64 K byte addressing space.


Figure 2. MK68200 Logical Pinout, Single-Chip Mode


Figure 3. MK68200 Single-Chip Pin Assignment (48-Pin DIP)

The MK68200 is designed to serve the needs of a wide variety of control applications, which require high performance operation with a minimal parts count implementation. Industrial controls, instrumentation, and intelligent computer peripheral controls are all examples of applications served by the MK68200. High speed mathematical ability, rapid I/O addressing and interrupt response, and powerful bit manipulation instructions provide the necessary tools for these applications. In addition to its single-chip microcomputer configuration, both distributed intelligence and parallel multiprocessing system configurations are supported by the MK68200, as illustrated in Figures 13 and 14.
In applications requiring loosely-coupled distributed intelligence, several MK68200's may be interconnected on a common serial network. The on-chip USART supports a wake-up mode in which an additional bit is appended to the data stream to distinguish a serial data word as address or data. The wake-up logic prevents the serial channel from generating interrupts unless certain criteria have been met. The wake-up options available are: Wake-up on any address or data character, wake-up on any address, or wake-up on address match.
Alternately, the MK68200 may be configured as an expandable CPU device which can access external memory and I/O resources. In this operating mode, parallel I/O pins are replaced by multiplexed address/ data and control lines. Bus arbitration logic is incorporated on the chip to support a direct interface in parallel shared bus multiprocessor system configurations. Two versions exist which support two types of control signals present on the expanded bus configuration. The General Purpose (GP) bus option allows the MK68200 to operate either as an executive or a peripheral processor. As an executive procesor, the MK68200 can control an external system bus and grant the use of it to requesting devices, such as DMA controllers and/or peripheral processors. As a peripheral control processor, the MK68200 can provide intelligent local control of an I/O device in a computer system and, thereby, relieve the executive processor of these tasks. In this configuration, the MK68200 has the capability of effectively performing DMA transfers between system memory and the I/O device. The on-chip resources of ROM, RAM, and I/O are accessed within the MK68200 without affecting utilization of the shared system bus. Therefore, only external communications compete for bus bandwidth.

The Universal Peripheral Controller (UPC) bus option supports a direct interface to a 68000 executive processor. Thus, the MK68200 can be used as a cost-effective, intelligent peripheral controller in 68000 systems. The UPC version's direct bus interface to the 68000 makes the MK68200 particularly well-suited for performing many intelligent I/O functions in a 68000 system. For example, since the MK68200 includes both a serial channel and an external bus capable of performing DMA transfers, it can be programmed to act as
serial protocol controller with DMA capability, as shown in Figure 4.
Table 1 summarizes the specific MK68200 device types that are discussed in this data sheet. A complete guide to the part numbering scheme used throughout this document may be found in the Ordering Information section. All MK68200 devices retain most of the I/O features when they are used in the expanded bus mode; however, 24 pins of parallel I/O are sacrificed when this mode is used. When the expanded bus mode is selected, the MK68201/XX generates UPC (68000-compatible) control signals, while the MK68211/XX generates GP control signals. Also available are 84-pin emulator versions of these devices that do not have on-chip ROM, but instead have additional pins to support a second complete address/data bus to access off-chip ROM, RAM, EPROM, or I/O devices. This bus is referred to as the private bus and is not bonded out on 48 -pin versions.

For additional information on the MK68200, refer to the MK68200 Principles of Operation Manual, publication number 4420399.

## SINGLE-CHIP DESCRIPTION

Figure 2 illustrates the functions of specific pins for an MK68201 or MK68211, operating in a single-chip mode. When the device is operating in one of the expanded bus modes, the pins on Port 0 become the multiplexed address/data bus, and the upper half of Port 1 becomes the control signals (GP or UPC) for the bus. The following description applies to the pins only when the device is used in the non-expanded or single-chip mode. Descriptions of the pin functions for the expanded bus modes are in the Expanded Bus Operation section of this data sheet.
$\mathbf{V}_{\mathbf{C C}}$, GND
(Power, Ground)
Power Supply pins.
(single +5 V )

## RESET

Input, active low. $\overline{R E S E T}$ input overrides ongoing execution (including interrupts) and resets the chip to its initial power-up condition. RESET cannot be masked.

## CLKOUT

(Clock Output)
Output. CLKOUT will output the instruction clock rate, which is one-half of the frequency provided on CLK1 and CLK2.

## CLK1, CLK2

(Time base Inputs)
Inputs. CLK1 and CLK2 may be connected to a crystal, or CLK1 may be connected to an external TTLcompatible oscillator while CLK2 is left floating. The


Figure 4. Serial DMA Controller

Table 1. Device Type Summary

| Device Type | Expanded <br> Bus Version | ROM <br> (Bytes) | RAM <br> (Bytes) | PKG. |
| :--- | :---: | :---: | :---: | :--- |
| MK68201/04 | UPC | 0 |  | (1P |
| MK68201/44 | UPC | $4 K$ | 256 | 48 -pin DIP |
| MK68E201/04 | UPC | 0 | 256 | 88-pin DIP |
| MK68211/04 | GP | 0 | 256 | 48 -pin DIP, 52-pin PLCC |
| MK68211/44 | GP | $4 K$ | 256 | 48 -pin DIP, 52-pin PLCC |
| MK68E211/04 | GP | 0 | 256 | 84-pin LCC |
| MK68E221/0C | UPC/GP | 0 | 1024 | 84 -pin LCC, PGA |

instruction clock rate is one-half of the frequency provided on CLK1 and CLK2.

## $\overline{\text { NMI }}$ <br> (Non-Maskable Interrupt)

Input, active low, negative edge triggered. The NMI request line has a higher priority than all of the maskable interrupts. NMI is always enabled regardless of the state of the L1E (Level 1 Interrupt Enable) bit in the Status Register.

## MODE

Input. The MODE pin is used to configure the MK68200 on power-up and reset to one of the following states:

Mode Pin
$V_{C C} \quad$ - No expansion (single chip mode)
GND - Partial Expansion
CLKOUT - Full Expansion

## P0-0 - P0-15

(Port 0)
Input/Output. Each bit in Port 0 may be individually programmed for general purpose input or output. Port 0 also has several handshaking modes to allow parallel, asynchronous communication with other devices. The high and low bytes may be programmed individually or jointly to be inputs, outputs, or bidirectional.

## P1-0 - P1-15

(Port 1)
Input/Output. Each of the 16 bits in Port 1 may be individually programmed for input or output. Additionally, the lowest seven bits of Port 1 may be programmed to serve specific alternate functions, as listed below.

P1-6/XI2
(External Interrupt 2)
Input, rising or falling edge triggered. The programmer may select the rising or falling edge as active for XI2.

P1-5/XI1
(External Interrupt 1)
Input, fixed falling edge triggered. The XI1 interrupt may be used to interrupt the MK68200 on the falling edge of an input pulse.

## P1-4/XI0

(External Interrupt 0)
Input, low level triggered. The XIO interrupt input is leveltriggered (unlike XI1, XI2). It may be used to produce an internally vectored interrupt or to cause an external fetch of an interrupt vector number when the MK68200 is used in an expanded mode with the GP bus.

## P1-3/SI

(Serial Input)
Input, active high. SI is used to input receive serial data when the receiver is enabled.

## P1-2/RCLK

(Receive Clock)
Input/Output, active high. Depending on the mode programmed, RCLK can be used by the serial port as either an input or an output pin. When used as an input pin, RCLK provides the receive clock and/or the transmit clock. When RCLK is not providing the transmit or receive clock, it can be used as an output for Timer C. In this mode, the receive clock is being provided by Timer C .

## P1-1/TCLK

## (Transmit-Clock)

Input/Output, active high. Depending on the mode programmed, TCLK can be used by the serial port as either an input or an output pin. When used as an input pin, TCLK provides the transmit clock. When TCLK is not providing the transmit clock, it can be used as an output for Timer C. In this mode, the transmit clock is being provided by either Timer C or RCLK.

## P1-1/SO

(Serial Output)
Output, active high. SO is used to output transmit serial data when the transmitter is enabled.

## P4-8 - P4-15

## (Port 4)

Inputs and Outputs. P4-8, P4-9, P4-14, and P4-15 may be used as general purpose outputs, and P4-10, P4-11, P4-12, and P4-13 may be used as general purpose inputs. Interrupts may be generated on the positive transitions on P4-10 and P4-11. Depending on the mode selected, interrupts may be generated on the positive or negative transitions on P4-12, or they may be generated on the positive, negative, or combined transitions on P4-13. Additionally, these bits may be programmed to serve specific alternate functions, as listed below.

## P4-15/TAO

(Timer A Output)
Output. TAO may be programmed for special functions in the interval, event, and pulse modes for Timer A. In the interval mode, TAO's state is determined by the Timer A latch (high or low) that is currently active. That is, if the counter is using the high latch for comparison, TAO is high. If the counter is using the low latch for comparison, TAO is low. In the event mode, TAO is initialized to a " 1 " state and toggles each time the counter matches the Timer A high latch. In the pulse/period modes, TAO is initiated to a " 1 " state and toggles on positive transitions on TAI.

## P4-14/TBO

(Timer B Ouput)
Output. TBO may be programmed for special functions in the interval and one-shot modes for Timer B. In the interval mode, TBO is initialized to a " 1 " state and toggles each time the counter matches the Timer $B$ latch value. In the one-shot modes, TBO is initialized to a " 1 " state, and the counter begins counting in response to the occurrence of an active edge on TBI. TBO will not go low until the counter matches the value loaded into the Timer B latch.

## P4-13/TAI

## (Timer A Input)

Input, positive and/or negative edge triggered. TAI may be programmed for special functions in the event mode or pulse/period modes for Timer A. In the event mode, the counter is incremented on each active transition
(positive or negative edge programmable) on TAI. In the pulse/period modes, the counter measures the time during which the signal on TAI remains high and low.

## P4-12/TBI

(Timer B Input)
Input, positive or negative edge triggered. TBI may be programmed for special functions for the Timer $B$ oneshot modes. In the one-shot modes, TBI acts as a trigger input.

P4-11/STRH, P4-10iSTRL
(Strobe High Byte, Strobe Low Byte)
Input, active high. STRH and STRL are both used for input, output, and bidirectional handshaking on Port 0 .

1) Output mode: The positive edge of this strobe is issued by the peripheral to acknowledge the receipt of data made available by the MK68200.
2) Input mode: The strobe is issued by the peripheral to load data from the peripheral into the Port 0 input register. Data is latched into the MK68200 on the negative edge of this signal.
3) Bidirectional mode: When the STRH signal is active, data from the Port 0 output register is gated onto the Port 0 bidirectional data bus.

The negative edge of STRH acknowledges the receipt of the output data. The negative edge of the signal applied to the STRL signal is used to latch input data into Port 0.

## P4-9/RDYH, P4-8/RDYL

(Ready High Byte, Ready Low Byte)
Output, active high. RDYH and RHYL are used for input, output, and bidirectional handshaking on Port 0.

1) Output mode: The ready signal goes active to indicate that the Port 0 output register has been loaded, and the peripheral data is stable and ready for transfer to the peripheral device.
2) Input mode: The ready signal is active when the Port 0 input register is empty and is ready to accept data from the peripheral device.
3) Bidirectional mode: The RDYH signal is active when data is available in Port 0 output register for transfer to the peripheral device. In this mode, data is not placed on the Port 0 data bus unless STRH is active. The RDYL signal is active when the Port 0 input register is empty and is ready to accept data from the peripheral device.

## PROCESSOR ARCHITECTURE

The MK68200 microcomputer contains an advanced processor architecture, combining the best properties of both 8 - and 16 -bit processors. A large majority
of instructions operate on either byte or word operands. Figure 5 summarizes the internal architecture of the MK68200.

## REGISTERS

The MK68200 register set includes three system registers, six address registers, and eight data registers. The three 16 -bit system registers (Figure 6) include a Program Counter, a Status Register, and a Stack Pointer. The six address registers may be used either for 16 -bit data or for memory addressing. The eight 16-bit data registers are used for data and may be referenced as sixteen 8 -bit registers, providing great flexibility in register allocation.

## ADDRESSING

The MK68200 directly addresses a 64K byte memory space, which is organized as 32 K 16 -bit words. The memory is byte-addressable, but most transfers occur 16 bits at a time, for increased performance over 8 -bit microcomputers. All input/output is memory-mapped, and the on-chip I/O is situated in the top 1 K bytes of the address space. In the single-chip mode, all resources including ROM, RAM, and I/O, are accessed via an internal or private bus. The memory map, which is accessed by this bus in the single-chip mode, is depicted in Figure 7. Note on-chip RAM always begins at \$FBFF and extends downward. ROM always begins at zero and extends upward.

Nine addressing modes provide ease of access to data in the MK68200, as depicted in Table 2. The four register indirect forms utilize the address registers and the Stack Pointer and support many common data structures such as arrays, stacks, queues, and linked lists. I/O Port addressing is a short form addressing mode for the first 16 words of the I/O port space and allows most instruc-
tions to access the most often referenced I/O ports in just one word. Many microcomputer applications are I/O intensive and short, fast addressing of I/O has a significant impact on performance.

## INSTRUCTION SET

The MK68200 instruction set has been designed with regularity and ease of programming in mind. In addition, instructions have been encoded to minimize code space, a feature which is especially important in singlechip microcomputers. Small code space is related to execution speed, and most instructions execute in either three or six instruction clock periods. (An instruction clock period is equal to 167 ns with a 6 MHz instruction clock). See Table 3.

In addition to operations on bytes and words, the MK68200 has rapid bit manipulation instructions that can operate on registers, memory, and ports. The bit to be affected may be an immediate operand of the instruction, or it may be dynamically specified in a register. Operations available include bit set, clear, test, change, and exchange; and all bit operations perform a bit test as well. Since each instruction is indivisible, this provides the necessary test-and-set function for the implementation of semaphores.

The MOVE group of instructions has the most extensive capabilities. A wide variety of addressing mode combinations is supported including memory-tomemory transfers. A special move multiple is included to save and restore a specified portion of the registers rapidly.

In total, the MK68200 instruction set provides a programming environment, similar to the 68000, which has been optimized for the needs of the single-chip microcomputer marketplace. A summary of the instruction set is provided in Table 4.

Table 2. Addressing Modes
gister
Register Indirect
Register Indirect with Post-increment
Register Indirect with Pre-decrement
Register Indirect with Displacement
Program Counter Relative
Memory Absolute
Immediate
I/O Port


Figure 5. MK68200 Block Diagram

DATA REGISTERS:


ADDRESS REGISTERS:


SYSTEM REGISTERS:


Figure 6. Register Set


ADDRESS
SFFFF
\$FC28
\$FC27
\$FC00
\$FBFF
\$F800
CONTENTS
FUTURE I/O EXPANSION AREA (RESERVED)

PORT 0 THROUGH PORT 19

ON-CHIP RAM (UP TO 1024 BYTES)

FUTURE RAM AND
ROM EXPANSION


Figure 7. Addressing Space For Single-Chip Configuration

Table 3. Instruction Execution Times

| Instruction Type | Clock <br> Periods | Execution Time <br> with 6 MHz <br> Clock $(\mu \mathrm{s})$ |
| :--- | :---: | :---: |
| Move Register-to-register | 3 | 0.5 |
| Add Register-to-register (binary or BCD) | 3 | 0.5 |
| Move Memory-to-register | 6 | 1.0 |
| Add Register-to-memory | 9 | 1.5 |
| Multiply (16 $\times 16$ ) | 21 | 3.5 |
| Divide (32/16) | 55 | 3.84 |
| Move Multiple (save or restore all registers) | 9.2 |  |

Table 4. Instruction Set Summary

| INSTRUCTION | DESCRIPTION | INSTRUCTION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| ADD | ADD | HALT | HALT |
| ADD.B | ADD BYTE | JMPA | JUMP ABSOLUTE |
| ADDC | ADD WITH CARRY | JMPR | JUMP RELATIVE |
| ADDC.B | ADD WITH CARRY BYTE | LIBA | LOAD INDEXED BYTE ADDRESS |
| AND | LOGICAL AND | LIWA | LOAD INDEXED WORD ADDRESSED |
| AND.B | LOGICAL AND BYTE | LSR | LOGICAL SHIFT RIGHT |
| ASL | ARITHMETIC SHIFT LEFT | LSR.B | LOGICAL SHIFT RIGHT BYTE |
| ASL.B | ARITHMETIC SHIFT LEFT BYTE | MOVE | MOVE |
| ASR | ARITHMETIC SHIFT RIGHT | MOVE.B | MOVE BYTE |
| ASR.B | ARITHMETIC SHIFT RIGHT BYTE | MOVEM | MOVE MULTIPLE REGISTERS |
| BCHG | BIT CHANGE | MOVEM.B | MOVE MULTIPLE REGISTERS BYTE |
| BCLR | BIT CLEAR | MULS | MULTIPLY SIGNED |
| BEXG | BIT EXCHANGE | MULU | MULTIPLY UNSIGNED |
| BSET | BIT SET | NEG | NEGATE |
| BTST | BIT TEST | NEG.B | NEGATE BYTE |
| CALLA | CALL ABSOLUTE | NEGC | NEGATE WITH CARRY |
| CALLR | CALL RELATIVE | NEGC.B | NEGATE WITH CARRY BYTE |
| CLR | CLEAR | NOP | NO OPERATION |
| CLR.B | CLEAR BYTE | NOT | ONE'S COMPLEMENT |
| CMP | COMPARE | NOT.B | ONE'S COMPLEMENT BYTE |
| CMP.B | COMPARE BYTE | OR | LOGICAL OR |
| DADD | DECIMAL ADD | OR.B | LOGICAL OR BYTE |
| DADD.B | DECIMAL ADD BYTE | POP | POP |
| DADDC | DECIMAL ADD WITH CARRY | POPM | POP MULTIPLE REGISTERS |
| DADDC.B | DECIMAL ADD WITH CARRY BYTE | PUSH | PUSH |
| DI | DISABLE INTERRUPTS | PUSHM | PUSH MULTIPLE REGISTERS |
| DIVU | DIVIDE UNSIGNED | RET | RETURN FROM SUBROUTINE |
| DJNZ | DECREMENT COUNT AND JUMP | RETI | RETURN FROM INTERRUPT |
|  | IF NON-ZERO | ROL | ROTATE LEFT |
| DJNZ.B | DECREMENT COUNT BYTE AND | ROL. $B$ | ROTATE LEFT BYTE |
|  | JUMP IF NON-ZERO | ROLC | ROTATE LEFT THROUGH CARRY |
| DNEG | DECIMAL NEGATE | ROLC.B | ROTATE LEFT THROUGH CARRY |
| DNEG.B | DECIMAL NEGATE BYTE |  | BYTE |
| DNEGC | DECIMAL NEGATE WITH CARRY | ROR | ROTATE BYTE |
| DNEGC.B | DECIMAL NEGATE WITH CARRY | ROR.B | ROTATE RIGHT BYTE |
|  | BYTE | RORC | ROTATE RIGHT THROUGH CARRY |
| DSUB | DECIMAL SUBTRACT | RORC.B | ROTATE RIGHT THROUGH CARRY |
| DSUB.B | DECIMAL SUBRTRACT BYTE |  | BYTE |
| DSUBC | DECIMAL SUBTRACT WITH CARRY | SUB | SUBTRACT |
| DSUBC.B | DECIMAL SUBTRACT WITH CARRY | SUB.B | SUBTRACT BYTE |
|  | BYTE | SUBC | SUBTRACT WITH CARRY |
| El | ENABLE INTERRUPTS | SUBC.B | SUBTRACT WITH CARRY BYTE |
| EOR | EXCLUSIVE OR | TEST | TEST |
| EOR.B | EXCLUSIVE OR BYTE | TEST.B | TEST BYTE |
| EXG | EXCHANGE | TESTN | TEST NOT |
| EXG.B | EXCHANGE BYTE | TESTN.B | TEST NOT BYTE |
| EXT | EXTEND SIGN |  |  |

## INPUT/OUTPUT ARCHITECTURE

The I/O capabilities of the MK68200 are extensive, encompassing timers, a serial channel, parallel I/O, and an interrupt controller. All of these devices are accessible to the programmer as ports within the top 1 K bytes of the address space, and the most commonly accessed ports may be accessed with the short port addressing mode. A description of these ports is given in Table 5.

In total, 40 pins of the 48 are used for I/O, and their functions are highly programmable by the user. In particular, many pins can perform multiple functions, and the programmer selects which ones are to be used. For example, TAI may be used as an input for Timer A, an interrupt source, or a general purpose input pin. The interrupt source may be selected simultaneously with either of the other functions.

Table 5. Port Descriptions

| PORT | ADDRESS | READ/WRITE | BYTE- <br> ADDRESSABLE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 0 | \$FC00 | READ/WRITE | YES | 16 EXTERNAL I/O PINS OR ADDRESS/DATA BUS |
| 1 | \$FC02 | READ/WRITE | YES | 16 EXTERNAL I/O PINS (INCLUDING INTERRUPT, SERIAL I/O PINS, AND BUS CONTROL) |
| 2 | \$FC04 | - | - | (RESERVED) |
| 3 | \$FC06 | LOW BYTE: READ/WRITE HIGH BYTE: READ | YES | SERIAL TRANSMIT (LOW BYTE) AND RECEIVE (HIGH BYTE) BUFFER |
| 4 | \$FC08 | INPUTS: READ ONLY OUTPUTS: READ/WRITE | NO | 8 EXTERNAL I/O PINS (TIMER CONTROL AND PORT 0 HANDSHAKE CONTROL) |
| 5 | \$FCOA | - | - | (RESERVED) |
| 6 | \$FCOC | - | - | (RESERVED) |
| 7 | \$FCOE | READ/WRITE | NO | INTERRUPT LATCH REGISTER |
| 8 | \$FC10 | READ/WRITE | NO | INTERRUPT MASK REGISTER |
| 9 | \$FC12 | STATUS: READ ONLY CONTROL: READ/WRITE | NO | SERIAL I/O RECEIVE CONTROL AND STATUS |
| 10 | \$FC14 | STATUS: READ ONLY CONTROL: READ/WRITE | NO | SERIAL I/O TRANSMIT CONTROL AND STATUS |
| 11 | \$FC16 | READ GETS COUNTER WRITE GOES TO LATCH | NO | TIMER B LATCH |
| 12 | \$FC18 | READ GETS COUNTER OR LATCH <br> WRITE GOES TO LATCH | NO | TIMER A, LOW LATCH |
| 13 | \$FC1A | READ GETS COUNTER OR LATCH <br> WRITE GOES TO LATCH | NO | TIMER A, HIGH LATCH |
| 14 | \$FC1C | READ/WRITE | NO | TIMER CONTROL, INTERRUPT EDGE SELECT |
| 15 | \$FC1E | READ/WRITE | NO | PORT O HANDSHAKE MODE BITS, FAST/ STANDARD, BUS LOCK, BUS SEGMENT BITS |
| 16 | \$FC20 | READ/WRITE | NO | PORT 0 DIRECTION CONTROL (DDRO) |
| 17 | \$FC22 | READ/WRITE | NO | PORT 1 DIRECTION CONTROL (DDR1) |
| 18 | \$FC24 | READ/WRITE | NO | SERIAL I/O MODE AND SYNC REGISTER |
| 19 | \$FC26 | READ GETS COUNTER WRITE GOES TO LATCH AND COUNTER | NO | TIMER C LATCH |

## TIMERS

The MK68200 includes three on-chip timers, each with unique features. They are denoted Timer A, Timer B, and Timer C. All three timers are a full 16 bits in width, and count at the instruction clock rate of the MK68200 processor. Thus, this rate provides a resolution equal to the instruction clock period (tc) of the MK68200. The maximum count interval is equal to tc $* 2^{16}$. For a 6 MHz MK68200, a 167 nanosecond clock is provided with a maximum count interval of 10.945 milliseconds. Each timer has the capability to interrupt the processor when it matches a predetermined value stored in an associated latch.

Timer A is capable of operating in interval, event, or two pulse/period modes. There is one 16 -bit counter and two 16 -bit latches (high and low) associated with Timer A. Once Timer A is initialized in the interval mode, the counter is reset, then increments at the instruction clock rate until the value loaded into the high latch is reached. The counter is then reset, increments until the low latch value is reached, and the cycle is repeated. In the event mode, the counter is incremented for every active edge on TAI (programmable as positive or negative) until the value in the high latch is reached. The counter is then reset, and the cycle repeats. In the pulse/period modes, the times are measured during which the pulse applied stays high and low. The counter is reset on the occurrence of any transition on TAI, and increments at the instruction clock rate until the occurrence of the next transition. The value in the counter at the end of the high level or low level time is loaded into the appropriate latch. Interrupts may be generated each time the
counter reaches the high latch or low latch value in the interval mode or when the counter reaches the high latch in the event mode. Also, an interrupt is generated whenever the counter overflows. See the Pin Description section of this data sheet for TAI and TAO functions in the various Timer A modes.

Timer B is capable of operating in interval and one-shot modes. There is one 16 -bit counter and one 16 -bit latch associated with Timer B. In the interval mode, the counter is initially reset and incremented at the instruction clock rate until the value in the latch is reached. The counter is then reset, and the cycle repeats. In the oneshot modes, the counter begins incrementing in response to an active transition (programmable as positive or negative) on TBI. The counter is reset when the value in the Timer $B$ latch is reached. In the retriggerable one-shot mode, active transitions on TBI always cause the counter to reset and begin incrementing. In the non-retriggerable one-shot mode, active transitions on TBI have no effect until the counter reaches the latch value. Interrupts may be generated each time the counter reaches the latch value. See the Pin Description section of this data sheet for TBI and TBO functions in the various Timer $B$ modes.

Timer C has a 16-bit down counter and latch associated with it and operates only in the interval mode. The output of Timer $C$ toggles each time the counter value rolls over from 0 to the latch value and may be used to internally supply the baud rate clock for the serial port. Also, an interrupt may be generated each time the counter rolls over to the latch value. Timer C may be output on the TCLK pin (P1-3), depending on the mode programmed.

Table 6. Timer Modes

| Timer | Modes |
| :---: | :--- |
| A | Interval |
| A | Event |
| A | Pulse Width and Period Measurement |
| B | Interval |
| B | Retriggerable One-shot |
| B | Non-retriggerable One-shot |
| C | Interval |
| C | Baud Rate Generation |

## SERIAL CHANNEL

The serial channel on the MK68200 (Figure 8) is a fullduplex USART with double buffering on both transmit and receive. Word length, parity, stop bits, and modes
are fully programmable. The asynchronous mode supports bit rates up to 375 Kbps , and the byte synchronous mode operates up to 1.5 Mbps . Either internal or external clocks may be used.


Figure 8. Serial Channel

In addition to the typical USART functions, the serial channel can operate in a special wake-up mode with a wake-up bit appended to each data word, as illustrated in Figure 9. This wake-up bit is used to differentiate normal data words and special address words. The receiver can be programmed to receive only address words or
only address words with a specific data value. In this way, the processor can be interrupted only when it receives its particular address and can then change mode to receive the following data words. Wake-up capability is especially useful when several MK68200 microcomputers are interconnected on one serial link.

| START $\dagger$ | DATA | MSB | PARITY <br> (OPTIONAL) | WAKE-UP <br> (OPTIONAL) | STOP $\dagger$ |
| :---: | ---: | ---: | ---: | ---: | ---: |

## †USED IN ASYNCHRONOUS MODE ONLY

Figure 9. Serial Frame Format

## PARALLEL I/O

Two 16-bit ports, P0 and P1, may be used for parallel I/O. If individual bits are desired, each of the 32 bits may be separately defined as input or output. Bits may be grouped to provide the exact data widths desired. Port 0 has the additional capability of operating under the control of external handshaking signals. Eight- or sixteen-bit sections of PO may be individually controlled as input, output, or bidirectional I/O. Two pairs of Ready and Strobe signals, which are available as programmable options on Port 4, provide the necessary control.

## INTERRUPT CONTROLLER

The MK68200 interrupt controller provides rapid service of up to 15 interrupt sources, each with a unique internal vector. The lowest 16 words of the address space contain the starting addresses of the service routines of each potential interrupt source and reset, as shown in Figure 10.

Interrupt sources and RESET are prioritized in the order shown in Figure 10, with RESET having the highest priority. NMI is the only non-maskable interrupt. All of

| VECTOR NUMBER | NAME | MNEMONIC | VECTOR LOCATION |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | RESET | RESET | 0000 |  |
| 1 | NON-MASKABLE INTERRUPT | NMI | 0002 | LEVEL 2 |
| 2 | SPARE | SPARE | 0004 |  |
| 3 | EXTERNAL INTERRUPT 2 | XI2 | 0006 |  |
| 4 | STROBE LOW | STRL | 0008 |  |
| 5 | TIMER A OUTPUT | TAO | 000A |  |
| 6 | TIMER A INPUT | TAI | 000C |  |
| 7 | STROBE HIGH | STRH | O00E |  |
| 8 | RECEIVE SPECIAL CONDITION | RSC | 0010 | LEVEL |
| 9 | RECEIVE NORMAL | RN | 0012 |  |
| A | EXTERNAL INTERRUPT 1 | XI1 | 0014 |  |
| B | TIMER B OUTPUT | TBO | 0016 |  |
| C | TIMER B INPUT | TBI | 0018 |  |
| D | EXTERNAL INTERRUPT 0 | XIO | 0014 |  |
| E | TRANSMIT | XMT | 001C |  |
| F | TIMER C | TC | 001E |  |

Figure 10. Interrupt and Reset Vectors
the other sources share an interrupt enable bit in the processor Status Register. This bit is automatically cleared whenever an interrupt is acknowledged. Also, each of these sources has a corresponding individual mask bit. This feature allows selective masking of particular interrupts, including the ability to choose (with minimal software overhead) any priority scheme desired. In fact, 15 levels of nested priority may be programmed.

## EXPANDED BUS OPERATION

When it is necessary to expand beyond the on-chip complement of RAM, ROM, or I/O, or when operation in a parallel multiprocessing system is desired, the

MK68200 may be placed in an external bus mode. The MODE pin is used to select the expansion capability on reset. The MODE pin has three states, which select fully expanded external bus, partially expanded external bus, or no expanded bus (single-chip configuration). The MK68200 may also be reconfigured dynamically through software. In an expansion mode, Port 0 becomes the 16 -bit multiplexed, address/data bus, and eight bits from Port 1 become control signals which handle data transfer and bus arbitration. Sixteen lines are still available for I/O functions, including eight lines from Port 1 and all eight lines of Port 4.

As shown in Figure 11, two different control bus versions are available: a Universal Peripheral Controller (UPC),


Figure 11. MK68200 Logical Pinout Expanded Bus


Figure 12. MK68200 Expanded Bus
which generates 68000-compatible signals, and a General Purpose (GP) bus, which can be used to interface to a wide variety of existing microprocessor buses. With the selection of an expanded bus mode, the MK68200 can act either as a general purpose CPU chip (bus grant device) or as an intelligent peripheral I/O controller to a host CPU (bus request device). These two system configurations are illustrated in Figures 13 and 14.

With the GP bus option, the user may configure the MK68200 in either of the two ways shown in Figures 13 and 14. As a host CPU (Figure 13), the MK68200 bus arbitration logic causes the device to act as the system bus grantor. In other words, the MK68200 would normally have control of the system bus and would grant its use to DMA devices or peripheral CPUs. Alternately, the MK68200 may be configured as a peripheral CPU (Figure 14) that must issue a request to the bus grant device before being allowed to use the system bus. The selection of one of these two configurations is accomplished by the P4-11 pin at reset time. During reset, P4-11 serves as the R/G input ( $0=$ bus grantor, $1=$ bus requestor). Following reset and at all times during program execution, P4-11 may be used as a general purpose input pin.

With the GP bus operating in the host CPU configuration, the MK68200 may be used to interface with external memory and I/O devices in a manner that is analogous to any general purpose microprocessor. Additionally, the MK68200 retains its on-chip RAM and I/O resources, with on-chip ROM as an option,


Figure 13. Host CPU Hardware Configuration


Figure 14. Peripheral I/O Controller Configuration
depending on the expansion configuration selected. $\overline{B U S I N}$ and $\overline{B U S O U T}$ are used to perform the bus arbitration handshake function, where $\overline{B U S I N}$ acts as the bus request input and BUSOUT as the bus grant output.

In the full expansion configuration, any on-chip ROM is disabled, and program memory starting at location $\$ 0000$ is located off-chip and is addressed via the expanded bus, as shown in Figure 15. In effect, the internal bus from locations $\$ 0000-\$ F A F F$ is mapped onto the external bus. In the partially expanded configuration (Figure 16), on-chip ROM may be accessed on the internal bus. To gain greater addressability in the partial expansion configuration, a scheme is implemented to allow access of a full 64 K -byte address space in four segments on the expanded system bus through the 16 K byte "window" on the internal bus. Basically, the most significant two bits of address on the expanded bus are replaced with two user-defined segment bits available to the programmer in an internal I/O control port location.

As a peripheral I/O controller, the MK68200 operates as a bus requestor that gains mastership of the system bus from the bus grant CPU. The GP bus version may
be selected to implement this system configuration in cases where an interface to a general purpose CPU is desired. In this case, the BUSIN and BUSOUT lines are again used to perform the bus arbitration handshake function, where BUSOUT now acts as bus request out put, and BUSIN acts as bus grant input. In this configuration, the MK68200 can conceivably act as a complete peripheral I/O control subsystem on a single chip, with 16 lines of I/O and its on-chip ROM, RAM, timers, and serial I/O performing the necessary interface to the I/O device. The UPC bus version provides the peripheral I/O control function with a direct interface to a 68000 bus grant CPU. Note that the UPC bus version can operate only as a bus request device. Once the MK68200 has gained mastership of the system bus via the 68000 bus arbitration handshake lines ( $\overline{B R}, \overline{B G}$, and $\overline{\mathrm{BGACK}}$ ), it may proceed to perform DMA transfers and communicate with system memory or other I/O devices in the system.

As in the case of the GP bus grant configuration, the portion of the internal (or private) bus address space that is mapped onto the expanded bus when the part is operating as either a GP or a UPC bus request device is determined by the expansion configuration selected. In the partial expansion bus requestor case, the


Figure 15. Full Expansion Bus Grantor Memory Map (256 byte RAM version shown)
resulting memory map is identical to that shown for the GP bus grant configuration in Figure 16. During the time the MK68200 is executing its programs from ROM and accessing internal RAM and I/O resources, the expanded bus is held in a tri-state condition. The bus arbitration logic within the MK68200 monitors each memory reference to detect external bus addresses (referenced in segments via the 16K byte DMA window). Whenever such an external reference occurs, the logic automatically holds the processor in a wait state as it proceeds to obtain mastership of the bus. When use of the system bus is obtained, the processor is allowed to continue the reference. This procedure is transparent to the programmer. In case of successive external references, the expanded bus is retained until an internal reference is encountered.

Finally, if the on-chip resources are insufficient to perform the control task in the bus requestor configuration, the internal bus address range (excluding on-chip RAM, I/O) may be mapped onto an external local bus, which is physically the same as the system bus but logically separated with bus buffers. This is the full expansion bus requestor configuration. The memory map for this configuration is shown in Figure 17. The bus arbitration sequence is performed only when the system bus is referenced through the DMA window. In this manner, the I/O subsystem is isolated from the host CPU.

When operating as a bus request device, it is possible to retain the external bus for an indefinite duration by using a bus lock feature. This will help facilitate the
transfer of large blocks of data. Thus, the on-chip bus arbitration logic allows (with a minimum of hardware and software overhead) a maximum of concurrent processing in parallel, multiprocessing configurations. The bus lock feature may be used by the MK68200 in a bus grantor mode to keep any peripheral from gaining mastership of the bus.

In any of the GP expanded bus modes, the MK68200 may respond to peripheral devices on the expanded bus which generate an interrupt request on XIO. The MK68200 will obtain the XIO interrupt vector number from the requesting peripheral on the bus during an interrupt acknowledge cycle. When responding to an interrupt on XIO, the MK68200 will wait for the bus arbitration logic to gain control of the bus and then asserts neither $\overline{\mathrm{HB}}$ nor $\overline{\mathrm{LB}}$ while asserting $\overline{\mathrm{AS}}$ to signify that an interrupt acknowledge cycle is in progress.

Timing diagrams and design parameters for the read, write, and bus arbitration cycles are given in the AC Electrical Specifications section for both the GP and the UPC bus options. Bus timing for the interrupt acknowledge cycle is given for the GP device in the AC Electrical Specifications section. There is a userprogrammable speed selection associated with the read and write cycles for both the UPC and GP mask option parts. A bit in an internal I/O port allows the user to select either the standard or the fast read/write cycle on the expanded bus. The standard bus cycle is four clock periods, while the fast bus cycle is three clock periods.


Figure 16. Partial Expansion Memory Map (256 byte RAM, 4K byte ROM version shown)


Figure 17. Full Expansion Bus Requestor Memory Map ( 256 byte RAM version shown)

## EXPANDED BUS SIGNALS (Common for GP and UPC Options)

## $R / \bar{W}$ <br> (Read/Write)

Output, active high and low. R/W determines whether a read or a write is being performed during the current bus cycle. It is stable for the entire bus operation. A high signal denotes a read, and a low signal denotes a write.

## $\overline{\text { DTACK }}$

## (Data Transfer Acknowledge)

Input, active low. When the addressed device has either placed the requested read data on the bus or taken the write data from the bus, DTACK should be brought low to signify completion. The data portion of the bus cycle will be extended indefinitely until this signal is asserted. For systems using the GP bus, in which no devices need wait states, DTACK may be strapped low.

## $\overline{\text { AS }}$

## (Address Strobe)

Output, active low. $\overline{\mathrm{AS}}$ is used to signify that the address is stable on the multiplexed bus. $\overline{\mathrm{AS}}$ is high at the beginning of each bus cycle, goes low after the address has stabilized, and returns to the high state near the end of the bus cycle.

## UPC BUS SIGNALS

## UDS <br> (Upper Data Strobe)

Output, active low. $\overline{\text { UDS }}$ is used to signify the data portion of the bus cycle for the upper byte of the data bus. For read operations, UDS should be used by the external device to gate its most significant byte onto the multiplexed address/data bus. For writes, UDS signifies that the upper byte of the bus contains valid data to be written from the processor.

## $\overline{\text { LDS }}$

(Lower Data Strobe)
Output, active low. $\overline{\text { LDS }}$ is used to signify the data portion of the bus cycle for the lower byte of the data bus. For read operations, $\overline{\text { LDS }}$ should be used by the external device to gate its least significant byte onto the multiplexed address/data bus. For writes, $\overline{\mathrm{LDS}}$ signifies that the lower byte of the bus contains valid data to be written from the processor.

## $\overline{B R}$

## (Bus Request)

Output, active low, open drain. $\overline{B R}$ goes low when the MK68200 requires external bus master status.

## $\overline{\mathbf{B G}}$

(Bus Grant)
Input, active low. $\overline{B G}$ notifies that the MK68200 has been granted the external bus master status.

## BGACK

(Bus Grant Acknowledge)
Output, active low, open drain. The MK68200 will assert BGACK when it assumes mastership of the system bus.

## GP BUS SIGNALS

## P4-11 / R/G <br> (Request/Grant)

During reset, P4-11 serves as the R/G input ( $0=$ bus grantor, $1=$ bus requestor). Following reset, and at all times during program execution, P4-11 may be used as a general purpose input pin.

## $\overline{\text { DS }}$

## (Data Strobe)

Output, active low. $\overline{\mathrm{DS}}$ is used to signify the data portion of the bus cycle. For read operations, $\overline{\mathrm{DS}}$ should be used by the external device to gate its contents onto the multiplexed address/data bus. For writes, $\overline{\mathrm{DS}}$ signifies that valid data from the processor is on the bus.

## $\overline{H B}$

## (High Byte)

Output, active low. $\overline{\mathrm{HB}}$ signifies that the upper byte of the data is to be read or written. $\overline{\mathrm{HB}}$ remains active for the entire bus cycle.

## $\overline{L B}$

(Low Byte)
Output, active low. $\overline{L B}$ signifies that the lower byte of the data bus is to be read or written. (Both $\overline{\mathrm{HB}}$ and $\overline{\mathrm{LB}}$ active imply that an entire word is to be read or written). $\overline{\mathrm{LB}}$ remains active for the entire bus cycle.

## BUSIN

(Bus Input)
Input, active low. $\overline{B U S I N}$ provides either bus request or bus grant. When the MK68200 is the bus grant device, its $\overline{B U S I N}$ signal is a bus request input from a requesting device on the bus. When the MK68200 is a bus request device, its $\overline{B U S I N}$ signal is a bus grant from the granting device on the bus.

## BUSOUT

(Bus Output)
Output, active low. BUSOUT provides the opposite function of BUSIN. When BUSIN is a bus request signal, $\overline{B U S O U T}$ is the corresponding bus grant, and vice versa.

## EMULATOR VERSION

The emulator versions of the MK68200 are available in 84-pin, leadless or leaded chip carrier packages or pingrid array packages. Figure 18 illustrates the logical pinout of the emulator version. Table 1 summarizes the emulator parts described in this data sheet. The emulator versions have no on-chip ROM, but instead include
a second complete bus, referred to as the private bus. The private bus includes a multiplexed address/data bus as well as bus control signals. There are 22 pins associated with the private bus. All 40 I/O port pins that exist on the 48-pin versions are available to the user for configuration either as general purpose or special I/O pins, or as expanded bus pins.


+ AVAILABLE ON MK68E221 (1K RAM VERSION)

Figure 18. MK68E200 Logical Pinout

## PRIVATE BUS OPERATION

The address/data lines and control signals that constitute the private bus are functionally equivalent to the internal signals used to access internal resources on the 48 -pin versions of the MK68200. Thus, the private bus may be used to interface EPROM memory in emulating mask ROM versions of the MK68200. Alternately, any combination of ROM, RAM, and I/O may reside on the private bus.

The address that is generated on the private bus is identical to that which is internally generated for 48-pin versions. When the part is used in a configuration that supports system bus addressing through the DMA window, any references in this region of the memory map produce an address on the private bus identical to that specified by the programmer. In other words, the segment bits have no effect on the private bus address. Write data appears on the private bus pins for all write operations, regardless of whether the reference is onchip or off-chip. The MK68200 emulator version reads data from the private busi unless data is read from onchip RAM, I/O, or the external bus formed by the Port 0 and Port 1 I/O pins.

The I/O port range of the memory map (\$FC00-\$FFFF) is actually subdivided into space which is exclusively reserved for on-chip I/O (\$FC00-\$FDFF) and space which is exclusively reserved for in-circuit-emulator, or AIM, use (\$FE00-\$FFFF). The user should ensure that no external devices reside in the in-circuit-emulator area.

The private bus interface is the same as that for the GP expanded bus. All read/write transfers made exclusively on the private bus are three clock periods, regardless of the state of the Fast/Standard (F/S) bus timing selection bit. The user should ignore all activity on the pri-
vate bus while accesses are in progress on the expanded bus. Care should also be taken that no external devices reside on the private bus in the memory space intended for expanded bus accesses.

## FUNCTION CODE PINS

Function code pins will be available on some versions of the emulator to define the memory cycle currently being executed. They are valid during the time private bus address strobe (PBAS*) is active. The cycle types are interrupt, data fetch, branch, and program fetch. The branch cycle is defined as the first program fetch after a branch occurs. A branch can occur as a result of a jump or call instruction, or an interrupt. For internal interrupts, the interrupt cycles are defined as the two writes to the stack and the read of the vector location which occur during the interrupt acknowledge routine. For external interrupts, the interrupt cycles are defined as the 3 cycles above plus the read of the vector number. The interrupt cycle is a special case of the data fetch cycle. The function code pins are defined below.

| TYPE OF CYCLE | FC1 | FC2 |
| :--- | :---: | :---: |
| Interrupt | 0 | 0 |
| Data Fetch | 0 | 1 |
| Branch | 1 | 0 |
| Program Fetch | 1 | 1 |

## CRYSTAL SELECTION

The wide frequency range of crystals that can be chosen for the MK68200 offers the user a large degree of flexibility. To aid in the selection of a suitable crystal, the suggestions shown in Figure 20 should be considered by the user. The MK68200 offers an output pin that will provide a system clock signal at one-half of the crystal frequency.


Figure 19. Crystal Connection


Figure 20. Summary of Crystal Specifications

## ASSEMBLER DIRECTIVES

| Directive | Function | Assembler Syntax |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DC | Define constant | [label:] | DC[.size]*1 | expr $\{$,expr $\}$ |
| DS | Define storage | [label:] | DS[.size]*1 | expr |
| DUP | Duplicate constant block | [label:] | DUP[.size]** | length, value |
| END | Program end |  | END | [start address] |
| EQU | Equate symbol value | label: | EQU | expr |
| FAIL | Programmer generated error |  | FAIL | expr |
| FORMAT | Format the source listing |  | FORMAT |  |
| IDNT | Generate module ID | module_name: | IDNT | version, revision |
| LIST | Enable the assembly listing |  | LIST |  |
| LLEN | Specify line length |  | LLEN | length |
| NOFORMAT | Do not format listing |  | NOFORMAT |  |
| NOLIST | Disable assembly listing |  | NOLIST |  |
| NOOBJ | Disable object code generation |  | NOOBJ |  |
| NOPAGE | Suppress paging |  | NOPAGE |  |
| OFFSET | Define Offsets |  | OFFSET | expr |
| OPT | Assembler output options |  | OPT | option ${ }^{2}$ \{, option $\}$ |
| ORG | Define absolute origin |  | ORG | expr |
| PAGE | Eject a page in the listing |  | PAGE |  |
| REG | Define register list | reg__list_name: | REG[.size] | register list |
| SECTION | Define relocatable program section | [section__name:] | SECTION | number |
| SET | Set symbol value | label: | SET | expr |
| SPC | Space between source lines |  | SPC | number |
| TTL | Specify heading title string |  | TTL | title string |
| XDEF | External symbol definition |  | XDEF | symbol \{, symbol \} |
| XREF | External symbol reference |  | XREF | [sect no:] symbol \{,[sect no]: symbol\} |

## NOTES:

1.. size $=. B$ or.$W$ (byte or word size)
2. Options for the OPT directive include:
NOCEX Do not print DC expansions (default)
CL Print conditional assembly directives (defauit)
NOCL Do not print conditional assembly directives
CRE Print cross-reference table
IMM.L Forces immediate operands for arithmetic instructions ADD, SUB, DADD, and DSUB to use the long instruction form

IMM.S Allows the assembler to select automatically the short form of the arithmetic instructions for small immediate values (0-15) (default)

## GENERAL SYMBOL DEFINITIONS

| SYMBOL | GENERAL SYMBOL DEFINITIONS |
| :---: | :---: |
| Rn | General Purpose Registers - DO-D7, AO-A5, SP, SR, DHO-DH7, DLO-DL7. |
| RPn | Register Pairs - D0-D1, D2-D3, D4-D5, D6-D7, A0-A1, A2-A3, A4-A5. |
| An | Address Registers - A0-A5, SP. |
| Pn | Ports - PO-P15, PHO-PH3, PLO-PL3. |
| CC | Condition Code - See Table. |
| d16 | 16-Bit Address Displacement Field In Words. |
| d13 | 13-Bit Address Displacement Field In Bytes. |
| d9 | 9-Bit Address Displacement Field In Bytes. |
| d8 | 8-Bit Address Displacement Field In Bytes. |
| \#nx | Immediate Data Field - x Number of Bits. |
| s | Size Bit - '1' = Word, '0' = Byte. |
| REGn | 4-Bit Register Field - See Table. |
| PORTIT | 4-Bit Port Field - See Table. |
| An | 3-Bit Address Register Field - See Table. |
| PRTI | 3-Bit Port Field - See Table. |
| RGn | 3-Bit Register Pair Field - See Table. |
| M | Register Mask Field - See Table. |
| COND | Condition Code Field - See Table. |
| C3 | 3-Bit Class Field - See Table. |
| c2 | 2-Bit Class Field - See Table |
| c1 | 1-Bit Class Field-See Table |
| a | Address Field-16 Bits. |
| \# | Immediate Data Field. |
| $n$ | 3 -Bit Shift Field - $2 \leq n \leq 7$. |
| b\# | 4-Bit Bit Select Field. |
| d | Displacement Field. |
| . ${ }^{\text {d }}$ | Byte Attribute. |
| W | Word Attribute. |
| .L | Long Attribute. |
| . S | Short Attribute. |
| [ ] | Optional Field. |



| PORTn 4-Bit Port Map |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Port |  | Bit Field |  |  | $\frac{\text { Port }}{\text { P8 }}$ | Bit Field |
| PO | PHO |  | 00 |  |  | 1000 |
| P1 | PLO |  | 00 | 1 | P9 | 1001 |
| P2 | PH1 | 0 | 01 | 0 | P10 | 1010 |
| P3 | PL1 | 0 | 01 | 1 | P11 | 1011 |
| P4 | PH2 | 0 | 10 | 0 | P12 | 1100 |
| P5 | PL2 | 0 | 10 | 1 | P13 | 1101 |
| P6 | PH3 | 0 | 11 | 0 | P14 | 1110 |
| P7 | PL3 | 0 | 11 | 1 | P15 | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ |

An 3-Bit Addr Reg Map

| Register | Bit Field |
| :---: | :---: |
| AO | 000 |
| A1 | 001 |
| A2 | 010 |
| A3 | 011 |
| A4 | 100 |
| A5 | 101 |
| SP | 110 |


| PTRn | 3-Bit Port Map |
| :---: | :---: |
| Port | Bit Field |
| PHO | 000 |
| PLO | 001 |
| PH1 | 010 |
| PL1 | 011 |
| PH2 | 100 |
| PL2 | 101 |
| PH3 | 110 |
| PL3 | 111 |


| RGn 3-Bit Reg Pair Map |  |
| :---: | :---: |
| Register | Bit Field |
| D0-D1 | 000 |
| D2-D3 | 001 |
| D4-D5 | 010 |
| D6-D7 | 011 |
| A0-A1 | 100 |
| A2-A3 | 101 |
| A4-A5 | 110 |


| M-REGISTER MASK MAP FOR MOVEM, PUSHM, AND POPM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Inc Word | SR | SP | A5 | A4 | A3 | A2 | A1 | AO | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Dec <br> Word | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | A0 | A1 | A2 | A3 | A4 | A5 | SP | SR |
| Inc Byte | DH7 | DL7 | DH6 | DL6 | DH5 | DL5 | DH4 | DL4 | DH3 | DL3 | DH2 | DL2 | DH1 | DL1 | DHO | DLO |
| Dec <br> Byte | DLO | DHO | DL1 | DH1 | DL2 | DH2 | DL3 | DH3 | DL4 | DH4 | DL5 | DH5 | DL6 | DH6 | DL7 | DH7 |


| COND CONDITION CODE TABLE |  |  |  |
| :---: | :---: | :---: | :---: |
| Condition Code | Bit <br> Field | Description | Test |
| $\begin{gathered} \mathrm{Z} \\ \mathrm{EQ} \end{gathered}$ | 0000 | Zero <br> Equal | Z |
| Mi | 0001 | Minus | N |
| $\begin{gathered} \mathrm{LO}^{2} \\ \mathrm{CS} \end{gathered}$ | 0010 | Lower Carry Set | C |
| VS | $\begin{array}{lllll}0 & 0 & 1 & 1\end{array}$ | Overflow Set | V |
| $\mathrm{GE}^{2}$ | 01000 | Greater than or Equal | $\overline{\text { N.EOR. V }}$ |
| $\mathrm{GT}^{2}$ | $\begin{array}{llll}0 & 1 & 0 & 1\end{array}$ | Greater than | $\overline{\mathrm{Z}}$.AND. ( $\overline{\mathrm{N} . E O R . V})$ |
| $\mathrm{HI}^{2}$ | 01110 | Higher | $\overline{\mathrm{C}} . \mathrm{AND}$. $\overline{\mathrm{Z}}$ |
| F ${ }^{1}$ | 01011 | False | Always False |
| $\begin{aligned} & \text { NE } \\ & \text { NZ } \end{aligned}$ | 1000 | Not Equal Not Zero | $\bar{Z}$ |
| PL | 1001 | Plus | $\bar{N}$ |
| $\begin{gathered} \mathrm{HS}^{2} \\ \mathrm{CC} \end{gathered}$ | 1010 | Higher or Same Carry Clear | $\overline{\mathrm{C}}$ |
| VC | 10011 | Overflow Clear | V |
| $\mathrm{LT}^{2}$ | 11000 | Less than | N .EOR. V |
| LE ${ }^{2}$ | $\begin{array}{lllll}1 & 1 & 0 & 1\end{array}$ | Less than or Equal | Z OR. (N.EOR. V) |
| $\mathrm{LS}^{2}$ | $\begin{array}{lllll}1 & 1 & 1 & \\ \end{array}$ | Lower or Same | C.OR. Z |
| $\mathrm{T}^{1}$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | True | Always True |

NOTES:

1. The assembler does not recognize the $T$ and $F$ condition codes.
2. LT, LE, GT, and GE are used for unsigned conditions; LO, LS, HI, and HS are for unsigned conditions.

| INSTRUCTION CLASS FIELDS |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| [c3 - 3-Bit Field |  |  | C2-2-Bit Field |  |  | [c] - 1-Bit Field |  |  |  |
| Bit Field | Shift Instr | $\begin{aligned} & \text { Bit }^{1} \\ & \text { Instr } \end{aligned}$ | Bit Field | Arith ${ }^{2}$ Instr | Logical Instr | Bit Field | Arith ${ }^{2}$ Instr | Test Instr | $\mathrm{Neg}^{2}$ <br> Instr |
| 000 | ROR | BSET | 00 | ADDC | OR | 0 | ADD | TESTN | NEGC |
| 001 | ROL | BCHG | 01 | SUBC | EOR | 1 | SUB | TEST | NEG |
| 010 | RORC | BCLR | 10 | ADD | AND |  |  |  |  |
| 011 | ROLC | BTST | 11 | SUB | - |  |  |  |  |
| 100 | ASR | - |  |  |  |  |  |  |  |
| 101 | ASL | - |  |  |  |  |  |  |  |
| 110 | LSR | - |  |  |  |  |  |  |  |
| 111 | - | BEXG |  |  |  |  |  |  |  |

## NOTES:

1. The bit fields do not apply to bit instructions using a port operand.
2. These fields also apply to $B C D$ instructions.

## INSTRUCTION FORMAT

| PREFIX WORD |
| :---: |
| (used only in some forms of the decimal and bit instructions) |


| INSTRUCTION MNEMONIC | ATTR SIZE | OPERAND ASSEMBLER SYNTAX <br> Source $=$ Src Destination = Dst <br> Src. Dst | $151413{ }^{13} 12$ | $\begin{aligned} & \text { OPERA } \\ & \text { WOO } \\ & 11098 \end{aligned}$ | $\begin{aligned} & A \text { TIO N } \\ & \text { ARD } \\ & \begin{array}{lll\|l} 7 & 6 & 5 & 4 \end{array} \end{aligned}$ | $\begin{array}{l\|l\|l\|l\|} \hline & 2 & 1 & 0 \\ \hline \end{array}$ | $\begin{aligned} & W \\ & o \\ & R \\ & \text { D } \\ & \text { S } \end{aligned}$ | E $\mathbf{X}$ $\mathbf{T}$ $\mathbf{E}$ $\mathbf{N}$ $\mathbf{S}$ $\mathbf{1}$ $\mathbf{O}$ N | $\begin{array}{l\|l} \mathbf{c} \\ \mathbf{Y} \\ \mathbf{C} \\ \mathbf{L} \\ \mathbf{E} \\ \mathbf{S} \end{array}$ | OPERATION | status FLAGS $\mathrm{N} \mathbf{z} \mathbf{c}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD <br> ADDC <br> SUB <br> SUBC | $\stackrel{8}{[\mathrm{~W}]}$ | Ry.Rx | 2 | REGx |  | [ REGy] | 1 | - | 3 | ADD: <br> Src + Dst - Dst | * * * * |
|  | $\stackrel{8}{\|\mathrm{w}\|}$ | (Ay), Rx | 2 | REGX | [s]c2 1 | $0[\overrightarrow{A y}]$ | 1 | - | 6 | ADDC <br> $\mathrm{Src}+\mathrm{Dst}+\mathrm{C}-$ Dst |  |
|  | $\stackrel{B}{\mathrm{~B}}[\mathrm{~W}]$ | d16(Ay). Ax | 2 | REGX | s] c2] ${ }^{\text {c }}$ | 1 Ay | 2 | d | 9 | $\begin{aligned} & \text { SUB: } \\ & \text { Dst }-\mathrm{Src}-\mathrm{Dst} \end{aligned}$ |  |
|  | $\stackrel{\mathrm{B}}{[\mathrm{~W}]}$ | Addr, Rx | 2 | REGX | s] c2 1 | F | 2 | a | 9 | $\begin{aligned} & \text { SuBC } \\ & \text { Dst - Src - C - Dst } \end{aligned}$ |  |
|  | $\stackrel{B}{[\mathrm{~W}]}$ | An16,Rx | 2 | REGX | [s] [c2 1 | 7 | 2 | \# | 6 | Note: For addressing modes mn, $R \mathrm{x}$ and $\mathrm{m}_{\mathrm{n}}$, Ax ) with the ADD and SUB instructions. |  |
|  | $\stackrel{8}{[\mathrm{~W}]}$ | Ry.(Ax) | 3 | 0 Ax | (5) c2] 0 | REGy | 1 | - | 9 | the assembler uses the short version for immediate values $\leq 4$ bits. |  |
|  | $\underset{\|\mathrm{W}\|}{\mathrm{B}}$ | (Ax). (Ay) | 3 | $0[A x]$ | [s] [c2] 1 | 0 Ay | 1 | - | 12 |  |  |
|  | $\begin{gathered} B \\ {[W]} \end{gathered}$ | \%n16.(Ax) | 3 | 0 [ Ax | [s][c2] ${ }^{\text {c }}$ | 7 | 2 | \# | 12 |  |  |
|  | $\stackrel{B}{[\mathbf{W}]}$ | $(A x)+(A y)+$ | 3 | $1[A x]$ | s] c2 1 | $0\left[A_{y}\right]$ | 1 | - | 12 |  |  |
|  | $\begin{gathered} B \\ {[. W]} \end{gathered}$ | \#n16, (Ax) + | 3 | 1 Ax ] | s] c2 1 | 7 | 2 | * | 12 |  |  |
|  | $\stackrel{.}{\mathrm{B}} \underset{[\mathrm{~W}]}{ }$ | $-(A x), \cdots(A y)$ | 3 | 1 Ax [5 | cc ce 1 | 1 [Ay] | 1 | - | 12 |  |  |
|  | $\stackrel{. B}{[W]}$ | \#n16. - (Ax) | 3 | $1\lceil A x /[$ | [s][c2] 1 | F | 2 | \# | 12 |  |  |
|  | $\stackrel{B}{\mathrm{~B}} \underset{[\mathrm{~W}]}{ }$ | Ry.d16(Ax) | 3 | $1[A x]$ [ | [s], c2] 0 | REGy | 2 | d | 12 |  |  |
|  | $\begin{gathered} B \\ {[\mathrm{~W}]} \end{gathered}$ | Ry,Addr | 3 | $F$ | $5]^{5}[\overline{2}] 0$ | REGY | 2 | a | 12 |  |  |















| INSTRUCTION MNEMONIC | ATTR SIZE | OPERAND ASSEMBLER SYNTAX <br> Source - Sre Destination = Dst <br> Src, Dst | $\begin{aligned} & \text { OPERATION } \\ & \text { WORD } \\ & \hline \end{aligned}$ |  |  |  |  | $\begin{gathered} \mathbf{w} \\ \mathbf{o} \\ \text { R } \\ \mathbf{D} \\ \mathbf{S} \end{gathered}$ | EXTENSION | $\begin{aligned} & \mathbf{C} \\ & \mathbf{Y} \\ & \mathbf{C} \\ & \mathbf{L} \\ & \mathbf{E} \\ & \mathbf{S} \end{aligned}$ | OPERATION | Status <br> flags |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $15: 14$ 13 12 | 11/10 9 8 8 | 7 | $\begin{array}{l\|l\|} 5 & 4 \\ \hline \end{array}$ | $3{ }^{3}$ |  |  |  |  | $N$ | z | V | C |
| MOVE (cont.) | $\begin{gathered} B \\ \{\mathrm{~W} \mid \end{gathered}$ | $(A x)+(A y)+$ | 1 | 1 [ $A x$ | s) | 01 | 0 | 1 | - | 9 | Src - Dst | - - - - |  |  |  |
|  | $\begin{gathered} B \\ \|W\| \end{gathered}$ | \#n16.(Ax) + | 1 | 1 Ax | s] | 01 |  | 2 | \# | 9 |  |  |  |  |  |
|  | $\begin{gathered} B \\ \|W\| \end{gathered}$ | Rx. - (Ay) | 1 | REGX | s) | 10 |  | 1 | - | 6 |  |  |  |  |  |
|  | $\stackrel{8}{\|W\|}$ | PX, -(Ay) | 0 | PORTX | s] | 10 | 1 | 1 | - | 9 |  |  |  |  |  |
|  | $\stackrel{.}{\mathrm{B}} \mid$ | $\cdots(A x),-(A y)$ | 1 | $1[A x$ | s] | 01 | 1 | 1 | - | 9 |  |  |  |  |  |
|  | $\begin{gathered} \mathrm{B} \\ {[\mathrm{~W}]} \end{gathered}$ | *n16. -(Ax) | 1 | 1 Ax | [s] | 01 |  | 2 | \# | 9 |  |  |  |  |  |
|  | $\stackrel{B}{[\mathrm{~W} \mid}$ | Ry.d16(Ax) | 1 | 1 - Ax | [s] | 00 |  | 2 | d | 9 |  |  |  |  |  |
|  | $\stackrel{B}{\mathrm{~W} \mid}$ | Ry,Addr | 1 | F |  | 00 |  | 2 | a | 9 |  |  |  |  |  |
| MOVEM | $\begin{gathered} B \\ {[\mathrm{~W} \mid} \end{gathered}$ | (Ay) + , REGLIST | 1 | 7 |  | 01 | 0 | 2 | M | $9+3 n$ | (Ay) + - REGLIST | ---- |  |  |  |
|  | $\stackrel{B}{[\mathrm{~W}]}$ | - (Ay).REGLIST | 1 | 7 |  | 01 |  | 2 | M | $9+3 n$ | -(Ay) - REGLIST |  |  |  |  |
|  | $\stackrel{\mathrm{B}}{[\mathrm{~W}]}$ | REGLIST.(Ay) + | 1 | F |  | 01 |  | 2 | M | $7+3 n$ | REGLIST - (Ay) + |  |  |  |  |
|  | $\underset{[\mathrm{W}]}{\mathrm{B}}$ | REGLIST, - (Ay) | 1 | F |  | 01 |  | 2 | M | $7+3 n$ | REGLIST - - (Ay) |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  | NOTE. A minimum of 2 registers must pe specified and may be specified in any order. |  |  |  |  |





The following symbols are used to describe the state of the Status Register flags:
Set according to result of operation.
${ }^{\circ}$ Cleared.
1 Set.

- Not affected

| Port Map |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Port |  | Addr <br> \$FC00 | Description <br> 16 External I/O or Addr/Data Bus in Expanded Bus Mode | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PO | $\begin{array}{\|l\|} \hline \text { PHO } \\ \text { PLO } \end{array}$ |  |  |  |  |  |  |  |  |  |  |
| P1 | $\begin{array}{\|l\|} \mathrm{PH} 1 \\ \mathrm{PL} .1 \end{array}$ | \$FC02 | 16 Ext $/ / 0$, Ext interrupts. Serial Port $1 / 0$, Bus Control | $\begin{aligned} & \text { LB } \\ & \hline \text { LDS } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { HB } \\ & \text { UDS } \end{aligned}$ | R/W | $\begin{gathered} \text { DS } \\ \text { BGACK } \end{gathered}$ | DTACK | AS | $\begin{gathered} \text { BUSIN } \\ \text { BG } \end{gathered}$ | $\begin{gathered} \text { BUSOUT } \\ \text { BR } \end{gathered}$ |
| P2 | $\left\lvert\, \begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{PL} 2 \end{aligned}\right.$ | \$FC04 | Reserved | $\longrightarrow$ RESERVED $\longrightarrow$ |  |  |  |  |  |  |  |
| P3 | $\begin{array}{\|l\|} \hline \mathrm{PH} 3 \\ \mathrm{PL} 3 \\ \hline \end{array}$ | \$FC06 | Serial Receive and Serial Transmit Buffers | RECEIVE BUFFER |  |  |  |  |  |  |  |
| P4 |  | \$FC08 | 8 External I/O or Timer and Port 0 Handshake | TAO | TBO | TAI | TBI | $\begin{gathered} \hline \text { STRH } \\ \text { R/G } \end{gathered}$ | STRL | RDYH | RDYL |
| P5 |  | \$FCOA | Reserved | $4 \longrightarrow$ RESERVED $\longrightarrow \square$ |  |  |  |  |  |  |  |
| P6 |  | \$FCOC | Reserved | 4 RESERVED $\longrightarrow$ |  |  |  |  |  |  |  |
| P7 |  | \$FCOE | Interrupt Latch Register | RES | NMI | SPARE | XI21 | STRLI | TAOI | TAll | STRHI |
| P8 |  | \$FC10 | Interrupt Mask Register | RESERVED |  | SPARE | XI2M | STRLM | TAOM | TAIM | STRHM |
| P9 |  | \$FC12 | Serial I/O Receive Control and Status Register | RE | IS | RW1 | RW0 | RC | SIS | RESERVED |  |
| P10 |  | \$FC14 | Serial I/O Transmit Control and Status Register | TE | AT | LM | TW1 | TW0 | TC | P/S | RES |
| P11 |  | \$FC16 | Timer B Latch |  |  |  |  |  |  |  |  |
| P12 |  | \$FC18 | Timer A Low Latch |  |  |  |  |  |  |  |  |
| P13 |  | \$FC1A | Timer A High Latch |  |  |  |  |  |  |  |  |
| P14 |  | \$FC1C | Timer Control, Interrupt Edge Select | TEST | RESERVED |  | XI2C | RESERVED |  | TCOC | TAM1 |
| P15 |  | \$FC1E | Port 0 Handshake mode, Bus Lock. Bus Segment Bits | SEG1 | SEGO | BLCK | F/S | PM3 | PM2 | PM1 | PMO |
| P16 |  | \$FC20 | Port 0 Direction Control <br> (DDRO) |  |  |  |  |  |  |  |  |
| P17 |  | \$FC22 | Port 1 Direction Control <br> (DDR1) |  |  |  |  |  |  |  |  |
| P18 |  | \$FC24 | Serial I/O Mode and <br> Sync Register | A/S | WL1 | WLO | ST | PAR1 | PARO | TCO | WS |
| P19 |  | \$FC26 | Timer C Latch |  |  |  |  |  |  |  |  |


| Port Map |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Initial Condition |
|  |  |  |  |  |  |  |  | - |
| I/O | X12 | XI1 | X10 | SI | RCLK | TCLK | so | - |
| RESERVED |  |  |  |  |  |  |  | - |
| TRANSMIT BUFFER |  |  |  |  |  |  |  | - |
| - RESERVED $\longrightarrow$ |  |  |  |  |  |  |  | $\begin{aligned} & \text { High Byte } \\ & 00-\quad-\quad \end{aligned}$ |
| RESERVED $\longrightarrow$ |  |  |  |  |  |  |  | - |
| RESERVED $\longrightarrow$ |  |  |  |  |  |  |  | - |
| RSCI | RNI | X111 | TBOI | TBII | X101 | XMTI | TCI | \$0000 |
| RSCM | RNM | XIIM | TBOM | твIM | XIOM | XMTM | TCM | \$0000 |
| BF | OE | PE | FE | SFIAF | $\longleftarrow$ RESERVED $\longrightarrow$ |  |  | \$0000 |
| BE | UE | END |  |  |  |  |  | \$00A0 |
|  |  |  |  |  |  |  |  | - |
|  |  |  |  |  |  |  |  | - |
|  |  |  |  |  |  |  |  | - |
| TAMO | TAE | TAIC | TAOC | TBM1 | твMO | TBE | TBIC | \$0000 |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | \$0000 |
|  |  |  |  |  |  |  |  | \$0000 |
| SYNC7 | SYNC6 | SYNC5 | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | \$0000 |
|  |  |  |  |  |  |  |  | - |

NOTE:
When a reserved bit is read, it is read as a zero.

## PORT DESCRIPTIONS

Important note: All port bits that are not explicitly defined are reserved for possible use in future MK68200 family members. If reserved bits are written, they should be written with zero values. When reserved bits are read, they are read as zeros.

PORT 0 - 16 External I/O Bits; read/write
\$FC00 (used as address/data lines in external bus configurations)


PORT 1 -16 External I/O Bits, including Interrupt, Serial I/O,
\$FC02 and Bus Control (shown for GP bus); read/write


PORT 2 -Reserved
PORT 3 -Serial I/O:Transmit Buffer (Low byte; read/write) \$FC06

Receive Buffer (High Byte; read only)


PORT 4 -8 External I/O Pins (Timer and Port 0 Handshake Lines);
\$FC08 inputs: read only Outputs: read/write


Note: STRH is also R/ $\bar{G}$ in the expanded bus modes.
PORT 5 -Reserved
PORT 6 -Reserved
PORT 7 -Interrupt Latch Register; read/write \$FCOE

|  | N | S | X | S | T | T |  | R | R | X | T | T | X | X |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | M | P | 1 | T | A | A | T | S | $N$ | 1 | B | B | 1 | M | c |
| e | 1 | A | 2 | R | 0 | 1 | R | C | 1 | 1 | 0 | । | 0 | T | 1 |
| s |  | $\begin{aligned} & \mathrm{R} \\ & \mathrm{~F} \end{aligned}$ |  | L |  |  | $\underset{~ H}{H}$ | 1 |  | 1 | 1 | 1 | 1 | 1 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

PORT 8 -Interrupt Mask Register; read/write \$FC10


## INTERRUPT AND RESET VECTORS

| VECTOR NUMBER | NAME | MNEMONIC | VECTOR LOCATION |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | RESET | RESET | \$0000 |  |
| 1 | NON-MASKABLE INTERRUPT | NMI | \$0002 | LEVEL 2 |
| 2 | SPARE | SPARE | \$0004 |  |
| 3 | EXTERNAL INTERRUPT 2 | XI2 | \$0006 |  |
| 4 | STROBE LOW | STRL | \$0008 |  |
| 5 | TIMER A OUTPUT | TAO | \$000A |  |
| 6 | TIMER A INPUT | TAI | \$000C |  |
| 7 | STROBE HIGH | STRH | \$000E |  |
| 8 | RECEIVE SPECIAL CONDITION | RSC | \$0010 |  |
| 9 | RECEIVE NORMAL | RN | \$0012 |  |
| A | EXTERNAL INTERRUPT 1 | XI1 | \$0014 |  |
| B | TIMER B OUTPUT | TBO | \$0016 |  |
| C | TIMER B INPUT | TBI | \$0018 |  |
| D | EXTERNAL INTERRUPT 0 | X10 | \$001A |  |
| E | TRANSMIT | XMT | \$001C |  |
| F | TIMER C | TC | \$001E |  |

NOTE: Reset and Interrupt sources are listed in order of decreasing priority with RESET having the highest priority.

PORT 9 -Serial I/O Receive Control and Status Register;
\$FC12 High byte: control register; read/write
Low byte: status register; read only


Bit Descriptions:

RE
(Receiver Enable control)
IS
(Ignore Syncs control)

RW1, RW0
(Receiver Wake-up control)
$0=$ Disabled; all status flags cleared.
1 = Enabled.
$0=$ Disabled; interrupts may occur on all characters received.
$1=$ Enabled; interrupts cannot occur on sync characters received after the sync match is found.

The receiver wake-up control bits operate as follows.

| MODE | RW1 | RWO | APPENDED WAKE-UP | BUFFER <br> LOADED | INTERRUPT GENERATED |
| :---: | :---: | :---: | :---: | :---: | :---: |
| No Wake up | 0 | 0 | no | any character | RN |
| Wake-up on Any Character | 0 | 1 | yes | any character | RN |
| Wake-up on Address Match | 1 | 0 | yes | address match | RSC |
| Wake-up on Any Address | 1 | 1 | yes | any address | RSC |

RC
(Receive Clock control)
$0=$ Selects external receive clock applied on RCLK.
$1=$ Selects internal clock from the onchip baud rate generator (Timer C) for the receive clock.

This bit is ignored when either the TCO bit or the LM (Loopback Mode) bit is set.


PORT 10-Serial I/O Transmit Control and Status Register
\$FC14 High byte: control register; read/write
Low byte: status register; read only

TE
(Transmitter Enable control)
AT
(Automatic Turn Around control)

TW1, TW0
(Transmit Wake-up control)

## TC

(Transmit Clock control)
$0=$ Disable the transmitter; any word being shifted out will continue until completion.
$1=$ Enable the transmitter.
$0=$ No effect on TE or RE.
1 = Causes RE to be set to a " 1 " and TE to be set to a " 0 " automatically at the end of a transmission.
$0=$ Disables loopback mode.
1 = Causes the transmitter output to be internally connected to receiver input. Also causes Timer $C$ to be used for both the transmit and receive clocks regardless of the state of TC, RC, TCO, and TCOC.

These bits provide control for wakeup operation as follows.

| TW1 | TW0 |  | OPERATION |
| :---: | :---: | :---: | :--- |
|  | 0 |  | Transmit Data |
| 1 | 1 |  | Transmit Address |
| 0 | $X$ |  | No Wake-up |

$0=$ Selects the external clock signal applied on TCLK for the transmit clock.
$1=$ Selects the internal baud rate generator output (Timer C) for the transmit clock.

This bit is ignored if either the TCO bit or the LM bit is set.

| P/S <br> (Previous/Sync control) | $0=$ Selects continuous transmission of the contents of the sync character register in the synchronous mode when there is no data to transmit. $1=$ Selects continuous transmission of the transmit data buffer in synchronous mode when there is no data to transmit. |
| :---: | :---: |
| BE <br> (Buffer Empty status) | $0=$ Transmit Buffer is full; reset to this condition after the transmit buffer is reloaded. <br> $1=$ Transmit Buffer is empty; set to this condition after the transmit buffer contents are transferred to the output shift register. |
| UE <br> (Underrun Error status) | $0=$ No underrun error; cleared following a read of the transmit buffer. <br> $1=$ Underrun error; set only in the synchronous mode when the last word has been shifted out and transmit buffer has not been reloaded. |
| END <br> (End of Transmission status) | $0=$ No end of transmission; cleared by enabling the transmitter. <br> $1=$ End of transmission detected; set when the transmitter is disabled and the last character has been shifted out. |

PORT 11- Timer B Latch; read gets counter value;
\$FC16 write goes to latch


PORT 12-Timer A, Low Latch; read gets counter or latch value; \$FC18 write goes to latch


PORT 13-Timer A, High Latch; read gets counter or latch value;
\$FC1A write goes to latch


PORT 14-Timer Control, Interrupt Edge Select; read/write \$FC1C

| T |  | X |  | T | T | T | T | T | T | T | T | T | T |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| E |  | 1 |  | C | A | A | A | A | A | B | B | B | B |
| S | (res) | 2 | (res) | 0 | M | M | E | 1 | 0 | M | M | E | 1 |
| T |  | C |  | C | 1 | 0 |  | C | C | 1 | 0 |  | C |
| 15 | 4 | 12 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bit Descriptions:

TEST
(Test mode control)

XI2C
(External Interrupt 2 Control)
TCOC
(Timer C Output Control)
$0=$ Normal operation; cleared on user control and on reset.
$1=$ Selects test mode; not to be used during normal operation.
$0=$ interrupt on falling edge of XI2.
$1=$ Interrupt on rising edge of XI2.
$0=$ When TCO $=1$, TCLK is selected for use as a general purpose I/O pin.
$1=$ When TCO $=1$, TCLK is selected for use as an output for Timer C.

TCOC has no effect when $T C O=0$.

TAM1, TAM0
(Timer A Mode control)
TAE
(Timer A Enable control)
TAIC
(Timer A Input Control)
TAOC
(Timer A Output Control)
TBM1, TBMO
(Timer B Mode control)

TBE
(Timer B Enable control)

TBIC
(Timer B Input Control)

These bits select the operating mode of Timer A as follows.

| TAM1 |  | TAMO |  | MODE |
| :---: | :---: | :---: | :--- | :--- |
|  |  |  |  |  |
| 0 | 1 |  | Everval |  |
| 0 |  |  |  | Event |
| 1 |  | 0 |  | Pulse/period 1 |
| 1 |  | 1 |  | Pulse/period 2 |

$0=$ Disables Timer A; all Timer A operations are inhibited, and the timer counter is initialized.
$1=$ Enables Timer A; the timer begins operation as defined by the other Timer A control bits.
$0=$ Selects a negative transition as the active edge for TAI.
$1=$ Selects a positive transition as the active edge for TAI.
$0=$ Selects TAO as a general purpose output pin.
$1=$ Selects TAO as an ouput pin associated with Timer A; TAO is initialized low when TAOC is a one and TAE is zero.

These bits select the operating mode of Timer B as described below.

| TBM1 | TBMO | MODE |
| :---: | :---: | :---: |
| 0 | 0 | Interval 0 (TBO is not used) |
| 0 | 1 | Interval 1 (TBO is used) |
| 1 | 0 | Retriggerable one-shot |
| 1 | 1 | Non-retriggerable one-shot |
| $0=$ Disables Timer B; all operations are inhibited, and the timer counter is initialized. <br> $1=$ Enables Timer B; the timer begins operation as defined by the other Timer $B$ control bits. |  |  |
|  |  |  |
| $0=$ Selects a negative transition as active on TBI. |  |  |
| $1=$ Selects a positive transition as active on TBI. |  |  |

PORT 15-Port 0 Handshake Mode, Fast/Standard, Bus Lock, and Bus \$FC1E Segment Bits; read/write


Bit Descriptions:

SEG1, SEG0 (Segment bits)

BLCK
(Bus Lock control)
F/S
(Fast/Standard timing control)

PM0, PM1, PM2, PM3 (Port Mode control)

| PM3 | PM2 | PM1 | PMO | HIGH HANDSHAKE | LOW HANDSHAKE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Inactive | PLO or PO output |
| 0 | 0 | 0 | 1 | PHO output | PLO output |
| 0 | 0 | 1 | 0 | Inactive | PLO input |
| 0 | 0 | 1 | 1 | PHO input | PLO input |
| 0 | 1 | 0 | 0 | PHO input | PLO ouput |
| 0 | 1 | 0 | 1 | Inactive | PO input (word only) |
| 0 | 1 | 1 | 0 | PLO output | PLO input (bidirectional) |
| 0 | 1 | 1 | 1 | PO output | PO input (bidirectional) |
| - | - | - | - |  |  |
| 1 | 1 | 0 | 0 | Inactive | Inactive |
| - | - | - | - |  |  |
| 1 | 1 | 1 | 0 | Full Expansion (62K | external bus) |
| 1 | 1 | 1 | 1 | Partial Expansion (16 | K external bus) |

PORT 16-Port 0 Data Direction Control (DDR0); read/write \$FC20


PORT 17-Port 1 Data Direction Control (DDR1); read/write \$FC22

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |  | 0 |

0 -Corresponding Port 1 bit is input.
1-Corresponding Port 1 bit is output.
PORT 18-Serial I/O Mode and Sync Register; read/write
\$FC24

| A | W | W | S | P | P | T | W | S | S | S | S | S | S | S | S |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| l | L | L | T | A | A | C | S | Y | Y | Y | Y | Y | Y | Y | Y |
| S | 1 | 0 |  | R | R | O |  | N | N | N | N | N | N | N | N |
|  |  |  |  | 1 | 0 |  |  | C | C | C | C | C | C | C | C |
|  |  |  |  |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Bit Descriptions:

## $A / \bar{S}$

(Asynchronous/Synchronous mode control)

WL1, WLO
(Word Length control)
$0=$ Selects synchronous operation for the serial port; transmit and receive clocks are divided by 1.
1 = Selects asynchronous operation for serial port; transmit and receive clocks are divided by 16.

These two bits select the length of the data word as follows.

| WL1 | WLO | Word Length |
| :---: | :---: | :---: |
| 0 | 0 | 8 bits |
| 0 | 1 | 7 bits |
| 1 | 0 | 6 bits |
| 1 | 1 | 5 bits |

ST
(Stop Bit control)

PAR1, PARO (Parity control)

TCO
(Timer C Output mode control)

WS
(Wake-up Sense)

SYNC7-SYNC0
(Sync character bits)

This bit is only used in the asynchronous mode. It selects the number of stop bits transmitted.

| $\frac{\text { ST }}{0}$ | Number of Stop Bits |
| :---: | :---: |
|  |  |

These two bits provide parity control for both the synchronous and asynchronous modes.

| PAR1 |  | PAR0 |  | Parity |
| :---: | :---: | :---: | :--- | :--- |
|  |  |  | 0 |  |
| 0 |  | 1 |  | fixed " 0 "" parity |
| 1 |  | 0 |  | odd parity |
| 1 |  | 1 |  | even parity |

Note that even parity is defined such that the sum of the data and parity bits is even.
$0=$ Disables Timer C output mode. $1=$ Enables Timer C output mode; disables Timer C's use as a baud rate generator when LM = 0 ; causes transmit and receive clocks to be internally connected to RCLK so that TCLK may be used either as general purpose I/O or as an output for Timer C.

The following table lists the effects of the WS bit.

| WS | Wake-up bit | Meaning |
| :---: | :---: | :---: |
| 0 | 0 | Address Word |
| 0 | 1 | Data Word |
| 1 | 0 | Data Word |
| 1 | 1 | Address Word |

These eight bits are used to store the
sync character or the device address for the wake-up mode.

PORT 19-Timer C Latch; read gets counter, write goes to latch and counter \$FC26


## ELECTRICAL SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS

| Temperature Under Bi | $-25^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin with Respect to Ground. | -0.3 V to +7 V |
| Power Dissipation | 1.5 W |

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 sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## MK68200 DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{a}}=0^{\circ}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST <br> CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input low voltage; all inputs | -0.3 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input high voltage; all inputs | 2.0 | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output low voltage; all outputs |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output high voltage; all outputs | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-250 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Input power supply current |  | 220 | mA | Outputs Open |
| $\mathrm{I}_{\mathrm{LI}}$ | Input leakage current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Three-state output leakage current in <br> float |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0.4 \mathrm{~V}$ to |
| $\mathrm{V}_{\mathrm{CC}}$ |  |  |  |  |  |

## CAPACITANCE

$T_{a}=25^{\circ} \mathrm{C}, \mathrm{f}=12 \mathrm{MHz}$ with unmeasured pins returned to ground.

| SYMBOL | PARAMETER | MAX | UNIT | TEST CONDITION |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 10 | pF | Unmeasured pins <br> returned to <br> ground |
| $\mathrm{C}_{\text {OUT }}$ | Three-state Output Capacitance | 10 | pF |  |

## MK68200 AC ELECTRICAL SPECIFICATIONS

$T_{a}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.
$A C$ measurements are referenced from minimum $\mathrm{V}_{\mathrm{IH}}$ or maximum $\mathrm{V}_{\mathrm{IL}}$ for inputs and from minimum $\mathrm{V}_{\mathrm{OH}}$ or maximum $\mathrm{V}_{\mathrm{OL}}$ for outputs.

| NO. | DESCRIPTION | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 1 | RESET low time | 20 |  | 20 |  | state times | 1 |
| 2 | CLK 1 width high (external clock input) | 45 |  | 30 |  | ns |  |
| 3 | CLK 1 width low (external clock input) | 45 |  | 30 |  | ns |  |
| 4 | CLK 1 period (external clock input) | 125 | 1000 | 83 | 1000 | ns |  |
| 5 | Crystal input frequency | 1.000 | 8.000 | 1.000 | 12.000 | MHz |  |
| 6 | Clock Period (PHI 1) | 250 |  | 167 |  | ns |  |
| 7 | PHI 1 low to PHI 1 high | 125 |  | 83 |  | ns |  |
| 8 | PHI 1 high to PHI 1 low | 125 |  | 83 |  | ns |  |
| 9 | PHI 1 low to CLKOUT low |  | 40 |  | 27 | ns |  |
| 10 | PHI 1 high to CLKOUT high |  | 40 |  | 27 | ns |  |

MK68200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (UPC, GP, AND PRIVATE BUSES)

| NO. | DESCRIPTION | 4MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 11 | PHI 1 low to $\mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{HB}}$, or $\overline{\mathrm{LB}}$ valid |  | 115 |  | 76 | ns | 2 |
| 12 | PHI 1 high to $\overline{\text { AS }}$ low |  | 115 |  | 76 | ns | 2 |
| 13 | PHI 1 low to address valid |  | 115 |  | 76 | ns | 2 |
| 14 | $\overline{\text { AS }}$ low to address invalid | 70 |  | 50 |  | ns | 2 |
| 15 | PHI 1 low to tri-state address |  | 90 |  | 60 | ns | 2 |
| 16 | Tri-state address to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or UDS starting low (fast cycle) | 10 |  | 10 |  | ns | 2 |
| 17 | PHI 1 low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ low (fast cycle) |  | 165 |  | 110 | ns | 2 |
| 18 | PHI 1 low to data out valid during write |  | 115 |  | 76 | ns | 2 |
| 19 | PHI 1 low to $\mathrm{R} \overline{\bar{W}}, \overline{\mathrm{HB}}, \overline{\mathrm{LB}}$ invalid | 0 |  | 0 |  | ns | 2 |
| 20 | PHI 1 low to address/data bus driven | 0 |  | 0 |  | ns | 2 |
| 21 | $\overline{\mathrm{AS}}$ low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ starting low (fast cycle) | 100 | 225 | 70 | 150 | ns | 2 |

MK68200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS
(UPC AND GP BUSES)

| NO. | DESCRIPTION | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 22 | Tri-state address to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or UDS starting low (standard cycle) | 135 |  | 90 |  | ns |  |
| 23 | PHI 1 high to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ low (standard cycle) |  | 165 |  | 110 | ns | 2 |
| 24 | Valid Data Setup to PHI 1 low | 10 |  | 5 |  | ns | 2 |
| 25 | $\overline{\mathrm{A} S}$ low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ starting low (standard cycle) | 225 | 350 | 150 | 230 | ns | 2 |
| 26 | $\mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{HB}}$, or $\overline{\mathrm{LB}}$ valid to $\overline{\mathrm{AS}}$ starting low | 60 |  | 60 |  | ns |  |
| 27 | Address valid to $\overline{\mathrm{AS}}$ starting low | 60 |  | 60 |  | ns |  |
| 28 | Input data hold time from PHI 1 low | 45 |  | 30 |  | ns |  |
| 29 | Input data hold time from $\overline{\mathrm{DS}}$, $\overline{\text { LDS, }}$ or UDS high | 0 |  | 0 |  | ns |  |
| 30 | PHI 1 low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ high |  | 180 |  | 120 | ns |  |
| 31 | $\overline{\text { DTACK }}$ low setup to PHI 1 high | 15 |  | 10 |  | ns |  |
| 32 | $\overline{\text { LDS }}, \overline{U D S}$, or $\overline{\mathrm{DS}}$ high to DTACK high (hold time) | $-30$ |  | $-30$ |  | ns |  |
| 33 | प̄DS, $\overline{\text { UDS }}$, or $\overline{\mathrm{DS}}$ pulse width | 240 |  | 150 |  | ns |  |
| 34 | PHI 1 high to $\overline{\mathrm{AS}}$ high |  | 90 |  | 60 | ns |  |
| 35 | PHI 1 low to data out invalid | 0 |  | 0 |  | ns |  |
| 36 | $\overline{\mathrm{AS}}$ inactive | 235 |  | 150 |  | ns |  |
| 37 | $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ high to data out invalid | 180 |  | 110 |  | ns |  |
| 38 | $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ high to $\overline{\mathrm{AS}}$ high | 5 |  | 5 |  | ns |  |

MK68200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (UPC BUS)

| NO. | DESCRIPTION | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 39 | $\overline{\text { BGACK }}$ low to $\overline{B R}$ high | 100 | 450 | 100 | 300 | ns |  |
| 40 | $\overline{\mathrm{BG}}$ low to $\overline{\mathrm{BGACK}}$ low | 50 | 600 | 50 | 400 | ns |  |
| 41 | $\overline{\text { BGACK, }} \overline{\text { AS }}, \overline{\mathrm{DTACK}}$, inactive to $\overline{B G A C K}$ low; $\overline{B G}$ already low | 0 | 600 | 0 | 400 | ns |  |
| 42 | $\overline{\mathrm{BGACK}}$ low to $\overline{\mathrm{AS}}, \overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}$, or address/data bus driven | 40 | 135 | 40 | 90 | ns |  |
| 43 | $\overline{\mathrm{AS}}, \overline{\mathrm{LDS}}, \overline{\mathrm{UDS}}$ or address/data bus tri-state to BGACK high | 0 | 180 | 0 | 120 | ns |  |

MK68211 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (GP BUS)

| NO. | DESCRIPTION | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 44 | Tri-state $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{LB}}, \overline{\mathrm{HB}}$ to BUSOUT low (bus grantor, fast cycle, (no wait states) | 175 |  | 100 |  | ns |  |
| 45 | $\overline{\text { BUSIN }}$ low to $\overline{\text { BUSOUT }}$ low (bus grantor, fast cycle, no wait states) |  | 1900 |  | 1200 | ns |  |
| 46 | $\overline{B U S O U T}$ high to $\overline{A S}, R \bar{W}, \overline{L B}$, $\overline{\mathrm{HB}}$ driven (bus grantor) | 15 |  | 15 |  | ns |  |
| 47 | $\overline{B U S I N}$ high to $\overline{B U S O U T}$ high (bus grantor) | 520 | 900 | 300 | 600 | ns |  |
| 48 | Tri-state address/data bus to BUSOUT low (bus grantor) | 70 |  | 70 |  | ns |  |
| 49 | $\overline{\text { BUSOUT }}$ high to address/data bus driven (bus grantor) | 50 |  | 50 |  | ns |  |
| 50 | $\overline{\text { BUSOUT }}$ low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}$, $\overline{\mathrm{LB}}, \overline{\mathrm{HB}}$ driven (bus requestor, BUSIN low) | 240 |  | 150 |  | ns |  |
| 51 | $\overline{B U S I N}$ low to $\overline{A S}, \overline{D S}, R / \bar{W}, \overline{L B}$, $\overline{\mathrm{HB}}$ driven (bus requestor, BUSOUT low) | 270 | 650 | 180 | 500 | ns |  |
| 52 | Tri-state $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{LB}}, \overline{\mathrm{HB}}$, to BUSOUT high (bus requestor) | 180 |  | 100 |  | ns |  |
| 53 | $\overline{B U S O U T}$ high to BUSIN high (bus requestor) |  | 530 |  | 400 | ns |  |
| 54 | $\overline{\text { BUSIN }}$ low to address/data bus driven (bus requestor) | 350 |  | 250 |  | ns |  |
| 55 | Tri-state address/data bus to BUSOUT high (bus requestor) | 100 |  | 65 |  | ns |  |

MK68E200 BUS AC ELECTRICAL SPECIFICATIONS (PRIVATE BUS)

| NO. | DESCRIPTION | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 56 | Valid Data Setup to PHI 1 low | 30 |  | 20 |  | ns |  |
| 57 | PBR/ $\bar{W}$ valid to $\overline{\text { PBAS }}$ starting low | 40 |  | 40 |  | ns |  |
| 58 | Address valid to $\overline{\text { PBAS }}$ starting low | 35 |  | 35 |  | ns |  |
| 59 | Input data hold time from PHI 1 low | 0 |  | 0 |  | ns |  |
| 60 | Input data hold time from $\overline{\text { PBDS }}$ high | -25 |  | -25 |  | ns |  |

MK68E200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (PRIVATE BUS) (Cont.)

| NO. | DESCRIPTION | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| 61 | PHI 1 low to PBDS high |  | 160 |  | 105 | ns |  |
| 62 | PBDTACK low setup to PHI 1 high | 20 |  | 15 |  | ns |  |
| 63 | $\overline{\text { PBDS }}$ high to $\overline{\text { PBDTACK high }}$ (hold time) | -15 |  | -15 |  | ns |  |
| 64 | $\overline{\text { PBDS }}$ pulse width | 190 |  | 125 |  | ns |  |
| 65 | PHI 1 high to $\overline{\text { PBAS }}$ high |  | 115 |  | 75 | ns |  |
| 66 | PHI 1 low to data out invalid | 10 |  | 10 |  | ns |  |
| 67 | PBAS inactive | 200 |  | 135 |  | ns |  |
| 68 | $\overline{\text { PBDS }}$ high to data out invalid | 200 |  | 135 |  | ns |  |
| 69 | $\overline{\text { PBDS }}$ high to $\overline{\text { PBAS }}$ high | 15 |  | 15 |  | ns |  |

MK68200 INPUT/OUTPUT AC ELECTRICAL CHARACTERISTICS

| NO. | DESCRIPTION |  | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |  |
| 70 | Active and inactive pulse times | XI2, XI1, RH, STRL, , TBI, $\overline{\text { NMI }}$ | 5 |  | 5 |  | state times | 1 |
|  |  | XIO | 3 |  | 3 |  |  |  |
| 71 | Input data setup to falling edge of STRH, STRL |  | 15 |  | 10 |  | ns |  |
| 72 | Input data hold from the falling edge of STRH, STRL |  | 60 |  | 40 |  | ns |  |
| 73 | RDYH, RDYL low time |  | 1 | 3 | 1 | 3 | state <br> times | 1 |
| 74 | Delay from STRH, STRL high to RDYH, RDYL low |  |  | 110 |  | 75 | ns |  |
| 75 | Delay from data valid to RDYH, RDYL high (output mode) |  |  | 3 |  | 3 | state times | 1 |
| 76 | Delay from STRH high to data out (bidirectional mode) |  |  | 90 |  | 60 | ns |  |
| 77 | Port 0 data hold time from STRH low (bidirectional mode) |  | 25 |  | 20 |  | ns |  |
| 78 | Delay to Port 0 float from STRH low (bidirectional mode) |  |  | 85 |  | 55 | ns |  |
| 79 | TCLK,RCLK period (asynchronous) | as input | . 250 | DC | . 167 | DC | $\mu \mathrm{S}$ |  |
|  |  | as output | . 500 | DC | . 334 | DC |  |  |
|  | TCLK,RCLK period (synchronous) |  | 1.0 | DC | . 667 | DC |  |  |
| 80 | TCLK, RCLK width low | as input | 1 | DC | 1 | DC | state | 1 |
|  |  | as output | 2 | DC | 2 | DC |  |  |
| 81 | TCLK, RCLK width high | as input | 1 | DC | 1 | DC | state <br> times | 1 |
|  |  | as output | 2 | DC | 2 | DC |  |  |

MK68200 INPUT/OUTPUT AC ELECTRICAL SPECIFICATIONS

| NO. | DESCRIPTION |  | 4 MHz |  | 6 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |  |
| 82 | TCLK low to SO delay (sync mode) | TCLK as input | 330 |  | 220 |  | ns |  |
|  |  | TCLK as output | 75 |  | 50 |  |  |  |
| 83 | SI to RCLK high setup time (sync mode) | RCLK as input | 30 |  | 20 |  | ns |  |
|  |  | RCLK as output | 180 |  | 120 |  |  |  |
| 84 | SI hold time from RCLK high (sync mode) | RCLK as input | 45 |  | 30 |  | ns |  |
|  |  | RCLK as output | 0 |  | 0 |  |  |  |

## NOTES

1. One state time is equal to one-half of the instruction clock (PHI 1) period.
2. For the private bus case, the signals referenced apply to the equivaient private bus signals.

## LOAD 1



TEST LOAD 2 IS APPLICABLE TO P1-12 AND P1-8.

TEST LOAD 1 IS APPLICABLE TO
ALL PINS EXCEPT P1-12 AND P1-8.

Figure 21. Output Test Load

CLK 1
(EXTERNAL CLOCK SIGNAL)
$\overline{\text { RESET }}$

XI2, XI1, XIO, TAI, TBI, NMI STRL, STRH


Figure 22. MK68200 AC Timing


Figure 23. MK68201 UPC Bus Timing (Fast Cycle)


Figure 24. MK68201 UPC Bus Timing (Standard Cycle)


Figure 25. MK68201 UPC Bus Arbitration Timing


Figure 26. MK68211 GP Bus Timing (Fast Cycle)


Figure 27. MK68211 GP Bus Timing (Standard Cycle)


Figure 28. MK68211 GP Bus Timing (Interrupt Acknowledge Timing)


Figure 29. MK68211 GP Bus Arbitration Timing (Bus Grantor)


Figure 30. MK68211 GP Bus Arbitration Timing (Bus Requestor)


Figure 31. MK68200 Private Bus Timing (Fast Cycle)


Figure 32. Input/Output AC Timing (Data Input)


Figure 33. Input/Output AC Timing (Data Output)


Figure 34. Input/Output AC Timing (Bidirectional I/O)


Figure 35. Input/Output AC Timing (Serial I/O)

## PART NUMBERING INFORMATION

There are two types of part numbers for the 68200 family of devices. The generic part number describes the basic device type, the amount of ROM and RAM,
the desired package type, temperature range, power supply tolerance, and expandable bus interface type. The device order number indicates the specific mask set Mostek will use to manufacture the device, along with package type, speed grade and temperature range.

## Generic Part Number

An example of the generic part number is shown below:


[^43]
## Device Order Number

An example of the device order number is shown below:


## NOTES

1. Available for emulator only.
2. Intended for prototype orders only.
3. Contact Mostek for availability.

| PART NUMBER EXAMPLES (A noninclusive list) |  |
| :---: | :---: |
| MK68201/44N-04 | ```Device Order Number = MK41XXXN-04 Speed =4MHz Temperature = 0 to 70 C Package =48 pin plastic RAM = 256 bytes ROM = 4096 bytes Bus = UPC``` |
| MK68211/04N-06 | ```Device Order Number = MK42002N-06 Speed = 6MHz Temperature = 0 to 70 % Package = 48 pin plastic RAM = 256 bytes ROM = None Bus = GP``` |
| MK68E211/04E-14 | ```Device Order Number = MK40010E-14 Speed = 4MHz Temperature = -40 to +85 % Package = 84 pin ceramic LCC RAM = 256 bytes ROM = None Bus = GP``` |
| MK68E221/0CG-06 | ```Device Order Number = MK40020G-06 Speed = 6MHz Temperature = 0 to 70 % Package = 84 lead PGA RAM = 1024 bytes ROM = None Bus = GP/UPC``` |

MK68200 48-Pin Plastic Dual-In-Line Package ( N )


|  | MILLIMETERS |  | INCHES |  |
| :---: | ---: | ---: | ---: | ---: |
| DIM. | MIN | MAX | MIN | MAX |
| A | 61.468 | 62.738 | 2.420 | 2.470 |
| B | 14.986 | 16.256 | 0.590 | 0.640 |
| C | 13.462 | 13.97 | 0.530 | 0.550 |
| D | 3.556 | 4064 | 0.140 | 0.160 |
| E | 0.381 | 1.524 | 0.015 | 0.060 |
| F | 3048 | 3.81 | 0.120 | 0.150 |
| G | 1.524 | 2.286 | 0.060 | 0.090 |
| H | 1.186 | 1.794 | 0.090 | 0.110 |
| J | 15.24 | 17.78 | 0.600 | 0.700 |
| K | 0.381 | 0.533 | 0.015 | 0.021 |
| L | 0.203 | 0.305 | 0.008 | 0.012 |
| M | 1.143 | 1.778 | 0.045 | 0.070 |

MK68200 48-Pin Ceramic Dual-In-Line

## Package ( P )



| DIM. | INCHES |  | NOTES |
| :---: | :---: | :---: | :---: |
|  | MIN. | MAX. |  |
| A | . 085 | . 190 |  |
| A 1 | . 020 | . 070 | 1 |
| B | . 015 | . 023 |  |
| B ${ }_{1}$ | . 038 | . 060 |  |
| C | . 008 | . 012 |  |
| D | 2.370 | 2.430 |  |
| E | . 595 | . 625 |  |
| $E_{1}$ | . 580 | . 610 |  |
| e | . 590 | . 700 | 2 |
| $\mathrm{e}_{1}$ |  |  |  |
| L | . 120 | . 170 |  |
| Q ${ }_{1}$ |  |  |  |
| S | . 035 | 065 |  |



NOTES

1. Package stand off to be measured per JEDEC requirements.
2. Measured from centerline to centerline at lead tips.


| DIM. | INCHES |  |
| :---: | :---: | :---: |
|  | MIN | MAX |
| A | 1.138 | 1.167 |
| B | 1.138 | 1.167 |
| C | 0.070 | 0.090 |
| D | 0.080 | 0.110 |
| E | 0.044 | 0.056 |
| F | 0.044 | 0.056 |
| G | 0.075 | 0.095 |
| H | 0.048 | 0.052 |
| J | 0.033 | 0.039 |
| K | 0.010 | 0.018 |
| L | 0.495 | 0.505 |
| M | 0.495 | 0.505 |



| LCC | FUNCTION | LCC | FUNCTION | LCC | FUNCTION | LCC | FUNCTION |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | P1-4/XIO | 24 | P4-8/RDYL | 44 | P0-6 | 65 | PB-9 |
| 2 | P1-5/XI1 | 25 | P4-9/RDYH | 45 | P0-5 | 66 | PB-10 |
| 3 | P1-6/XI2 | 26 | P4-10/STRL | 46 | P0-4 | 67 | PB-11 |
| 4 | P1-7 | 27 | P4-11/STRH | 47 | P0-3 | 68 | PB-12 |
| 5 | P1-8 | 28 | MODE | 48 | P0-2 | 69 | PB-13 |
| 6 | P1-9 | 29 | CLK2 | 49 | P0-1 | 70 | PB-14 |
| 7 | P1-10 | 30 | CLK2 | 50 | P0-0 | 71 | PB-15 |
| 8 | P1-11 | 31 | CLKOUT | 51 | FC2 + | 72 | P4-13/TAI |
| 13 | GP/UPC | 32 | FC1 + | 54 | VCC | 73 | P4-12/TBI |
| 14 | P1-12 | 34 | GROUND | 55 | GROUND | 76 | P4-15/TAO |
| 15 | P1-13 | 35 | P0-15 | 56 | PB-0 | 77 | P4-14/TBO |
| 16 | P1-14 | 36 | P0-14 | 57 | PB-1 | 78 | RESET |
| 17 | P1-15 | 37 | P0-13 | 58 | PB-2 | 79 | NMI |
| 18 | PBLB | 38 | P0-12 | 59 | PB-3 | 80 | P1-0/SO |
| 19 | PBHB | 39 | P0-11 | 60 | PB-4 | 81 | P1-1/TCLK |
| 20 | PBR/W | 40 | P0-10 | 61 | PB-5 | 82 | P1-2/RCLK |
| 21 | PBDTACK | 41 | P0-9 | 62 | PB-6 | 83 | P1-3/SI |
| 22 | PBAS | 42 | P0-8 | 63 | PB-7 | 84 | VCC |
| 23 | PBDS | 43 | P0-7 | 64 | PB-8 |  |  |

+ AVAILABLE ON MK68E221 (1K RAM VERSION)

Figure 36. MK68E200 Pin Assignment, Emulator Version

COMPONENTS

## FEATURES

$\square$ 16-bit high performance, single-chip microcomputer
$\square$ Modular architecture
$\square$ Power saving stop and idle modes
$\square 14$ address and data registers

- Eight 16-bit or sixteen 8-bit data registers
- Six 16-bit address registers
$\square$ Advanced 16-bit instruction set
- Bit, byte and word operands
- Nine addressing modes
- Byte and word BCD arithmetic

High performance (12.5 MHz instruction clock)
$-0.24 \mu$ s register-to-register move or add
$-1.68 \mu \mathrm{~s} 16 \times 16$ multiply
$-1.84 \mu \mathrm{~s} 32 / 16$ divide
$\square$ Available with 0 or 4 k bytes of ROM

- 256 bytes of RAM
$\square$ Three 16-bit timers
- Interval modes
- Event modes
- One-shot modes
- Pulse and period measurement modes

Serial channel

- Double buffered receive and transmit
- Asynchronous to 781 Kbps
- Synchronous to 3.125 Mbps
- Address wake-up recognition and generation
- Internal/external baud rate generation

Parallel I/O

- Up to 40 pins
- Direction programmable by bit
- One 16 -bit or 28 -bit port(s) with handshaking
$\square$ Interrupt controller
- 16 independent vectors
- Expandable to handle an unlimited number of interrupts
- Eight external interrupt sources
- One non-maskable interrupt
- Individual interrupt masking

Optional external bus

- 16-bit multiplexed address/data bus
- Automatic bus request/grant arbitration
- Two control bus versions
- 68000 compatible bus (UPC) (MK68HC201)
- General Purpose bus (GP) (MK68HC211)

Emulator version available

- Added private bus
- No on-chip ROM
- 512 bytes on-chip RAM
- GP or UPC bus version with one part (MK68HC221)16,20 , and 25 MHz time base versions produce 8 , 10 and 12.5 MHz instruction clock rates respectively
- Crystal or external TTL clock

Single +5 volt power supplyPlastic or Ceramic Chip carrier packaging

## GENERAL DESCRIPTION

MK68HC200 designates a series of new highperformance, 16-bit, single-chip microcomputers from Thomson Components - Mostek Corporation. Implemented in 1.5 micron HCMOS technology, they incorporate an architecture designed for superior performance in computation-intensive control applications. A modern, comprehensive instruction set (which features both high speed execution and code space efficiency) is combined on-chip with extensive, flexible I/O capabilities. On-chip RAM and optional on-chip ROM are provided with a full 64K byte addressing space.

The MK68HC200 can be used to design a true application specific microcontroller. The circuit is partitioned into three major functional blocks: CPU, memory, and I/O. The CPU is the core of the circuit and communicates with the memory via the memory address and data bus, and with the I/O via the I/O bus. New I/O or
memory modules can be designed and added to the CPU core to customize the MK68HC200 for a particular application. The initial product offerings in the MK68HC200 family will contain I/O and memory fea-
tures listed abuve. This is consistent with the features available on the NMOS MK68200. Future product offerings will contain various assortments of on-chip l/O and memory modules.


Figure 1. MK68HC200 - Modular Architecture Concept


Figure 2. MK68HC201, MK68HC211 Logical Pinout, Single-Chip Mode

## SINGLE-CHIP DESCRIPTION

Figure 2 illustrates the functions of specific pins for an MK68HC201 or MK68HC211, operating in a single-chip mode. When the device is operating in one of the expanded bus modes, the pins on Port 0 become the multiplexed address/data bus, and the upper half of

Port 1 becomes the control signals (GP or UPC) for the bus. The following description applies to the pins only when the device is used in the non-expanded or singlechip mode. Descriptions of the pin functions for the expanded bus modes are in the Expanded Bus Operation section of this data sheet.

| MNEMONIC | PIN FUNCTIONS FOR SINGLE-CHIP OPERATION |
| :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage 4.5 to 5.5 V |
| GND | Ground |
| RESET | Reset (input, active low) - $\overline{\text { RESET input overrides ongoing execution (including interrupts) }}$ and resets the chip to its initial power-up condition. RESET cannot be masked. |
| CLKOUT | Clock Output (output) - CLKOUT will output the instruction clock rate, which is one-half of the frequency provided on CLK1 and CLK2. |
| CLK1, CLK2 | Time base inputs (inputs) - CLK1 and CLK2 may be connected to a crystal, or CLK1 may be connected to an external TTL-compatible oscillator while CLK2 is left floating. |
| $\overline{\text { NMI }}$ | Non-maskable interrupt (input, active low, negative edge triggered) - The $\overline{\text { NMI }}$ request line has a higher priority than all of the maskable interrupts. NMI is always enabled regardless of the state of the LIE (Level 1 Interrupt Enable) bit in the Status Register. |
| MODE | Mode (input) - The MODE pin has three states, which select fully expanded external bus, partially expanded external bus, or no expanded bus (single-chip configuration). |
| PO-0 - P0-15 | Port 0 (input/output) - Each bit in Port 0 may be individually programmed for general purpose input or output. Port 0 also has several handshaking modes to allow parallel, asynchronous communication with other devices. The high and low bytes may be programmed individually or jointly to be inputs, outputs, or bidirectional. |
| P1-0 - P1-15 | Port 1 (input/output) - Each of the 16 bits in Port 1 may be individually programmed for input or output. Additionally, the lowest seven bits of Port 1 may be programmed to serve specific alternate functions as shown below. |
| P1-6/XI2 | External Interrupt 2 (input, rising or falling edge triggered) - The programmer may select the rising or falling edge as active for XI2. |
| P1-5/XI1 | External Interrupt 1 (input, falling edge triggered) - The XII may be used to interrupt the MK68HC200 on the falling edge of an input pulse. |
| P1-4/X10 | External Interrupt 0 (input, low level triggered) - The XIO interrupt input is level triggered (unlike XI1 and XI2). It may be used to produce an internally vectored interrupt or to cause an external fetch of an interrupt vector number when the MK68HC200 is used in an expanded mode with the GP bus. |
| P1-3/SI | Serial Input (input, active high) - SI is used to receive serial data when the receiver is enabled. |
| P1-2/RCLK | Receive Clock (input/output, active high) - Depending on the mode programmed, RCLK can be used by the serial port as either an input or an output pin. When used as an input pin, RCLK provides the receive clock and/or the transmit clock. When RCLK is not providing the transmit or receive clock, it can be used as an output for Timer C. In this mode, the receive clock is being provided by Timer C. |
| P1-1/TCLK | Transmit Clock (input/output, active high) - Depending on the mode programmed, TCLK can be used by the serial port as either an input or an output pin. When used as an input pin, TCLK provides the transmit clock. When TCLK is not providing the transmit clock, it can be used as an output for the Timer C. In this mode, the transmit clock is being provided by either Timer C or RCLK. |
| P1-0/SO | Serial Output (output, active high) - SO is used to transmit serial data when the transmitter is enabled. |


| MNEMONIC | PIN FUNCTIONS FOR SINGLE-CHIP OPERATION |
| :---: | :--- |
| P4-8-P4-15 | Port 4 (inputs and outputs) - P4-8, P4-9, P4-14, and P4-15 may be used as general purpose <br> outputs, and P4-10, P4-11, P4-12, and P4-13 may be used as general purpose inputs. Inter- <br> rupts may be generated on the positive transitions on P4-10 and P4-11. Depending on the <br> mode selected, interrupts may be generated on the positive or the negative transitions on <br> P4-12, and they may be generated on the positive, negative or combined transitions on <br> P4-13. Additionally, these bits may be programmed to serve specific alternate functions, <br> as listed below. |
| P4-15/TAO | Timer A Output (output) - TAO may be programmed for special functions in the interval, <br> event, and pulse/period modes for Timer A. In the interval mode, TAO's state is determined <br> by the Timer A latch (high and low) that is currently active. That is, if the counter is using <br> the high latch for comparison, TAO is high. In the event mode, TAO is initialized to a "1" <br> state and toggles each time the counter matches the Timer A high latch. In the pulse/period <br> modes, TAO is initialized to a "1" state and toggles on positive transitions on TAI. |
| P4-14/TBO | Timer B Output (output) - TBO may be programmed for special functions in the interval <br> and one-shot modes for Timer B. In the interval mode, TBO is initialized to a " 1 " state and <br> toggles each time the counter matches the Timer B latch value. In the one-shot modes <br> TBO is initialized to a "1" state, and the counter begins counting in response to the occur- <br> rence of an active edge on TBI. TBO will not go low until the counter matches the value <br> loaded into the Timer B latch. |
| P4-13/TAI | Pimer A Input (input, positive and/or negative edge triggered) - TAI may be programmed <br> P4-11/STRH, <br> for special functions in the event mode or the pulse/period modes for Timer A. In the event <br> mode, the counter is incremented on each active transition (positive or negative edge <br> programmable) on TAI. In the pulse/period modes, the counter measures the time during <br> which the signal on TAI remains high and low. |
| P4-10/STRL |  |

## MK68HC200 APPLICATIONS

The MK68HC200 is designed to serve the needs of a wide variety of control applications, which require high performance operation with a minimal parts count implementation. Industrial controls, instrumentation, and intelligent computer peripheral controls are all examples of applications served by the MK68HC200. High speed mathematical ability, rapid I/O addressing and interrupt response, and powerful bit manipulation instructions provide the necessary tools for these applications. In addition to its single-chip microcomputer configuration, both distributed intelligence and parallel multiprocessing system configurations are supported by the MK68HC200, as illustrated in Figures 10 and 11.

In applications requiring loosely-coupled distributed intelligence, several MK68HC200's may be interconnect-
ed on a common serial network. The on-chip USART supports a wake-up mode in which an additional bit is appended to the data stream to distinguish a serial data word as address or data. The wake-up logic prevents the serial channel from generating interrupts unless certain criteria have been met. The wake-up options available are: Wake-up on any address or data character, wake-up on any address, or wake-up on address match.

Alternately, the MK68HC200 may be configured as an expandable CPU device which can access external memory and I/O resources. In this operating mode, parallel I/O pins are replaced by multiplexed address/data and control lines. Bus arbitration logic is incorporated on the chip to support a direct interface in parallel shared bus multiprocessor system configurations. Two versions exist which support two types of con-
trol signals present on the expanded bus configuration. The General Purpose (GP) bus option allows the MK68HC200 to operate either as an executive or a peripheral processor. As an executive processor, the MK68HC200 can control an external system bus and grant the use of it to requesting devices, such as DMA controllers and/or peripheral processors. As a peripheral control processor, the MK68HC200 can provide intelligent local control of an I/O device in a computer system and, thereby, relieve the executive processor of these tasks. In this configuration, the MK68HC200 has the capability of effectively performing DMA transfers between system memory and the I/O device. The onchip resources of ROM, RAM, and I/O are accessed within the MK68HC200 without affecting utilization of the shared system bus. Therefore, only external communications compete for bus bandwidth.

The Universal Peripheral Controller (UPC) bus option supports a direct interface to a 68000 executive processor. Thus, the MK68HC200 can be used as a cost-
effective intelligent peripheral controller in 68000 systems. The UPC version's direct bus interface to the 68000 makes the MK68HC200 particularly well-suited for performing many intelligent I/O functions in a 68000 system. For example, since the MK68HC200 includes both a serial channel and an external bus capable of performing DMA transfers, it can be programmed to act as serial protocol controller with DMA capability.

For additional information on the MK68HC200 refer to the MK68HC200 Principles of Operation Manual, publication number 4430196.

## PROCESSOR ARCHITECTURE

The MK68HC200 microcomputer contains an advanced processor architecture, combining the best properties of both 8 - and 16 -bit processors. A large majority of instructions operate on either byte or word operands. Figure 3 summarizes the internal architecture of the MK68HC201 and MK68HC211.


Figure 3. MK68HC201, MK68HC211 Block Diagram

## REGISTERS

The MK68HC200 register set includes three system registers, six address registers, and eight data registers. The three 16 -bit system registers (Figure 4) include a Program Counter, a Status Register, and a Stack Pointer. The six address registers may be used either for 16 -bit data or for memory addressing. The eight 16 -bit data registers are used for data and may be referenced as sixteen 8 -bit registers, providing great flexibility in register allocation.

## ADDRESSING

The MK68HC200 directly addresses a 64 K byte memory space, which is organized as 32 K 16 -bit words. The memory is byte-addressable, but most transfers occur 16 bits at a time, for increased performance over 8 -bit microcomputers. All input/output is memorymapped, and the on-chip I/O is situated in the top 1 K bytes of the address space. In the single-chip mode, all resources including ROM, RAM, and I/O, are accessed via an internal or private bus. The memory map, which is accessed by this bus in the single-chip mode, is depicted in Figure 5. Note on-chip RAM always begins at \$FBFF and extends downward. ROM always begins at zero and extends upward.

Nine addressing modes provide ease of access to data in the MK68HC200, as depicted in Table 1. The four register indirect forms utilize the address registers and the Stack Pointer and support many common data structures such as arrays, stacks, queues, and linked lists. I/O Port addressing is a short form addressing mode for the first 16 words of the I/O port space and allows most instructions to access the most often referenced I/O ports in just one word. Many microcomputer
applications are I/O intensive and short, fast addressing of I/O has a significant impact on performance.

## INSTRUCTION SET

The MK68HC200 instruction set has been designed with regularity and ease of programming in mind. In addition, instructions have been encoded to minimize code space, a feature which is especially important in single-chip microcomputers. Small code space is related to execution speed, and most instructions execute in either three or six instruction clock periods. See Table 2 .

In addition to operations on bytes and words, the MK68HC200 has rapid bit manipulation instructions that can operate on registers, memory, and ports. The bit to be affected may be an immediate operand of the instruction, or it may be dynamically specified in a register. Operations available include bit set, clear, test, change, and exchange; and all bit operations perform a bit test as well. Since each instruction is indivisible, this provides the necessary test-and-set function for the implementation of semaphores.

The MOVE group of instructions has the most extensive capabilities. A wide variety of addressing mode combinations is supported including memory-tomemory transfers. A special move multiple is included to save and restore a specified portion of the registers rapidly.

In total, the MK68HC200 instruction set provides a programming environment, similar to the 68000, which has been optimized for the needs of the single-chip microcomputer marketplace. A summary of the instruction set is provided in Table 3.

## Table 1. Addressing Modes

> Register
> Register Indirect
> Register Indirect with Post-increment
> Register Indirect with Pre-decrement
> Register Indirect with Displacement
> Program Counter Relative
> Memory Absolute
> Immediate
> I/O Port

DATA REGISTERS:


ADDRESS REGISTERS:


SYSTEM REGISTERS:


Figure 4. Register Set


Figure 5. Addressing Space For Single-Chip Configuration

Table 2. Instruction Execution Times

| Instruction Type | Clock <br> Periods | Execution Time <br> with 8 MHz <br> Clock $(\mu \mathbf{s})$ | Execution Time <br> with 10 MHz <br> Clock $(\mu \mathbf{s})$ | Execution Time <br> with 12.5 MHz <br> Clock $(\mu \mathbf{s})$ |
| :--- | :---: | :---: | :---: | :---: |
| Move Register-to-register | 3 | 0.38 | 0.30 | 0.24 |
| Add Register-to-register (binary or BCD) | 3 | 0.38 | 0.30 | 0.24 |
| Move Memory-to-register | 6 | 0.75 | 0.60 | 0.48 |
| Add Régister-to-memory | 9 | 1.13 | 0.90 | 0.72 |
| Multiply (16 $\times 16$ ) | 21 | 2.63 | 2.10 | 1.68 |
| Divide (32/16) | 23 | 2.88 | 2.30 | 1.84 |
| Move Multiple (save or restore all registers) | 55 | 6.88 | 5.50 | 4.40 |

Table 3. Instruction Set Summary

| INSTRUCTION | DESCRIPTION | INSTRUCTION | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| ADD | ADD | JMPA | JUMP ABSOLUTE |
| ADD.B | ADD BYTE | JUMPR | JUMP RELATIVE |
| ADDC | ADD WITH CARRY | LIBA | LOAD INDEXED BYTE ADDRESS |
| ADDC.B | ADD WITH CARRY BYTE | LINK | LINK |
| AND | LOGICAL AND | LIWA | LOAD INDEXED WORD ADDRESS |
| AND.B | LOGICAL AND BYTE | LSR | LOGICAL SHIFT RIGHT |
| ASL | ARITHMETIC SHIFT LEFT | LSR.B | LOGICAL SHIFT RIGHT BYTE |
| ASL.B | ARITHMETIC SHIFT LEFT BYTE | MOVE | MOVE |
| ASR | ARITHMETIC SHIFT RIGHT | MOVE.B | MOVE BYTE |
| ASR.B | ARITHMETIC SHIFT RIGHT BYTE | MOVEM | MOVE MULTIPLE REGISTERS |
| BCHG | BIT CHANGE | MOVEM.B | MOVE MULTIPLE REGISTERS BYTE |
| BCLR | BIT CLEAR | MULS | MULTIPLY SIGNED |
| BEXG | BIT EXCHANGE | MULU | MULTIPLY UNSIGNED |
| BSET | BIT SET | NEG | NEGATE |
| BTST | BIT TEST | NEG.B | NEGATE BYTE |
| CALLA | CALL ABSOLUTE | NEGC | NEGATE WITH CARRY |
| CALLR | CALL RELATIVE | NEGC.B | NEGATE WITH CARRY BYTE |
| CLR | CLEAR | NOP | NO OPERATION |
| CLR.B | CLEAR BYTE | NOT | ONE'S COMPLEMENT |
| CMP | COMPARE | NOT.B | ONE'S COMPLEMENT BYTE |
| CMP.B | COMPARE BYTE | OR | LOGICAL OR |
| DADD | DECIMAL ADD | OR.B | LOGICAL OR BYTE |
| DADD.B | DECIMAL ADD BYTE | POP | POP |
| DADDC | DECIMAL ADD WITH CARRY | POPM | POP MULTIPLE REGISTERS |
| DADDC.B | DECIMAL ADD WITH CARRY BYTE | PUSH | PUSH |
| DI | DISABLE INTERRUPTS | PUSHM | PUSH MULTIPLE REGISTERS |
| DIVU | DIVIDE UNSIGNED | RET | RETURN FROM SUBROUTINE |
| DJNZ | DECREMENT COUNT AND JUMP IF NON-ZERO | RETI $\mathrm{ROL}$ | RETURN FROM INTERRUPT ROTATE LEFT |
| DJNZ.B | DECREMENT COUNT BYTE AND | ROL.B | ROTATE LEFT BYTE |
|  | JUMP IF NON-ZERO | ROLC | ROTATE LEFT THROUGH CARRY |
| DNEG | DECIMAL NEGATE | ROLC.B | ROTATE LEFT THROUGH CARRY |
| DNEG.B | DECIMAL NEGATE BYTE |  | BYTE |
| DNEGC | DECIMAL NEGATE WITH CARRY | ROR | ROTATE BYTE |
| DNEGC.B | DECIMAL NEGATE WITH CARRY | ROR.B | ROTATE RIGHT BYTE |
|  | BYTE | RORC | ROTATE RIGHT THROUGH CARRY |
| DSUB | DECIMAL SUBTRACT | RORC.B | ROTATE RIGHT THROUGH CARRY |
| DSUB.B | DECIMAL SUBTRACT BYTE |  | BYTE |
| DSUBC | DECIMAL SUBTRACT WITH CARRY | STOP | STOP |
| DSUBC.B | DECIMAL SUBTRACT WITH CARRY | SUB | SUBTRACT |
|  | BYTE | SUB.B | SUBTRACT BYTE |
| El | ENABLE INTERRUPTS | SUBC | SUBTRACT WITH CARRY |
| EOR | EXCLUSIVE OR | SUBC.B | SUBTRACT WITH CARRY BYTE |
| EOR.B | EXCLUSIVE OR BYTE | TEST | TEST |
| EXG | EXCHANGE | TEST.B | TEST BYTE |
| EXG.B | EXCHANGE BYTE | TESTN | TEST NOT |
| EXT | EXTEND SIGN | TESTN.B | TEST NOT BYTE |
| HALT | HALT | UNLK | UNLINK |
| IDLE | IDLE |  |  |

## INPUT/OUTPUT ARCHITECTURE

The I/O capabilities of the MK68HC200 are extensive, encompassing timers, a serial channel, parallel I/O, and an interrupt controller. All of these devices are accessible to the programmer as ports within the top 1 K bytes of the address space, and the most commonly accessed ports may be accessed with the short port addressing mode. A description of these ports is given in Table 4.

In total, 40 pins of the 48 are used for I/O, and their functions are highly programmable by the user. In particular, many pins can perform multiple functions, and the programmer selects which ones are to be used. For example, TAI may be used as an input for Timer A, an interrupt source, or a general purpose input pin. The interrupt source may be selected simultaneously with either of the other functions.

Table 4. Port Descriptions

| PORT | ADDRESS | READ/WRITE | BYTE- <br> ADDRESSABLE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 0 | \$FC00 | READ/WRITE | YES | 16 EXTERNAL I/O PINS OR ADDRESS/DATA BUS |
| 1 | \$FC02 | READ/WRITE | YES | 16 EXTERNAL I/O PINS (INCLUDING INTERRUPT, SERIAL I/O PINS, AND BUS CONTROL) |
| 2 | \$FC04 | - | - | (RESERVED) |
| 3 | \$FC06 | LOW BYTE: READ/WRITE HIGH BYTE: READ | YES | SERIAL TRANSMIT (LOW BYTE) AND RECEIVE (HIGH BYTE) BUFFER |
| 4 | \$FC08 | INPUTS: READ ONLY OUTPUTS: READ/WRITE | NO | 8 EXTERNAL I/O PINS (TIMER CONTROL AND PORT 0 HANDSHAKE CONTROL) |
| 5 | \$FCOA | - | - | (RESERVED) |
| 6 | \$FCOC | - | - | (RESERVED) |
| 7 | \$FCOE | READ/WRITE | NO | INTERRUPT LATCH REGISTER |
| 8 | \$FC10 | READ/WRITE | NO | INTERRUPT MASK REGISTER |
| 9 | \$FC12 | STATUS: READ ONLY CONTROL: READ/WRITE | NO | SERIAL I/O RECEIVE CONTROL AND STATUS |
| 10 | \$FC14 | STATUS: READ ONLY CONTROL: READ/WRITE | NO | SERIAL I/O TRANSMIT CONTROL AND STATUS |
| 11 | \$FC16 | READ GETS COUNTER WRITE GOES TO LATCH | NO | TIMER B LATCH |
| 12 | \$FC18 | READ GETS COUNTER OR LATCH <br> WRITE GOES TO LATCH | NO | TIMER A, LOW LATCH |
| 13 | \$FC1A | READ GETS COUNTER OR LATCH <br> WRITE GOES TO LATCH | NO | TIMER A, HIGH LATCH |
| 14 | \$FC1C | READ/WRITE | NO | TIMER AND HANDSHAKE CONTROL |
| 15 | \$FC1E | STATUS: READ ONLY CONTROL: READ/WRITE | NO | EXPANDED BUS CONTROL AND STATUS |
| 16 | \$FC20 | READ/WRITE | NO | PORT 0 DIRECTION CONTROL (DDRO) |
| 17 | \$FC22 | READ/WRITE | NO | PORT 1 DIRECTION CONTROL (DDR1) |
| 18 | \$FC24 | READ/WRITE | NO | SERIAL I/O MODE AND SYNC REGISTER |
| 19 | \$FC26 | READ GETS COUNTER WRITE GOES TO LATCH AND COUNTER | NO | TIMER C LATCH |

## TIMERS

The MK68HC200 includes three on-chip timers, each with unique features. They are denoted Timer A, Timer B, and Timer C. All three timers are a full 16 bits in width, and count at the instruction clock rate of the MK68HC200 processor. Thus, this rate provides a resolution equal to the instruction clock period (tc) of the MK68HC200. The maximum count interval is equal to tc $* 2^{16}$. Each timer has the capability to interrupt the processor when it matches a predetermined value stored in an associated latch.

Timer A is capable of operating in interval, event, or two pulse/period modes. There is one 16 -bit counter and two 16-bit latches, a high latch (Port 13), and a low latch (Port 12), associated with Timer A. Once Timer A is initialized in the interval mode, the counter is reset, then increments at the instruction clock rate until the value loaded into the high latch is reached. The counter is then reset, increments until the low latch value is reached, and the cycle is repeated. In the event mode, the counter is incremented for every active edge on TAI (programmable as positive or negative) until the value in the high latch is reached. The counter is then reset, and the cycle repeats. In the pulse/period modes, the times are measured during which the applied pulse stays high and low. The counter is reset on the occurrence of any transition on TAI, and increments at the instruction clock rate until the occurrence of the next transition. The value in the counter at the end of the high level or low level time is loaded into the appropriate latch. Interrupts may be generated each time the counter reaches the high latch or low latch value in the interval mode or when the counter reaches the high latch in the event mode. Also, an interrupt is generated
whenever the counter overflows. See the Pin Description section of the data sheet for TAI and TAO functions in the various Timer A modes.

Timer B is capable of operating in interval or one-shot modes. There is one 16 -bit counter and one 16 -bit latch (Port 11) associated with Timer B. In the interval mode, the counter is initially reset and incremented at the instruction clock rate until the value in the latch is reached. The counter is then reset, and the cycle repeats. In the one-shot modes, the counter begins incrementing in response to an active transition (programmable as positive or negative) on TBI. The counter is reset when the value in the Timer B latch is reached. In the retriggerable one-shot mode, active transitions on TBI always cause the counter to reset and begin incrementing. In the non-retriggerable one-shot mode, active transitions on TBI have no effect until the counter reaches the latch value. Interrupts may be generated each time the counter reaches the latch value. See the Pin Description section of this data sheet for TBI and TBO functions in the various Timer $B$ modes.

Timer C has a 16-bit down counter and latch (Port 19) associated with it and operates only in the interval mode. The output of Timer C toggles each time the counter value rolls over from 0 to the latch value and may be used to internally supply the baud rate clock for the serial port. Also, an interrupt may be generated each time the counter rolls over to the latch value. Timer C may be output on the TCLK pin (P1-3), depending on the mode programmed.

A detailed description of the Timer Control Port is given on the next page.

Table 5. Timer Modes

| Timer | Modes |
| :---: | :--- |
| A | Interval |
| A | Event |
| A | Pulse Width and Period Measurement |
| B | Interval |
| B | Retriggerable One-shot |
| B | Non-retriggerable One-shot |
| C | Interval |
| C | Baud Rate Generation |

PORT 14-Timer Control Register; read/write \$FC1C


TAM1, TAMO (Timer A Mode control)

## TAE

(Timer A Enable control)

TAIC
(Timer A Input control)

TAOC
(Timer A Output control)

TBM1, тBM0
(Timer B Mode control)
TCOC has no effect when TCO (Port 18) $=0$.

These bits select the operating mode of Timer A as follows.

| TAM1 |  | TAMO |  | MODE |
| :---: | :---: | :---: | :--- | :--- |
|  |  |  |  | Interval |
| 0 |  |  |  | Event |
| 1 |  | 0 |  | Pulse/period 1 |
| 1 |  | 1 |  | Pulse/period 2 |

$0=$ Disables Timer A; all Timer A operations are inhibited, and the timer counter is initialized.
$1=$ Enables Timer A; the timer begins operation as defined by the other Timer A control bits.
$0=$ Selects a negative transition as the active edge for TAI.
$1=$ Selects a positive transition as the active edge for TAI.
$0=$ Selects TAO as a general purpose output pin.
$1=$ Selects TAO as an ouput pin associated with Timer A; TAO is initialized low when TAOC is a one and TAE is zero.

These bits select the operating mode of Timer B as described below.

| TBM1 | твмо | MODE |
| :---: | :---: | :---: |
| 0 | 0 | Interval 0 |
|  |  | (TBO is not used) |
| 0 | 1 | Interval 1 |
|  |  | (TBO is used) |
| 1 | 0 | Retriggerable one-shot |
| 1 | 1 | Non-retriggerable one-shot |
| 3-276 |  |  |

TBE
(Timer B Enable control)

TBIC
(Timer B Input control)
$0=$ Disables Timer B; all operations are inhibited, and the timer counter is initialized.
$1=$ Enables Timer B; the timer begins operation as defined by the other Timer B control bits.
$0=$ Selects a negative transition as active on TBI.
$1=$ Selects a positive transition as active on TBI.

## INTERRUPT CONTROLLER

The MK68HC200 interrupt controller provides rapid service of up to 15 interrupt sources, each with a unique internal vector. The lowest 16 words of the address space contain the starting addresses of the service routines of each potential interrupt source and reset, as shown in Figure 6.

Interrupt sources and RESET are prioritized in the order shown in Figure 6, with RESET having the highest priority. When an interrupt is pending it sets the corresponding bit in the interrupt latch located in Port 7. NMI is the only non-maskable interrupt. All of the other sources share an interrupt enable bit in the processor

Status Register. This bit is automatically cleared whenever an interrupt is acknowledged. Also, each of these sources has a corresponding individual mask bit located in Port 8. This feature allows selective masking of particular interrupts, including the ability to choose (with minimal software overhead) any priority scheme desired. In fact, 15 levels of nested priority may be programmed.

Note that the XI2 interrupt is detected on either a rising or falling edge, depending upon the status of the XI2C bit (bit 12 in Port 14). An interrupt will be generated on the falling edge if this bit is set to a " 0 "; however, if the bit is set to a " 1 ", an interrupt will be generated on the rising edge.

PORT 7 -Interrupt Latch Register; read/write \$FCOE


PORT 8 -Interrupt Mask Register; read/write \$FC10


| VECTOR NUMBER | NAME |
| :---: | :---: |
| 0 | RESET |
| 1 | NON-MASKABLE INTERRUPT |
| 2 | SPARE |
| 3 | EXTERNAL INTERRUPT 2 |
| 4 | STROBE LOW |
| 5 | TIMER A OUTPUT |
| 6 | TIMER A INPUT |
| 7 | STROBE HIGH |
| 8 | RECEIVE SPECIAL CONDITION |
| 9 | RECEIVE NORMAL |
| A | EXTERNAL INTERRUPT 1 |
| B | TIMER B OUTPUT |
| C | TIMER B INPUT |
| D | EXTERNAL INTERRUPT 0 |
| E | TRANSMIT |
| F | TIMER C |


| MNEMONIC | VECTOR LOCATION |  |
| :---: | :---: | :---: |
| RESET | 0000 I |  |
| NMI | 0002 | LEVEL 2 |
| SPARE | 0004 |  |
| XI2 | 0006 |  |
| STRL | 0008 |  |
| TAO | 000A |  |
| TAI | 000C |  |
| STRH | 000E |  |
| RSC | 0010 |  |
| RN | 0012 | LEVEL 1 |
| XI1 | 0014 |  |
| TBO | 0016 |  |
| TBI | 0018 |  |
| XIO | 001A |  |
| XMT | 001C |  |
| TC | 001E |  |

Figure 6. Interrupt and Reset Vectors

## SERIAL CHANNEL

The serial channel on the MK68HC200 (Figure 7) is a full-duplex USART with double buffering on both transmit and receive. Port 3 High Byte is the Receive Buffer, and Port 3 Low Byte is the Transmit Buffer.

Word length, parity, stop bits, and modes are fully programmable. The asynchronous mode supports bit rates up to 781 Kbps with an external clock and up to 390 Kbps with an internal clock. The byte synchronous mode operates up to 3.125 Mbps with either an internal or an external clock.


Figure 7. Serial Channel

In addition to the typical USART functions, the serial channel can operate in a special wake-up mode with a wake-up bit appended to each data word, as illustrated in Figure 8. This wake-up bit is used to differentiate normal data words and special address words. The receiver can be programmed to receive only address words or only address words with a specific data value. In this way, the processor can be interrupted only when
it receives its particular address and can then change mode to receive the following data words. Wake-up capability is especially useful when several MK68HC200 microcomputers are interconnected on one serial link.

A detailed description of the serial channel control ports is given on the following pages.

| START + | DATA | MSB | PARITY <br> (OPTIONAL) | WAKE-UP <br> (OPTIONAL) | STOP + |
| :---: | ---: | ---: | ---: | ---: | ---: |

Figure 8. Serial Frame Format

PORT 9 -Serial I/O Receive Control and Status Register;
\$FC12 High byte: control register; read/write
Low byte: status register; read only


Bit Descriptions:

RE
(Receiver Enable control)
IS
(Ignore Syncs control)
$0=$ Disabled; all status flags cleared.
$1=$ Enabled.
$0=$ Disabled; interrupts may occur on all characters received.
$1=$ Enabled; interrupts cannot occur on sync characters received after the sync match is found.

RW1, RW0
(Receiver Wake-up control)

The receiver wake-up control bits operate as follows.

| MODE | RW1 | RWO | APPENDED WAKE-UP | BUFFER LOADED | INTERRUPT GENERATED |
| :---: | :---: | :---: | :---: | :---: | :---: |
| No Wake up | 0 | 0 | no | $\begin{aligned} & \text { any } \\ & \text { character } \end{aligned}$ | RN |
| Wake-up on Any Character | 0 | 1 | yes | any character | RN |
| Wake-up on Address Match | 1 | 0 | yes | address match | RSC |
| Wake-up on Any Address | 1 | 1 | yes | $\begin{gathered} \text { any } \\ \text { address } \end{gathered}$ | RSC |

RC
(Receive Clock control)
$0=$ Selects external receive clock applied on RCLK.
$1=$ Selects internal clock from the on-chip baud rate generator (Timer C) for the receive clock.

This bit is ignored when either the TCO bit or the LM (Loopback Mode) bit is set.


TE
(Transmitter Enable control)
AT
(Automatic Turn Around control)
LM
(Loopback Mode control)

TW1, TW0
(Transmit Wake-up control)

## TC

(Transmit Clock control)

## P/ $\bar{S}$

(Previous/ $\overline{\text { Sync }}$ control)
$0=$ Disable the transmitter; any word being shifted out will continue until completion.
$1=$ Enable the transmitter.
$0=$ No effect on TE or RE.
1 = Causes RE to be set to a " 1 " and TE to be set to a " 0 " automatically at the end of a transmission.
$0=$ Disables loopback mode.
1 = Causes the transmitter output to be internally connected to receiver input. Also causes Timer $C$ to be used for both the transmit and receive clocks regardless of the state of TC, RC, TCO, and TCOC.

These bits provide control for wake-up operation as follows.

| TW1 |  | TW0 |  | OPERATION |
| :---: | :---: | :---: | :--- | :--- |
|  |  | 0 |  | Transmit Data |
| 1 | 1 |  | Transmit Address |  |
| 0 | $X$ |  | No Wake-up |  |

$0=$ Selects the external clock signal applied on TCLK for the transmit clock.
$1=$ Selects the internal baud rate generator output (Timer C) for the transmit clock.

The TC bit is ignored if either the TCO bit or the LM bit is set.
$0=$ Selects continuous transmission of the contents of the sync character register in the synchronous mode when there is no data to transmit.
$1=$ Selects continuous transmission of the transmit data buffer in synchronous mode when there is no data to transmit.

| BE <br> (Buffer Empty status) | $0=$ Transmit Buffer is full; reset to this condition after the transmit buffer is reloaded. <br> $1=$ Transmit Buffer is empty; set to this condition after the transmit buffer contents are transferred to the output shift register. |
| :---: | :---: |
| UE <br> (Underrun Error status) | $0=$ No underrun error; cleared following a read of the transmit buffer. <br> $1=$ Underrun error; set only in the synchronous mode when the last word has been shifted out and transmit buffer has not been reloaded. |
| END <br> (End of Transmission status) | $0=$ No end of transmission; cleared by enabling the transmitter. <br> $1=$ End of transmission detected; set when the transmitter is disabled and the last character has been shifted out. |

PORT 18-Serial I/O Mode and Sync Register; read/write
\$FC24

| A | W | W | S | P | P | T | W | S | S | S | S | S | S | S | S |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | L | L | T | A | A | C | S | Y | Y | Y | Y | Y | Y | Y | Y |
| $\overline{\mathrm{S}}$ | 1 | 0 |  | R | R | 0 |  | N | N | N | N | N | N | N | N |
|  |  |  |  | 1 | 0 |  |  | C | C | C | C | C | C | C | C |
|  |  |  |  |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bit Descriptions:

A/ $\bar{S}$
(Asynchronous/ Synchronous mode control)

WL1, WL0
(Word Length control)

ST
(Stop Bit control)
$0=$ Selects synchronous operation for the serial port; transmit and receive clocks are divided by 1.
$1=$ Selects asynchronous operation for serial port; transmit and receive clocks are divided by 16.

These two bits select the length of the data word as follows.

| WL. 1 |  | WLO |  |  |
| :---: | :---: | :---: | :--- | :--- |
| 0 |  |  | Word Length |  |
| 0 | 1 |  | 7 bits |  |
| 1 |  | 7 |  | 6 bits |
| 1 | 1 | 5 bits |  |  |

This bit is only used in the asynchronous mode. It selects the number of stop bits transmitted.

| $\frac{\text { ST }}{0}$ | Number of Stop Bits |
| :---: | :---: |
|  | 1 |

PAR1, PARO
(Parity control)

## TCO

(Timer C Output mode control)

## WS

(Wake-up Sense control)

SYNCT-SYNC0
(Sync character bits)

These two bits provide parity control for both the synchronous and asynchronous modes.

| PAR1 | PARO | Parity |
| :---: | :---: | :---: |
| 0 | 0 | no parity |
| 0 | 1 | fixed " 0 " parity |
| 1 | 0 | odd parity |
| 1 | 1 | even parity |

Note that even parity is defined such that the sum of the data and parity bits is even.
$0=$ Disables Timer C output mode.
$1=$ Enables Timer C output mode; disables Timer C's use as a baud rate generator when $\mathrm{LM}=0$; causes transmit and receive clocks to be internally connected to RCLK so that TCLK may be used either as general purpose I/O or as an output for Timer C.

The following table lists the effects of the WS bit.

| $\frac{\text { WS }}{0}$ |  | Wake-up bit |  |
| :---: | :---: | :---: | :---: |
|  | 0 |  | Meaning |
| 0 | 1 |  | Dddress Word Word |
| 1 | 0 |  | Data Word |
| 1 | 1 |  | Address Word |

These eight bits are used to store the sync character or the device address for the wake-up mode.

## PARALLEL I/O AND HANDSHAKING

Two 16-bit ports, P0 and P1, may be used for parallel I/O. If individual bits are desired, each of the 32 bits may be separately defined as input or output. This is achieved by setting the corresponding bits in the Data Direction Registers, Port 16 (Data Direction Register for Port 0) and Port 17 (DDR for Port 1). Bits may be grouped to provide the exact data widths desired.

Eight additional I/O bits are provided in Port 4. Bits 15, 14, 9 and 8 are output only, and bits 13,12, 11 and 10 are input only.

Port 0 has the additional capability of operating under the control of external handshaking signals. Eight-bit or sixteen-bit sections of PO may be individually controlled as input, output or bidirectional I/O. This is achieved by programming the handshake control bits as detailed below.

PORT 14-Handshake Control Register; read/write \$FC1C


|  | HSE <br> (Handshake enable control) | $0=$ Handshaking is disabled. <br> $1=$ Handshaking is enabled. |  |
| :---: | :---: | :---: | :--- |
|  | HSM2, HSM1, HSMO <br> (Handshake Mode control) | The handshake mode bits operate as <br> follows: |  |
| HSM2 | HSM1 | HSMO | HIGH HANDSHAKE |
| 0 | 0 | 0 | Inactive |
| 0 | 0 | 1 | PHO output |

Two pairs of Ready and Strobe signals, which are available as programmable options on Port 4, provide the necessary control for handshaking.

## P4-9/RDYH, P4-8/RDYL

(Ready High Byte, Ready Low Byte)
Output, active high. RDYH and RHYL are used for input, output, and bidirectional handshaking on Port 0.

1) Output mode: The ready signal goes active to indicate that the Port 0 output register has been loaded, and the peripheral data is stable and ready for transfer to the peripheral device.
2) Input mode: The ready signal is active when the Port 0 input register is empty and is ready to accept data from the peripheral device.
3) Bidirectional mode: The RDYH signal is active when data is available in Port 0 output register for transfer to the peripheral device. In this mode, data is not
placed on the Port 0 data bus unless STRH is active. The RDYL signal is active when the Port 0 input register is empty and is ready to accept data from the peripheral device.

## P4-11/STRH, P4-10/STRL

(Strobe High Byte, Strobe Low Byte)
Input, active high. STRH and STRL are both used for input, output, and bidirectional handshaking on Port 0.

1) Output Mode; The positive edge of this strobe is issued by the peripheral to acknowledge the receipt of data made available by the MK68HC200.
2) Input mode: The strobe is issued by the peripheral to load data from the peripheral into the Port 0 input register. Data is latched into the MK68HC200 on the negative edge of this signal.
3) Bidirectional mode: When the STRH signal is active, data from the Port 0 output register is gated onto the Port 0 bidirectional data bus.

The negative edge of STRH acknowledges the receipt of the output data. The negative edge of the signal applied to the STRL signal is used to latch input data into Port 0.

## EXPANDED BUS OPERATION

When it is necessary to expand beyond the on-chip complement of RAM, ROM, or I/O, or when operation in a parallel multiprocessing system is desired, the MK68HC200 may be placed in an external bus mode. The MODE pin is used to select the expansion capability on power-up and reset to one of the following states:

## MODE PIN

$\mathrm{V}_{\mathrm{CC}} \quad$ - No expansion (single chip mode)
GND - Partial Expansion
CLKOUT - Full Expansion
By programming the appropriate bits in Port 15 (which are described below), the MK68HC200 may be reconfigured dynamically. In an expansion mode Port 0 becomes the 16 -bit multiplexed address/data bus and eight bits from Port 1 become control signals which handle data transfer and bus arbitration. Sixteen lines are still available for I/O functions, including eight lines from Port 1 and all eights lines of Port 4. See figure 9 for the expanded bus pinout. The following page describes the functions of the expanded bus pins.


Figure 9. MK68HC201, MK68HC211 Logical Pinout Expanded Bus

| MNEMONIC | PIN FUNCTIONS FOR EXPANDED BUS OPERATION (Common for GP and UPC options) |
| :---: | :---: |
| R/ $\bar{W}$ | Read/Write (output, active high and low) - R $\bar{W}$ determines whether a read or a write is being performed during the current bus cycle. It is stable for the entire bus operation. A high signal denotes a read, and a low signal denotes a write. |
| $\overline{\text { DTACK }}$ | Data Transfer Acknowledge (input, active low) - When the addressed device has either placed the requested read data on the bus or taken the write data from the bus, DTACK should be brought low to signify completion. The data portion of the bus cycle will be extended indefinitely until this signal is asserted. For systems using the GP bus, in which no devices need wait states, DTACK may be strapped low. |
| $\overline{\text { AS }}$ | Address Strobe (output, active low) - $\overline{\mathrm{AS}}$ is used to signify that the address is stable on the multiplexed bus. $\overline{A S}$ is high at the beginning of each bus cycle, goes low after the address has stabilized, and returns to the high state near the end of the bus cycle. |
| MNEMONIC | PIN FUNCTIONS FOR UPC BUS OPERATION |
| $\overline{\text { UDS }}$ | Upper Data Strobe (output, active low) - $\overline{\text { UDS }}$ is used to signify the data portion of the bus cycle for the upper byte of the data bus. For read operations, UDS should be used by the external device to gate its most significant byte onto the multiplexed address/data bus. For writes, UDS signifies that the upper byte of the bus contains valid data to be written from the processor. |
| $\overline{\text { LDS }}$ | Lower Data Strobe (output, active low) - $\overline{\mathrm{LDS}}$ is used to signify the data portion of the bus cycle for the lower byte of the data bus. For read operations, $\overline{\text { LDS }}$ should be used by the external device to gate its least significant byte onto the multiplexed address/data bus. For writes, $\overline{\mathrm{LDS}}$ signifies that the lower byte of the bus contains valid data to be written from the processor. |
| $\overline{B R}$ | Bus Request (output, active low, open drain) - $\overline{\mathrm{BR}}$ goes low when the MK68HC200 requires external bus master status. |
| $\overline{\mathrm{BG}}$ | Bus Grant (input, active low) - $\overline{B G}$ notifies that the MK68HC200 has been granted the external bus master status. |
| $\overline{\text { BGACK }}$ | Bus Grant Acknowledge (output, active low, open drain) - The MK68HC200 will assert $\overline{\text { BGACK }}$ when it assumes mastership of the system bus. |
| MNEMONIC | PIN FUNCTIONS FOR GP BUS OPERATION |
| P4-11/R/G | Request//Grant (input) - During reset, P4-11 served as the R/G input ( $0=$ bus grantor, $1=$ bus requestor). Following reset, and at all times during program execution, P4-11 may be used as a general purpose input pin. |
| $\overline{\text { DS }}$ | Data Strobe (output, active low) - $\overline{\mathrm{DS}}$ is used to signify the data portion of the bus cycle. For read operations, $\overline{\mathrm{DS}}$ should be used by the external device to gate its contents onto the multiplexed address/data bus. For writes, $\overline{D S}$ signifies that valid data from the processor is on the bus. |
| $\overline{H B}$ | High Byte (output, active low) $-\overline{\mathrm{HB}}$ signifies that the upper byte of the data is to be read or written. $\overline{\mathrm{HB}}$ remains active for the entire bus cycle. |
| $\overline{L B}$ | Low Byte (output, active low) - $\overline{\mathrm{LB}}$ signifies that the lower byte of the data bus is to be read or written. $\overline{L B}$ remains active for the entire bus cycle. |
| $\overline{\text { BUSIN }}$ | Bus Input (input, active low) - $\overline{B U S I N}$ provides either bus request or bus grant. When the MK68HC200 is the bus grant device, its BUSIN signal is a bus request input from a requesting device on the bus. When the MK68HC200 is a bus request device, its BUSIN signal is a bus grant from the granting device on the bus. |
| BUSOUT | Bus Output (output, active low) - BUSOUT provides the opposite function of $\overline{\text { BUSIN. When }}$ $\overline{B U S I N}$ is a bus request signal, BUSOUT is a corresponding bus grant, and vice versa. |

PORT 15- Expanded bus control and status register \$FCIE

High byte: read/write
Low byte: read only


Bit Descriptions:

SEG1, SEGO
(Segment bits)
BLCK
(Bus Lock control)
F/工
(Fast/Standard timing control)
EXP
(Expanded Mode control)
F/ $\bar{P}$
(Full/Partial control)
UPC/ $\overline{\mathrm{GP}}$
(UPC/GP status)
R/ $\overline{\mathrm{G}}$
(Request/Grant status)

Used in the expanded bus mode when a reference is made to the DMA window. The contents of SEG1 and SEG0 are then output on pins AD15 and AD14, respectively.
$0=$ Disables the bus lock function.
$1=$ Enables the bus lock function.
$0=$ Selects standard timing of read/write cycles on the external bus ( 4 clock periods).
$1=$ Selects fast timing of read/write cycles on the external bus ( 3 clock periods.)
$0=$ Expanded mode is disabled.
$1=$ Expanded mode is enabled.
$0=$ Partial expand when EXP bit is set to 1 .
$1=$ Full expand when EXP bit is set to 1.
$0=$ Part is programmed in GP mode.
$1=$ Part is programmed in UPC mode.
$0=$ Part is programmed bus grantor.
$1=$ Part is programmed bus requestor.

As shown in figure 9, two different control bus versions are available: a Universal Peripheral Controller (UPC), and which generates 68000 compatible bus signals, and a General Purpose (GP) bus, which can be used to interface to a wide variety of existing microprocessor buses. With the selection of an expanded bus mode, the MK68HC200 can act either as a general purpose CPU chip (bus grant device) or as an intelligent peripheral I/O controller to a host CPU (bus request device). These two system configurations are illustrated in figures 10 and 11.

With the GP bus option, the user may configure the MK68HC200 in either of the two ways shown in figures 10 and 11. As a host CPU (Figure 10), the MK68HC200 bus arbitration logic causes the device to act as the system bus grantor. In other words, the MK68HC200 would have control of the system bus and would grant its use
to DMA devices or peripheral CPUs. Alternately the MK68HC200 may be configured as a peripheral CPU (Figure 11) that must issue a request to the bus grant device before being allowed to use the system bus. The selection of one of these two configurations is accomplished by the P4-11 pin at reset time. During reset, P4-11 serves as the R/G input ( $0=$ bus grantor, $1=$ bus requestor). Following reset and at all times during program execution, P4-11 may be used as a general purpose input pin.

With the GP bus operating in the host CPU configuration, the MK68HC200 may be used to interface with external memory and I/O devices in a manner that is analagous to any general purpose microprocessor. Additionally, the MK68HC200 retains its on chip RAM and I/O resources, with on-chip ROM as an option,


Figure 10. Host CPU Hardware Configuration


Figure 11. Peripheral I/O Controller Configuration
depending on the expansion configuration selected. $\overline{B U S I N}$ and BUSOUT are used to perform the bus arbitration handshake function, where BUSIN acts as the bus request input and $\overline{\mathrm{BUSOUT}}$ as the bus grant output.

In the full expansion configuration, any on-chip ROM is disabled, and program memory starting at location $\$ 0000$ is located off-chip and is addressed via the expanded bus, as shown in Figure 13. In effect, the internal bus from locations \$0000-\$FAFF is mapped onto the external bus. In the partially expanded configuration (Figure 12), on-chip ROM may be accessed on the internal bus. To gain greater addressability in the partial expansion configuration, a scheme is implemented to allow access of a full 64 K -byte address space in four segments on the expanded system bus through the 16 K byte "window" on the internal bus. Basically, the most significant two bits of address on the expanded bus are replaced with two user-defined segment bits available to the programmer in the expanded bus control and status register, Port 15.

As a peripheral I/O controller, the MK68HC200 operates as a bus requestor that gains mastership of the system bus from the bus grant CPU. The GP bus version may be selected to implement this system configuration in cases where an interface to a general purpose CPU is desired. In this case, the BUSIN and BUSOUT lines are again used to perform the bus arbitration handshake function, where BUSOUT now acts as bus request output, and $\overline{B U S I N}$ acts as bus grant input. In this configuration, the MK68HC200 can conceivably act as a complete peripheral I/O control subsystem on a single chip, with 16 lines of I/O and its on-chip ROM, RAM, timers, and serial $1 / O$ performing the necessary interface to the I/O device. The UPC bus version provides the peripheral I/O control function with a direct interface to a 68000 bus grant CPU. Note that the UPC bus version can operate only as a bus request device. Once the MK68HC200 has gained mastership of the system bus via the 68000 bus arbitration handshake lines $(\overline{B R}, \overline{B G}$, and $\overline{\text { BGACK }}$ ), it may proceed to perform DMA transfers and communicate with system memory or other I/O devices in the system.

As in the case of the GP bus grant configuration, the portion of the internal (or private) bus address space that is mapped onto the expanded bus when the part is operating as either a GP or a UPC bus request device is determined by the expansion configuration selected. In the partial expansion bus requestor case, the resulting memory map is identical to that shown for the GP bus grant configuration in Figure 12. During the time the MK68HC200 is executing its programs from ROM and accessing internal RAM and I/O resources, the expanded bus is held in a tri-state condition. The bus arbitration logic within the MK68HC200 monitors each
memory reference to detect external bus addresses (referenced in segments via the 16 K byte DMA window). Whenever such an external reference occurs, the logic automatically holds the processor in a wait state as it proceeds to obtain mastership of the bus. When use of the system bus is obtained, the processor is allowed to continue the reference. This procedure is transparent to the programmer. In case of successive external references, the expanded bus is retained until an internal reference is encountered.

Finally, if the on-chip resources are insufficient to perform the control task in the bus requestor configuration, the internal bus address range (excluding on-chip RAM, I/O) may be mapped onto an external local bus, which is physically the same as the system bus but logically separated with bus buffers. This is the full expansion bus requestor configuration. The memory map for this configuration is shown in Figure 14. The bus arbitration sequence is performed only when the system bus is referenced through the DMA window. In this manner, the I/O subsystem is isolated from the host CPU.

When operating as a bus request device, it is possible to retain the external bus for an indefinite duration by using a bus lock feature. This will help facilitate the transfer of large blocks of data. Thus, the on-chip bus arbitration logic allows (with a minimum of hardware and software overhead) a maximum of concurrent processing in parallel, multiprocessing configurations. The bus lock feature may be used by the MK68HC200 in a bus grantor mode to keep any peripheral from gaining mastership of the bus.

In any of the GP expanded bus modes, the MK68HC200 may respond to peripheral devices on the expanded bus which generate an interrupt request on XIO. The MK68HC200 will obtain the XIO interrupt vector number from the requesting peripheral on the bus during an interrupt acknowledge cycle. When responding to an interrupt on XIO, the MK68HC200 will wait for the bus arbitration logic to gain control of the bus and then asserts neither $\overline{\mathrm{HB}}$ nor $\overline{\mathrm{LB}}$ while asserting $\overline{\mathrm{AS}}$ to signify that an interrupt acknowledge cycle is in progress. The X10 interrupt will be the lowest priority interrupt when operating in any of the GP expanded bus modes.

There is a user-programmable speed selection associated with the read and write cycles for both the UPC and GP mask option parts. A bit in the expanded bus control and status register, Port 15, allows the user to select either the standard or the fast read/write cycle on the expanded bus. The standard bus cycle is four clock periods, while the fast bus cycle is three clock periods.


Figure 12. Partial Expansion Memory Map ( 256 byte RAM, 4K byte ROM version shown)


Figure 13. Full Expansion Bus Grantor Memory Map (256 byte RAM version shown)


Figure 14. Full Expansion Bus Requestor Memory Map ( 256 byte RAM version shown)

## EMULATOR VERSION

The emulator versions of the MK68HC200 are available in 84-pin, leadless or leaded chip carrier packages. Figure 15 illustrates the logical pinout of the emulator version. The emulator versions have no on-chip ROM, but instead include a second complete bus, referred to
as the private bus. The private bus includes a multiplexed address/data bus as well as bus control signals. There are 22 pins associated with the private bus. All 40 I/O port pins that exist on the 52-pin versions are available to the user for configuration either as general purpose or special I/O pins, or as expanded bus pins.


Figure 15. Logical Pinout for MK68HC221

## PRIVATE BUS OPERATION

The address/data lines and control signals that constitute the private bus are functionally equivalent to the internal signals used to access internal resources on the ROM versions of the MK68HC200. Thus, the private bus may be used to interface to EPROM memory in emulating mask ROM versions of the MK68HC200. Alternately, any combination of ROM, RAM, and I/O may reside on the private bus.

The address that is generated on the private bus is identical to that which is internally generated for 48 -pin versions. When the part is used in a configuration that supports system bus addressing through the DMA window, any references in this region of the memory map produce an address on the private bus identical to that specified by the programmer. In other words, the segment bits have no effect on the private bus address. The DMODE pin will go active during a reference to the DMA window. Write data appears on the private bus pins for all write operations, regardless of whether the reference is on-chip or off-chip. The MK68HC221 emu-
lator version reads data from the private bus unless data is read from on-chip RAM, I/O, or the external bus formed by the Port 0 and Port 1 I/O pins.

The I/O port range of the memory map (\$FC00-\$FFFF) is actually subdivided into space which is exclusively reserved for on-chip I/O (\$FC00-\$FDFF) and space which is exclusively reserved for in-circuit-emulator use (\$FEO0-\$FFFF). The user should ensure that no external devices reside in the in-circuit-emulator area.

The private bus interface is the same as that for the GP expanded bus. All read/write transfers made exclusively on the private bus are three clock periods, regardless of the state of the Fast/Standard ( $\mathrm{F} / \overline{\mathrm{S}}$ ) bus timing selection bit. In systems using the expanded bus, the user should be sure to tie the FPRIV pin low so that expanded bus operation is not effected. The user should ignore all activity on the private bus while accesses are in progress on the expanded bus. Care should also be taken that no external devices reside on the private bus in the memory space intended for expanded bus accesses.

There are six additional control pins available on the emulator version that are not on the ROM version. Five of these pins are meant to be used by the development system. FC1, FC2, $\overline{\mathrm{DMODE}}$, and $\overline{\mathrm{EXPMC}}$ are used to define the memory cycle currently being executed. FPRIV will affect the memory cycle currently being executed. These signals are made available to simplify the design of the development system. Using these signals, the development system only has to interface to the private bus and not also to the expanded bus. The user might also be able to use these signals to simplify his design, however care should be taken when using FPRIV since this input will affect expanded bus memory cycles.

| MNEMONIC | ADDITIONAL PIN FUNCTIONS FOR THE EMULATOR |
| :---: | :---: |
| UPC/GP | UPC/GP (input, active high and low). This pin is used to select either the UPC or GP control bus configuration for the expanded bus. ( $1=$ UPC bus, $0=$ GP bus). It is sampled only when reset is active |
| FC1, FC2 | Function Code 1, Function Code 2 (outputs, active high and low). These pins (FC1 and FC2) define the memory cycle currently being executed. They are valid during the time private bus address strobe ( $\overline{\mathrm{PBAS}})$ is active. The cycle types are interrupt, data, branch, and program fetch. The branch cycle is defined as the first program fetch after a branch occurs. A branch can occur as a result of a jump or call instruction, or an interrupt. For internal interrupts, the interrupt cycles are defined as the two writes to the stack and the read of the vector location which occur during the interrupt acknowledge routine. For external interrupts, the interrupt cycles are defined as the 3 cycles above plus the read of the vector number. The interrupt cycle is a special case of the data cycle. The function code pins are defined below. |
|  | TYPE OF CYCLE FC1 FC2 |
|  | Interrupt 0 |
|  | Data 0 |
|  | Branch 10 |
|  | Program Fetch 1 |
| $\overline{\text { DMODE }}$ | DMA Mode (output, active low). This pin goes low when the segment bits are being output on AD14 and AD15 on the expanded bus. (The address output on the private bus will not contain the segment bits.) $\overline{\mathrm{DMODE}}$ is stable for the entire bus operation. |
| EXPMC | Expanded Memory Cycle (output, active low). This pin goes low when the expanded bus is being accessed. EXPMC is stable for the entire bus operation. |
| FPRIV | Force Private (input, active high). This pin is used to force the MK68HC200 to read data from the private bus when the address is actually located on the expanded bus. In normal operation this pin should be tied low and the expanded bus operation will be unaffected. |

## CRYSTAL SELECTION

The wide frequency range of crystals that can be chosen for the MK68HC200 offers the user a large degree of flexibility. To aid in the selection of a suitable crystal,
the suggestions shown in Figure 16 should be considered by the user. The MK68HC200 offers an output pin that will provide a system clock signal at one-half of the crystal frequency.


Figure 16. Crystal Connection


Figure 17a. MK68HC201, MK68HC211 Pin Assignment, ROM Version


| LCC | FUNCTION | LCC | FUNCTION | LCC | FUNCTION | LCC | FUNCTION |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | P1-4/XIO | 22 | $\overline{\text { PBAS }}$ | 43 | P0-7 | 64 | PB-8 |
| 2 | P1-5/XI1 | 23 | $\overline{\text { PBDS }}$ | 44 | P0-6 | 65 | PB-9 |
| 3 | P1-6/XI2 | 24 | P4-8/RDYL | 45 | P0-5 | 66 | PB-10 |
| 4 | P1-7 | 25 | P4-9/RDYH | 46 | P0-4 | 67 | PB-11 |
| 5 | P1-8 | 26 | P4-10/STRL | 47 | P0-3 | 68 | PB-12 |
| 6 | P1-9 | 27 | P4-11/STRH | 48 | P0-2 | 69 | PB-13 |
| 7 | P1-10 | 28 | MODE | 49 | P0-1 | 70 | PB-14 |
| 8 | P1-11 | 29 | CLK2 | 50 | P0-0 | 71 | PB-15 |
| 9 | EXPMC | 30 | CLK1 | 51 | FC2 | 72 | P4-13/TAI |
| 10 | VCC | 31 | CLKOUT | 52 | DMODE | 73 | P4-12/TBI |
| 11 | NO CONNECT | 32 | FC1 | 53 | FPRIV | 74 | VCC |
| 12 | GROUND | 33 | VCC | 54 | VCC | 75 | GROUND |
| 13 | UPC/GP | 34 | GROUND | 55 | GROUND | 76 | P4-15/TAO |
| 14 | P1-12 | 35 | P0-15 | 56 | PB-0 | 77 | P4-14/TBO |
| 15 | P1-13 | 36 | P0-14 | 57 | PB-1 | 78 | RESET |
| 16 | P1-14 | 37 | PO-13 | 58 | PB-2 | 79 | NMI |
| 17 | P1-15 | 38 | P0-12 | 59 | PB-3 | 80 | P1-0/SO |
| 18 | PBLB | 39 | P0-11 | 60 | PB-4 | 81 | P1-1/TCLK |
| 19 | PBHB | 40 | P0-10 | 61 | PB-5 | 82 | P1-2/RCLK |
| 20 | PBR/ | PBDACK | 41 | P0-9 | 62 | PB-6 | 83 |
| 21 | PBTACK | 42 | P0-8 | 63 | PB-7 | 84 | VCC |

Figure 17b. MK68HC221 Pin Assignment, Emulator Version

ASSEMBLER DIRECTIVES

| Directive | Function | Assembler Syntax |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DC | Define constant | [label:] | DC[.size]*1 | expr \{,expr\} |
| DS | Define storage | [label:] | DS[.size]*1 | expr |
| DUP | Duplicate constant block | [label:] | DUP[.size] ${ }^{\star 1}$ | length, value |
| END | Program end |  | END | [start address] |
| EQU | Equate symbol value | label: | EQU | expr |
| FAIL | Programmer generated error |  | FAIL | expr |
| FORMAT | Format the source listing |  | FORMAT |  |
| IDNT | Generate module ID | module_name: | IDNT | version, revision |
| LIST | Enable the assembly listing |  | LIST |  |
| LLEN | Specify line length |  | LLEN | length |
| NOFORMAT | Do not format listing |  | NOFORMAT |  |
| NOLIST | Disable assembly listing |  | NOLIST |  |
| NOOBJ | Disable object code generation |  | NOOBJ |  |
| NOPAGE | Suppress paging |  | NOPAGE |  |
| OFFSET | Define Offsets |  | OFFSET | expr |
| OPT | Assembler output options |  | OPT | option ${ }^{2}$ \{, option $\}$ |
| ORG | Define absolute origin |  | ORG | expr |
| PAGE | Eject a page in the listing |  | PAGE |  |
| REG | Define register list | reg_list_name: | REG[.size] | register list |
| SECTION | Define relocatable program section | [section__name:] | SECTION | number |
| SET | Set symbol value | label: | SET | expr |
| SPC | Space between source lines |  | SPC | number |
| TTL | Specify heading title string |  | TTL | title string |
| XDEF | External symbol definition |  | XDEF | symbol \{, symbol\} |
| XREF | External symbol reference |  | XREF | [sect no:] symbol \{,[sect no]: symbol\} |

## NOTES:

1. .size $=$.B or.$W$ (byte or word size)
2. Options for the OPT directive include

CEX Print DC expansions
NOCEX Do not print DC expansions (default)
$\mathrm{CL} \quad$ Print conditional assembly directives (default)
NOCL Do not print conditional assembly directives
CRE Print cross-reference table
IMM.L Forces immediate operands for arithmetic instructions ADD, SUB, DADD, and DSUB to use the long instruction form
IMM.S Allows the assembler to select automatically the short form of the arithmetic instructions for small immediate values (0-15) (default)

MC Print macro calls (default)
NOMC Do not print macro calls
MD
Print macro definitions (default)
NOMD Do not print macro definitions
MEX Print macro expansions
NOMEX Do not print macro expansions (default)

STR
Print code generated by structured statements Do not print code generated by structured statements (default)

GENERAL SYMBOL DEFINITIONS

| SYMBOL | GENERAL SYMBOL DEFINITIONS |
| :---: | :---: |
| Rn | General Purpose Registers - DO-D7, AO-A5, SP, SR, DHO-DH7, DLO-DL7. |
| RPn | Register Pairs - D0-D1, D2-D3, D4-D5, D6-D7, A0-A1, A2-A3, A4-A5. |
| An | Address Registers - A0-A5, SP. |
| Pn | Ports - P0-P15, PH0-PH3, PL0-PL3. |
| CC | Condition Code - See Table. |
| d16 | 16-Bit Address Displacement Field In Words. |
| d13 | 13-Bit Address Displacement Field In Bytes. |
| d9 | 9-Bit Address Displacement Field In Bytes. |
| d8 | 8-Bit Address Displacement Field In Bytes. |
| \#nx | Immediate Data Field - x Number of Bits. ${ }^{1}$ |
| s | Size Bit - '1' = Word, '0' = Byte. |
| REGn | 4-Bit Register Field - See Table. |
| PORTn | 4-Bit Port Field - See Table. |
| An | 3-Bit Address Register Field - See Table. |
| PRTn | 3-Bit Port Field - See Table. |
| RGn | 3-Bit Register Pair Field - See Table. |
| M | Register Mask Field - See Table. |
| COND | Condition Code Field - See Table. |
| c3 | 3-Bit Class Field - See Table. |
| c2 | 2-Bit Class Field - See Table |
| C1 | 1-Bit Class Field-See Table |
| a | Address Field - 16 Bits. |
| \# | Immediate Data Field. |
| n | 3 -Bit Shift Field - $2 \leq n \leq 7$. |
| b\# | 4-Bit Bit Select Field. |
| d | Displacement Field. |
| .B | Byte Attribute. |
| W | Word Attribute. |
| .L | Long Attribute. |
| .S | Short Attribute. |
| [ ] | Optional Field. |

## NOTE

1. When using the byte format of an instruction with a 16 -bit immediate data field, both the high and low byte of the data field must contain the same 8 -bit data.

| REGn 4-Bit Register Map |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register |  | BitField |  |  | Register |  | $\begin{aligned} & \text { Bit } \\ & \text { Field } \end{aligned}$ |  |  |  |
| D0 | DHO |  | 00 |  | AO | DLO | 1 | 0 |  | 00 |
| D1 | DH1 |  | 00 |  | A1 | DL1 | 1 | 0 |  | 1 |
| D2 | DH2 | 0 | 01 |  | A2 | DL2 | 1 | 0 |  | 10 |
| D3 | DH3 |  | 01 |  | A3 | DL3 | 1 | 0 |  | 1 |
| D4 | DH4 | 0 | 10 |  | A4 | DL4 | 1 | 1 |  | 0 |
| D5 | DH5 |  | 10 |  | A5 | DL5 | 1 | 1 |  | 1 |
| D6 | DH6 | 0 | 11 |  | SP | DL6 | 1 | 1 |  | 0 |
| D7 | DH7 |  | 11 |  | SR | DL7 | 1 | 1 |  | 11 |



| An 3-Bit Addr Reg Map |  |
| :---: | :---: |
| Register | Bit <br> Field |
| A0 | 0000 |
| A1 | 0001 |
| A2 | 0110 |
| A3 | 0111 |
| A4 | 100 |
| A5 | 101 |
| SP | 110 |


| PTRn | 3-Bit Port Map |
| :---: | :---: |
| Port | Bit <br> Field |
| PH0 | 000 |
| PLO | 0011 |
| PH1 | 0110 |
| PL1 | 0111 |
| PH2 | 1000 |
| PL2 | 1011 |
| PH3 | 110 |
| PL3 | 111 |

RGn 3-Bit Reg Pair Map

| Register | Bit <br> Field |  |
| :---: | :---: | :---: |
| D0-D1 | 0 | 0 | 0


| M-REGISTER MASK MAP FOR MOVEM, PUSHM, AND POPM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Inc <br> Word | SR | SP | A5 | A4 | A3 | A2 | A1 | AO | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Dec Word | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | A0 | A1 | A2 | A3 | A4 | A5 | SP | SR |
| Inc Byte | DH7 | DL7 | DH6 | DL6 | DH5 | DL5 | DH4 | DL4 | DH3 | DL3 | DH2 | DL2 | DH1 | DL1 | DH0 | OLO |
| Dec Byte | DLO | DHO | DL1 | DH1 | DL2 | DH2 | DL3 | DH3 | DL4 | DH4 | DL5 | DH5 | DL6 | DH6 | DL7 | DH7 |


| COND CONDITION CODE TABLE |  |  |  |
| :---: | :---: | :---: | :---: |
| Condition Code | Bit <br> Field | Description | Test |
| $\begin{gathered} z \\ E Q \end{gathered}$ | 0000 | Zero <br> Equal | Z |
| MI | 0001 | Minus | N |
| $\begin{gathered} \mathrm{LO}^{2} \\ \mathrm{CS} \end{gathered}$ | 0010 | Lower Carry Set | C |
| VS | 0011 | Overflow Set | V |
| $\mathrm{GE}^{2}$ | 0100 | Greater than or Equal | $\overline{N . E O R . V}$ |
| GT ${ }^{2}$ | 0101 | Greater than | $\overline{\mathbf{Z}}$.AND. ( $\overline{\mathrm{N} . E O R . ~ V})$ |
| $\mathrm{HI}^{2}$ | 0110 | Higher | $\overline{\mathrm{C}} . \mathrm{AND} . \overline{\mathrm{Z}}$ |
| $\mathrm{F}^{1}$ | $\begin{array}{llll}0 & 1 & 1 & 1\end{array}$ | False | Always False |
| $\begin{aligned} & \mathrm{NE} \\ & \mathrm{NZ} \end{aligned}$ | 1000 | Not Equal Not Zero | $\bar{Z}$ |
| PL | 1001 | Plus | $\bar{N}$ |
| $\begin{gathered} \mathrm{HS}^{2} \\ \mathrm{CC} \end{gathered}$ | 1010 | Higher or Same Carry Clear | $\overline{\mathrm{C}}$ |
| VC | 1011 | Overflow Clear | $\overline{\mathrm{V}}$ |
| $\mathrm{LT}^{2}$ | 1100 | Less than | $N$.EOR. V |
| LE ${ }^{2}$ | 11001 | Less than or Equal | Z OR. (N.EOR. V) |
| L. ${ }^{2}$ | 1110 | Lower or Same | C OR. Z |
| $\mathrm{T}^{1}$ | 1111 | True | Always True |

## NOTES:

1. The assembler does not recognize the $T$ and $F$ condition codes.
2. LT, LE, GT, and GE are used for unsigned conditions; LO, LS, HI, and HS are for unsigned conditions.

| INSTRUCTION CLASS FIELDS |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| [C3 - 3-Bit Field |  |  | C2-2-Bit Field |  |  | [C] - 1-Bit Field |  |  |  |
| Bit Field | Shift Instr | Bit ${ }^{1}$ Instr | Bit Field | Arith ${ }^{2}$ Instr | Logical Instr | Bit Field | Arith ${ }^{2}$ Instr | Test Instr | $\mathrm{Neg}^{2}$ <br> Instr |
| 000 | ROR | BSET | 00 | ADDC | OR | 0 | ADD | TESTN | NEGC |
| 001 | ROL | BCHG | 01 | SUBC | EOR | 1 | SUB | TEST | NEG |
| 010 | RORC | BCLR | 10 | ADD | AND |  |  |  |  |
| 011 | ROLC | BTST | 11 | SUB | - |  |  |  |  |
| 100 | ASR | - |  |  |  |  |  |  |  |
| 101 | ASL | - |  |  |  |  |  |  |  |
| 110 | LSR | - |  |  |  |  |  |  |  |
| 111 | - | BEXG |  |  |  |  |  |  |  |

## NOTES:

1. The bit fields do not apply to bit instructions using a port operand.
2. These fields also apply to BCD instructions.

## INSTRUCTION FORMAT



| INSTRUCTION MNEMONIC | $\begin{aligned} & \text { ATTR } \\ & \text { SIZE } \end{aligned}$ | OPERAND <br> ASSEMBLER <br> SYNTAX <br> Source $=$ Src <br> Destination $=$ Dst <br> Src, Dst | ${ }_{1} 151141131$ |  |  | $\begin{array}{l:l\|l} 3 & 2 & 0 \end{array}$ | $\begin{aligned} & \text { w } \\ & \text { o } \\ & \text { R } \\ & \text { D } \\ & \text { S } \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{C} \\ & \mathrm{Y} \\ & \mathrm{C} \\ & \mathrm{~L} \\ & \mathrm{E} \\ & \mathrm{~S} \end{aligned}$ | operation | N | Statu |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD ADOC SUB SUBC | + ${ }_{\text {B }}$ | Ry.Rx | 2 | REGX | (s) 620 | REGY | 1 | - |  | 3 | ADD | * | * |
|  | $\stackrel{\stackrel{8}{\mathrm{~B}}}{[1}$ | (Ay). $\mathrm{A} x$ | 2 | AEGx |  | $0 \mid$ Ay | 1 | - |  | 6 | ADDC <br> Src $\cdot$ Dst $+\mathrm{C} \rightarrow$ Dst |  |  |
|  | $\stackrel{8}{\|w\|}$ | ${ }^{\text {d16 }}$ (Ay), Ax | 2 | [. REGX | s ca 1 | 1 Ay | 2 | d |  | 9 | SUB <br> Dst Src - Dst |  |  |
|  | $\stackrel{8}{8}(\mathrm{w})$ | Addr, Rx | 2 | REGx | [s] c2] 1 | F | 2 | a |  | 9 | subc. <br> Dst . Src C $\rightarrow$ Dst |  |  |
|  | $\stackrel{8}{\mathrm{~B}} \mid$ | *n16. Ax | 2 | REGX | [s] c2] 1 |  | 2 | * |  | 6 | Note: For addressing modes mn, Rx and $k n,(\mathrm{Ax})$ with the |  |  |
|  | $\stackrel{8}{8})$ | Ry.(Ax) | 3 | 0 Ax | sj\|c2 0 |  | 1 | - |  | 9 | the assembler uses the short version for immediate values $<4$ bits |  |  |
|  | $\stackrel{B}{\mathrm{~B}} \mid$ | (Ax).(Ay) | 3 | 0 - Ax | s] c2: ${ }^{1}$ | 0 - Ay | 1 | - |  | 12 |  |  |  |
|  | $\begin{gathered} B \\ {[\mathrm{~W})} \end{gathered}$ | *n16,(Ax) | 3 | 0 Ax | [s] [c2] 1 | 7 | 2 | * |  | 12 |  |  |  |
|  | ¢ $\stackrel{\text { B }}{\text { ¢ }}$ | (Ax) + , (Ay) + | 3 | 1 AX | [s] c2 1 | 0 Ay | 1 | - |  | 12 |  |  |  |
|  | $\begin{aligned} & \mathrm{B} \\ & \text { [W] } \end{aligned}$ | *n16.(Ax) + | 3 | 1 Ax | [s) c2 ${ }^{1}$ | 7 | 2 | * |  | 12 |  |  |  |
|  | $\stackrel{\mathrm{B}}{\mathrm{w}}]$ | -(Ax), (Ay) | 3 | 1 Ax | [s) c2 1 | 1 Ay | 1 | - |  | 12 |  |  |  |
|  | $\stackrel{8}{\mathrm{~B}}(\mathrm{w})$ | *n16, - (Ax) | 3 | 1 Ax | s [c2 ${ }^{1}$ | F | 2 | * |  | 12 |  |  |  |
|  | $\stackrel{8}{\stackrel{B}{[W]}}$ | Ry,d16(Ax) | 3 | 1 Ax | s ca 0 | REGY | 2 | d |  | 12 |  |  |  |
|  | $\begin{gathered} \mathrm{B} \\ {[\mathrm{~W}]} \end{gathered}$ | Ry,Addr | 3 | F | [3] c2] 0 | AEGy ${ }^{\text {a }}$ | 2 | a |  | 12 |  |  |  |



















The following symbols are used to describe the state of the Status Register flags
Set according to result of operation.
1 Cleared.

- Not affected
u Undefined.

*NOTE: Both test bits should remain a 0 during normal operation.


NOTE:
When a reserved bit is read, it is read as a zero.

## ELECTRICAL SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS

Voltage on any pin relative to GND. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -1.0 V to +7.0 V
Total Device Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
Ambient Storage Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Operating Temperature ( $T_{L}<T_{A}<T_{H}$ ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Commercial MK68HC2xx/xxx-Cx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Industrial MK68HC2xx/xxx-Vx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Military MK68HC2xx/xxx-Mx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
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 sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## MK68200 DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\left.\mathrm{T}_{\mathrm{H}}\right)$

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input low voltage; all inputs | -0.3 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input high voltage; all inputs except CLK1 | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input high voltage; CLK1 | $0.7 \times \mathrm{V}_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output low voltage; all outputs |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output high voltage; all outputs | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-250 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output high voltage; all outputs | $\mathrm{V}_{\mathrm{CC}}-0.1$ |  | V | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input leakage current |  | $\pm 1$ | vA | $\mathrm{V}_{\mathrm{IN}}=0$ to $\mathrm{V}_{\mathrm{CC}}$ |
| 'Lo | Three-state output leakage current in float |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{gathered} V_{\text {OUT }}=0.4 \mathrm{~V} \text { to } \\ V_{\mathrm{CC}} \end{gathered}$ |
| ${ }^{\text {cC1 }}$ | Input power supply current CLKOUT $=12.5 \mathrm{MHz}$ <br> CLKOUT $=10 \mathrm{MHz}$ <br> CLKOUT $=8 \mathrm{MHz}$ <br> CLKOUT $=0.5 \mathrm{MHz}$ |  | $\begin{aligned} & 75 \\ & 65 \\ & 55 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ | Outputs Open |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power supply current in IDLE mode. <br> CLKOUT $=12.5 \mathrm{MHz}$ <br> CLKOUT $=10 \mathrm{MHz}$ <br> CLKOUT $=8 \mathrm{MHz}$ <br> CLKOUT $=0.5 \mathrm{MHz}$ |  | $\begin{aligned} & 20 \\ & 20 \\ & 20 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ | Outputs Open. All I/O functions active. |
| $\mathrm{I}_{\text {cc3 }}$ | Power supply current in STOP mode |  | 5 | mA | Outputs Open |

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX | UNIT | TEST CONDITION |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 10 | pF | Unmeasured pins <br> returned to <br> ground |
| $\mathrm{C}_{\text {OUT }}$ | Three-state Output Capacitance | 10 | pF | (10 |

## MK68HC200 AC ELECTRICAL SPECIFICATIONS

$T_{A}=T_{L}$ to $T_{H}, V_{C C}=+5 \mathrm{~V} \pm 10 \%$ unless otherwise specified.
$A C$ measurements are referenced from minimum $V_{I H}$ or maximum $V_{I L}$ for inputs and from minimum $V_{O H}$ or maximum $\mathrm{V}_{\mathrm{OL}}$ for outputs.

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 1 | RESET low time | 20 |  | 20 |  | 20 |  | state times | 1 |
| 2 | CLK 1 width high (external clock input) | 22 |  | 18 |  | 14 |  | ns |  |
| 3 | CLK 1 width low (external clock input) | 22 |  | 18 |  | 14 |  | ns |  |
| 4 | CLK 1 period (external clock input) | 62 | 1000 | 50 | 1000 | 40 | 1000 | ns |  |
| 5 | Crystal input frequency | 1.000 | 16.000 | 1.000 | 20.000 | 1.000 | 25.000 | MHz |  |
| 6 | Clock Period (PHI 1) (tc) | 125 |  | 100 |  | 80 |  | ns |  |
| 7 | PHI 1 low to PHI 1 high | 62 |  | 50 |  | 40 |  | ns |  |
| 8 | PHI 1 high to PHI 1 low | 62 |  | 50 |  | 40 |  | ns |  |
| 9 | PHI 1 low to CLKOUT Iow |  | 20 |  | 16 |  | 13 | ns |  |
| 10 | PHI 1 high to CLKOUT high |  | 20 |  | 16 |  | 13 | ns |  |

MK68HC200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (UPC, GP, AND PRIVATE BUSES)

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 11 | PHI 1 low to R $/ \bar{W}, \overline{H B}, \overline{L B}, F C 1$, FC2, EXPMC, DMODE Valid |  | 58 |  | 46 |  | 37 | ns | 2 |
| 12 | PHI 1 high to $\overline{\mathrm{AS}}$ low |  | 58 |  | 46 |  | 37 | ns | 2 |
| 13 | PHI 1 low to address valid |  | 60 |  | 50 |  | 40 | ns | 2 |
| 14 | $\overline{\text { AS }}$ low to address invalid | 35 |  | 30 |  | 24 |  | ns | 2 |
| 15 | PHI 1 low to tri-state address |  | 45 |  | 36 |  | 29 | ns | 2 |
| 16 | Tri-state address to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or UDS starting low (fast cycle) | 10 |  | 10 |  | 10 |  | ns | 2 |
| 17 | PHI 1 low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ low (fast cycle) |  | 83 |  | 66 |  | 53 | ns | 2 |
| 18 | PHI 1 low to data out valid during write |  | 60 |  | 50 |  | 40 | ns | 2 |
| 19 | PHI 1 low to $\mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{HB}}, \overline{\mathrm{LB}}, \mathrm{FC} 1$, FC2, EXPMC, DMODE invalid | 0 |  | 0 |  | 0 |  | ns | 2 |
| 20 | PHI 1 low to address/data bus driven | 0 |  | 0 |  | 0 |  | ns | 2 |
| 21 | $\overline{\mathrm{AS}}$ low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ starting low (fast cycle) | 50 | 113 | 42 | 90 | 33 | 72 | ns | 2 |
| 85 | $\overline{\text { AS }}$ high to FPRIV invalid | 0 |  | 0 |  | 0 |  | ns |  |
| 86 | Address valid to FPRIV valid (fast cycle) |  | 121 |  | 94 |  | 75 | ns |  |
| 87 | Valid data setup to $\overline{\mathrm{DS}}, \overline{\mathrm{UDS}}$ or $\overline{\mathrm{LDS}}$ high during write (fast cycle) | 65 |  | 50 |  | 40 |  | ns | 2 |

MK68HC200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (UPC AND GP BUSES)

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 22 | Tri-state address to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or UDS starting low (standard cycle) | 67 |  | 54 |  | 43 |  | ns |  |
| 23 | PHI 1 high to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ low (standard cycle) |  | 83 |  | 66 |  | 53 | ns | 2 |
| 24 | Valid Data Setup to PHI 1 low | 5 |  | 5 |  | 5 |  | ns | 2 |
| 25 | $\overline{\mathrm{AS}}$ low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ starting low (standard cycle) | 112 | 175 | 90 | 138 | 72 | 111 | ns | 2 |
| 26 | $\mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{HB}}$, or $\overline{\mathrm{LB}}$ valid to $\overline{\mathrm{AS}}$ starting low | 45 |  | 36 |  | 29 |  | ns |  |
| 27 | Address valid to $\overline{\text { AS }}$ starting low | 45 |  | 36 |  | 29 |  | ns |  |
| 28 | Input data hold time from PHI 1 low | 22 |  | 18 |  | 14 |  | ns |  |
| 29 | Input data hold time from $\overline{\mathrm{DS}}$, LDS, or UDS high | 0 |  | 0 |  | 0 |  | ns |  |
| 30 | PHI 1 low to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\text { UDS }}$ high |  | 90 |  | 72 |  | 58 | ns |  |
| 31 | $\overline{\text { DTACK }}$ low or FPRIV valid setup to PHI 1 high | 7 |  | 6 |  | 5 |  | ns |  |
| 32 | $\overline{\mathrm{LDS}}, \overline{\mathrm{UDS}}$, or $\overline{\mathrm{DS}}$ high to DTACK high (hold time) | 0 |  | 0 |  | 0 |  | ns |  |
| 33 | $\overline{\mathrm{LDS}}, \overline{\text { UDS }}$, or $\overline{\mathrm{DS}}$ pulse width | 120 |  | 90 |  | 72 |  | ns |  |
| 34 | PHI 1 high to $\overline{\text { AS }}$ high |  | 45 |  | 36 |  | 29 | ns |  |
| 35 | PHI 1 low to data out invalid | 0 |  | 0 |  | 0 |  | ns |  |
| 36 | $\overline{\text { AS }}$ inactive | 117 |  | 90 |  | 72 |  | ns |  |
| 37 | $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ high to data out invalid | 90 |  | 66 |  | 53 |  | ns |  |
| 38 | $\overline{\overline{D S}}$, $\overline{\text { LDS }}$, or $\overline{\text { UDS }}$ high to $\overline{\mathrm{AS}}$ high | 5 |  | 5 |  | 5 |  | ns |  |
| 88 | Address valid to FPRIV valid (standard cycle) |  | 246 |  | 194 |  | 155 | ns |  |
| 89 | Valid data setup to $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$, or $\overline{\mathrm{UDS}}$ during write (standard cycle) | 190 |  | 150 |  | 120 |  | ns | 2 |
| 90 | $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$ or $\overline{\mathrm{UDS}}$ low to data in valid (fast cycle) |  | 37 |  | 29 |  | 22 | ns | 2 |
| 91 | $\overline{\mathrm{DS}}, \overline{\mathrm{LDS}}$ or $\overline{\mathrm{UDS}}$ low to data in valid (standard cycle) |  | 100 |  | 79 |  | 62 | ns | 2 |
| 92 | Address valid to data in valid (fast cycle) |  | 185 |  | 145 |  | 115 | ns |  |
| 93 | Address valid to data in valid (standard cycle) |  | 310 |  | 245 |  | 195 | ns |  |

MK68HC200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (UPC BUS)

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 39 | $\overline{\text { BGACK }}$ low to $\overline{B R}$ high | 100 | 225 | 75 | 180 | 60 | 144 | ns |  |
| 40 | $\overline{\mathrm{BG}}$ low to BGACK low | 50 | 300 | 50 | 240 | 40 | 192 | ns |  |
| 41 | $\overline{\mathrm{BGACK}}, \overline{\mathrm{AS}}, \overline{\mathrm{DTACK}}$, inactive to $\overline{B G A C K}$ low; $\overline{B G}$ already low | 0 | 300 | 0 | 240 | 0 | 192 | ns |  |
| 42 | $\overline{B G A C K}$ low to $\overline{A S}, \overline{U D S}, \overline{L D S}, R / \bar{W}$ or address/data bus driven | 40 | 68 | 30 | 54 | 25 | 43 | ns |  |
| 43 | $\overline{\mathrm{AS}}, \overline{\mathrm{LDS}}, \overline{\mathrm{UDS}}, \mathrm{R} \overline{\mathrm{W}}$ or address/data bus tri-state to BGACK high | 0 | 90 | 0 | 72 | 0 | 58 | ns |  |

MK68HC200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (GP BUS)

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 45 | $\overline{\text { BUSIN }}$ low to $\overline{\text { BUSOUT }}$ low (bus grantor, fast cycle, no wait states) |  | 950 |  | 720 |  | 576 | ns |  |
| 46 | $\overline{\text { BUSOUT }}$ high to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{LB}}$, $\overline{\mathrm{HB}}$ or address/data bus driven (bus grantor) | 15 |  | 15 |  | 15 |  | ns |  |
| 47 | $\overline{\text { BUSIN }}$ high to $\overline{B U S O U T}$ high (bus grantor) | 260 | 450 | 180 | 360 | 144 | 288 | ns |  |
| 48 | Tri-state $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{LB}}, \overline{\mathrm{HB}}$ or address /data bus to BUSOUT low (bus grantor) | 50 |  | 42 |  | 33 |  | ns |  |
| 50 | $\overline{B U S O U T}$ low to $\overline{A S}, \overline{D S}, R / \bar{W}$, $\overline{\mathrm{LB}}, \overline{\mathrm{HB}}$ or address/data bus driven (bus requestor, $\overline{B U S I N}$ low) | 120 |  | 90 |  | 72 |  | ns |  |
| 51 | $\overline{\text { BUSIN }}$ low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} \overline{\mathrm{W}}, \overline{\mathrm{LB}}$, $\overline{\mathrm{HB}}$ or address/data bus driven (bus requestor, BUSOUT low) | 135 | 325 | 108 | 300 | 86 | 240 | ns |  |
| 53 | BUSOUT high to BUSIN high (bus requestor) |  | 275 |  | 240 |  | 192 | ns |  |
| 55 | Tri-state $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{HB}}, \overline{\mathrm{LB}}$ or address/data bus to BUSOUT high (bus requestor) | 50 |  | 39 |  | 31 |  | ns |  |

MK68HC200 BUS AC ELECTRICAL SPECIFICATIONS (PRIVATE BUS)

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 56 | Valid Data Setup to PHI 1 low | 15 |  | 12 |  | 10 |  | ns |  |
| 57 | PBR/ $\bar{W}$ valid to $\overline{\text { PBAS }}$ starting low | 30 |  | 24 |  | 19 |  | ns |  |
| 58 | Address valid to $\overline{\text { PBAS }}$ starting low | 27 |  | 21 |  | 17 |  | ns |  |
| 59 | Input data hold time from PHI 1 low | 0 |  | 0 |  | 0 |  | ns |  |
| 60 | Input data hold time from $\overline{\text { PBDS }}$ high | 0 |  | 0 |  | 0 |  | ns |  |

MK68HC200 EXPANDED BUS AC ELECTRICAL SPECIFICATIONS (PRIVATE BUS) (Cont.)

| NO. | DESCRIPTION | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 61 | PHI 1 low to $\overline{\text { PBDS }}$ high |  | 80 |  | 63 |  | 50 | ns |  |
| 62 | PBDTACK low setup to PHI 1 high | 10 |  | 9 |  | 7 |  | ns |  |
| 63 | $\overline{\text { PBDS }}$ high to $\overline{\text { PBDTACK }}$ high (hold time) | -15 |  | -15 |  | -15 |  | ns |  |
| 64 | $\overline{\text { PBDS }}$ pulse width | 95 |  | 75 |  | 60 |  | ns |  |
| 65 | PHI 1 high to $\overline{\text { PBAS }}$ high |  | 58 |  | 45 |  | 36 | ns |  |
| 66 | PHI 1 low to data out invalid | 10 |  | 10 |  | 10 |  | ns |  |
| 67 | $\overline{\text { PBAS }}$ inactive | 100 |  | 81 |  | 65 |  | ns |  |
| 68 | $\overline{\text { PBDS }}$ high to data out invalid | 100 |  | 81 |  | 65 |  | ns |  |
| 69 | $\overline{\text { PBDS }}$ high to $\overline{\text { PBAS }}$ high | 15 |  | 15 |  | 15 |  | ns |  |
| 94 | $\overline{\text { PBDS }}$ low to data in valid |  | 27 |  | 27 |  | 37 | ns |  |
| 95 | Address valid to data in valid |  | 159 |  | 159 |  | 238 | ns |  |

MK68HC200 INPUT/OUTPUT AC ELECTRICAL CHARACTERISTICS

| NO. | DESCRIPTION |  |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 70 | Active and inactive pulse times | For XI2, XI1, STRH, STRL, TAI, TBI, NMI |  | 5 |  | 5 |  | 5 |  | state times | 1 |
|  |  |  |  | 3 |  | 3 |  | 3 |  |  |  |
| 71 | Input data setup to falling edge of STRH, STRL |  |  | 7 |  | 6 |  | 5 |  | ns |  |
| 72 | Input data hold from the falling edge of STRH, STRL |  |  | 30 |  | 24 |  | 19 |  | ns |  |
| 73 | RDYH, RDYL low time |  |  | 1 | 3 | 1 | 3 | 1 | 3 | state times | 1 |
| 74 | Delay from STRH, STRL high to RDYH, RDYL low |  |  |  | 55 |  | 45 |  | 36 | ns |  |
| 75 | Delay from data valid to RDYH, RDYL high (output mode) |  |  |  | 3 |  | 3 |  | 3 | state times | 1 |
| 76 | Delay from STRH high to data out (bidirectional mode) |  |  |  | 45 |  | 36 |  | 29 | ns |  |
| 77 | Port 0 data hold time from STRH low (bidirectional mode) |  |  | 15 |  | 12 |  | 10 |  | ns |  |
| 78 | Delay to Port 0 float from STRH low (bidirectional mode) |  |  |  | 43 |  | 33 |  | 26 | ns |  |
| 79 | TCLK,RCLK period (asynchronous) |  | as input | . 125 | DC | . 100 | DC | . 080 | DC | $\mu \mathrm{S}$ |  |
|  |  |  | as output | . 250 | DC | . 200 | DC | . 160 | DC |  |  |
|  | TCLK,RCLK period (synchronous) |  |  | . 500 | DC | . 400 | DC | . 320 | DC |  |  |
| 80 | TCLK, RCLK width low or high (asynchronous) |  | as input | 1 | DC | 1 | DC | 1 | DC | state <br> times <br> state <br> times | 1 |
|  |  |  | as output | 2 | DC | 2 | DC | 2 | DC |  |  |
|  | TCLK, RCLK width low or high (synchronous) |  | as input | 3 | DC | 3 | DC | 3 | DC |  | 1 |
|  |  |  | as output | 4 | DC | 4 | DC | 4 | DC |  |  |

MK68HC200 INPUT/OUTPUT AC ELECTRICAL SPECIFICATIONS

| NO. | DESCRIPTION |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 82 | TCLK low to SO delay (sync mode) | TCLK as input | 165 |  | 132 |  | 106 |  | ns |  |
|  |  | TCLK as output | 37 |  | 30 |  | 24 |  |  |  |
| 83 | SI to RCLK high setup time (sync mode) | RCLK as input | 15 |  | 12 |  | 10 |  | ns |  |
|  |  | RCLK as output | 90 |  | 72 |  | 58 |  |  |  |
| 84 | SI hold time from RCLK high (sync mode) | RCLK as input | 22 |  | 18 |  | 14 |  | ns |  |
|  |  | RCLK as output | 0 |  | 0 |  | 0 |  |  |  |

## NOTES

1. One state time is equal to one-half of the instruction clock ( PHI 1 ) period.
2. For the private bus case, the signals referenced apply to the equivalent private bus signals.

LOAD 1


TEST LOAD 1 IS APPLICABLE TO ALL PINS EXCEPT P1-12, P1-8, AND CLKOUT.

LOAD 2


TEST LOAD 2 IS APPLICABLE TO P1-12 AND P1-8.

LOAD 3

test load 3 IS APPLICABLE TO CLKOUT.

Figure 18. Output Test Load

CLK 1
(EXTERNAL CLOCK SIGNAL)

## $\overline{\text { RESET }}$




Figure 19. MK68HC200 AC Timing


Figure 20. MK68HC201 UPC Bus Timing (Fast Cycle)


Figure 21. MK68HC201 UPC Bus Timing (Standard Cycle)


Figure 22. MK68HC201 UPC Bus Arbitration Timing


Figure 23. MK68HC211 GP Bus Timing (Fast Cycle)


Figure 24. MK68HC211 GP Bus Timing (Standard Cycle)


Figure 25. MK68HC211 GP Bus Timing (Interrupt Acknowledge Timing)


Figure 26. MK68HC211 GP Bus Arbitration Timing (Bus Grantor)


Figure 27. MK68HC211 GP Bus Arbitration Timing (Bus Requestor)


Figure 28. MK68HC221 Private Bus Timing (Fast Cycle)


Figure 29. Input/Output AC TIming (Data Input)


Figure 30. Input/Output AC Timing (Data Output)


Figure 31. Input/Output AC Timing (Bidirectional I/O)


Figure 32. Input/Output AC Timing (Serial I/O)

## PART NUMBERING INFORMATION

There are two types of part numbers for the MK68HC200 family of devices. The generic part number describes the basic device type, the amount of ROM and RAM,
the desired package type, temperature range, power supply tolerance, and expandable bus interface type. The device order number indicates the specific mask set Mostek will use to manufacture the device, along with package type, speed grade and temperature range.

## Generic Part Number

An example of the generic part number is shown below:


## NOTES

1. Must be " 4 " when specifying the ROM version.
2. Must be " 8 " when specifying the emulator version.
3. Must be " 0 " when specifying the emulator version.

## Device Order Number

An example of the device order number is shown below:


Denotes maximum instruction clock frequency.
$8=8 \mathrm{MHz}$
$10=10 \mathrm{MHz}$
$12=12.5 \mathrm{MHz}$
Denotes operating temperature range.
$\mathrm{C}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$\mathrm{V}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$\mathrm{M}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Package Type. $\mathrm{E}=$ Ceramic Leadless Chip Carrier Q = Plastic Leaded Chip Carrier

Version/Code Specific Number.
For MK68HC201, MK68HC211:
002 = No ROM version (standard catalog item)
$0 x x=$ Reserved for catalog codes
100-999 = Customer Code (Mostek Assigned)
For MK68HC221:
030 = GP/UPC, 512 bytes RAM, no ROM

Basic Device Type.
$40=$ Emulator Version
43 = UPC, 0 or 4 K bytes ROM, 256 bytes RAM
$44=\mathrm{GP}, 0$ or 4 K bytes ROM, 256 bytes RAM

| PART NUMBER EXAMPLES (A noninclusive list) |  |
| :---: | :---: |
| MK68HC201/44Q-C10 | ```Device Order Number \(=\) MK43XXXQ-C10 Speed \(=10 \mathrm{MHz}\) Temperature \(=0^{\circ}\) to \(70^{\circ} \mathrm{C}\) Package \(=52\) pin plastic LCC RAM \(=256\) bytes ROM \(=4096\) bytes Bus = UPC``` |
| MK68HC211/04Q-C8 | $\begin{aligned} & \text { Device Order Number }=\text { MK44002Q-C8 } \\ & \text { Speed }=8 \mathrm{MHz} \\ & \text { Temperature }=0^{\circ} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Package }=52 \text { pin plastic LCC } \\ & \text { RAM }=256 \text { bytes } \\ & \text { ROM }=\text { None } \\ & \text { Bus }=G P \end{aligned}$ |
| MK68HC221/08E-M12 | $\begin{aligned} & \text { Device Order Number }=\text { MK40030E-M12 } \\ & \text { Speed }=12.5 \mathrm{MHz} \\ & \text { Temperature }=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & \text { Package }=84 \text { pin ceramic LCC } \\ & \text { RAM }=512 \text { bytes } \\ & \text { ROM }=\text { None } \\ & \text { Bus }=\text { GP/UPC } \end{aligned}$ |
| MK68HC201/44Q-V8 | $\begin{aligned} & \text { Device Order Number }=\text { MK43XXXQ-V8 } \\ & \text { Speed }=8 \mathrm{MHz} \\ & \text { Temperature }=-40 \text { to }+85^{\circ} \mathrm{C} \\ & \text { Package }=52 \text { pin plastic LCC } \\ & \text { RAM }=256 \text { bytes } \\ & \text { ROM }=4096 \text { bytes } \\ & \text { Bus }=\text { UPC } \end{aligned}$ |

MK68HC200 52-Pin
Ceramic Leadless Chip Carrier (E)


TOP VIEW

## NOTES:

1. Body material shall be ceramic.


[^44]

BOTTOM VIEW

| DIM. | INCHES |  | NOTES |
| :---: | :---: | :---: | :---: |
|  | MIN. | MAX. |  |
| A | . 070 | . 095 |  |
| $A_{1}$ | . 080 | . 110 |  |
| $\mathrm{B}_{1}$ | . 022 | . 028 |  |
| D | . 739 | . 761 |  |
| $\mathrm{D}_{2}$ | . 590 | . 610 |  |
| E | . 739 | . 761 |  |
| $E_{2}$ | . 590 | . 610 |  |
| e | . 048 | . 052 |  |
| h | . 035 | . 045 |  |
| j | . 035 | . 045 |  |
| L | . 045 | . 055 |  |
| $L_{1}$ | . 075 | . 095 |  |

1 INCH $=2.54$ CENTIMETERS

## MK68HC200 52-Pin

Plastic Leaded Chip Carrier (Q)


| DIM. | INCHES |  | NOTES |
| :---: | :---: | :---: | :---: |
|  | MIN. | MAX. |  |
| $A$ | .165 | .185 | 2 |
| $A_{1}$ | .090 | .120 | 2 |
| $B$ | .026 | .032 | 2 |
| $B_{1}$ | .013 | .021 | 2 |
| $D$ | .785 | .795 |  |
| $D_{1}$ | .750 | .756 |  |
| $D_{2}$ | .690 | .730 |  |
| $E_{1}$ | .785 | .795 |  |
| $E_{1}$ | .750 | .756 |  |
| $E_{2}$ | .690 | .730 |  |
| $h$ | .042 | .060 |  |
| $j$ | .042 | .060 |  |
| $k$ | .042 | .056 |  |

## NOTES:

1. LEAD FINISH TO BE SPECIFIED PER CUSTOMER AGREEMENT.
2. WHEN SOLDER DIP LEAD FINISH IS SPECIFIED, THE MAXIMUM LIMIT SHALL BE INCREASED BY .003.


## MK68HC221 84-Pin

Ceramic Leadless Chip Carrier (E)


| DIM. | INCHES |  |
| :---: | :---: | :---: |
|  | MIN | MAX |
| A | 1.138 | 1.167 |
| B | 1.138 | 1.167 |
| C | 0.070 | 0.090 |
| D | 0.080 | 0.110 |
| E | 0.044 | 0.056 |
| F | 0.044 | 0.056 |
| G | 0.075 | 0.095 |
| H | 0.048 | 0.052 |
| J | 0.033 | 0.039 |
| K | 0.010 | 0.018 |
| L | 0.495 | 0.505 |
| M | 0.495 | 0.505 |

1 INCH = 2.54 CENTIMETERS

## MK68HC221 84-Pin

Plastic Leaded Chip Carrier (Q)


| DIM. | INCHES |  | NOTES |
| :---: | :---: | :---: | :---: |
|  | MAX. |  |  |
| $A$ | .165 | .200 | 2 |
| $A_{1}$ | .090 | .130 | 2 |
| $B$ | .026 | .032 | 2 |
| $B_{1}$ | .013 | .021 | 2 |
| $D_{1}$ | 1.185 | 1.195 |  |
| $D_{1}$ | 1.150 | 1.158 |  |
| $D_{2}$ | 1.090 | 1.130 |  |
| $E_{1}$ | 1.185 | 1.1 .95 |  |
| $E_{1}$ | 1.150 | 1.158 |  |
| $E_{2}$ | 1.090 | 1.130 |  |
| $h$ | .042 | .060 |  |
| $j$ | .042 | .060 |  |
| $k$ | .042 | .056 |  |

## NOTES:

1. LEAD FINISH TO be SPECIFIED PER CUSTOMER AGREEMENT.
2. WHEN SOLDER DIP LEAD

FINISH IS SPECIFIED. THE MAXIMUM LIMIT SHALL BE INCREASED BY . 003.
$1 \mathrm{INCH}=2.54$ CENTIMETERS

CHAPTER 4-68000 PERIPHERALS

## 68000 PERIPHERALS SELECTION GUIDE

| Part number | Description | Technology | Alt source | CLK freq. (MHz) | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { MK68230-8 } \\ & \text { MK68230-10 } \end{aligned}$ | Parallel Interface Timer (PI/T) - 68000 bus compatible 24-bit programmable timer modes | HMOS | $\begin{aligned} & \text { MC68320-8 } \\ & \text { MC68230-10 } \end{aligned}$ | $\begin{gathered} \hline 8 \\ 10 \end{gathered}$ | 4-3 |
| MK68451-8 <br> MK68451-10 <br> MK68451-12 | Memory management unit - Compatible with TS68000 and TS68008 | NMOS | $\begin{aligned} & \text { MC68451-8 } \\ & \text { MC68451-10 } \end{aligned}$ | $\begin{gathered} \hline 8 \\ 10 \end{gathered}$ | 4-13 |
| MK68564-04 <br> MK68564-05 | Dual serial Input Output controller asynchronous, synchronous byte-oriented and synchronous bit oriented protocols | HMOS | - | $\begin{aligned} & 4 \\ & 5 \end{aligned}$ | 4-17 |
| $\begin{aligned} & \text { MK68901-00 } \\ & \text { MK68901-05 } \end{aligned}$ | Multifunction peripheral - 8 I/O-16 Source interrupt controller - Single channel USART full duplex 68000 bus compatible | HMOS | - | $\begin{aligned} & 4 \\ & 5 \end{aligned}$ | 4-29 |
| TS68HC901 | CMOS version of the MK68901 | HCMOS |  | 4, 5, 8 | 4-59 |



## FEATURES

68000 Bus Compatible$\square$ Port Modes Include:
Bit I/O
Unidirectional 8 -bit and 16 -bit Bidirectional 8 -bit and 16 -bitProgrammable Handshaking Options
$\square$ 24-bit Programmable Timer Modes
$\square$ Five Separate Interrupt VectorsSeparate Port and Timer Interrupt Service RequestsRegisters are Read/Write and Directly AddressableRegisters are Addressed for MOVEP (Move Peripheral) and DMAC Compatibility

## general description

The MK68230 Parallel Interface/Timer (PI/T) provides versatile double-buffered parallel interfaces and an operating syst m oriented timer to MK68000 systems. The parallel interfaces operate in unidirectional or bidirectional modes, either 8 or 16 bits wide. In the unidirectional modes, an associated data direction register determines whether the port pins are inputs or outputs. In the bidirectional modes, the data direction registers are ignored, and the direction is determined dynamically by the state of four handshake pins. These programmable handshake pins provide an interface flexible enough for connection to a wide variety of low, medium, or high speed peripherals or other computer systems. The PI/T ports allow use of vectored or autovectored interrupts, and also provide a DMA request pin for connection to the Direct Memory Access Controller or a similar circuit. The PI/T timer contains a 24 -bit wide counter and a 5 -bit prescaler. The timer may be clocked by the system clock (PI/T CLK pin) or by an external clock (TIN pin), with the option of using a 5 -bit prescaler. It can generate periodic interrupts, a square wave, or a single interrupt after a programmed timer period. Also, it can be used for elapsed time measurement or as a device watchdog.

The PI/T consists of two logically independent sections: the ports and the timer. The port section consists of Port

MK68230
Figure 1


## PIN ASSIGNMENT

Figure 2

| D5 1 | , | 48 | D4 |
| :---: | :---: | :---: | :---: |
| D6 2 |  | 47 | D3 |
| D74 3 |  | 46 | D2 |
| PAOL 4 |  | 45 | D1 |
| PA1 5 |  | 44 | DO |
| PA2 6 |  | 43 | R / $\bar{W}$ |
| PA30 7 |  | 42 | DTACK |
| PA4 88 |  | 41 | $\bigcirc \overline{\mathrm{CS}}$ |
| PA5 9 |  | 40 | CLLK |
| PA6 10 |  | 39 | - RESET |
| PA7011 |  | 38 | $\mathrm{VV}_{\text {ss }}$ |
| $\mathrm{V}_{\text {cc }} 12$ | - | 37 | PPC7/TIACK |
| H1 13 | N | 36 | PPC6/ $\overline{\text { PIACK }}$ |
| H2 414 | $\stackrel{+}{\mathbf{8}}$ | 35 | PPC5/ $\overline{\text { PIRQ }}$ |
| H3 15 | $\Sigma$ | 34 | P PC4/DMAREQ |
| H40 16 |  | 33 | PPC3/TOUT |
| PBO¢ 17 |  | 32 | PC2/TIN |
| PB1 18 |  | 31 | P PC1 |
| PB2 19 |  | 30 | P PCO |
| PB3 20 |  | 29 | PRS1 |
| PB4 21 |  | 28 | RRS2 |
| PB5 22 |  | 27 | PRS3 |
| PB6 023 |  | 26 | pRS4 |
| PB7 024 |  | 25 | PRS5 |

## LOGICAL PIN ASSIGNMENT

Figure 3

*Individually Programmable Dual-Function Pin

A (PAO-PA7), Port B (PBO-PB7), four handshake pins ( $\mathrm{H} 1, \mathrm{H} 2, \mathrm{H} 3$, and H 4 ), two general I/O pins, and six dualfunction pins. The dual-function pins can individually operate as a third port (Port C) or as an alternate function related to either Ports A and B, or the timer. The four programmable handshake pins, depending on the mode, can control data transfer to and from the ports, can be used as interrupt generating inputs, or can be used as I/O pins. The timer consists of a 24-bit counter, optionally clocked by a 5 -bit prescaler. Three pins provide complete timer I/O: PC2/TIN, PC3/TOUT, and PC7/ TIACK. Of course, only the ones needed for the given configuration perform the timer function, while the others remain Port C I/O.

The system bus interface provides for asynchronous transfer of data from the $\mathrm{PI} / \mathrm{T}$ to a bus master over the data bus (D0-D7). Data transfer acknowledge (DTACK), register selects (RS1-RS5), chip select, the read/write line (R $\overline{\mathrm{W}}$ ), and Port Interrupt Acknowledge ( $\overline{\mathrm{PIACK}}$ ) or Timer Interrupt Acknowledge (TIACK) control data transfer between the $\mathrm{PI} / \mathrm{T}$ and the MK68000.

## MK68320 BLOCK DIAGRAM

Figure 4



## PIN DESCRIPTION

Throughout this data sheet, signals are presented using the terms active and inactive, or asserted and negated independent of whether the signal is active in the highvoltage state or low-voltage state. (The active state of each logic pin is given below.) Active low signals are denoted by a superscript bar. RNW indicates a "write" is active low and a "read" active high.

D0-D7 The data bus pins D0-D7 form an 8-bit (Bidirectional Data Bus) or other bus master. These pins are active RS1-RS5 (Register Selects)
$\mathrm{R} \bar{W}$
(Read/Write
Input) Output)
$\overline{\mathrm{CS}} \quad \overline{\mathrm{CS}}$ is a high-impedance input that selects
(Chip Select the $\mathrm{PI} / \mathrm{T}$ registers for the current bus cycle. Input) Address strobe and the data strobe (upper and lower) of the bus master, along with the appropriate address bits, must be included in the chip select equation. A low level corresponds to an asserted chip select.
$\overline{\text { DTACK }} \quad \overline{\text { DTACK }}$ is an active low output that signals (Data the completion of the bus cycle. During Transfer read or interrupt acknowledge cycles, Acknowledge DTACK is asserted by the MK68230 after high.

RS1-RS5 are active high, high-impedance inputs that determine which of the 25 possible registers is being addressed. They are provided by the MK68000 or other bus master.
$\mathrm{R} \overline{\mathrm{W}}$ is the high-impedance Read/ $\overline{\text { Write }}$ signal from the MK68000 or bus master, indicating whether the current bus cycle is a read (high cycle) or write (low cycle).

DTACK is asserted by the MK68230 after
data has been provided on the data bus; during write cycles it is asserted after data
has been accepted at the data bus. Data transfer acknowledge is compatible with the MK68000 and with other Mostek bus masters. A holding resistor is required to maintain DTACK high between bus cycles.
$\mathrm{H} 1-\mathrm{H} 4$
(Handshake Pins Inputs or Output)
$\overline{\text { RESET }}$
(Reset Input)

CLK The clock pin is a high-impedance, TTL(Clock Input)

PAO-PA7 and PB0-PB7 (Port A and Port B)
$\overline{\text { RESET }}$ is a high-impedance input used to initialize all $\mathrm{PI} / \mathrm{T}$ functions. All control and data direction registers are cleared and most internal operations are disabled by the assertion of RESET (low). compatible signal with the same specifications as the MK68000. The PI/T contains dynamic logic throughout, and hence this clock must not be gated off at any time. It is not necessary that this clock maintain any particular phase relationship with the MK68000 clock. It may be connected to an independent frequency source (faster or slower) as long as all bus specifications are met.

Ports A and B are 8-bit ports that may be concatenated to form a 16-bit port in certain modes. The ports may be controlled in conjunction with the handshake pins $\mathrm{H} 1-\mathrm{H} 4$. For stabilization during system power-up, Ports $A$ and $B$ have internal pull up resistors to Vcc. All port pins are active high.

Handshake pins $\mathrm{H} 1-\mathrm{H} 4$ are multi-purpose pins that (depending on operational mode) may provide an interlocked handshake, a pulsed handshake, an interrupt input (independent of data transfers), or simple I/O pins. For stabilization during system power-
up, $\mathrm{H}-2$ and H 4 have internal pullup resistors to Vcc. Their sense (active high or low) may be programmed in the Port General Control Register bits 3-0. Independent of the mode, the instantaneous level of the handshake pins can be read from the Port Status Register.

Port C This port can be used as eight general (PCO-PC7) Alternate Function) purpose I/O pins (PCO-PC7) or any combination of six special function pins and two general purpose I/O pins (PCO-PC1). (Each dual function pin can be standard I/O or a special function independent of the other Port C pins.) The dual function pins are defined in the following paragraphs. When used as a Port C pin, these pins are active high. They may be individually programmed as inputs or outputs by the Port C Data Direction Register.

The alternate functions (TIN, TOUT,

TIACK) are timer I/O pins. TIN may be used as a rising-edge triggered external clock input or an external run/halt control pin (the timer is in the run state if run/halt is high and in the halt state if run/halt is low). TOUT may provide an active low timer interrupt request output or a generalpurpose square-wave output, initially high. TIACK is an active low high-impedance input used for timer interrupt acknowledge.

Port $A$ and $B$ functions have an independent pair of active low interrupts request ( $\overline{\mathrm{PIRQ}}$ ) and interrupt acnkowledge ( $\overline{\mathrm{PIACK}})$ pins.

The $\overline{\text { DMAREQ }}$ (Direct Memory Access Request) pin provides an active low Direct Memory Access Controller (DMAC) request pulse of three clock cylcles.

## MAXIMUM RATINGS

| Characteristics | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

## NOTE:

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions
be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$ ).

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$, unless otherwise noted)

| Characteristics | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage All inputs | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {SS }}+2.0$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input Low Voltage All inputs | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+0.8$ | V |
| Input Leakage Current $\left(\mathrm{V}_{\text {in }}=0\right.$ to 5.25 V$)$ H1, H3, R/ $\bar{W}, \overline{R E S E T}$, CLK, RS1-RS5, $\overline{\text { CS }}$ | In | - | 10.0 | $\mu \mathrm{A}$ |
| Hi-Z (Off State) Input Current $\left(\mathrm{V}_{\text {in }}=0.4\right.$ to $\frac{2.4)}{\text { DTACK, PCO-PC7, DO-D7 }}$ H2, H4, PAO-PA7, PB0-PB7 | ITSI | $-\overline{0.1}$ | $\begin{gathered} 20 \\ -1.0 \end{gathered}$ | $\begin{gathered} \mu \mathrm{A} \\ \mathrm{~mA} \end{gathered}$ |
|  | $\mathrm{V}_{\mathrm{OH}}$ | $V_{S S}+2.4$ | - | v |
|  | VOL | - | 0.5 | v |
| Internal Power Dissipation (Measured at $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ ) | PINT | - | 750 | mW |
| Input Capacitance ( $\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ ) | $\mathrm{C}_{\text {in }}$ | - | 15 | pF |

AC ELECTRICAL SPECIFICATIONS - CLOCK TIMING

| Characteristics | Symbol | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $f$ | 2.0 | 8.0 | 2.0 | 10.0 | 4.0 | 12.0 | MHz |
| Cycle Time | $\mathrm{t}_{\mathrm{cyc}}$ | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| Clock Pulse Width | $\begin{aligned} & { }^{\mathrm{t}_{\mathrm{CLL}}} \\ & \hline \end{aligned}$ | $\begin{aligned} & 55 \\ & 55 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \\ & \hline \end{aligned}$ | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ | $\begin{aligned} & 125 \\ & 125 \end{aligned}$ | ns |
| Clock Rise and Fall Times | $\begin{aligned} & \mathrm{t}_{\mathrm{tr}} \\ & \text { n } \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | 二 | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | 二 | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | ns |

AC ELECTRICAL SPECIFICATIONS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$, unless otherwise noted)

| Number | Characteristics | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | R $\bar{W}$, RS1-RS5 Valid to CS Low (Setup Time) | 0 | - | 0 | - | 0 | - | ns |
| 2 | $\overline{\mathrm{CS}}$ Low to R$\overline{\mathrm{W}}$ and RS1-RS5 Invalid (Hold Time) | 100 | - | 65 | - | 60 | - | ns |
| 3(1) | $\overline{\text { CS }}$ Low to CLK Low (Setup Time) | 30 | - | 20 | - | 20 | - | ns |
| 4(2) | $\overline{\mathrm{CS}}$ Low to Data Out Valid | - | 75 | - | 65 | - | 55 | ns |
| 5 | RS1-RS5, R/ $\bar{W}$ Valid to Data Out | - | 140 | - | 100 | - | 80 | ns |
| 6 | CLK Low to $\overline{\text { TTACK }}$ Low (Read/Write Cycle) | 0 | 70 | 0 | 60 | 0 | 55 | ns |
| 7(3) | $\overline{\text { DTACK }}$ Low to $\overline{\text { CS }}$ High (Hold Time) | 0 | - | 0 | - | 0 | - | ns |
| 8 | $\overline{\mathrm{CS}}$ or $\overline{\text { PIACK }}$ or $\overline{\text { TIACK }}$ High to Data Out Invalid (Hold Time) | 0 | - | 0 | - | 0 | - | ns |
| 9 | $\overline{\mathrm{CS}}$ or $\overline{\text { PIACK }}$ or $\overline{\text { TIACK High to DO-D7 }}$ High Impedance | - | 50 | - | 45 | - | 45 | ns |

AC ELECTRICAL SPECIFICATIONS (Continued)

| Number | Characteristic | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| 10 | $\overline{\mathrm{CS}}$ or $\overline{\mathrm{PIACK}}$ or TIACK High to $\overline{\text { DTACK }}$ High | - | 50 | - | 45 | - | 40 | ns |
| 11 | $\overline{\mathrm{CS}}$ or $\overline{\text { PIACK }}$ or $\overline{\text { TIACK }}$ High to $\overline{\text { DTACK }}$ High Impedance | - | 100 | - | 55 | - | 45 | ns |
| 12 | Data In Valid to CS Low (Setup Time) | 0 | - | 0 | - | 0 | - | ns |
| 13 | $\overline{\mathrm{CS}}$ Low to Data In Invalid (Hold Time) | 100 | - | 65 | - | 60 | - | ns |
| 14 | Port Input Data Valid to H1(H3) Asserted (Setup Time) | 100 | - | 60 | - | 50 | - | ns |
| 15 | H1(H3) Asserted to Port Input Data Invalid (Hold Time) | 20 | - | 20 | - | 20 | - | ns |
| 16 | Handshake Input H1(H4) Pulse Width Asserted | 40 | - | 40 | - | 40 | - | ns |
| 17 | Handshake Input H1(H4) Pulse Width Negated | 40 | - | 40 | - | 40 | - | ns |
| 18 | $\mathrm{H} 1(\mathrm{H} 3)$ Asserted to $\mathrm{H} 2(\mathrm{H} 4)$ Negated (Delay Time) | - | 150 | - | 120 | - | 100 | ns |
| 19 | CLK Low to H2(H4) Asserted (Delay Time) | - | 100 | - | 100 | - | 80 | ns |
| 20(4) | $\mathrm{H} 2(\mathrm{H} 4)$ Asserted to $\mathrm{H} 1(\mathrm{H} 3)$ Asserted | 0 | - | 0 | - | 0 | - | ns |
| 21(5) | CLK Low to H2(H4) Pulse Negated (Delay Time) | - | 125 | - | 125 | - | 100 | ns |
| 22(9,10) | Synchronized $\mathrm{H}_{1}(\mathrm{H} 3)$ to CLK Low on which DMARE $\bar{Q}$ is Asserted | 2.5 | 3.5 | 2.5 | 3.5 | 2.5 | 3.5 | CLK Per. |
| 23 | CLK Low on which DMAREQ is Asserted to CLK Low on which DMAREQ is Negated | 2.5 | 3 | 2.5 | 3 | 2.5 | 3 | CLK Per. |
| 24 | CLK Low to Port Output Data Valid (Delay Time) (Modes 0 and 1) | - | 150 | - | 120 | - | 100 | ns |
| 25(9,10) | Synchronized H1(H3) to Port Output Data Invalid (Modes 0 and 1) | 1.5 | 2.5 | 1.5 | 2.5 | 1.5 | 2.5 | $\begin{aligned} & \text { CLLK } \\ & \text { Per. } \end{aligned}$ |
| 26 | H1 Negated to Port Output Data Valid (Modes 2 and 3) | - | 70 | - | 50 | - | 50 | ns |
| 27 | H1 Asserted to Port Output Data High Impedance (Modes 2 and 3) | 0 | 70 | 0 | 70 | 0 | 70 | ns |
| 28 | Read Data Valid to $\overline{\text { DTACK }}$ Low (Setup Time) | 0 | - | 0 | - | 0 | - | ns |
| 29 | CLK Low to Data Output Valid, Interrupt Acknowledge Cycle | - | 120 | - | 100 | - | 80 | ns |
| 30(7) | H1(H3) Asserted to CLK High (Setup Time) | 50 | - | 40 | - | 40 | - | ns |
| 31 | PIACK or TIACK Low to CLK Low (Setup Time) | 50 | - | 40 | - | 30 | - | ns |


| Number | Characteristic | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| 32(10) | Synchronized $\overline{\mathrm{CS}}$ to CLK Low on which DMAREQ is Asserted | 3 | 3 | 3 | 3 | 3 | 3 | $\begin{aligned} & \text { CLK } \\ & \text { Per. } \end{aligned}$ |
| 33(9,10) | Synchronized $\mathrm{H}_{1}(\mathrm{H} 3)$ to CLK Low on which $\mathrm{H} 2(\mathrm{H} 4)$ is Asserted | 3.5 | 4.5 | 3.5 | 4.5 | 3.5 | 4.5 | $\begin{aligned} & \text { CLK } \\ & \text { Per. } \end{aligned}$ |
| 34 | CLK Low to $\overline{\text { DTACK }}$ Low Interrupt Acknowledge Cycle (Delay Time) | - | 100 | - | 100 | - | 80 | ns |
| 35 | CLK Low to DMAREQ Low (Delay Time) | 0 | 120 | 0 | 100 | 0 | 80 | ns |
| 36 | CLK Low to $\overline{\text { DMAREQ }}$ High (Delay Time) | 0 | 120 | 0 | 100 | 0 | 80 | ns |
| 37(10) | Synchronized $\mathrm{H} 1(\mathrm{H} 3)$ to CLK Low on which PIRQ is Asserted | 2.5 | 3.5 | 2.5 | 3.5 | 2.5 | 3.5 | $\begin{aligned} & \text { CLK } \\ & \text { Per. } \end{aligned}$ |
| 38(10) | Synchronized $\overline{\mathrm{CS}}$ to CLK Low on which $\overline{\mathrm{PIRQ}}$ is High Impedance | 3 | 3 | 3 | 3 | 3 | 3 | CLK Per. |
| 39 | CLK Low to PIRQ Low or High Impedance | 0 | 250 | 0 | 225 | 0 | 200 | ns |
| 40(8) | TIN Frequency (External Clock) - Prescaler Used | 0 | 1 | 0 | 1 | 0 | 1 | $\begin{gathered} f_{\text {clk }} \\ (H z)(6) \end{gathered}$ |
| 41 | TIN Frequency (External Clock) - Prescaler Not Used | 0 | 1/8 | 0 | 1/8 | 0 | 1/8 | $\begin{gathered} f_{\text {clk }} \\ (H z)(6) \end{gathered}$ |
| 42. | TIN Pulse Width High or Low (External Clock) | 55 | - | 45 | - | 45 | - | ns |
| 43 | TIN Pulse Width Low (Run/Halt Clock) | 1 | - | 1 | - | 1 | - | CLK <br> Per. |
| 44 | CLK Low to TOUT High, Low, or High Impedance | 0 | 250 | 0 | 225 | 0 | 200 | ns |
| 45 | $\overline{\mathrm{CS}}, \overline{\mathrm{PIACK}}$, or $\overline{\mathrm{TIACH}}$ High to $\overline{\mathrm{CS}}, \overline{\text { PIACK }}$, or TIACK Low | 50 | - | 30 | - | 30 | - | ns |

## NOTES:

1. This specification only applies if the $\mathrm{P} / \mathrm{T}$ had completed all operations initiated by the previous bus cycle when $\overline{\mathrm{CS}}$ was asserted. Following a normal read or write bus cycle, all operations are complete within three clocks after the falling edge of the CLK pin on which $\overline{\text { DTACK }}$ was asserted. If $\overline{C S}$ is asserted prior to completion of these operations, the new bus cycle, and hence, DTACK is postponed.
If all operations of the previous bus cycle were complete when $\overline{\mathrm{CS}}$ was asserted, this specification is made only to insure that $\overline{\text { DTACK }}$ is asserted with respect to the falling edge of the CLK pin as shown in the timing diagram, not to guarantee operation of the part. If the CS setup time is violated, DTACK may be asserted as shown, or may be asserted one clock cycle later.
2. Assuming the RS1-RS5 to data valid time has also expired.
3. This specification imposes a lower bound on $\overline{\mathrm{CS}}$ low time, guaranteeing that CS will be low for at least 1 CLK period.
4. This specification assures recognition of the asserted edge of $\mathrm{H} 1(\mathrm{H} 3)$.
5. This specification applies only when a pulsed handshake option is chosen and the pulse is not shortened due to an early asserted edge of $\mathrm{H} 1(\mathrm{H} 3)$.
6. CLK refers to the actual frequency of the CLK pin, not the maximum allowable CLK frequency.
7. If the setup time on the rising edge of the clock is not met, $\mathrm{H}_{1}(\mathrm{H} 3)$ may
not be recognized until the next rising of the clock.
8. This limit applies to the frequency of the signal at TIN compared to the frequency of the CLK signal during each clock cycle. If any period of the waveform at TIN is smaller than the period of the CL.K signal at that instant, then it is likely that the timer circuit will completely ignore one cycle of the TIN signal.
If these two signals are derived from different sources, they will have different instantaneous frequency variations. In this case the frequency applied to the TIN pin must be distinctly less than the frequency at the CLK pin to avoid lost cycles of the TIN signal. With signals derived from different crystal oscillators applied to the TIN and CLK pins with fast rise and fall times, the TIN frequency can approach 80 to $90 \%$ of the frequency of the CLK signal without a loss of a cycle of the TIN signal.
If these two signals are derived from the same frequency source then the frequency of the signal applied to TIN can be 100\% of the frequency at the CLK pin. They may be generated by different buffers from the same signal or one may be an inverted version of the other. The TIN signal may be generated by and 'AND' function of the clock and a control signal.
9. The maximum value is caused by a peripheral access $(\mathrm{H} 1(\mathrm{H} 3)$ asserted) and bus access (CS asserted) occurring at the same time.
10. Synchronized means that the input signal has been seen by the $\mathrm{PI} / \mathrm{T}$ on the appropriate edge of the clock (rising edge for $\mathrm{H} 1(\mathrm{H} 3)$ and falling edge for $\overline{\mathrm{CS}}$ ).

## CLOCK INPUT TIMING DIAGRAM

Figure 6


READ CYCLE TIMING DIAGRAM
Figure 7


## WRITE CYCLE TIMING DIAGRAM

Figure 8


NOTE:
Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted

## IACK TIMING DIAGRAM

## Figure 9



NOTE:
Timing measurements are referenced to and from a low voitage of 0.8 volts and
a high voltage of 2.0 volts, unless otherwise needed.

## PERIPHERAL INPUT TIMING DIAGRAM

Figure 10


PERIPHERAL OUTPUT TIMING DIAGRAM
Figure 11


NOTES:

[^45]
## MK68230 ORDERING INFORMATION

| PART NO. | PACKAGE TYPE | MAX CLOCK FREQUENCY | TEMP. RANGE |
| :--- | :---: | :---: | :---: |
| MK68230N-8 | 48 Pin Plastic <br> DIP | 8.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| MK68230N-10 |  | 10.0 MHz |  |

## FEATURES

$\square$ Compatible with MK68000 and MK68008
$\square$ Provides virtual memory support for the MK68010
$\square$ Provides efficient memory allocation
$\square$ Seperates address spaces of system and user resources
$\square$ Provides write protection
$\square$ Supports paging and segmentation
$\square 32$ segments of variable size with each MMUMultiple MMU capability to expand to any number of segmentsAllows inter-task communication through shared segments

Quick context switching to cut operating system overheadSimplifies programming model of address space
$\square$ Increases system reliabilityDMA-compatible

## GENERAL DESCRIPTION

The MK68451 memory management unit (MMU) provides address translation and protection for the 16 megabyte addressing range of the MK68000 MPU. Each bus master (or processor) in the MK68000 family provides a function code and an address during each bus cycle. The function code specifies an address space, and the address specifies a location within that address space. The function codes distinguish between user and supervisor spaces and, within these, between data and program spaces. This separation of address spaces provides the basis for memory management and protection by the operating system. Provision is also made for other bus masters to have separate address spaces for logical DMA.

MK68451
Figure 1


A multitasking operating system is simplified, and reliability is enhanced, through the use of the MMU.

The MK68451 memory management unit (MMU) is the basic element of a memory management mechanism (MMM) in an MK68000 family system. The operating system is responsible for insuring the proper execution of user tasks in the system environment, and memory management is basic to this responsibility. The MMM provides the operating system with the capability to allocate, control, and protect the system memory. A block diagram of a single-MMU system is shown in Figure 3.

An MMM, implemented with one or more MK68451 MMUs, can provide address translation, separation, and write protection for the system memory. The MMM can be programmed to cause an interrupt when a chosen section of memory is accessed, and can directly translate a logical address into a physical address, making it available to the MPU for use by the operating system. Using these features, the MMM can provide separation and security for user programs and allow the operating system to manage the memory in an efficient fashion for multitasking.

PIN ASSIGNMENT
Figure 2


SIMPLIFIED BLOCK DIAGRAM OF SINGLE-MMU
SYSTEM
SYTEM
Figure 3


## FUNCTIONAL DESCRIPTION

## MEMORY SEGMENTS

The MMM partitions the logical address space into contiguous pieces called segments. Each segment is a section of the logical address space of a task which is mapped via the MMM into the physical address space. Each task may have any number of segments. Segments may be defined as user or supervisor, data-only or program-only, or program and data. They may be accessed by only one task or shared between two or more tasks. In addition, any segment can be write protected to insure system integrity. A fault (MK68000 bus error) is generated by the MMM if an undefined segment is accessed.

## FUNCTION CODES AND ADDRESS SPACES

Each bus master in the MK68000 family provides a function code during each bus cycle to indicate the address space to be used for that cycle. The address bus then specifies a location within this address space for the operation taking place during that bus cycle.

The function codes appear on the FC0-FC2 lines of the MK68000 and divide the memory references into two logical address spaces-the supervisor and the user spaces. Each of these is further divided into program and data spaces. A separate address space is also provided for internal CPU-related activities, such as interrupt acknowledge, giving a total of five defined function codes. The address space of the MK68000 is shown in Figure 4.

ADDRESS SPACE OF MK68000
Figure 4


In addition to the 3-bit function code provided by the MK68000, the MK68451 MMU also allows a fourth bit (FC3) which provides for the possibility of another bus master in the system. In this case, FC3 would be a function of bus grant acknowledge ( $\overline{\mathrm{BGACK}}$ ) of the MK68000 to enable a second set of eight function codes. This raises the total number of possible function codes to 16. If there
is only one bus master (the MPU), the FC3 pin on the MMU should be tied low, and only eight address spaces can then be used.

## ADDRESS SPACE NUMBER

Each task in a system has an address space comprised of all the segments defined for that task. This address space is assigned a number by programming all the address space number (ASN) fields in its descriptors with the same value. This value can be considered a task number. The currently active task's number is kept in the appropriate entry(s) in the address space table (AST).

The AST is a set of MMU registers that defines which task's segments are to be used in address translation for each cycle type (supervisor program, supervisor data, etc.). The AST contains an 8-bit entry for each possible function code. Each entry is assigned an ASN (task number) and this is used to select which descriptors may be used for translation. The logical address is then translated by one of these to produce the physical address. Figure 5 is a typical memory map of a task's address space.

MEMORY MAP OF TYPICAL TASK ADDRESS SPACE Figure 5
SUPERVISOR
$\square$

V7IDID Task 01 Segment

## DESCRIPTORS

Address translation is done using descriptors. A descriptor is a set of six registers (nine bytes) which describe a memory segment and how that segment is to be mapped to the physical addresses. Each descriptor contains base addresses for the logical address masks. The size of the segment is then defined by "don't cares" in the masks. This method allows segment sizes from a minimum of 256 bytes to a maximum of 16 megabytes in binary increments (i.e., powers of two). This also forces both logical and physical addresses of segment boundaries to lie on a segment size boundary. That is, a segment can only start on an address which is a multiple of $2 k$. The segments can be defined in such a way to allow them to be logically or physically shared between tasks. Descriptor mapping is shown schematically in Figure 6.

SCHEMATIC DIAGRAM OF DESCRIPTOR MAPPING Figure 6


## TRANSLATION

During normal translation, the MMU translates the logical address provided by the MK68000 to produce a physical address which is then presented to the memory array. This is accomplished by matching the logical address with the information in the descriptors and then mapping it into the physical address space. A block diagram of the MK68451 is shown in Figure. 7

Refer to Figure 3 for the following information. The logical address is composed of address lines A1-A23. The upper 16 bits of this address (A8-A23) are translated by the MMU and mapped into a physical address (PA8-PA23). The lower seven bits of the logical address (A1-A7) bypass the MMU and become the low-order physical address bits (PA1-PA7). In addition, the data strobes ( $\overline{U D S}$ and $\overline{\mathrm{LDS}}$ ) remain unmapped to become the physical data strobes for a total of eight unmapped address lines.

FUNCTIONAL BLOCK DIAGRAM
Figure 7


## ORDERING INFORMATION

| Part Number | Package Type | Max Clock <br> Frequency | Temperature <br> Range |
| :--- | :--- | :--- | :--- |
| MK68451N-8 | Plastic | 8.0 MHz |  |
| MK68451N-10 | Plastic | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |  |
| $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |  |  |  |

## PACKAGE DESCRIPTION

Dual In-Line
64-Pin


5. WHEN THE SOLDER LEAD FINISH IS SPECIFIED, THE MAXIMUM LIMIT SHALL BE INCREASED BY . 003 IN.
4. MEASURED FROM CENTERLINE TO CENTERLINE AT LEAD TIPS.
3. PACKAGE STANDOFF TO BE MEASURED PER JEDEC REQUIREMENTS.
2. OVERALL LENGTH INCLUDES $\mathbf{.} 010$ IN. FLASH ON EITHER END OF THE PACKAGE.

1. LEAD FINISH IS TO BE SPECIFIED ON THE DETAIL SPECIFICATION.

NOTES;


| DIM. | INCHES |  | NOTES |
| :---: | ---: | ---: | :---: |
|  | MIN. | MAX. |  |
| A | 3.180 | 3.230 | 2 |
| B | .890 | .940 |  |
| C | .790 | .810 |  |
| D | .170 | .190 |  |
| E | .020 | .060 | 3 |
| F | .120 | .150 |  |
| G | .040 | .070 |  |
| H | .090 | .110 |  |
| J | .900 | 1.000 | 4 |
| K | .015 | .021 | 5 |
| L | .008 | .012 | 5 |
| M | .045 | .070 |  |

PRELIMINARY

## FEATURES

Compatible with MK68000 CPUCompatible with MK68000 Series DMA'sTwo independent, full-duplex channelsTwo independent baud rate generators

- Crystal oscillator input
- Single-phase TTL clock inputDirectly addressable registers (all control registers are read/write)Data rate in synchronous or asynchronous modes
- 0-1.25 M bits/second with 5.0 MHz system clock rateSelf-test capabilityReceive data registers are quadruply buffered; transmit data registers are doubly bufferedDaisy-chain priority interrupt logic provides automatic interrupt vectoring without external logicModem status can be monitored
- Separate modem controls for each channel
$\square$ Asynchronous features
- 5, 6, 7, or 8 bits/character
- $1,11 / 2$, or 2 stop bits
- Even, odd, or no parity
- x1, x16, x32, and x64 clock modes
- Break generation and detection
- Parity, overrun, and framing error detection
$\square$ Byte synchronous features
- Internal or external character synchronization
- One or two sync characters in separate registers
- Automatic sync character insertion
- CRC-16 or CRC-CCITT block check generation and checking
$\square$ Bit synchronous features
- Abort sequence generation and detection
- Automatic zero insertion and deletion
- Automatic flag insertion between messages
- Address field recognition
- I-field residue handling
- Valid receive messages protected from overrun
- CRC-CCITT block check generation and checking


## MK68564

Figure 1


## PIN DESCRIPTION

Figure 2

| D1 1 d |  | 248 Do |
| :---: | :---: | :---: |
| D3 2 - |  | 047 D2 |
| D5 3 - |  | 246 D4 |
| D7 4 - |  | $\bigcirc 45$ D6 |
| INTR 5 - |  | $\bigcirc 44 \mathrm{R} / \overline{\mathrm{W}}$ |
| CLK 65 |  | 043 IACK |
| XTAL1 7 - |  | $242 \overline{\text { DTACK }}$ |
| XTAL2 8 - |  | 241 CS |
| MESET 9 - |  | 040 RxRDYB |
| RXRDYA $10-$ |  | 739 TXRDYB |
| $\overline{\text { TxRDYA } 11}$ |  | $\square 38$ GND |
| $\mathrm{V}_{\mathrm{cc}} 12 \mathrm{G}$ | SIO | $\mathrm{Q}^{37}$ IEI |
| IEO 13 - |  | $\square 36$ SYNCB |
| SYNCA 14 - |  | $\square 35 \overline{\text { TXCB }}$ |
| TxCA $15 \square$ |  | -34 $\overline{\mathrm{RXCB}}$ |
| $\overline{\text { RXCA } 16-1}$ |  | - 33 RxDB |
| RxDA 17 - |  | $\square 32$ TxDB |
| TxDA 18 - |  | $\square 31$ DTRB |
| DTRA 19 - |  | 30 RTSB |
| RTSA $20-$ |  | 229 CTSB |
| CTSA 21 - |  | $\square 28 \overline{\text { DCDB }}$ |
| DCDA 22 - |  | $\bigcirc 27$ A1 |
| A2 23 回 |  | $\bigcirc 26$ A3 |
| A4 24 - |  | ]25 A5 |

## GENERAL DESCRIPTION

The MK68564 SIO is a dual-channel, Serial Input/Output Controller, designed to satisfy a wide variety of serial data communications requirements in microcomputer systems. Its basic function is a serial-to-parallel, parallel-to-serial converter/controller; however, within that role, it is systems software configurable so that it may be optimized for any given serial data communications application.

The MK68564 is capable of handling asynchronous protocols, synchronous byte-oriented protocols (such as IBM Bisync), and synchronous bit-oriented protocols (such as HDLC and IBM SDLC). This versatile device can also be used to support virtually any serial protocol for applications other than data communications (cassette or floppy disk interface, for example).

The MK68564 can generate and check CRC codes in any synchronous mode and may be programmed to check data integrity in various modes. The device also has facilities for modem controls in each channel. In applications where these controls are not needed, the modem controls may be used for general-purpose I/O.

## SIO PIN DESCRIPTION

| GND: | Ground. |
| :--- | :--- |
| $V_{C C}:$ | +5 volts $( \pm 5 \%)$. |

$\overline{\mathrm{CS}:} \quad$ Input active low. $\overline{\mathrm{CS}}$ is used to select the Chip Select
$R / \bar{W}$ : Input. $R / \bar{W}$ is the signal from the bus
Read/Write

DTACK:
Data Transfer
Acknowledge

A1-A5:
Address Bus

D0-D7:
Data Bus

CLK:
Clock MK68564 SIO for access to the internal registers. $\overline{\mathrm{CS}}$ and $\overline{\mathrm{IACK}}$ must not be asserted at the same time. master, indicating whether the current bus cycle is a read (high) or write (low) cycle.

Output, active low, tri-stateable. $\overline{\text { DTACK }}$ is used to signal the bus master that data is ready or that data has been accepted by the MK68564 SIO.

Inputs. The address bus is used to select one of the internal registers during a read or write cycle.

Bidirectional, tri-stateable. The data bus is used to transfer data to or from the internal registers during a read or write cycle. It is also used to pass a vector during an interrupt acknowledge cycle.

LK: Input. This input is used to provide the internal timing for the MK68564 SIO.
$\overline{\text { RESET }}$
Device Reset
$\overline{\text { INTR }}$ Interrupt Request
$\overline{\text { IACK }}$
Interrupt Acknowledge Interrupt Enable In
$\overline{\text { IEO }}$
Interrupt Enable Out

XTAL1 XTAL2
Baud Rate Generator
Inputs

RxRDYA
RxRDYB
Receiver Ready
$\overline{\text { TxRDYA }}$
TxRDYB
Transmitter
Ready
CTSA
CTSB
Clear to
Send
$\overline{|E|} \quad$ Input, active low. $\overline{|E|}$ is used to signal
Input, active low. Reset disables both receivers and transmitters, forces TxDA and TXDB to a marking condition, forces the modem controls high, and disables all interrupts. With the exception of the status registers, data registers, and the vector register, all internal registers are cleared. The vector register is reset to "OFH".

Output, active low, open drain. $\overline{\text { NTR }}$ is asserted when the MK68564 SIO is requesting an interrupt. INTR is negated during an interrupt acknowledge cycle or by clearing the pending interrupt(s) through software.

Input, active low. $\overline{\mathrm{IACK}}$ is used to signal the MK68564 SIO that the CPU is acknowledging an interrupt. $\overline{\mathrm{CS}}$ and IACK must not be asserted at the same time. If interrupts are not used then $\overline{\text { IACK }}$ should be pulled high. the MK68564 SIO that no higher priority device is requesting interrupt service.

Output, active low. $\overline{\mathrm{IEO}}$ is used to signal lower priority peripherals that neither the MK68564 SIO nor another higher priority peripheral is requesting interrupt service.

Inputs.A crystal may be connected between XTAL1 and XTAL2, or XTAL1 may be driven with a TTL level clock. When using a crystal, external capacitors must be connected. When driving XTAL1 with a TTL level clock, XTAL2 must be allowed to float.

Outputs, active low. Programmable DMA output for the receiver. The RxRDY pins pulse low when a character is available in the receive buffer.

Outputs, active low. Programmable DMA output for the transmitter. The TxRDY pins pulse low when the transmit buffer is empty.

Inputs, active low. If Tx Auto Enables is selected, these inputs enable the transmitter of their respective channels. If Tx Auto Enables is not selected, these inputs may be used as general purpose input pins. The inputs are Schmitttrigger buffered to allow slow rise-time input signals.

| $\overline{\text { DCDA }}$ | Inputs, active low. If Rx Auto Enables <br> is selected, these inputs enable the <br> receiver of their respective channels. If |
| :--- | :--- |
| DCDB Carrier |  |
| Rete Auto Enable is not selected, these |  |
| inputs may be used as general purpose |  |
| input pins. The inputs are Schmitt-trig- |  |
| ger buffered to allow slow rise-time |  |
| input signals. |  |

## MK68564 ELECTRICAL SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under | $-25^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature. | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin with | - 3 V to +7 V |
| Power Dissipation. | 1.5. Watt |
| -Stresses above those listed under of the device at these or any other rating conditions for extended perio | oniy and functional operation osure to absolute maximum |

## DC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$ )

| CHARACTERISTIC | SYM | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| INPUT HIGH VOLTAGE ALL INPUTS | $\mathrm{V}_{\mathrm{IH}}$ | GND + 2.0 | $\mathrm{V}_{\mathrm{Cc}}$ | V |
| INPUT LOW VOLTAGE ALL INPUTS | $\mathrm{V}_{\text {IL }}$ | GND -0.3 | GND +0.8 | V |
| POWER SUPPLY CURRENT OUTPUTS OPEN | $\mathrm{I}_{\text {LL }}$ |  | 190 | mA |
| INPUT LEAKAGE CURRENT ( $\mathrm{V}_{\mathrm{IN}}=0$ to 5.25 ) | IN |  | $\pm 10$ | $\mu \mathrm{A}$ |
| THREE-STATE (OFF STATE) INPUT CURRENT $0<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\mathrm{CC}} \overline{\mathrm{DTACK}}, \mathrm{DO}-\mathrm{D7} ; \overline{\mathrm{SYNC}}, \overline{\mathrm{TXC}}, \overline{\mathrm{RXC}}$, INTR | $\mathrm{I}_{\text {TSI }}$ |  | $\begin{gathered} 20 \\ \pm 10 \end{gathered}$ | ${ }_{\mu \mathrm{A}}^{\mu \mathrm{A}}$ |
| OUTPUT HIGH VOLTAGE <br> ( $\mathrm{L}_{\text {LOAD }}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=$ MIN $) \overline{\text { DTACK }}$, DO-D7 <br> ( LOAD $=-150 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{MIN}$ ) ALL OTHER <br> OUTPUTS (EXCEPT XTAL2 \& $\overline{\text { NTR }}$ )* | $\mathrm{V}_{\mathrm{OH}}$ | GND +2.4 |  | V |
| OUTPUT LOW VOLTAGE <br> ( $\mathrm{L}_{\mathrm{LAD}}=5.3 \mathrm{~mA}, \mathrm{~V}_{\text {CC }}=\mathrm{MIN}$ ) $\overline{\mathrm{NTR}}, \overline{\mathrm{DTACK}}$, DO-D7 ( $\left.L_{\text {LOAD }}=2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{MIN}\right)$ ALL OTHER <br> OUTPUTS (EXCEPT XTAL2)* | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.5 | V |

*XTAL2 SPECIAL
INTR (OPEN DRAIN)

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C}, f=1 \mathrm{MHz}$ unmeasured pins returned to ground.

| CHARACTERISTIC |  | SYM | MAX | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\overline{\mathrm{CS}}, \overline{\mathrm{ACK}}$ ALL OTHERS | $\mathrm{C}_{\mathrm{IN}}$ | $\begin{aligned} & 15 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pf} \\ & \mathrm{pf} \end{aligned}$ | Unmeasured pins returned to ground |
| Tri-state Output Capacitance |  | Cout | 10 | pf |  |

## AC ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{GND}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$ )

| NUMBER | PARAMETER | 3.0 MHz |  | 4.0 MHz |  | 5.0 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 1 | CLK Period | 330 | 1000 | 250 | 1000 | 200 | 1000 | ns |  |
| 2 | CLK Width High | 145 |  | 105 |  | 80 |  | ns |  |
| 3 | CLK Width Low | 145 |  | 105 |  | 80 |  | ns |  |
| 4 | CLK Fall Time |  | 30 |  | 30 |  | 30 | ns |  |
| 5 | CLK Rise Time |  | 30 |  | 30 |  | 30 | ns |  |
| 6 | $\overline{\mathrm{CS}}$ Low to CLK High (Setup Time) | 0 |  | 0 |  | 0 |  | ns | 1 |
| 7 | A1-A5 Valid to $\overline{\text { CS }}$ Low (Setup Time) | 0 |  | 0 |  | 0 |  | ns |  |
| 8 | DATA Valid to $\overline{\mathrm{CS}}$ Low (Write Cycle) | 0 |  | 0 |  | 0 |  | ns |  |
| 9 | $\overline{\text { CS Width High }}$ | 50 |  | 50 |  | 50 |  | ns | 1 |
| 10 | $\overline{\text { DTACK }}$ Low to A1-A5 Invalid (Hold Time) | 0 |  | 0 |  | 0 |  | ns |  |
| 11 | $\overline{\text { DTACK }}$ Low to DATA Invalid (Write Cycle Hold Time) | 0 |  | 0 |  | 0 |  | ns |  |
| 12 | $\overline{\mathrm{CS}}$ High to $\overline{\mathrm{DTACK}}$ High (Delay) |  | 60 |  | 55 |  | 50 | ns |  |
| 13 | CLK High to $\overline{\text { DTACK }}$ Low |  | 325 |  | 320 |  | 295 | ns |  |
| 14 | R $\overline{\bar{W}}$ Valid to $\overline{\mathrm{CS}}$ Low (Setup Time) | 0 |  | 0 |  | 0 |  | ns |  |
| 15 | DTACK Low to R $\bar{W}$ Invalid (Hold Time) | 0 |  | 0 |  | 0 |  | ns |  |
| 16 | CLK Low to DATA Out |  | 550 |  | 450 |  | 450 | ns |  |
| 17 | $\overline{\mathrm{CS}}$ High to DATA Out Invalid (Hold Time) | 0 |  | 0 |  | 0 |  | ns | 11 |
| 18 | $\overline{\text { CS }}$ High to $\overline{\text { TTACK }}$ High Impedance |  | 110 |  | 105 |  | 100 | ns |  |
| 19 | $\overline{\text { DTACK }}$ Low to $\overline{\text { CS }}$ High | 0 |  | 0 |  | 0 |  | ns |  |
| 20 | DATA Valid to DTTACK Low | 70 |  | 70 |  | 70 |  | ns |  |
| 21 | IACK Width High | 50 |  | 50 |  | 50 |  | ns | 1 |
| 22 | IACK Low to CLK High (Setup Time) | 0 |  | 0 |  | 0 |  | ns | 1 |
| 23 | CLK Low to INTR Disabled |  | 410 |  | 410 |  | 410 | ns | 2 |
| 24 | CLK Low to DATA Out |  | 330 |  | 330 |  | 330 | ns | 2 |
| 25 | $\overline{\text { DTACK }}$ Low to $\overline{\text { ACK }}$, İİ High | 0 |  | 0 |  | 0 |  | ns |  |
| 26 | $\overline{\text { IACK }}$ High to $\overline{\text { DTACK }}$ High |  | 60 |  | 55 |  | 50 | ns |  |
| 27 | $\overline{\mathrm{IACK}}$ High to $\overline{\mathrm{DTACK}}$ High Impedance |  | 110 |  | 105 |  | 100 | ns |  |
| 28 | $\overline{\text { IACK }}$ High to DATA Out Invalid (Hold Time) | 0 |  | 0 |  | 0 |  | ns |  |
| 29 | DATA Valid to $\overline{\text { TTACK }}$ Low | 195 |  | 195 |  | 195 |  | ns | 2 |
| 30 | CLK Low to IEO Low |  | 220 |  | 220 |  | 220 | ns | 3 |

AC ELECTRICAL CHARACTERISTICS (Cont.)
$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{GND}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| NUMBER | PARAMETER | 3.0 MHz |  | 4.0 MHz |  | 5.0 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 31 | $\overline{\text { IEI }}$ Low to IEO Low |  | 140 |  | 140 |  | 140 | ns | 3 |
| 32 | $\overline{\text { IEI High to } \overline{E O}}$ High |  | 190 |  | 190 |  | 190 | ns | 4 |
| 33 | $\overline{\text { IACK }}$ High to $\overline{\text { EO }}$ High |  | 190 |  | 190 |  | 190 | ns | 4 |
| 34 | IACK High to INTR Low |  | 200 |  | 200 |  | 200 | ns | 5 |
| 35 | $\overline{\text { IEI }}$ Low to CLK Low (Setup Time) | 10 |  | 10 |  | 10 |  | ns |  |
| 36 | $\overline{\mathrm{IEI}}$ Low to INTR Disabled |  | 500 |  | 425 |  | 425 | ns | 6 |
| 37 | $\overline{\text { EII Low to DATA Out Valid }}$ |  | 225 |  | 225 |  | 225 | ns | 6 |
| 38 | DATA Out Valid to $\overline{\text { DTACK }}$ Low | 55 |  | 55 |  | 55 |  | ns | 6 |
| 39 | IACK High to DATA Out High Impedance |  | 150 |  | 120 |  | 90 | ns |  |
| 40 | $\overline{\mathrm{CS}}$ High to DATA Out High Impedance |  | 150 |  | 120 |  | 90 | ns |  |
| 41 | $\overline{\mathrm{CS}}$ or $\overline{\mathrm{IACK}}$ High to CLK Low | 100 |  | 100 |  | 100 |  | ns | 7 |
| 42 | $\overline{\text { TxRDY }}$ or RxRDY Width Low |  | 3 |  | 3 |  | 3 | $\begin{gathered} \text { CLKK } \\ \text { Period } \\ \hline \end{gathered}$ | 8,10 |
| 43 | CLK High to $\overline{\text { TxRDY }}$ or $\overline{\text { RxRDY }}$ Low |  | 300 |  | 300 |  | 300 | ns |  |
| 44 | CLK High to TxRDY or $\overline{\text { RxRDY }}$ High |  | 335 |  | 300 |  | 300 | ns |  |
|  | $\overline{\mathrm{ACK}}$ High to $\overline{\mathrm{CS}}$ Low or $\overline{\mathrm{CS}}$ High to IACK Low (not shown) | 50 |  | 50 |  | 50 |  | ns | 1 |
| 45 | $\overline{C T S}, \overline{\mathrm{DCD}}, \overline{\text { SYNC Pulse Width High }}$ | 200 |  | 200 |  | 200 |  | ns |  |
| 46 | $\overline{\mathrm{CTS}}, \overline{\mathrm{DCD}}, \overline{\text { SYNC Pulse Width Low }}$ | 200 |  | 200 |  | 200 |  | ns |  |
| 47 | $\overline{\text { TXC Period }}$ | 1320 | DC | 1000 | DC | 800 | DC | ns | 9 |
| 48 | $\overline{\mathrm{TXC}}$ Width Low | 180 | DC | 180 | DC | 180 | DC | ns |  |
| 49 | $\overline{\mathrm{TXC}}$ Width High | 180 | DC | 180 | DC | 180 | DC | ns |  |
| 50 | $\overline{\mathrm{TXC}}$ Low to TxD Delay (X1 Mode) |  | 300 |  | 300 |  | 300 | ns |  |
| 51 | $\overline{\overline{T x C}}$ Low to $\overline{\text { INTR Low Delay }}$ | 5 | 9 | 5 | 9 | 5 | 9 | $\begin{gathered} \text { CLK } \\ \text { Period } \\ \hline \end{gathered}$ | 10 |
| 52 | $\overline{\mathrm{RxC}}$ Period | 1320 | DC | 1000 | DC | 800 | DC | ns | 9 |
| 53 | $\overline{\mathrm{RxC}}$ Width Low | 180 | DC | 180 | DC | 180 | DC | ns |  |
| 54 | $\overline{\mathrm{RxC}}$ Width High | 180 | DC | 180 | DC | 180 | DC | ns |  |
| 55 | R×D to $\overline{\mathrm{R} \times \mathrm{C}}$ High Setup Time (X1 Mode) | 0 |  | 0 |  | 0 |  | ns |  |
| 56 | $\overline{\mathrm{RxC}}$ High to RxD Hold Time (X1 Mode) | 140 |  | 140 |  | 140 |  | ns |  |
| 57 | $\overline{\mathrm{RxC}}$ High to $\overline{\mathrm{NTR}}$ Low Delay | 10 | 13 | 10 | 13 | 10 | 13 | $\begin{gathered} \hline \text { CLK } \\ \text { Period } \\ \hline \end{gathered}$ | 10 |
| 58 | $\overline{\mathrm{RXC}}$ High to $\overline{\mathrm{SYNC}}$ Low Delay (Output Modes) | 4 | 7 | 4 | 7 | 4 | 7 | CLK Period | 10 |

AC ELECTRICAL CHARACTERISTICS (Cont.)
$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{GND}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$ )

| NUMBER | PARAMETER | 3.0 MHz |  | 4.0 MHz |  | 5.0 MHz |  | UNITS | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| 59 | RESET Low | 1 |  | 1 |  | 1 |  | CLK <br> Period | 10 |
| 60 | XTAL 1 Width High (TTL in) | 145 |  | 100 |  | 80 |  | ns |  |
| 61 | XTAL 1 Width Low (TTL in) | 145 |  | 100 |  | 80 |  | ns |  |
| 62 | XTAL 1 Period (TTL in) | 330 | 2000 | 250 | 2000 | 200 | 2000 | ns |  |
| 63 | XTAL 1 Period (Crystal in) | 330 | 1000 | 250 | 1000 | 200 | 1000 | ns |  |

## NOTES:

1. This specification only applies if the SIO has completed all operations initiated by the previous bus cycle, when $\overline{\mathrm{CS}}$ or $\overline{\mathrm{IACK}}$ was asserted. Following a read, write, or interrupt acknowledge cycle, all operations are complete within two CLK cycles after the rising edge of $\overline{\mathrm{CS}}$ or $\overline{\mathrm{A} C K}$. If $\overline{\mathrm{CS}}$ or $\overline{\mathrm{IACK}}$ is asserted prior to the completion of the internal operations, the new bus cycle will be postponed.
2. If IEI meets the setup time to the falling edge of CLK, $11 / 2$ cycles following the clocking in of $\overline{\mathrm{ACK}}$.
3. No internal interrupt request pending at the start of an interrupt acknowledge cycle.
4. Time starts when first signal goes invalid (high).
5. If an internal interrupt is pending at the end of the interrupt acknowledge cycle.
6. If Note 2 timing is not met.
7. If this spec is met, the delay listed in note 1 will be one CLK cycle instead of two.
8. Ready signals will be negated asynchionous to the CLK, if the condition causing the assertion of the signals is cleared.
9. If $\overline{\mathrm{RXC}}$ and $\overline{\mathrm{TxC}}$ are asynchronous to the System Clock, the maximum clock rate into $\overline{\mathrm{RXC}}$ and $\overline{\mathrm{TXC}}$ should be no more than one-fifth the System Clock rate. If $\overline{R x C}$ and $\overline{\mathrm{XC}}$ are synchronized to the falling edge of the System Clock, the maximum clock rate into $\overline{\mathrm{RXC}}$ and $\overline{\mathrm{TXC}}$ can be one-fourth the System Clock rate.
10. SIO Clock (CLK) Cycles as defined in Parameter 1
11. Due to the dynamic nature of the internal data bus, if $\overline{\mathrm{CS}}$ is held low for more than a few hundred milliseconds the read data may go to 00 H before the end of the cycle.

## OUTPUT TEST LOAD

Figure 3

for all outputs except $\overline{\text { DTACK, }}$ DO-D7,
INTR, XTAL2
$C_{L}=130 \mathrm{pf}$
$R_{\mathrm{L}}=16 \mathrm{~K} \Omega$
$\mathrm{R}_{1}=450 \Omega$
for DTACK, DO-D7
$C_{L}=130 \mathrm{pf}$
$\mathrm{R}_{\mathrm{L}}=6 \mathrm{~K} \Omega$
$R_{1}=200 \Omega$

## INTR TEST LOAD

Figure 4

NOTE:


XTAL2 output test load is a cyrstal.

READ CYCLE
Figure 5


NOTE:
Waveform measurements for all inputs and outputs are specified at logic high
$=2.0$ volts, logic low $=0.8$ volts.

## WRITE CYCLE

Figure 6


NOTE:
Waveform measurements for all inputs and outputs are specified at logic high
$=2.0$ volts, logic low $=0.8$ volts.

## INTERRUPT ACKNOWLEDGE CYCLE (IEI LOW)

Figure 7


NOTE:
Waveform measurements for all inputs and outputs are specified at logic high
$=2.0$ volts, logic low $=0.8$ volts.

## INTERRUPT ACKNOWLEDGE CYCLE (IEI HIGH)

## Figure 8



NOTE:
Waveform measurements for all inputs and outputs are specified at logic high $=2.0$ volts, logic low $=0.8$ volts.

DM INTERFACE TIMING
Figure 9



THIN


CRYSTAL in

NOTE:
Waveform measurements for all inputs and outputs are specified at logic high
$=2.0$ volts, logic low $=0.8$ volts.

## SERIAL INTERFACE TIMING

Figure 10


## NOTE:

Waveform measurements for all inputs and outputs are specified at logic high
$=2.0$ volts, logic low $=0.8$ volts.

MK68564 ORDERING INFORMATION

| PART NO. | PACKAGE TYPE | MAX. CLOCK FREQUENCY | TEMPERATURE RANGE |
| :--- | :---: | :---: | :---: |
| MK68564N-03 | Plastic | 3.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| MK68564N-04 | Plastic | 4.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| MK68564N-05 | Plastic | 5.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |

MK68564 PLASTIC PIN PACKAGE DRAWING

## N SUFFIX PLASTIC PACKAGE



|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 61.468 | 62.738 | 2.420 | 2.470 |
| B | 14.986 | 16.256 | .590 | .640 |
| C | 13.462 | 13.97 | .530 | .550 |
| D | 3.556 | 4.064 | .140 | .160 |
| E | 0.381 | 1.524 | .015 | .060 |
| F | 3.048 | 3.81 | .120 | .150 |
| G | 1.524 | 2.286 | .060 | .090 |
| H | 2.286 | 2.794 | .090 | .110 |
| J | 15.24 | 17.78 | .600 | .700 |
| K | 0.381 | 0.533 | .015 | .021 |
| L | 0.203 | 0.305 | .008 | .012 |
| M | 1.143 | 1.778 | .045 | .070 |



## FEATURES

$\square 8$ Input/Output Pins

- Individually programmable direction
- Individual interrupt source capability
- Programmable edge selection
$\square 16$ Source interrupt controller
- 8 Internal sources
- 8 External sources
- Individual source enable
- Individual source masking
- Programmable interrupt service modes
- Polling
- Vector generation
- Optional In-service status
- Daisy chaining capability

$\square$ Four timers with individually programmable prescaling
- Two multimode timers
- Delay mode
- Pulse width measurement mode
- Event counter mode
- Two delay mode timers
- Independent clock input
- Time out output option

Single channel USART

- Full Duplex
- Asynchronous to 65 kbps
- Byte synchronous to 1 Mbps
- Internal/external baud rate generation
- DMA handshake signals
- Modem control
- Loop back mode
$\square 68000$ Bus compatible
$\square 48$ Pin DIP or 52 Pin PLCC


## INTRODUCTION

The MK68901 MFP (Multi-Function Peripheral) is a combination of many of the necessary peripheral functions in a microprocessor system. Included are:

Eight parallel I/O lines
Interrupt controller for 16 sources
Four timers
Single channel full duplex USART


Figure 2. Device Pinout

The use of the MFP in a system can significantly reduce chip count, thereby reducing system cost. The MFP is completely 68000 bus compatible, and 24 directly addressable internal registers provide the necessary control and status interface to the programmer.

The MFP is a derivative of the MK3801 STI, a Z80 family peripheral.

## PIN DESCRIPTION

GND: Ground
$\mathrm{V}_{\mathrm{CC}}:+5$ volts $( \pm 5 \%)$
$\overline{\mathrm{CS}}$ : Chip Select (input, active low). $\overline{\mathrm{CS}}$ is used to select the MK68901 MFP for accesses to the internal registers. $\overline{\mathrm{CS}}$ and IACK must not be asserted at the same time.
$\overline{\mathrm{DS}}$ : Data Strobe (input, active low.) $\overline{\mathrm{DS}}$ is used as part of the chip select and interrupt acknowledge functions.
$\mathrm{R} / \overline{\mathrm{W}}$ : Read/Write (input). $\mathrm{R} / \overline{\mathrm{W}}$ is the signal from the bus master indicating whether the current bus cycle is a Read (High) or Write (Low) cycle.

DTACK: Data Transfer Acknowledge. (output, active low, tri-stateable). DTACK is used to signal the bus master that data is ready, or that data has been accepted by the MK68901 MFP.

A1-A5: Address Bus (inputs). The address bus is used to address one of the internal registers during a read or write cycle.

D0-D7: Data Bus (bi-directional, tri-stateable). The data bus is used to receive data from or transmit data to one of the internal registers during a read or write cycle. It is also used to pass a vector during an interrupt acknowledge cycle.

CLK: Clock (input). This input is used to provide the internal timing for the MK68901 MFP.

RESET: Device reset. (input, active low). Reset disables the USART receiver and transmitter, stops all timers and forces the timer outputs low, disables all interrupt channels and clears any pending interrupts. The General Purpose Interrupt///O lines will be placed in the tri-state input mode. All internal registers (except the timer, USART data registers, and transmit status register) will be cleared.

INTR: Interrupt Request (output, active low, open drain). INTR is asserted when the MK68901 MFP is requesting an interrupt. INTR is negated during an interrupt acknowledge cycle or by clearing the pending interrupt(s) through software.

IACK: Interrupt Acknowledge (input, active low). $\overline{\text { IACK }}$ is used to signal the MK68901 MFP that the CPU is acknowledging an interrupt. $\overline{\mathrm{CS}}$ and $\overline{\mathrm{IACK}}$ must not be asserted at the same time.
$\overline{|E|: ~ I n t e r r u p t ~ E n a b l e ~ I n ~(i n p u t, ~ a c t i v e ~ l o w) . ~ \overline{E I ~}}$ is used to signal the MK68901 MFP that no higher priority device is requesting interrupt service.

IEO: Interrupt Enable Out (output, active low). $\overline{\text { IEO }}$ is used to signal lower priority peripherals that neither the MK68901 MFP nor another higher priority peripheral is requesting interrupt service.

10-17: General Purpose Interrupt I/O lines. These lines may be used as interrupt inputs and/or I/O lines. When used as interrupt inputs, their active edge is programmable. A data direction register is used to define which lines are to be Hi-Z inputs and which lines are to be push-pull TTL compatible outputs.

SO: Serial Output. This is the output of the USART transmitter.

SI: Serial Input. This is the input to the USART receiver.

RC: Receiver Clock. This input controls the serial bit rate of the USART receiver.

TC: Transmitter Clock. This input controls the serial bit rate of the USART transmitter.
$\overline{R R}$ : Receiver Ready. (output, active low) DMA output for receiver, which reflects the status of Buffer Full in port number 15.

TR: Transmitter Ready. (output, active low) DMA output for transmitter, which reflects the status of Buffer Empty in port number 16.

TAO, TBO, Timer Outputs. Each of the four timers has TCO, TDO: an output which can produce a square wave. The output will change states each timer cycle; thus one full period of the timer out signal is equal to two timer cycles. TAO or TBO can be reset (logic " 0 ") by a write to TACR, or TBCR respectively.

XTAL1, Timer Clock inputs. A crystal can be con-
XTAL2: nected between XTAL1 and XTAL2, or XTAL1 can be driven with a TTL level clock. When driving XTAL1 with a TTL level clock, XTAL2 must be allowed to float. When using a crystal, external capacitors are required. See Figure 33. All chip accesses are independent of the timer clock.

TAI, TBI: Timer A, B inputs. Used when running the timers in the event count or the pulse width measurement mode. The interrupt channels associated with 14 and 13 are used for TAI and TBI, respectively. Thus, when running a timer in the pulse width measurement mode, 14 or 13 can be used for I/O only.

## INTERRUPTS

The General Purpose I/O-Interrupt Port (GPIP) provides eight I/O lines that may be operated either as inputs or outputs under software control. In addition, each line may generate an interrupt in either a positive going edge or a negative going edge of the input signal.

The GPIP has three associated registers. One allows the programmer to specify the Active Edge for each bit that will trigger an interrupt. Another register specifies the Data Direction (input or output) associated with each bit. The third register is the actual data I/O register used to input or output data to the port. These three registers are illustrated in Figure 5.

| Address <br> Port No. | Abbreviation | Register Name |
| :---: | :---: | :--- |
| 0 | GPIP | GENERAL PURPOSE I/O |
| 1 | AER | ACTIVE EDGE REGISTER |
| 2 | DDR | DATA DIRECTION REGISTER |
| 3 | IERA | INTERRUPT ENABLE REGISTER A |
| 4 | IERB | INTERRUPT ENABLE REGISTER B |
| 5 | IPRA | INTERRUPT PENDING REGISTER A |
| 6 | IPRB | INTERRUPT PENDING REGISTER B |
| 7 | ISRA | INTERRUPT IN-SERVICE REGISTER A |
| 8 | ISRB | INTERRUPT IN-SERVICE REGISTER B |
| 9 | IMRA | INTERRUPT MASK REGISTER A |
| A | IMRB | INTERRUPT MASK REGISTER B |
| B | VR | VECTOR REGISTER |
| C | TACR | TIMER A CONTROL REGISTER |
| D | TBCR | TIMER B CONTROL REGISTER |
| E | TCDCR | TIMERS C AND D CONTROL REGISTER |
| F | TADR | TIMER A DATA REGISTER |
| 10 | TBDR | TIMER B DATA REGISTER |
| 11 | TCDR | TIMER C DATA REGISTER |
| 12 | TDDR | TIMER D DATA REGISTER |
| 13 | SCR | SYNC CHARACTER REGISTER |
| 14 | UCR | USART CONTROL REGISTER |
| 15 | RSR | RECEIVER STATUS REGISTER |
| 16 | TSR | TRANSMITTER STATUS REGISTER |
| 17 | UDR | USART DATA REGISTER |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

Figure 4. Register Map


Figure 3. MK68901 Block Diagram

The Active Edge Register (AER) allows each of the General Purpose Interrupts to provide an interrupt on either a 1-0 transition or a 0-1 transition. Writing a zero to the appropriate bit of the AER causes the associated input to produce an interrupt on the 1-0 transition. The edge bit is simply one input to an exclusive-or gate, with the other input coming from the input buffer and the output going to a 1-0 transition detector. Thus, depending upon the state of the input, writing the AER can cause an interrupt-producing transition, which will cause an interrupt on the associated channel, if that channel is enabled. One would then normally configure the AER before enabling interrupts via IERA and IERB. Note: changing the edge bit, with the interrupt enabled, may cause an interrupt on that channel.

The Data Direction Register (DDR) is used to define 10-17 as inputs or as outputs on a bit by bit basis. Writing a zero into a bit of the DDR causes the corresponding Interrupt-I/O pin to be a Hi-Z input. Writing a one into a bit of the DDR causes the corresponding pin to be configured as a push-pull output. When data is written into the GPIP, those pins defined as inputs will remain in the $\mathrm{Hi}-\mathrm{Z}$ state while those pins defined as outputs will assume the state (high or low) of their cor-
responding bit in the GPIP. When the GPIP is read, the data read will come directly from the corresponding bit of the GPIP register for all pins defined as output, while the data read on all pins defined as inputs will come from the input buffers.

Each individual function in the MK68901 is provided with a unique interrupt vector that is presented to the system during the interrupt acknowledge cycle. The interrupt vector returned during the interrupt acknowledge cycle is shown in Figure 6, while the vector register is shown in Figure 7.

There are 16 vector addresses generated internally by the MK68901, one for each of the 16 interrupt channels.

The Interrupt Control Registers (Figure 8) provide control of interrupt processing for all I/O facilities of the MK68901. These registers allow the programmer to enable or disable any or all of the 16 interrupts, providing masking for any interrupt, and provide access to the pending and in-service status of the interrupt. Optional end-of-interrupt modes are available under software control. All the interrupts are prioritized as shown in Figure 9.

PORT 1 (AER)

| GPIP | GPIP | GPIP | GPIP | GPIP | GPIP | GPIP | GPIP |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | = RISING |
| :--- |
| 0 |

DATA DIRECTION REGISTER

PORT 2 (DDR) | GPIP | GPIP | GPIP | GPIP | GPIP | GPIP | GPIP | GPIP |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 0 | OUTPUT |  |  |  |  |  |
| 0 | INPUT |  |  |  |  |  |  |

GENERAL PURPOSE I/O DATA REGISTER

PORT 0 (GPIP)

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

Figure 5. General Purpose I/O Registers


Figure 6. Interrupt Vector


Figure 7. Vector Register

| ADDRESS |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PORT 3 | $\underset{(\text { IERA })}{A}$ | $\begin{gathered} \text { GPIP } \\ 7 \\ \hline \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \\ \hline \end{gathered}$ | TIMER A | $\begin{gathered} \hline \text { RCV } \\ \text { Buffer } \\ \text { Full } \end{gathered}$ | $\mathrm{RCV}$ Error | XMIT Buffer Empty | XMIT <br> Error | TIMER <br> B |
| PORT 4 | $\underset{\text { B }}{\text { (IERB) }}$ | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | TIMER C | $\begin{gathered} \text { TIMER } \\ \text { D } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 3 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 2 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 1 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 0 \end{gathered}$ |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\underset{(\text { IPRA })}{A}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | TIMER <br> A | $\begin{aligned} & \text { RCV } \\ & \text { Buffer } \\ & \text { Full } \end{aligned}$ | $\begin{aligned} & \text { RCV } \\ & \text { Error } \end{aligned}$ | XMIT Buffer Empty | XMIT <br> Error | $\begin{gathered} \text { TIMER } \\ \text { B } \end{gathered}$ |

PORT 6

| B | GPIP | GPIP | TIMER | TIMER | GPIP | GPIP | GPIP |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (IPRB) | GPIP |  |  |  |  |  |  |

WPITING 1 = UNCHANGED

| NTERRUPT IN-SERVICE REGISTERS |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PORT 7 | $\stackrel{A}{\text { (ISRA) }}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \\ \hline \end{gathered}$ | TIMER <br> A | RCV Buffer Full | RCV Error | XMIT <br> Buffer <br> Empty | XMIT Error | $\begin{gathered} \text { TIMER } \\ \mathbf{B} \\ \hline \end{gathered}$ |

PORT 8

| B |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (ISRB) | GPIP | GPIP | TIMER | TIMER | GPIP | GPIP | GPIP | GPIP |
| 5 | 4 | C | D | 3 | 2 | 1 | 0 |  |


|  |  | INTERRUPT MASK REGISTERS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PORT 9 | $\begin{gathered} \text { A } \\ \text { (IMRA) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | TIMER A | RCV Buffer Full | RCV Error | XMIT Buffer Empty | XMIT Error | TIMER <br> B |

PORT A

| $\begin{gathered} \text { B } \\ \text { (IMRB) } \end{gathered}$ | GPIP | GPIP | TIMER C | TIMER <br> D | $\begin{gathered} \text { GPIP } \\ 3 \end{gathered}$ | $\begin{aligned} & \text { GPIP } \\ & 2 \end{aligned}$ | $\begin{aligned} & \text { GPIP } \\ & 1 \end{aligned}$ | GPIP 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Figure 8. Interrupt Control Registers

| Priority | Channel | Description |
| :---: | :---: | :--- |
| HIGHEST | 1111 | General Purpose Interrupt 7(I7) |
|  | 1110 | General Purpose Interrupt 6(I6) |
|  | 1101 | Timer A |
|  | 1100 | Receive Buffer Full |
|  | 1011 | Receive Error |
|  | 1010 | Transmit Buffer Empty |
|  | 1001 | Transmit Error |
|  | 1000 | Timer B |
|  | 0111 | General Purpose Interrupt 5(15) |
|  | 0110 | General Purpose Interrupt 4(14) |
|  | 0101 | Timer C |
|  | 0100 | Timer D |
|  | 0011 | General Purpose Interrupt 3(I3) |
|  | 0010 | General Purpose Interrupt 2(12) |
|  | 0001 | General Purpose Interrupt 1(11) |
| LOWEST | 0000 | General Purpose Interrupt 0(10) |

Figure 9. Interrupt Control Register Definitions

Interrupts may be either polled or vectored. Each channel may be individual enabled or disabled by writing a one or a zero in the appropriate bit of Interrupt Enable Registers (IERA, IERB - see Figure 8 for all registers in this section). When disabled, an interrupt channel is completely inactive. Any internal or external action which would normally produce an interrupt on that channel is ignored and any pending interrupt on that channel will be cleared by disabling that channel. Disabling an interrupt channel has no effect on the corresponding bit in Interrupt In-Service Registers (ISRA, ISRB); thus, if the In-service Registers are used and an interrupt is in service on that channel when the channel is disabled, it will remain in service until cleared in the normal manner. IERA and IERB are also readable.

When an interrupt is received on an enabled channel, its corresponding bit in the pending register will be set. When that channel is acknowledged it will pass its vector, and the corresponding bit in the Interrupt Pending Register (IPRA or IPRB) will be cleared. IPRA and IPRB are readable; thus by polling IPRA and IPRB, it can be determined whether a channel has a pending interrupt. IPRA and IPRB are also writeable and a pending interrupt can be cleared without going through the acknowledge sequence by writing a zero to the appropriate bit. This allows any one bit to be cleared, without altering any other bits, simply by writing all ones except for the bit position to be cleared to IPRA or IPRB. Thus a fully polled interrupt scheme is possible. Note: writing a one to IPRA, IPRB has no effect on the interrupt pending register.

The interrupt mask registers (IMRA and IMRB) may be used to block a channel from making an interrupt request. Writing a zero into the corresponding bit of the mask register will still allow the channel to receive an interrupt and latch it into its pending bit (if that channel is enabled), but will prevent that channel from making an interrupt request. If that channel is causing an interrupt request at the time the corresponding bit in the mask register is cleared, the request will cease. If no other channel is making a request, INTR will go inactive. If the mask bit is re-enabled, any pending interrupt is now free to resume its request unless blocked by a higher priority request for service. IMRA and IMRB are also readable. A conceptual circuit of an interrupt channel is shown in Figure 10.

There are two end-of-interrupt modes: the automatic end-of-interrupt mode and the software end-of-interrupt mode. The mode is selected by writing a one or a zero to the $S$ bit of the Vector Register (VR). If the $S$ bit of


Figure 10. A Conceptual Circuit of an Interrupt Channel
the VR is a one, all channels operate in the software end-of-interrupt mode. If the $S$ bit is a zero, all channels operate in the automatic end-of-interrupt mode, and a reset is held on all in-service bits. In the automatic end-of-interrupt mode, the pending bit is cleared when that channel passes its vector. At that point, no further history of that interrupt remains in the MK68901 MFP. In the software end-of-interrupt mode, the in-service bit is set and the pending bit is cleared when the channel passes its vector. With the in-service bit set, no lower priority channel is allowed to request an interrupt or to pass its vector during an acknowledge sequence; however, a lower priority channel may still receive an interrupt and latch it into the pending bit. A higher priority channel may still request an interrupt and be acknowledged. The in-service bit of a particular channel may be cleared by writing a zero to the corresponding bit in ISRA or ISRB. Typically, this will be done at the
conclusion of the interrupt routine just before the return. Thus no lower priority channel will be allowed to request service until the higher priority channel is complete, while channels of still higher priority will be allowed to request service. While the in-service bit is set, a second interrupt on that channel may be received and latched into the pending bit, though no service request will be made in response to the second interrupt until the inservice bit is cleared. ISRA and ISRB may be read at any time. Only a zero may be written into any bit of ISRA and ISRB; thus the in-service bits may be cleared in software but cannot be set in software. This allows any one bit to be cleared, without altering any other bits, simply by writing all ones except for the bit position to be cleared to ISRA or ISRB, as with IPRA and IPRB.

Each interrupt channel responds with a discrete 8-bit vector when acknowledged. The upper four bits of the


Figure 11a. A Conceptual Circuit of the MK68901 MFP Daisy Chaining


Figure 11b. Daisy Chaining
vector are set by writing the upper four bits of the VR. The four low order bits (Bit 3-Bit 0) are generated by the interrupting channel.

To acknowledge an interrupt, $\overline{\mid A C K}$ goes low, the $\overline{|E|}$ input must go low (or be tied low) and the MK68901 MFP must have an acknowledgeable interrupt pending. The Daisy Chaining capability (Figure 11) requires that all parts in a chain have a common IACK. When the common $\overline{\text { IACK }}$ goes low, all parts freeze and priortize interrupts in parallel. Then priority is passed down the chain, via $\overline{I E I}$ and IEO, until a part which has a pending interrupt is reached. The part with the pending interrupt, passes a vector, does not propagate IEO, and generates DTACK.

Figure 9 describes the 16 prioritized interrupt channels. As shown, General Purpose Interrupt 7 has the highest priority, while General Purpose Interrupt 0 is assigned the lowest priority. Each of these channels may be reprioritized, in effect, by selectively masking interrupts under software control. The binary numbers under "channel" correspond to the modified bits IV3, IV2, IV1, and IVO, respectively, of the Interrupt Vector for each channel (see Figure 6).

Each channel has an enable bit contained in IERA or IERB, a pending latch contained in IPRA or IPRB, a mask bit contained in IMRA or IMRB, and an in-service latch contained in ISRA or ISRB. Additionally, the eight General Purpose Interrupts each have an edge bit contained in the Active Edge Register (AER), a bit to define the line as input or output contained in the Data Direction Register (DDR) and an I/O bit in the General Purpose Interrupt-I/O Port (GPIP).

## TIMERS

There are four timers on the MK68901 MFP. Two of the timers (Timer A and Timer B) are full function timers which can perform the basic delay function and can also perform event counting, pulse width measurement, and waveform generation. The other two timers (Timer C and Timer D) are delay timers only. One or both of these timers can be used to supply the baud rate clocks for the USART. All timers are prescaler/counter timers with a common independent clock input (XTAL1, XTAL2). In addition, all timers have a time-out output function that toggles each time the timer times out.

The four timers are programmed via three Timer Control Registers and four Timer Data Registers. Timers $A$ and $B$ are controlled by the control registers TACR and TBCR, respectively (see Figure 12), and by the data registers TADR and TBDR (Figure 13). Timers C and $D$ are controlled by the control register TCDCR (see Figure 14) and two data registers TCDR and TDDR. Bits in the control registers allow the selection of operational mode, prescale, and control while the data registers are used to read the timer or write into the time constant register. Timer A and B input pins, TAI and TBI, are used for the event and pulse width modes for timers A and B .

With the timer stopped, no counting can occur. The timer contents will remain unaltered while the timer is stopped (unless reloaded by writing the Timer Data Register), but any residual count in the prescaler will be lost.

In the delay mode, the prescaler is always active. A count pulse will be applied to the main timer unit each


| $\mathbf{C}_{3}$ | $\mathbf{C}_{2}$ | $C_{1}$ | $\mathrm{C}_{0}$ | Timer |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | Delay Mode, : 4 Prescale |
| 0 | 0 | 1 | 0 | Delay Mode, : 10 Prescale |
| 0 | 0 | 1 | 1 | Delay Mode, : 16 Prescale |
| 0 | 1 | 0 | 0 | Delay Mode, : 50 Prescale |
| 0 | 1 | 0 | 1 | Delay Mode, : 64 Prescale |
| 0 | 1 | 1 | 0 | Delay Mode, : 100 Prescale |
| 0 | 1 | 1 | 1 | Delay Mode. : 200 Prescale |
| 1 | 0 | 0 | 0 | Event Count Mode |
| 1 | 0 | 0 | 1 | Pulse Width Mode, : 4 Prescale |
| 1 | 0 | 1 | 0 | Pulse Width Mode. : 10 Prescale |
| 1 | 0 | 1 | 1 | Pulse Width Mode, : 16 Prescale |
| 1 | 1 | 0 | 0 | Pulse Width Mode, : 50 Prescale |
| 1 | 1 | 0 | 1 | Puise Width Mode, : 64 Prescale |
| 1 | 1 | 1 | 0 | Pulse Width Mode, : 100 Prescale |
| 1 | 1 | 1 | 1 | Pulse Width Mode, : 200 Prescale |

Figure 12. Timer A and B Control Registers
time the prescribed number of timer clock cycles has elapsed. Thus, if the prescaler is programmed to divide by ten, a count pulse will be applied to the main counter every ten cycles of the timer clock.

Each time a count pulse is applied to the main counter, it will decrement its contents. The main counter is initially loaded by writing to the Timer Data Register. Each count pulse will cause the current count to decrement. When the timer has decremented down to " 01 ", the next count pulse will not cause it to decrement to " 00 ". Instead, the next count pulse will cause the timer to be reloaded from the Timer Data Register. Additionally, a "Time out" pulse will be produced. This Time Out pulse is coupled to the timer interrupt channel, and, if that channel is enabled, an interrupt will be produced. The Time Out pulse is also coupled to the timer output pin and will cause the pin to change states. The output will remain in this new state until the next Time Out pulse occurs. Thus the output will complete one full cycle for each two Time Out pulses.

If, for example, the prescaler were programmed to divide by ten, and the Timer Data Register were loaded with 100 (decimal), the main counter would decrement once for every ten cycles of the timer clock. A Time Out pulse will occur (hence an interrupt if that channel is
enabled) every 1000 cycles of the timer clock, and the timer output will complete one full cycle every 2000 cycles of the timer clock.

The main counter is an 8-bit binary down counter. It may be read at any time by reading the Timer Data Register. The information read is the information last clocked into the timer read register when the $\overline{\mathrm{DS}}$ pin had last gone high prior to the current read cycle. When written, data is loaded into the Timer Data Register, and the main counter, if the timer is stopped. If the Timer Data Register is written while the timer is running, the new word is not loaded into the timer until it counts through $H^{\prime \prime} 01$ ". However, if the timer is written while it is counting through H " 01 ", an indeterminate value will be written into the timer constant register. This may be circumvented by ensuring that the data register is not written when the count is $\mathrm{H}^{\prime} 01$ ".

If the main counter is loaded with " 01 ", a Time Out Pulse will occur every time the prescaler presents a count pulse to the main counter. If loaded with " 00 ", a Time Out pulse will occur every 256 count pulses.

Changing the prescale value with the timer running can cause the first Time Out pulse to occur at an indeterminate time, (no less than one nor more than 200 timer


Figure 13. Timer Data Registers (A, B, C, and D)


Figure 14. Timer C and D Register


Figure 15. A Conceptual Circuit of the MFP Timers In the Pulse Width Measurement Mode
clock cycles times the number in the time constant register), but subsequent Time Out pulses will then occur at the correct interval.

In addition to the delay mode described above, Timers $A$ and $B$ can also function in the Pulse Width Measurement mode or in the Event Count mode. In either of these two modes, an auxiliary control signal is required. The auxiliary control input for Timer A is TAI, and for Timer B, TBI is used. The interrupt channels associated with 14 and 13 are used for TAI and TBI, respectively, in Pulse Width mode. See Figure 15.

The pulse width measurement mode functions much like the delay mode. However, in this mode, the auxiliary control signal on TAI or TBI acts as an enable to the timer. When the control signal on TAI or TBI is inactive, the timer will be stopped. When it is active, the prescaler and main counter are allowed to run. Thus the width of the active pulse on TAI or TBI is determined by the number of timer counts which occur while the pulse allows the timer to run. The active state of the signal on TAI or TBI is dependent upon the associated Interrupt Channel's edge bit (GPIP 4 for TAI and GPIP 3 for TBI; see Active Edge Register in Figure 5.) If the edge bit associated with the TAI or TBI input is a one, it will be active high; thus the timer will be allowed to run when the input is at a high level. If the edge bit is a zero, the TAI or TBI input will be active low. As previously stated, the interrupt channel (13 or I4) associated with the input still functions when the timer is used in the pulse width measurement mode. However, if the timer is programmed for the pulse width measurement mode, the interrupt caused by transitions on the as-
sociated TAI or TBI input will occur on the opposite transition.

For example, if the edge bit associated with the TAI input (AER-GPIP 4) is a one, an interrupt would normally be generated on the 0-1 transition of the 14 input signal. If the timer asssociated with this input (Timer A) is placed in the pulse width measurement mode, the interrupt will occur on the 1-0 transition of the TAI signal instead. Because the edge bit (AER-GPIP 4) is a one, Timer A will be allowed to count while the input is high. When the TAI input makes the high to low transition, Timer A will stop, and it is at this point that the interrupt will occur (assuming that the channel is enabled). This allows the interrupt to signal the CPU that the pulse being measured has terminated; thus Timer A may now be read to determine the pulse width. (Again note that I3 and I4 may still be used for I/O when the timer is in the pulse width measurement mode.) If Timer A is reprogrammed for another mode, interrupts will again occur on the transition, as normally defined by the edge bit. Note that, like changing the edge bit, placing the timer into or taking it out of the pulse width mode can produce a transition on the signal to the interrupt channel and may cause an interrupt. If measuring consecutive pulses, it is obvious that one must read the contents of the timer and then reinitialize the main counter by writing to the timer data register. If the timer data register is written while the pulse is going to the active state, the write operation may result in an indeterminate value being written into the main counter. If the timer is written after the pulse goes active, the timer counts from the previous contents, and when it counts through H"01", the correct value is written into the timer. The
pulse width then includes counts from before the timer was reloaded.

In the event count mode, the prescaler is disabled. Each time the control input on TAI or TBI makes an active transition as defined by the associated Interrupt Channel's edge bit, a count pulse will be generated, and the main counter will decrement. In all other respects, the timer functions as previously described. Altering the edge bit while the timer is in the event count mode can produce a count pulse. The interrupt channel associated with the input (I3 for I4 for TAI) is allowed to function normally. To count transitions reliably, the input must remain in each state ( $1 / \mathrm{O}$ ) for a length of time equal to four periods of the timer clock; thus signals of a frequency up to one fourth of the timer clock can be counted.

The manner in which the timer output pins toggle states has previously been described. All timer outputs will be forced low by a device RESET. The output associated with Timers $A$ and $B$ will toggle on each Time Out pulse regardless of the mode the timers are programmed to. In addition, the outputs from Timers A and B can be forced low at any time by writing a " 1 " to the reset location in TACR and TBCR, respectively. The output will be forced to the low state during the WRITE operation, and at the conclusion of the operation, the output will again be free to toggle each time a Time Out pulse occurs. This feature will allow waveform generation.

During reset, the Timer Data Registers and the main counters are not reset. Also, if using the reset option on Timers A or B, one must make sure to keep the other
bits in the correct state so as not to affect the operation of Timers A and B.

## USART

Serial Communication is provided by a full-duplex double-buffered USART, which is capable of either asynchronous or synchronous operation. Variable word length and start/stop bit configurations are available under software control for asynchronous operation. For synchronous operation, a Sync Word is provided to establish synchronization during receive operations. The Sync Word will also be repeatedly transmitted when no other data is available for transmission. Moreover, the MK68901 allows stripping of all Sync Words received in synchronous operation. The handshake control lines RR (Receiver Ready) and TR (Transmitter Ready) allow DMA operation. Separate receive and transmit clocks are available, and separate receive and transmit status and data bytes allow independent operation of the transmit and receive sections.

The USART is provided with three Control/Status Registers and a Data Register. The USART Data Register form is illustrated in Figure 16. The programmer may specify operational parameters for the USART via the Control Register, as shown in Figure 17. Status of both the Receiver and Transmitter sections is ac cessed by means of the two Status Registers, as shown in Figures 18 and 19. Data written to the Data Register is passed to the transmitter, while reading the Data Register will access data received by the USART.


Figure 16. USART Data Register


Figure 17. USART Control Register (UCR)
$\div 16 / \div 1: \quad$ When this bit is zero, data will be clocked into and out of the receiver and transmitter at the frequency of their respective clocks. When this bit is loaded with a one, data will be clocked into and out of the
receiver and transmitter at one sixteenth the frequency of their respective clocks. Additionally, when placed in the divide by sixteen mode, the receiver data transition resynchronization logic will be enabled.

WLO-WL1: Word Length Control. These two bits set the length of the data word (exclusive of start bits, stop bits, and parity bits as follows:

| WL1 | WLO | Word Length |
| :---: | :---: | :---: |
| 0 | 0 | 8 bits |
| 0 | 1 | 7 bits |
| 1 | 0 | 6 bits |
| 1 | 1 | 5 bits |

STO-ST1: Start/Stop bit control (format control) These two bits set the format as follows:

| ST1 | STO | Start Bits | Stop Bits | Format |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | SYNC |
| 0 | 1 | 1 | 1 | ASYNC |
| $\dagger 1$ | 0 | 1 | 11/2 | ASYNC |
| 1 | 1 | 1 | 2 | ASYNC. |

PARITY: Parity Enabled. When set ("1"), parity will be checked by the receiver, parity will be calculated, and a parity bit will be inserted by the transmitter. When cleared ('" 0 '), no parity check will be made and no parity bit will be inserted for transmission.

For a.word length of 8 the MFP calculates the parity and appends it when transmitting a sync character. For shorter lengths, the parity must be stored in the Sync

Character Register (SCR) along with the sync character.

E/O: Even-Odd. When set ("1"), even parity will be used if parity is enabled. When cleared (" 0 '), odd parity will be used if parity is enabled.

Note that the synchronous or asynchronous format may be selected independently of $a \div 1$ or $\div 16$ clock. Thus it is possible to clock data synchronously into the device but still use start and stop bits. In this mode, all normal asynchronous format features still apply. Data will be shifted in after a start bit is encountered, and a stop bit will be checked to determine proper framing. If a transmit underrun condition occurs, the output will be placed in a marking state, etc. It is conversely possible to clock data in asynchronously using a synchronous format. There is data transition detection logic built into the receive clock circuitry which will re-synchronize the internal shift clock on each data transition so that, with sufficiently frequent data transitions, start bits are not required. In this mode, all other common synchronous features function normally. This re-synchronization logic is only active in $\div 16$ clock mode.

## RECEIVER

The receiver section of the USART is configured by the UCR as previously described. The status of the receiver can be determined by reading and writing to the Receiver Status Register (RSR). The RSR is configured as follows:

| Port 15 (RSR) | BUFFER <br> FULL | OVERRUN ERROR | PARITY ERROR | FRAME ERROR | FOUND/SEARCH OR BREAK DETECT | MATCH/CHARACTER IN PROGRESS | SYNC STRIP enable | RECEIVER ENABLE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Figure 18. Receiver Status Register (RSR)

BF: Buffer Full. This bit is set when the incoming word is transferred to the receive buffer. The bit is cleared when the receive buffer is read by reading the UDR. This bit of the RSR is read only.

OE: Overrun Error. This flag is set if the incoming word is completely received and due
to be transferred to the receive buffer, but the last word in the receive buffer has not yet been read. When this condition occurs, the word in the receive buffer is not overwritten by the new word. Note that the status flags always reflect the status of the data word currently in the receive buffer. As such, the OE flag is not actually set until
the good word currently in the buffer has been read. The interrupt associated with this error will also not be generated until the old word in the receive buffer has been read.

OE flag is cleared by reading the receiver status register, and new data words cannot be shifted to the receive buffer until this is done.

PE: Parity Error. This flag is set if the word received has a parity error. The flag is set when the received word is transferred from the shift register to the receive buffer if the error condition exists. The flag is cleared when the next word which does not have a parity error is transferred to the receive buffer.

FE: $\quad$ Frame Error. This flag only applies to the asynchronous format. A frame error is defined as a non-zero data word which is not followed by a stop bit. Like the PE flag, the FE flag is set or cleared when a word is transferred to the receive buffer.

F/S̄: Found/ $\overline{\text { Search. }}$. This combination control bit and flag bit is only used with the synchronous format. It can be set or cleared by writing to this bit of the RSR. When this bit is cleared, the receiver is placed in the search mode. In this mode, a bit by bit comparison of the incoming data to the character in the Sync Character Register (SCR) is made. The word length counter is disabled. When a match is found, this bit will be set automatically, and the word length counter will start as sync has not been achieved. An interrupt will be generated on the receive error channel when the match occurs. The word just shifted in will, of necessity, be equal to the sync character, and it will not be transferred to the receive buffer.

B: $\quad$ Break. This flag is used only when the asynchronous format is selected. This flag will be set when an all zero data word, followed by no stop bit, is received. The flag will stay set until both a non-zero bit is received and the RSR has been read at least once since the flag was set. Break indication will not occur if the receive buffer is full.

M/CIP: Match/Character in Progress. If the synchronous format is selected, this flag is the Match flag. It will be set each time the word transferred to the receive buffer matches
the sync character. It will be reset each time the word transferred to the receive buifer does not match the sync character. If the asynchronous format is selected, this flag represents Character in Progress. It will be set upon a start bit detect and cleared at the end of the word.

SS: Sync Strip Enable. If this bit is set to a one, data words that match the sync character will not be loaded into the receive buffer, and no buffer full signal will be generated.

RE: Receiver Enable. This control bit is used to enable or disable the receiver. If a zero is written to this bit of the RSR, the receiver will turn off immediately. All flags including the F/S bit will be cleared. If a one is written to this bit, normal receiver operation is enabled. The receive clock has to be running before the receiver is enabled.

There are two interrupt channels associated with the receiver. One channel is used for the normal Buffer Full condition, while the other channel is used whenever an error condition occurs. Only one interrupt is generated per word received, but dedicating two channels allows separate vectors: one for the normal condition, and one for an error condition. If the error channel is disabled. an interrupt will be generated via the Buffer $f$ ıll Chan nel, whether the word received is normal or in erron Those conditions which produce an interrupt via the er ror channel are: Overrun, Parity Error, Frame \&ror, Sync Found, and Break. If a received word has in error associated with it, and the error interrupt channel is enabled, an interrupt will occur on the error channel only.

Each time a word is transferred into the receive buffer, a corresponding set of flags is latched into the RSR. No flags (except CIP) are allowed to change until the data word has been read from the receive buffer. Reading the receive buffer allows a new data word to be transferred to the receive buffer when it is received. Thus one should first read the RSR then read the receive buffer (UDR) to ensure that the flags just read match the data word just read. If done in the reverse order, it is possible that subsequent to reading the data word from the receive buffer, but prior to reading the RSR, a new word may be received and transferred to the receive buffer and, with it, its associated flags latched into the RSR. Thus, when the RSR is read, those flags may actually correspond to a different data word. It is good practice, also to read the RSR prior to a data read as, when an overrun error occurs, the receiver will not assemble new characters until the RSR has been read.

As previously stated, when overrun occurs, the OE flag will not be set and the associated interrupt will not be
generated until the receive buffer has been read. If a break occurs, and the receive buffer has not yet been read, only the $B$ flag will be set (OE will not be set). Again, this flag will not be set until the last valid word has been read from the receive buffer. If the break condition ends and another whole data word is received before the receive buffer is read, both the $B$ and OE flags will be set once the receive buffer is read.

If a break occurs while the OE flag is set, the B flag will also be set.

A break generates an interrupt when the condition occurs and again when the condition ends. If the break condition ends before it is acknowledged by reading the RSR, the receiver error interrupt indicating end of break will be generated once the RSR is read.

Anytime the asynchronous format is selected, start bit detection is enabled. New data is not shifted into the shift register until a zero bit is detected. If a $\div 16$ clock
is selected, along with the asynchronous format, false start bit detection is also enabled. Any transition has to be stable for 3 positive going edges of the receive clock to be called a valid transition. For a start bit to be good, a valid 0-1 transition must not occur for 8 positive clock transitions after the initial valid 1-0 transition.

After a good start bit has been detected, valid transitions in the data are checked for continously. When a valid transition is detected, the counter is forced to state zero, and no more transition checking is started until state four. At state eight, the "previous state" of the transition checking logic is clocked into the receiver.

As a result of this resynchronization logic, it is possible to run with asynchronous clocks without start and stop bits if there are sufficient valid transitions in the data stream. This logic also makes the unit more tolerant of clock skew for normal asynchronous communications than a device which employs only start bit synchronization.


Figure 19. Transmitter Status Register (TSR)

## TRANSMITTER

The transmitter section of the USART is configured as to format, word length, etc. by the UCR, as previously described. The status of the transmitter can be determined by reading or writing the Transmitter Status Register (TSR). The TSR is configured as follows:

BE: Buffer Empty. This status bit is set when the word in the transmit buffer is transferred to the output shift register and thus the transmit buffer may be reloaded with the next data word. The flag is cleared when the transmit buffer is reloaded. The transmit buffer is loaded by writing to the UDR.

UE: $\quad$ This bit is set when the last word has been shifted out of the transmit shift register before a new word has been loaded into the transmit buffer. It is not necessary to clear this bit before loading the UDR.

This bit may be cleared by either reading the TSR or by disabling the transmitter. After the setting of the UE bit, one full transmitter clock cycle is required before this bit can be cleared by a read. The timing in some systems may allow a read of the TSR
before the required clock cycle has been completed. This would result in the UE bit not being cleared until the following read. To avoid this problem, a dummy read of the TSR should be performed at the end of the UE service routine.

Only one underrun error may be generated between loads of the UDR regardless of the number of transmitter clock cycles between UDR loads.

AT: $\quad$ This bit causes the receiver to be enabled at the end of the transmission of the last word in the transmitter if the transmitter has been disabled.

END: End of Transmission. When the transmitter is turned off with a character still in the output shift register, transmission will continue until that character is shifted out. Once it has cleared the output register, the END bit will be set. If no character is being transmitted when the transmitter is disabled, the transmitter will stop at the next rising edge of the internal shift clock, and END will immediately be set. The END bit is cleared by re-enabling the transmitter.

Break. This control bit will cause a break to be transmitted. When a " 1 " is written to the $B$ bit of the TSR, a break will be transmitted upon completion of the character (if any) currently being transmitted. A break will continue to be transmitted until the B bit is cleared by writing a " 0 " to this bit of the TSR. At that time, normal transmission will resume. The B bit has no function in the synchronous format. Setting the " $B$ " bit to a one keeps the "BE" bit from being set to a one. So, if there were a word in the buffer at the start of break, it would remain there until the end of break, at which time it would be transmitted (if the transmitter is still enabled). If the buffer were not full at the start of break, it could be written at any time during the break. If the buffer is empty at the end of break, the underrun flag will be set (unless the transmitter is disabled).

The BREAK bit cannot be set until the transmitter has been enabled and the
transmitter has had sufficient time (one clock cycle) to perform the internal reset and initialization functions.

H,L: High and Low. These two control bits are used to configure the transmitter output, when the transmitter is disabled, as follows:

| H | L | Output State |
| :--- | :--- | :--- |
|  |  |  |
| 0 | 0 | Hi-Z |
| 0 | 1 | Low ("0") |
| 1 | 0 | High |
| 1 | 1 | Loop-Connects transmitter |
|  |  | output to receiver input, |
|  |  | and TC to Receiver Clock |
|  |  | (RC and SI are not used; |
|  | they are bypassed internal- |  |
|  | ly). In loop back mode, |  |
|  |  |  |
|  | transmiter output goes |  |
| high when disabled. |  |  |



Figure 20. SYNC Character Register

Altering these two bits after Transmitter Enable (XE) is set will alter the output state until END is false. These bits should be set prior to enabling the transmitter. The state of these bits determine the state of the first transmitted character after the transmitter is enabled. If the high impedance mode was selected prior to the transmitter being enabled, the first bit transmitted is indeterminate.

XE: Transmitter Enable. This control bit is used to enable or disable the transmitter. When set, the transmitter is enabled. When cleared, the transmitter will be disabled. If disabled, any word currently in the output register will continue to be transmitted until finished. If a break is being transmitted when XE is cleared, the transmitter will turn off at the end of the break character boundary, and no end of break stop bit is transmitted. The transmit clock must be running before the transmitter is enabled. A "one" bit always precedes the first word out of the transmitter after the transmitter
is enabled. There is a delay between the time the transmitter enable bit is written and when the transmitter reset goes low; therefore, the H \& L bits should be written with the desired state prior to enabling the transmitter.

Like the receiver section, there are two separate interrupt channels associated with the transmitter. The buffer Empty condition causes an interrupt via one channel. while the Underrun and END conditions will cause an interrupt via the second channel. When underrun occurs in the synchronous format, the character in the SCR will be transmitted until a new word is loaded into the transmit buffer. In the asynchronous format. a "Mark" will be continuously transmitted when underrun occurs.

The transmit buffer can be loaded prior to enabling the transmitter. When the transmitter is disabled, any character currently in the process of being transminted will continue to conclusion, but any character in the transmit buffer will not be transmitted and will remain in the buffer. Thus no buffer empty interrupt will occur nor will the BE flag be set. If the buffer were already empty, the

BE flag would be set and would remain set. When the transmitter is disabled with a character in the output register but with no character in the transmit buffer, an Underrun Error will not occur when the character in progress concludes.

Often it is necessary to send a break for some particular period. To aid in timing a break transmission, a transmit error interrupt will be generated at every normal character boundary time during a break transmission. The status register information is unaffected by this error condition interrupt. It should be noted that an underrun error, if present, must be cleared from the TSR, and the interrupt pending register must be cleared of pending transmitter errors at the beginning of the break transmission or no interrupts will be generated at the character boundary time.

If the synchronous format is selected, the sync character should be loaded into the Sync Character Register (SCR) as shown in Figure 20. This character is compared to the received serial data during a Search, and will be continuously transmitted during an underrun condition.

All flags in the RSR or TSR will continue to function as described whether their associated interrupt channel is disabled or enabled. All interrupt channels are edge triggered and, in many cases, it is the actual output of a. flag bit or flag bits which is coupled to the interrupt channel. Thus, if a normal interrupt producing condition occurs while the interrupt channel is disabled, no interrupt would be produced even if the channel was subsequently enabled, because a transition did not occur while the interrupt channel was enabled. That particular flag bit would have to occur a second time before another "edge" was produced, causing an interrupt to be generated.

Error conditions in the USART are determined by monitoring the Receive Status Register and the Transmitter Status Register. These error conditions are only valid for each word boundary and are not latched. When executing block transfers of data, it is necessary to save any errors so that they can be checked at the end of a block. In order to save error conditions during data transfer, the MK68901 MFP interrupt controller may be used by enabling error interrupts for the desired channel (Receive error or Transmit error) and by masking these bits off. Once the transfer is complete, the Interrupt Pending Register can be polled, to determine the presence of a pending error interrupt, and therefore an error.

Unused bits in the sync character register are zeroed
out; therefore, word length should be set up prior to writing the sync word in some cases. Sync word length is the word length plus one when parity is enabled. The user has to determine the parity of the sync word when the word length is not 8 bits. The MK68901 MFP does not add a parity bit to the sync word if the word length is less than 8 bits. The extra bit in the sync word is transmitted as the parity bit. With a word length of eight, and parity selected, the parity bit for the sync word is computed and added on by the MK68901 MFP.

## $\overline{\operatorname{RR}}$ RECEIVER READY

$\overline{\mathrm{RR}}$ is asserted when the Buffer Full bit is set in the RSR unless a parity error or frame error is detected by the receiver.

## $\overline{T R}$ TRANSMITTER READY

$\overline{T R}$ is asserted when the Buffer Empty bit is set in the TSR unless a break is currently being transmitted.

## REGISTER ACCESSES

All register accesses are dependent on CLK as shown in the timing diagrams. To read a register, $\overline{\mathrm{CS}}$ and $\overline{\mathrm{DS}}$ must be asserted, and $R / \bar{W}$ must be high. The internal read control signal is essentially the combination of $\overline{\mathrm{CS}}$, $\overline{\mathrm{DS}}$, and RD/WR. Thus, the read operation will begin when $\overline{\mathrm{CS}}$ and $\overline{\mathrm{DS}}$ go active and will end when either $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ goes inactive. The address bus must be stable prior to the start of the operation and must remain stable until the end of the operation. Unless a read operation or interrupt acknowledge cycle is in progress the data bus $\left(D_{0}-D_{7}\right)$ will remain in the tri-state condition.

To write a register, $\overline{\mathrm{CS}}$ and $\overline{\mathrm{DS}}$ must be asserted and $R / \bar{W}$ must be low. The address must be stable prior to the start of the operation and must remain stable until the end of the operation. After the MK68901 asserts $\overline{\text { DTACK, }}$, the CPU negates $\overline{\mathrm{DS}}$. At this time, the MFP latches the data bus and writes the contents into the appropriate register. Also when $\overline{\mathrm{DS}}$ is negated, the MFP rescinds DTACK.

For an interrupt acknowledge, the operation starts when $\overline{\text { IACK }}$ goes low, and ends when IACK goes high. The data bus is tri-stated when either $\overline{\mathrm{IACK}}$ or $\overline{\mathrm{DS}}$ goes high.

When $\overline{\mathrm{CS}}$ or $\overline{\mathrm{IACK}}$ are asserted the MFP starts an internal cycle. $\overline{\mathrm{DS}}$ is needed to enable the address and data buffers. It is recommended that $\overline{\mathrm{CS}}$ and $\overline{\mathrm{ACK}}$ be gated by $\overline{\mathrm{DS}}$ so that $\overline{\mathrm{DS}}$ is always present whenever an MFP bus cycle starts.

## MK68901 ELECTRICAL SPECIFICATIONS - PRELIMINARY

## ABSOLUTE MAXIMUM RATINGS

Temperature Under Bias . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-25^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with Respect to Ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 0.3 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 W
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 operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.
D.C. CHARACTERISTICS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| SYM | PARAMETER | MIN | MAX | UNIT | TEST <br> CONDITION |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+.3$ | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage (except $\overline{\text { DTACK }})$ | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-120 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage (except $\overline{\mathrm{DTACK}})$ |  | 0.5 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{LL}}$ | Power Supply Current |  | 180 | mA | Outputs Open |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=0$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LOH}}$ | Tri-State Output Leakage Current in Float |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=2.4$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LOL}}$ | Tri-State Output Leakage Current in Float |  | -10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{OH}}$ | DTACK output source current |  | -400 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=2.4$ |
| $\mathrm{I}_{\mathrm{OL}}$ | $\overline{\text { DTACK output sink current }}$ |  | 5.3 | mA | $\mathrm{~V}_{\mathrm{OUT}}=0.5$ |

All voltages are referenced to ground

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ unmeasured pins returned to ground.

| SYM | PARAMETER | MAX | UNIT | TEST <br> CONDITION |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 10 | pF | Unmeasured <br> pins <br> returned to <br> ground |
| $\mathrm{C}_{\text {OUT }}$ | Tri-state Output Capacitance | 10 | pF |  |

AC ELECTRICAL CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{GND}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$ )

| NUM | CHARACTERISTIC | MK68901-0 |  | MK68901-5 |  | UNIT | FIG | NOTE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |  |
| 1. | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Width High | 50 |  | 35 |  | ns | 21,22 | 5 |
| 2 | R $\bar{W}$, A1-A5 Valid to falling $\overline{\mathrm{CS}}$ (Setup) | 0 |  | 0 |  | ns | 21,22 |  |
| 3 | Data Valid Prior to Falling CLK | 280 |  | 0 |  | ns | 22 |  |
| 4 | $\overline{\mathrm{CS}}$, IACK Valid to Falling Clock (Setup) | 50 |  | 45 |  | ns | 21-24 | 3 |
| 5 | CLK Low to DTACK Low |  | 220 |  | 180 | ns | 21,22 |  |
| 6 | $\overline{\mathrm{CS}}$, $\overline{\mathrm{DS}}$ or I/ACK High to $\overline{\text { DTACK }}$ high |  | 60 |  | 55 | ns | 21-24 |  |
| 7 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\text { ACK }}$ High to $\overline{\text { DTACK }}$ Tri-state |  | 100 |  | 95 | ns | 21-24 |  |
| 8 | $\overline{\text { DTACK }}$ Low to Data Invalid (Hold Time) | 0 |  | 0 |  | ns | 22 |  |
| 9 | $\overline{\text { CS, }} \overline{\mathrm{DS}}$ or $\overline{\mathrm{ACK}}$ High to Data Tri-state |  | 50 |  | 50 | ns | 21,23,24 |  |
| 10 |  | 0 |  | 0 |  | ns | 21,22 |  |
| 11 | Data Valid from $\overline{\mathrm{CS}}$ Low |  | 310 |  | 260 | ns | 21 | 3,6 |
| 12 | Read Data Valid to $\overline{\text { DTACK }}$ Low (Setup Time) | 50 |  | 50 |  | ns | 21 |  |
| 13 | $\overline{\text { DTACK Low to } \overline{\mathrm{DS}}, \overline{\mathrm{CS}} \text { or I/ } \overline{\text { ACK }} \text { High (Hold Time) }}$ | 0 |  | 0 |  | ns | 21-23 |  |
| 14 | $\overline{\text { IEI low to falling CLK }}$ (Setup) | 50 |  | 50 |  | ns | 23,24 |  |
| 15 | IEO Valid from Clock Low (Delay) |  | 180 |  | 180 | ns | 23 | 1 |
| 16 | Data Valid From Clock Low (Delay) |  | 300 |  | 300 | ns | 23 |  |
| 17 | $\overline{\text { EOO }}$ Invalid from IACK High (Delay) |  | 150 |  | 150 | ns | 23,24 |  |
| 18 | DTACK Low from Clock High (Delay) |  | 180 |  | 165 | ns | 23,24 |  |
| 19 | $\overline{\text { IEO Valid from IEI Low (Delay) }}$ |  | 100 |  | 100 | ns | 24 | 1 |
| 20 | Data Valid from IEI Low (Delay) |  | 220 |  | 220 | ns | 24 |  |
| 21 | Clock Cycle Time | 250 | 1000 | 200 | 1000 | ns | 21 |  |
| 22 | Clock Width Low | 110 |  | 90 |  | ns | 21 |  |
| 23 | Clock Width High | 110 |  | 90 |  | ns | 21 |  |
| 24 | $\overline{\mathrm{CS}}$, İACK Inactive to Rising Clock (Setup) | 100 |  | 80 |  | ns | 21-23 | 4,5 |
| 25 | I/O Minimum Active Pulse Width | 100 |  | 100 |  | ns | 25 |  |
| 26 | $\overline{\text { IACK }}$ width High | 2 |  | 2 |  | $\mathrm{T}_{\text {CLK }}$ | 23-24 | 2 |
| 27 | I/O Data valid from Rising $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ |  | 450 |  | 450 | ns | 26 |  |
| 28 | Receiver Ready Delay from Rising RC |  | 600 |  | 600 | ns | 27 |  |
| 29 | Transmitter Ready Delay from Rising TC |  | 600 |  | 600 | ns | 28 |  |
| 30 | Timer Output Low from Rising Edge of $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ (A \& B) (Reset $\mathrm{T}_{\text {OUT }}$ ) |  | 450 |  | 450 | ns | 29 | 7 |
| 31 | Tout Valid from Internal Timeout |  | $\begin{aligned} & 2 \mathrm{t}_{\mathrm{CLK}} \\ & +300 \end{aligned}$ |  | $\begin{array}{\|l\|} \hline 2 \mathrm{t}_{\mathrm{CLK}} \\ +300 \end{array}$ | ns | 29 | 2 |
| 32 | Timer Clock Low Time | 110 |  | 90 |  | ns | 29 |  |

AC ELECTRICAL CHARACTERISTICS (Continued) $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{GND}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| NUM | CHARACTERISTIC | MK68901-0 |  | MK68901-5 |  | UNIT | FIG | NOTE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |  |
| 33 | Timer Clock High Time | 110 |  | 90 |  | ns | 29 |  |
| 34 | Timer Clock Cycle Time | 250 | 1000 | 200 | 1000 | ns | 29 |  |
| 35 | RESET Low Time | 2 |  | 1.8 |  | $\mu \mathrm{S}$ | 30 |  |
| 36 | Delay to Falling INTR from External Interrupt Active Transition |  | 380 |  | 380 | ns | 25 |  |
| 37 | Transmitter Internal Interrupt Delay from Falling Edge of TC |  | 550 |  | 550 | ns | 28 |  |
| 38 | Receiver Buffer Full Interrupt Transition Delay from Rising Edge of RC |  | 800 |  | 800 | ns | 27 |  |
| 39 | Receiver Error Interrupt Transition Delay from Falling Edge of RC |  | 800 |  | 800 | ns | 27 |  |
| 40 | Serial In Set Up Time to Rising Edge of RC (Divide by one only) | 80 |  | 70 |  | ns | 27 |  |
| 41 | Data Hold Time from rising edge of RC (Divide by one only) | 350 |  | 325 |  | ns | 27 |  |
| 42 | Serial Output Data Valid from Falling Edge of TC ( $\div 1$ ) |  | 440 |  | 420 | ns | 28 |  |
| 43 | Transmitter Clock Low Time | 500 |  | 450 |  | ns | 28 |  |
| 44 | Transmitter Clock High Time | 500 |  | 450 |  | ns | 28 |  |
| 45 | Transmitter Clock Cycle Time | 1.05 | $\infty$ | 0.95 | $\infty$ | $\mu \mathrm{S}$ | 28 |  |
| 46 | Receiver Clock Low Time | 500 |  | 450 |  | ns | 27 |  |
| 47 | Receiver Clock High Time | 500 |  | 450 |  | ns | 27 |  |
| 48 | Receiver Clock Cycle Time | 1.05 | $\infty$ | 0.95 | $\infty$ | $\mu \mathrm{S}$ | 27 |  |
| 49 | $\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}$, $\overline{\mathrm{DS}}$ Width Low |  | 80 |  | 80 | $\mathrm{T}_{\text {CLK }}$ | 29 | 2 |
| 50 | Serial Output Data Valid from Falling Edge of TC ( $\div 16$ ) |  | 490 |  | 370 | ns | 28 |  |

## NOTES:

1. $\overline{\text { EOO }}$ only goes low if no acknowledgeable interrupt is pending. If $\overline{\mathrm{IEO}}$ goes low, DTACK and the data bus remain tri-stated.
2. TCLK refers to the clock applied to the MFP CLK input pin. TCLK refers to the timer clock signal, regardless of whether that signal comes from the XTAL 1/XTAL2 crystal clock inputs or the TAI or TBI timer inputs.
3. If the setup time is not met, $\overline{\mathrm{CS}}$ or $\overline{\mathrm{IACK}}$ will not be recognized until the next falling CLK.
4. If this setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.
5. $\overline{\mathrm{CS}}$ is latched internally, therefore if spec's 1 and 24 are met then $\overline{\mathrm{CS}}$ may be reasserted before the rising clock and still terminate the current bus cycle. The new bus cycle will be delayed by the MK68901 until all appropriate internal operations have completed.
6. Although CS and DTACK are synchronized with the clock, the data out during a read cycle is asynchronous to the clock, relying only on $\overline{\mathrm{CS}}$ for timing.
7. Spec. 30 applies to timer outputs TAO and TBO only.

## TIMER A.C. CHARACTERISTICS

Definitions:

```
Error = Indicated Time Value - Actual Time Value
tpsc = tcLK
Internal Timer Mode
Single Interval Error (free running)(Note 2) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 ns
Cumulative Internal Error . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0
Error Between Two Timer Reads . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 土(tpsc + 4 t tcLK)
Start Timer to Stop Timer Error . . . . . . . . . . . . . . . . . . . + (2 tcLK + 100 ns) to - (tpsc + 6t CLLK}+100 ns)
Start Timer to Read Timer Error . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +0 to - (tpsc + 6t cLK + 400 ns)
Start Timer to Interrupt Request Error (Note 3) . . . . . . . . . . . . . . . . . . . . . . - -2 t tcLK to - (4t CLK + 800 ns)
Pulse Width Measurement Mode
Measurement Accuracy (Note 1) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . + +2 trCLK to - (tpsc + 4t CLK)
Minimum Pulse Width
                            4tcLK
```


## Event Counter Mode

Minimum Active Time of TAI, TBI $4 t_{\text {CLK }}$
Minimum Inactive Time of TAI, TBI ..... ${ }^{4 t}$ CLK

## NOTES:

1. Error may be cumulative if repetitively performed.
2. Error with respect to TOUT or INT if note 3 is true.
3. Assuming it is possible for the timer to make an interrupt request immediately.


Figure 21. Read Cycle


NOTE:
$\overline{\mathrm{CS}}$ and $\overline{\mathrm{IACK}}$ must be a function of $\overline{\mathrm{DS}}$.

Figure 22. Write Cycle


Figure 23. Interrupt Acknowledge (IEI Low)


NOTE:
$\overline{\mathrm{CS}}$ and $\overline{\mathrm{IACK}}$ must be a function of $\overline{\mathrm{DS}}$.
Figure 24. Interrupt Acknowledge Cycle (IEI High)


NOTE: Active edge is assumed to be the rising edge.
Figure 25. Interrupt TIming


Figure 26. Port Timing


Figure 27. Receiver Timing


Figure 28. Transmitter Timing


Figure 29. Timer Timing


Figure 30. Reset Timing

for all outputs except DTACK
$C_{L}=100 \mathrm{pf}$
$R_{L}=20 k \Omega$
$R_{1}=180 \Omega$
For DTACK
$C_{L}=130 \mathrm{pf}$
$R_{\mathrm{L}}=6 \mathrm{k} \Omega$
$R_{1}=470 \Omega$


MK68901

CRYSTAL PARAMETERS:
Parallel resonance, fundamental mode AT cut
$R_{s} \leq 150 \Omega\left(F_{R}=2.8-5.0 \mathrm{MHz}\right) ;$
$R_{s} \leq 300 \Omega\left(F_{R}=2.0-2.7 \mathrm{MHz}\right)$
$C_{L}=18 \mathrm{pf} ; C_{M}=0.02 \mathrm{pf} ; C_{h}=5 \mathrm{pf} ; \mathrm{L}_{\mathrm{M}}=96 \mathrm{mH}$
$F_{\mathrm{R}}$ (typ) $=2.4676 \mathrm{MHz}$

Figure 31. Typical Output
Figure 33. MK68901 MFP External Oscillator Components

MK68901 ORDERING INFORMATION

| PART NO. | PACKAGE TYPE | MAX. CLOCK FREQUENCY | TEMPERATURE RANGE |
| :--- | :---: | :---: | :---: |
| 68901 P00 | Ceramic DIP | 4.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| 68901 P05 | Ceramic DIP | 5.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| 68901 N 00 | Plastic DIP | 4.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| 68901 N 05 | Plastic DIP | 5.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| 68901 Q00 $^{1}$ | Plastic PLCC | 4.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| $68901 \mathrm{Q} 05^{1}$ | Plastic PLCC | 5.0 MHz | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |

NOTE: 1. Contact Mostek for availability

MK68901 48-Pin Plastic Dual-In-Line Package (N)


|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 61.468 | 62.738 | 2.420 | 2.470 |
| B | 14.986 | 16.256 | .590 | .640 |
| C | 13.462 | 13.97 | .530 | .550 |
| D | 3.556 | 4064 | .140 | .160 |
| E | 0.381 | 1.524 | .015 | 060 |
| F | 3048 | 3.81 | .120 | .150 |
| G | 1.524 | 2.286 | .060 | .090 |
| H | 1.186 | 1.794 | .090 | .110 |
| J | 15.24 | 17.78 | .600 | .700 |
| K | 0.381 | 0.533 | .015 | .021 |
| L | 0.203 | 0.305 | .008 | .012 |
| M | 1.143 | 1.778 | .045 | .070 |

MK68901 48-Pin Ceramic Dual-In-Line Package ( P )


| DIM. | INCHES |  |
| :---: | ---: | ---: |
|  | MIN | MAX |
| A | 2.376 | 2.424 |
| B | 0.576 | 0.604 |
| C | 0.120 | 0.160 |
| D | 0.015 | 0.021 |
| F | 0.030 | 0.055 |
| G | 0.100 BSC |  |
| J | 0.008 | 0.013 |
| K | 0.100 | 0.165 |
| L | 0.590 | 0.616 |
| M | $0^{\circ}$ |  |
| N | 0.040 | 0.060 |



## MK68901 52-Pin

Plastic Leaded Chip Carrier (Q)


MK68901 PIN CONNECTIONS

| PLCC | DIP | FUNC. | PLCC | DIP | FUNC. | PLCC | DIP | FUNC. |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | - | NC | 19 | 17 | XTAL1 | 37 | 33 | IEO |
| 2 | 1 | R/W | 20 | 18 | XTAL2 | 38 | 34 | IEI |
| 3 | 2 | A1 | 21 | - | NC | 39 | 35 | CLK |
| 4 | 3 | A2 | 22 | 19 | TAI | 40 | 36 | GND |
| 5 | 4 | A3 | 23 | 20 | TBI | 41 | 37 | D0 |
| 6 | 5 | A4 | 24 | 21 | RESET | 42 | 38 | D1 |
| 7 | 6 | A5 | 25 | 22 | 10 | 43 | 39 | D2 |
| 8 | 7 | TC | 26 | 23 | 11 | 44 | 40 | D3 |
| 9 | 8 | SO | 27 | 24 | 12 | 45 | 41 | D4 |
| 10 | 9 | SI | 28 | 25 | I3 | 46 | 42 | D5 |
| 11 | 10 | RC | 29 | 26 | I4 | 47 | 43 | D6 |
| 12 | 11 | VCC | 30 | 27 | I5 | 48 | 44 | D7 |
| 13 | - | NC | 31 | 28 | I6 | 49 | 45 | IACK |
| 14 | 12 | NC | 32 | 29 | I7 | 50 | 46 | DTACK |
| 15 | 13 | TAO | 33 | - | NC | 51 | 47 | $\overline{\text { DS }}$ |
| 16 | 14 | TBO | 34 | 30 | TR | 52 | 48 | CS |
| 17 | 15 | TCO | 35 | 31 | RR |  |  |  |
| 18 | 16 | TDO | 36 | 32 | INTR |  |  |  |


| DIM. | INCHES |  |
| :---: | :---: | :---: |
|  | MIN | MAX |
| A | .165 | .180 |
| $\mathrm{~A}_{1}$ | .090 | .130 |
| D | .785 | .795 |
| $\mathrm{D}_{1}$ | .750 | .756 |
| $\mathrm{D}_{2}$ | .690 | .730 |
| E | .785 | .795 |
| $\mathrm{E}_{1}$ | .750 | .756 |
| $\mathrm{E}_{2}$ | .690 | .730 |
| H | .042 | .048 |
| J | .042 | .048 |
| K | .013 | .024 |
| L | .008 | .014 |
| M | .026 | .032 |
| $\mathrm{~N} / \mathrm{N}_{1}$ | .043 | .048 |

NOTE: NC - No Connection


## ADVANCE INFORMATION

The TS68HC901 muli-function peripheral (CMFP) is a member of the 68000 Family of peripherals and the CMOS version of the MK68901.The CMFP directly interfaces to the 68000 processor via an asynchronous bus structure and can also support both multiplexed and non multiplexed buses. Both vectored, non vectored and polled interrupt schemes are supported, with the CMFP providing unique vector number generation for each of its 16 interrupt sources. Additionally, handshake lines are provided to facilitate DMAC interfacing.

The TS68HC901 performs many of the functions common to most micro-processor-based systems. The resources available to the user include :

- Eight Individually Programmable I/O Pins with Interrupt Capability
- 16-Source Interrupt Controller with Individual Source Enabling and Masking
- Four Timers, Two of which are Multi-Mode Timers
- Timers may be used as Baud Rate Generators for the Serial Channel
- Single-Channel Full-Duplex Universal Synchronous/Asynchronous Receiver-Transmitter (USART) that Supports Asynchronous and with the Addition of a Polynominal Generator Checker Supports Byte Syn. chronous Formats.
By incorporating multiple functions within the CMFP, the system designer retains flexibility while minimizing device count.
The CMOS technology used for the TS68HC901 reduces also the power consumption of the system.



## HCMOS

## MULTI-FUNCTION PERIPHERAL



CB-522


FN SUFFIX
PLCC 52

## PIN ASSIGNMENT



## SECTION 1 <br> INTRODUCTION

The TS68HC901 multi-function peripheral (CMFP) is a member of the 68000 peripherals. The CMFP directly interfaces to the 68000 processor via an: asynchronous bus structure. Both vectored and polled interrupt schemes are supported, with the CMFP providing unique vecto number generation for each of its 16 interrupt sources. Additionally, handshake lines are provided to facilitate DMAC interfacing. Refer to block diagram of the TS68HC901.

The TS68HC901 performs many of the functions common to most microprocessor-based systems.
The resources available to the user include:

- Eight Individually Programmable I/O Pins with Interrupt Capability
- 16-Source Interrupt Controller with Individual Source Enabling and Masking
- Four Timers, Two of which are Multi-Mode Timers
- Timers May Be Used as Baud Rate Generators for the Serial Channel
- Single-Channel Full-Duplex Universal Synchronous/Asynchronous Receiver-Transmitte (USART) that Supports Asynchronous and with the Addition of a Polynomial Generato Checker Supports Byte Synchronous Formats

By incorporating multiple functions within the CMFP, the system designer retains flexibilit while minimizing device count.
rom a programmer's point of view, the versatility of the CMFP may be attributed to its register et. The registers are well organized and allow the CMFP to be easily tailored to a variety of pplications. All of the 24 registers are also directly addressable which simplifies programming. he register map is shown in Table 1-1.

Table 1-1. CMF P Register Map

| Address |  |  |  |  |  | Abbreviation | Register Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hex | Binary |  |  |  |  |  |  |
|  | RS5 | RS4 | RS3 | RS2 | RS1 |  |  |
| 01 | 0 | 0 | 0 | 0 | 0 | GPIP | General Purpose I/O Register |
| 03 | 0 | 0 | 0 | 0 | 1 | AER | Active Edge Register |
| 05 | 0 | 0 | 0 | 1 | 0 | DDR | Data Direction Register |
| 07 | 0 | 0 | 0 | 1 | 1 | IERA | Interrupt Enable Register A |
| 09 | 0 | 0 | 1 | 0 | 0 | IERB | Interrupt Enable Register B |
| OB | 0 | 0 | 1 | 0 | 1 | IPRA | Interrupt Pending Register A |
| OD | 0 | 0 | 1 | 1 | 0 | IPRB | Interrupt Pending Register B |
| OF | 0 | 0 | 1 | 1 | 1 | ISRA | Interrupt In-Service Register A |
| 11 | 0 | 1 | 0 | 0 | 0 | ISRB | Interrupt In-Service Register B |
| 13 | 0 | 1 | 0 | 0 | 1 | IMRA | Interrupt Mask Register A |
| 15 | 0 | 1 | 0 | 1 | 0 | IMRB | Interrupt Mask Register B |
| 17 | 0 | 1 | 0 | 1 | 1 | VR | Vector Register |
| 19 | 0 | 1 | 1 | 0 | 0 | TACR | Timer A Control Register |
| 1 B | 0 | 1 | 1 | 0 | 1 | TBCR | Timer B Control Register |
| 1 D | 0 | 1 | 1 | 1 | 0 | TCDCR | Timers C and D Control Register |
| 1 F | 0 | 1 | 1 | 1 | 1 | TADR | Timer A Data Register |
| 21 | 1 | 0 | 0 | 0 | 0 | TBDR | Timer B Data Register |
| 23 | 1 | 0 | 0 | 0 | 1 | TCDR | Timer C Data Register |
| 25 | 1 | 0 | 0 | 1 | 0 | TDDR | Timer D Data Register |
| 27 | 1 | 0 | 0 | 1 | 1 | SCR | Synchronous Character Register |
| 29 | 1 | 0 | 1 | 0 | 0 | UCR | USART Control Register |
| 2 B | 1 | 0 | 1 | 0 | 1 | RSR | Receiver Status Register |
| 2 D | 1 | 0 | 1 | 1 | 0 | TSR | Transmitter Status Register |
| 2 F | 1 | 0 | 1 | 1 | 1 | UDR | USART Data Register |

NOTE : Hex addresses assume that RS1 connects with A1, RS2 connects with A2, etc... and that DS is connected to LDS on the 68000 or DS is connected to DS on the 68008.

## SECTION 2 <br> SIGNAL AND BUS OPERATION DESCRIPTION

This section contains a brief description of the input and output signals. A discussion of bus operation during the various operations is also presented.

Note: The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active low" and "active high" signals. The term assert or assertion is used to indicate that a signal is active or true, independent of whether that level is represented by a high or low voltage. The term negate or negation is used to indicate that a signal is inactive or false.

### 2.1 SIGNAL DESCRIPTION

The input and output signals can be functionally organized into the groups shown in Figure 2-1. The following paragraphs provide a brief description of the signal and a reference (if applicable) to other sections that contain more detail about its function.


Figure 2-1. Input and Output Signals

### 2.1.1 VCC and GND

These inputs supply power to the CMFP. The $\mathrm{V}_{\mathrm{CC}}$ is power at +5 volts and GND is the grounc connection.

### 2.1.2 Clock (CLK)

The clock input is a single-phase TTL-compatible signal used for internal timing. This inpu should not be gated off at any time and must conform to minimum and maximum pulse widtr times. The clock is not necessarily the system clock in frequency nor phase. When the bus is multiplexed (MPX=1), an adress strobe signal is connected to this pin. In the non multiplexed mode (MPX=0), this input is connected to the system clock when used with a 68000 processo type or to $\mathrm{V}_{\mathrm{SS}}\left(0 \mathrm{~V}_{\mathrm{DC}}\right)$ when used with a 6800 processor type.

### 2.1.3 Asynchronous Bus Control

Asynchronous data transfers are controlled by chip select, data strobe, read/write, and data transfer acknowledge. The low order register select lines, RS1-RS5, select an internal CMFF register for a read or write operation. The reset line initializes the CMFP registers and the internal control signals.

### 2.1.3.1 CHIP SELECT ( $\overline{\mathbf{C S}})$. This input activates the CMFP for internal register access.

2.1.3.2 DATA STROBE ( $\overline{\mathrm{DS}}$ ). This input is part of the internal chip select and interrupt acknowl edge functions. The CMFP must be located on the lower portion of the 16-bit data bus so that th vector number passed to the processor during an interrupt acknowledge cycle will be located $i$ the low byte of the data word. As a result, $\overline{\mathrm{DS}}$ must be connected to the processor's lower dat strobe if vectored interrupts are to be used. Note that this forces all registers to be located at od addresses and latches data on the rising edge for writes. This signal is used as $\overline{\mathrm{RD}}$ with an Inte processor type.
2.1.3.3 READ/WRITE (R/W). This input defines a data transfer as a read (high) or a write (lou cycle. This signal is used as $\overline{W R}$ with an Intel processor type.
2.1.3.4. DATA TRANSFER ACKNOWLEDGE (研ACK). This output signals the completio of the operation phase of a bus cycle to the processor. If the bus cycle is a processor read, th CMFP asserts DTACK to indicate that the information on the data bus is valid. If the bus cycle is processor to the CMFP, $\overline{\mathrm{DTACK}}$ acknowledges the acceptance of the data by the CMFP. $\overline{\text { DTAC }}$ will be asserted only by an CMFP that has $\overline{\mathrm{CS}}$ or $\overline{\mathrm{ACK}}$ (and $\overline{\mathrm{IEI})}$ asserted. This signal is not use with a 6800 processor type.
2.1.3.5 REGISTER SELECT BUS (RS1 THROUGH RS5). The lower five bits of the register sele bus select an internal CMFP register during a read or write operation.
1.3.6 DATA BUS (DO THROUGH D7). This bidirectional bus is used to receive data from or ransmit data to the CMFP's internal registers during a processor read or write cycle. During an nterrupt acknowledge cycle, the data bus is used to pass a vector number to the processor. ince the CMFP is an 8-bit peripheral, the CMFP could be located on either the upper or lower ortion of the 16-bit data bus (even or odd address). However, during an interrupt acknowledge ycle, the vector number passed to the processor must be located in the low byte of the data vord. As a result, D0-D7 of the CMFP must be connected to the low order eight bits of the rocessor data bus, placing CMFP registers at odd addresses if vectored interrupts are to be sed.
1.3.7 RESET ( $\overline{\operatorname{RESET}})$. This input will initialize the CMFP during power up or in response to total system reset. Refer to $\mathbf{2 . 2 . 3}$ for further information.
2.3.8 MPX. This signal selects the data bus mode:

APX=0: non multiplexed mode
APX $=1$ : multiplexed mode. The register select lines RS1-RS5 and the data bus D0-D7 are nultiplexed. An adress strobe must be connected to the CLK pin.

### 1.4 Interrupt Control

he interrupt request and interrupt acknowledge signals are handshake lines for a vectored interrupt cheme. Interrupt enable in and the interrupt enable out implement a daisy-chained interrupt strucure.
1.4.1 INTERRUPT REQUEST ( $\overline{\mathrm{RQ}}$ ). This output signals the processor that an interrupt is penling from the CMFP. These are 16 interrupt channels that can generate an interrupt request. learing the interrupt pending registers (IPRA and IPRB) or clearing the interrupt mask registers MRA and IMRB) will cause $\overline{\mathrm{IQ}}$ to be negated. $\overline{\mathrm{IRQ}}$ will also be negated as the result of an nterrupt acknowledge cycle, unless additional interrupts are pending in the CMFP. Refer to ;ECTION 3 for further information.
1.4.2 INTERRUPT ACKNOWLEDGE (IACK). If both $\overline{\operatorname{IRQ}}$ and $\overline{\mathrm{IEI}}$ are active, the CMFP will egin an interrupt acknowledge cycle when $\overline{\overline{A C K}}$ and $\overline{\mathrm{DS}}$ are asserted. The CMFP will supply a inique vector number to the processor which corresponds to the interrupt handler for the articular channel requiring interrupt service. In a daisy-chained interrupt structure, all devices ) the chain must have a common $\overline{\text { IACK. Refer to 2.2.2 and 3.1.2 for additional information. }}$
1.4.3 INTERRUPT ENABLE IN (IEI). This input, together with the $\overline{\operatorname{IEO}}$ signal, provides a daisyhained interrupt structure for a vectored interrupt scheme. |EI indicates that no higher priority evice is requesting interrupt service. So, the highest priority device in the chain should have its $\overline{E \mid}$ in tied low. During an interrupt acknowledge cycle, an CMFP with a pending interrupt is not llowed to pass a vector number to the processor until its $\overline{I E I}$ pin is asserted. When the aisy-chain option is not implemented, all CMFPs should have their IEI pin tied low. Refer to 3.2 or additional information.
2.1.4.4 INTERRUPT ENABLE OUT (IEO). This output, together with the $\overline{\text { IEI }}$ signal, provides daisy-chained interrupt structure for a vectored interrupt scheme. The IEO of a particular CMFF signals lower priority devices that neither the CMFP nor any other higher-priority device is requesting interrupt service. When a daisy-chain is implemented, $\overline{I E O}$ is tied to the next lowe priority device's $\overline{E I}$ input. The lowest priority device's $\overline{\mathrm{EO}}$ is not connected. When the-daisychain option is not implemented, $\overline{I E O}$ is not connected. Refer to $\mathbf{3 . 2}$ for additional information

### 2.1.5 General Purpose I/O Interrupt Lines (IO Through 17)

This is an 8-bit pin-programmable I/O port with interrupt capability. The data direction registe (DDR) individually defines each line as either a high-impedance input or a TTL-compatible output As an input, each line can generate an interrupt on the user selected transition of the input signal Refer to SECTION 4 for further information.

### 2.1.6 Timer Control

These lines provide internal timing and auxiliary timer control inputs required for certain operatin modes. Additionally, the timer outputs are included in this group.
2.1.6.1 TIMER CLOCK (XTAL1 AND XTAL2). This input provides the timing signal for the fou timers. A crystal can be connected between the timer clock inputs, XTAL1 and XTAL2, or XTAL can be driven with a TTL-level clock while XTAL2 is not connected. The following cryst parameters are suggested:
a) Parallel resonance, fundamental mode $A T$-cut
b) Frequency tolerance measured with 18 picofarads load ( $0.1 \%$ accuracy) - drive level 1 microwatts
c) Shunt capacitance equals 7 picofarads maximum
d) Series resistance:

$$
\begin{aligned}
& 2.0<f<2.7 \mathrm{MHz} ; R \mathrm{RS} \leq 300 \Omega \\
& 2.8<\mathrm{f}<4.0 \mathrm{MHz} ; \mathrm{RS}^{2} \leq 150 \Omega
\end{aligned}
$$

2.1.6.2 TIMER INPUTS (TAI AND TBI). These inputs are control signals for timers $A$ and $B$ in th pulse width measurement mode and event count mode. These signals generate interrupts at th same priority level as the general purpose I/O interrupt lines 14 and 13 , respectively. While 14 and do not have interrupt capability when the timers are operated in the pulse width measurement mod or the event count mode, 14 and 13 may still be used for I/O. Refer to 5.1.2 and 5.1.3 for furthe information.
2.1.6.3 TIMER OUTPUTS (TAO, TBO, TCO, AND TDO). Each timer has an associated outpl which toggles when its main counter counts through 01 (hexadecimal), regardless of which opere tional mode is selected. When in the delay mode, the timer output will be a square wave with period equal to two timer cycles. This output signal may be used to supply the universal syr chronous/asynchronous receiver-transmitter (USART) baud rate clocks. Timer outputs TAO an TBO may be cleared at any time by writing a one to the reset location in timer control registers and B. Also, a device reset forces all timer outputs low. Refer to 5.2.2 for additional informatior

### 2.1.7 Serial I/O Control

The full duplex serial channel is implemented by a serial input and output line. The independent receive and transmit sections may be clocked by separate timing signals on the receiver clock input and the transmitter clock input.
2.1.7.1 SERIAL INPUT (SI). This input line is the USART receiver data input. This input is not used in the USART loopback mode. Refer to $\mathbf{6 . 3 . 2}$ for additional information.
2.1.7.2 SERIAL OUTPUT (SO). This output line is the USART transmitter data output. This output is driven high during a device reset.
2.1.7.3 RECEIVER CLOCK (RC). This input controls the serial bit rate of the receiver. This signal may be supplied by the timer output lines or by any external TTL-level clock which meets the minimum and maximum cycle times. This clock is not used in the USART loopback mode. Refer to 6.3.2 for additional information.
2.1.7.4 TRANSMITTER CLOCK (TC). This input controls the serial bit rate of the transmitter. This signal may be supplied by the timer output lines or by an external TTL-level clock which meets the minimum and maximum cycle times.

### 2.1.8 DMA Control

The USART supports DMA transfers through its receiver ready and transmitter ready status lines.
2.1.8.1 RECEIVER READY ( $\overline{R R}$ ). This output reflects the receiver buffer full status for DMA operations.
2.1.8.2 TRANSMITTER READY ( $\overline{\mathrm{TR}})$. This output reflects the transmitter buffer empty status for DMA operations.

### 2.1.9 Signal Summary

Table 2-1 is a summary of all the signals discussed in the previous paragraphs.
Table 2-1. Signal Summary

| Signal Name | Mnemonic | 1/0 | Active |
| :---: | :---: | :---: | :---: |
| Power Input | $\mathrm{V}_{\text {CC }}$ | Input | High |
| Ground | GND | Input | Low |
| Clock | CLK | Input | N/A |
| Chip Select | $\overline{C S}$ | Input | Low |
| Data strobe | $\overline{\text { DS }}$ | Input | Low |
| Read/Write | R/W | Input | Read - High, Write-Low |
| Data Transfer Acknowledge | $\overline{\text { DTACK }}$ | Output | Low |
| Register Select Bus | RS1-RS5 | Input | N/A |
| Data Bus | D0.D7 | 1/0 | $\mathrm{N} / \mathrm{A}$ |
| Reset | $\overline{\text { RESET }}$ | Input | Low |
| Interrupt Request | $\overline{\text { IRO }}$ | Output | Low |
| Interrupt Acknowledge | $\overline{\text { IACK }}$ | Input | Low |
| Interrupt Enable In | $\overline{\text { EI }}$ | Input | Low |
| Interrupt Enable Out | $\overline{\text { EOO }}$ | Output | Low |
| General Purpose 1/O-Interrupt Lines | 10-17 | 1/0 | N/A |
| Timer Clock | XTALI, XTAL 2 | Input | High |
| Timer Inputs | TAI, TBI | Input | N/A |
| Timer Outputs | TAO, TBO, TCO, TDO | Output | N/A |
| Serial Input | SI | Input | N/A |
| Serial Output | SO | Output | N/A |
| Receiver Clock | RC | Input | N/A |
| Transmitter Clock | TC | Input | N/A |
| Receiver Ready | $\overline{\bar{R}}$ | Output | Low |
| Transmitter Ready | $\overline{T \bar{R}}$ | Output | Low |
| MPX | MPX | Input | N/A |

### 2.2 BUS OPERATION

The following paragraphs explain the control signals and bus operation during data transfer opera tions and reset.

### 2.2.1 Data Transfer Operations

Transfer of data between devices involves the following pins:
Register Select Bus - RS1 through RS5
Data Bus - D0 through D7
Control Signals
The address and data buses are separate parallel buses used to transfer data using an asynchronou bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issue at both the start and end of a cycle. Additionally, the bus master is responsible for deskewing th acknowledge and data signals from the peripheral devices.
2.1.1 READ CYCLE. To read an CMFP register, $\overline{C S}$ and $\overline{\mathrm{DS}}$ must be asserted, and $R / \bar{W}$ must e high. The CMFP will place the contents of the register which is selected by the register select us (RS 1 through RS5) on the data bus (D0 through D7) and then assert $\overline{\text { DTACK. The register }}$ ddresses are shown in Table 1-1.
fter the processor has latched the data, $\overline{\mathrm{DS}}$ is negated. The negation of either $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ will erminate the read operation. The CMFP will drive DTACK high and place it in the highmpedance state. Also, the data bus will be in the high-impedance state. The timing for a read ycle is shown in Figure 2-2. Refer to $\mathbf{7 . 7}$ for actual timing numbers.


Figure 2-2. Read Cycle Timing
!.2.1.2 WRITE CYCLE. To write a register, $\overline{C S}$ and $\overline{\mathrm{DS}}$ must be asserted, and $\mathrm{R} / \overline{\mathrm{W}}$ must be ow. The CMFP will decode the address bus to determine which register is selected (the register nap is shown in Table 1-1). Then the register will be loaded with the contents of the data bus nd $\overline{\text { DTACK }}$ will be asserted.

When the processor recognizes $\overline{\overline{T T A C K}}, \overline{\mathrm{DS}}$ will be negated. The write cycle is terminated wher either $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ is negated. The CMFP will drive $\overline{\mathrm{DTACK}}$ high and place it in the high-impedance state. The timing for a write cycle is shown in Figure 2-3. Refer to 7.7 for actual numbers.


Figure 2-3. Write Cycle Timing

### 2.2.2 Interrupt Acknowledge Operation

The CMFP has 16 interrupt sources, eight internal sources, and eight external sources. Wher an interrupturequest is pending, the CMFP will assert $\overline{\operatorname{RQ}}$. In a vectored interrupt scheme, the processor will acknowledge the interrupt request by performing an interrupt acknowledg, cycle. $\overline{\mathrm{ACK}}$ and $\overline{\mathrm{DS}}$ will be asserted. The CMFP responds to the $\overline{\mathrm{IACK}}$ signal by placing a vecto number on the lower eight bits of the data bus. This vector number corresponds to the $\overline{\mathrm{RC}}$ handler for the particular interrupt requesting service. The format of this vector number is givet in Figure 3-1.

When the CMFP asserts $\overline{\text { DTACK }}$ to indicate that valid data is on the bus, the processor will latcl the data and terminate the bus cycle by negating $\overline{\mathrm{DS}}$. When either $\overline{\overline{D S}}$ or $\overline{\mathrm{ACK}}$ are negated, th CMFP will terminate the interrupt acknowledge operation by driving DTACK high and placing in the high-impedance state. Also, the data bus will be placed in the high-impedance state. IRC will be negated as a result of the $\overline{\text { IACK }}$ cycle unless additional interrupts are pending.

The CMFP can be part of a daisy-chain interrupt structure which allows multiple CMFPs to $b$ placed at the same interrupt level by sharing a common $\overline{\text { ACK }}$ signal. A daisy-chain priorit scheme is implemented with signals IEI and IEO. EI indicates that no higher priority device requesting interrupt service. IEO signals lower priority devices that neither this device nor an higher priority device is requesting service. To daisy-chain CMFPs, the highest priority CMF has its IEI tied low and successive CMFPs have their IEI connected to the next higher priorit device's IEO. Note that when the daisy-chain interrupt structure is not implemented, the IEI o all CMFPs must be tied low. Refer to $\mathbf{3 . 2}$ for additional information.

When the processor initiates an interrupt acknowledge cycle by driving $\overline{\mathrm{ACK}}$ and $\overline{\mathrm{DS}}$, the CMFP whose $\overline{E I}$ is low may respond with a vector number if an interrupt is pending. If this device does not have a pending interrupt, $\overline{\mathbb{E} O}$ is asserted which allows the next lower priority device to respond to the interrupt acknowledge. When an CMFP propagates IEO, it will not drive the data bus nor DTACK during the interrupt acknowledge cycle. The timing for an IACK cycle is shown n Figure 2-4. Refer to $\mathbf{7 . 6}$ for further information.


Figure 2-4. $\overline{\text { IACK }}$ Cycle Timing

### 2.2.3 Reset Operation

The reset operation will initialize the CMFP to a known state. The reset operation requires that the RESET input be asserted for a minimum of two microseconds. During a device reset condition, all internal CMFP registers are cleared except for the timer data registers (TADR, TBDR, TCDR, and TDDR), the USART data register (UDR), the transmitter status register (TSR) and the interrupt vector register. All timers are stopped and the USART receiver and transmitter are disabled. The interrupt channels are also disabled and any pending interrupts are cleared. In addition, the general purpose interrupt I/O lines are placed in the high-impedance input mode and the timer outputs are driven low. External CMFP signals are negated. The interrupt vector register is initialized to a \$OF.

### 2.2.4 Non Multiplexed mode

In this mode the MPX input must be set to zero, and the TS68HC901 can be used with a 68000 गrocessor type or a 6800 processor type. Refer to figure 7-4, 7-5, 7-8 for the electrical sharacteristics.

Nith a 6800 processor type the $\overline{\mathrm{DS}}$ pin is connected to the E signal of the processor, the $\overline{\mathrm{DTACK}}$ signal is not used and the CLK must be zeroed.

### 2.2.5 Multiplexed mode

The CMFP can be used either on a MOTOROLA or INTEL bus type. In this case the MPX pin connected to $\mathrm{V}_{\mathrm{CC}}$. The following table gives the signification of the different signals used. dummy access to the TS68HC901 has to be done before any valid access in order to set up th internal logic of sampling.

| Pin | MOTOROLA <br> 6800 type | MOTOROLA <br> Multiplexed | INTEL |
| :---: | :---: | :---: | :---: |
| 48 | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{CS}}$ |
| 47 | E | $\overline{\mathrm{DS}}$ | $\overline{\mathrm{RD}}$ |
| 1 | $\mathrm{R} / \overline{\mathrm{W}}$ | $\mathrm{R} / \overline{\mathrm{W}}$ | $\overline{\mathrm{WR}}$ |
| 35 | $\mathrm{~V}_{\mathrm{SS}}$ | AS | ALE |

## SECTION 3 INTERRUPT STRUCTURE

In a 68000 system, the CMFP will be assigned to one of the seven possible interrupt levels. All interrupt service requests from the CMFP's 16 interrupt channels will be presented at this level. Although, as an interrupt controller, the CMFP will internally prioritize its 16 interrupt sources. Additional interrupt sources may be placed at the same interrupt level by daisy-chaining multiple CMFPs. The CMFPs will be prioritized by their position in the chain.

### 3.1 INTERRUPT PROCESSING

Each CMFP provides individual interrupt capability for its various functions. When an interrupt is received on one of the external interrupt channels or from one of the eight internal sources, the CMFP will request interrupt service. The 16 interrupt channels are assigned a fixed priority so that multiple pending interrupts are serviced according to their relative importance. Since the CMFP can internally generate 16 vector numbers, the unique vector number which corresponds to the highest priority channel that has a pending interrupt is presented to the processor during an interrupt acknowledge cycle. This unique vector number allows the processor to immediately begin execution of the interrupt handler for the interrupting source, decreasing interrupt latency time.

### 3.1.1 Interrupt Channel Prioritization

The 16 interrupt channels are prioritized as shown in Table 3-1. General purpose interrupt 7 (17) is the highest priority interrupt channel and 10 is the lowest priority channel. Pending interrupts are presented to the CPU in order of priority unless they have been masked off. By selectively masking interrupts, the channels are in effect re-prioritized.

Table 3-1. Interrupt Channel Prioritization

| Priority | Channel | Description |
| :---: | :---: | :--- |
| Highest | 1111 | General Purpose Interrupt 7 (17) |
|  | 1110 | General Purpose Interrupt 6 (16) |
|  | 1101 | Timer A |
|  | 1100 | Receiver Buffer Full |
|  | 1011 | Receive Error |
|  | 1010 | Transmit Buffer Empty |
|  | 1001 | Transmit Error |
|  | 1000 | Timer B |
|  | 0111 | General Purpose Interrupt $5(15)$ |
|  | 0110 | General Purpose Interrupt 4 (14) |
|  | 0101 | Timer C |
|  | 0100 | Timer D |
|  | 0011 | General Purpose Interrupt 3 (13) |
|  | 0010 | General Purpose Interrupt $2(12)$ |
|  | 0001 | General Purpose Interrupt 1 (11) |
|  | Lowest | 0000 |
|  |  | General Purpose Interrupt 0 (10) |

### 3.1.2 Interrupt Vector Number Format

During an interrupt acknowledge cycle, a unique 8 -bit vector number is presented to the systen which corresponds to the specific interrupt source which is requesting service. The format of the vector is shown in Figure 3-1. The most significant four bits of the interrupt vector number are use programmable. These bits are set by writing the upper four bits of the vector register which i: shown in Figure 3-2. The low order bits are generated internally by the TS68HC901. Note that the binary channel number shown in Table 3-1 corresponds to the low order bits of the vector number associated with each channel.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\vee 7$ | $\vee 6$ | $\vee 5$ | $\vee 4$ | $\mid V 3$ | $\mid V 2$ | $\mid V 1$ | $1 V 0$ |

[^46]Figure 3-1. Interrupt Vector Format


V7-V4 The upper four bits of the vector register are written by the user. These bits become the most significant four bits of the interrupt vector number

$$
\begin{array}{ll}
\text { SET } & \text { a) MPU writes a one } \\
\text { CLEARED } & \text { a) MPU writes a zero } \\
& \text { b) Reset }
\end{array}
$$

S In-Service Register Enable. When the $S$ bit is ze, o, the CMFP is in the automatic end-of-interrupt mode and the in-service register bits are forced low. When the S bit is a one, the CMFP is in the software end-of-interrupt mode and the in-Service register bits are enabled. Refer to 3.4.2 and 3.4.3 for additional information.
tion.

| SET | a) MPU writes a one |
| :--- | :--- |
| CLEARED | a) MPU writes a zero |
|  | b) Reset |

Figure 3-2 Vector Register Format (VR)

### 3.2 DAISY-CHAINING CMFPs

As an interrupt controller, the TS68HC901 CMFP will support eight external interrupt sources in addition to its eight internal interrupt sources. When a system requires more than eight external interrupt sources to be placed at the same interrupt level, sources may be added to the prioritized structure by daisy-chaining CMFPs. Interrupt sources are prioritized internally within each CMFP and the CMFPs are prioritized by their position in the chain. Unique vector numbers are provided for each interrupt source.

The $\overline{\mathrm{IE}}$ and $\overline{\mathrm{IEO}}$ signals implement the daisy-chained interrupt structure. The $\overline{\mathrm{IEI}}$ of the highest priority CMFP is tied low and the $\overline{\mathrm{IEO}}$ output of this device is tied to the next highest priority CMFP's $\overline{I E I}$. The $\overline{\mathrm{EI}}$ and $\overline{\mathrm{EO}}$ signals are daisy-chained in this manner for all CMFPs in the chain, with the lowest priority CMFP's $\overline{\text { IEO }}$ left unconnected. A diagram of an interrupt daisy-chain is shown in Figure 3-3.


Figure 3-3. Daisy-Chained Interrupt Structure
Daisy-chaining requires that all parts in the chain have a common $\overline{\mathrm{ACK}}$. When the common $\overline{\mathrm{ACK}}$ is asserted during an interrupt acknowledge cycle, all parts will prioritize interrupts in parallel. When he $\overline{\text { IEI }}$ signal to a CMFP is asserted, the part may respond to the $\overline{\text { IACK }}$ cycle if it requires nterrupt service. Otherwise, the part will assert IEO to the next lower priority device. Thus, oriority is passed down the chain via $\overline{\mathrm{EI}}$ and $\overline{\mathrm{IEO}}$ until a part which has a pending interrupt is eached. The part with the pending interrupt passes a vector number to the processor and does not propagate $\overline{\mathrm{EO}}$.

### 3.3 INTERRUPT CONTROL REGISTERS

CMFP interrupt processing is managed by the interrupt enable registers $A$ and $B$, interrupt pending registers $A$ and $B$, and interrupt mask registers $A$ and $B$. These registers allow the programmer to enable or disable individual interrupt channels, mask individual interrupt channels, and access pending interrupt status information. In-service registers A and B allow interrupts to be nested as described in 3.4. The interrupt control registers are shown in Figure 3-4.

### 3.3.1 Interrupt Enable Registers

The interrupt channels are individually enabled or disabled by writing a one or zero, respectively, to the appropriate bit of interrupt enable register $A$ (IERA) or interrupt enable register B (IERB). The orocessor may read these registers at any time.

When a channel is enabled, interrupts received on the channel will be recognized by the CMFP and $\overline{\mathrm{RO}}$ will be asserted to the processor, indicating that interrupt service is required. On the other hand, a disabled channel is completely inactive; interrupts received on the channel are ignored by the CMFP.

Nriting a zero to a bit of interrupt enable register $A$ or $B$ will cause the corresponding bit of interrupt nending register $A$ or $B$ to be cleared. This will terminate all interrupt service requests for the chanרel and also negate $\overline{\mathrm{RO}}$, unless interrupts are pending from other sources. Disabling a channel, nowever, does not affect the corresponding bit in interrupt in-service registers A or B . So, if the CMFP is in the software end-of-interrupt mode (see 3.4.3) and an interrupt is in service when a channel is disabled, the in-service status bit for that channel will remain set until cleared by software.
(a) Interrupt Enable Registers (IERA and IERB)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address 07 <br> (Hex) | GPIP7 | GPIP6 | Timer A | RCV <br> Buffer Full | RCV Error | XMIT <br> Buffer <br> Empty | XMIT Error | $\begin{gathered} \text { Timer } \\ \text { B } \end{gathered}$ |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { Address } 09 \\ (H \mathrm{Hex}) \end{gathered}$ | GPIP5 | GPIP4 | Timer C | Timer D | GPIP3 | GPIP2 | GPIP1 | GPIPO |

When a bit is a zero, the associated interrupt channel is disabled. When a bit is a one, the associated interrupt channel is enabled.
SET
a) MPU writes a one
CLEARED
a) MPU writes a zero
b) Reset
(b) Interrupt Pending Registers (IPRA and IPRB)


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address 0D <br> (Hex) | GPIP5 |  |  |  |  |  |  |  |
|  | GPIP4 | Timer <br> C | Timer <br> D | GPIP3 | GPIP2 | GPIP1 | GPIP0 |  |

When a bit is a zero, no interrupt is pending on the associated interrupt channel. When a bit is a one, an interrupt is pending on the associated interrupt channel.
SET a) Interrupt is received on an enabled interrupt channel
CLEARED
a) Interrupt vector for the associated interrupt channel is passed during an $\overline{\mathrm{ICK}}$ cycle
b) Associated interrupt channel is disabled
c) MPU writes a zero
d) Reset
(c) Interrupt In-Service Registers (ISRA and ISRB)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { Address OF } \\ \text { (Hex) } \end{gathered}$ | GPIP7 | GPIP6 | Timer A | RCV Buffer Full | RCV Error | XMIT <br> Buffer <br> Empty | XMIT Error | $\begin{gathered} \text { Timer } \\ \text { B } \end{gathered}$ |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address 11 <br> (Hex) | GPIP5 | GPIP4 | Timer C | Timer D | GPIP3 | GPIP2 | GPIP1 | GPIP0 |

When a bit is a zero, no interrupt processing is in progress for the associated interrupt channel. When a bit is a one, interrupt processing is in progress for the associated interrupt channel.
SET
a) Interrupt vector number for the associated interrupt channel is passed during an $\overline{\text { IACK }}$ cycle and the $S$ bit of the vector register is set.

CLEARED a) Interrupt service is completed for the associated interrupt channel
b) The S bit of the vector register is a zero.
c) MPU writes a zero
d) Reset

Figure 3-4. Interrupt Control Registers (Sheet 1 of 2)

| (d) Interrupt Mask Registers (IMRA and IMRB) |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address 13 (Hex) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  | GPIP7 | GPIP6 | Timer A | RCV Buffer Full | RCV Error | XMIT <br> Buffer <br> Empty | XMIT Error | $\begin{gathered} \text { Timer } \\ 8 \end{gathered}$ |
|  | 7 | 6 | 5 4 |  | 3 | 2 | 1 | 0 |
| Address 15 (Hex) | GPIP5 | GPIP4 | $\begin{gathered} \text { Timer } \\ \mathrm{C} \\ \hline \end{gathered}$ | $\begin{gathered} \text { Timer } \\ 0 \\ \hline \end{gathered}$ | GPIP3 | GPIP2 | GPIP1 | GPIPO |

[^47]Figure 3-4. Interrupt Control Registers (Sheet 2 of 2)

### 3.3.2 Interrupt Pending Registers

When an interrupt is received on an enabled channel, the corresponding interrupt pending bit is set in interrupt pending register A or B (IPRA or IPRB). In a vectored interrupt scheme, this bit will be cleared when the processor acknowledges the interrupting channel and the CMFP responds with a vector number. In a polled interrupt system, the interrupt pending registers must be read to determine the interrupting channel and then the interrupt pending bit is cleared by the interrupt handling routine without performing an interrupt acknowledge sequence.

A single bit of the interrupt pending registers is cleared in software by writing ones to all bit positions except the bit to be cleared. Note that writing ones to IPRA and IPRB has no effect on the contents of the register. A single bit of the interrupt pending registers is also cleared when the corresponding channel is disabled by writing a zero to the appropriate bit of IERA or IERB.

### 3.3.3 Interrupt Mask Registers

Interrupts are masked for a channel by clearing the appropriate bit in interrupt mask register A or B (IMRA or IMRB). Even though an enabled channel is masked, the channel will recognize subsequent interrupts and set its interrupt pending bit. However, the channel is prevented from requesting interrupt service ( $\overline{\mathrm{RO}}$ to the processor) as long as the mask bit for that channel is cleared.

If a channel is requesting interrupt service at the time that its corresponding bit in IMRA or IMRB is cleared, the request will cease and IRO will be negated, unless another channel is requesting interrupt service. Later, when the mask bit is set, any pending interrupt on the channel will be processed according to the channel's assigned priority. IMRA and IMRB may be read at any time.

### 3.4 NESTING CMFP INTERRUPTS

In a 68000 vectored interrupt system, the CMFP is assigned to one of seven possible interrupt levels. When an interrupt is received from the CMFP, an interrupt acknowledge for that level is initiated. Once an interrupt is recognized at a particular level, interrupts at that same level or
below are masked by 68000. As long as the processor's interrupt mask is unchanged, the 68000 interrupt structure will prohibit the nesting of interrupts at the same interrupt level. However, additional interrupt requests from the CMFP can be recognized before a previous channel's interrupt service routine is completed by lowering the processor's interrupt mask to the next lower interrupt level within the interrupt handler.

When nesting CMFP interrupts, it may be desirable to permit interrupts on any CMFP channel, regardless of its priority, to preempt or delay interrupt processing of an earlier channel's interrupt service request. Or, it may be desirable to only allow subsequent higher priority channel interrupt requests to supercede previously recognized lower priority interrupt requests. The CMFP interrupt structure provides this flexibility by offering two end-of-interrupt options for vectored interrupt schemes. Note that the end-of-interrupt modes are not active in a polled interrupt scheme.

### 3.4.1 Selecting The End-Of-Interrupt Mode

In a vectored interrupt scheme, the CMFP may be programmed to operate in either the automatic end-of-interrupt mode or the software end-of-interrupt mode. The mode is selected by writing the $S$ bit of the vector register (see Figure 3-2). When the $S$ bit is programmed to a one, the CMFP is placed in the software end-of-structure mode and when the $S$ bit is a zero, all channels operate in the automatic end-of-interrupt mode.

### 3.4.2 Automatic End-Of-Interrupt

When an interrupt vector number is passed to the processor during an interrupt acknowledge cycle, the corresponding channel's interrupt pending bit is cleared. In the automatic end-ofinterrupt mode, no further history of the interrupt remains in the CMFP. The in-service bits of the interrupt in-service registers (ISRA and ISRB) are forced low. Subsequent interrupts which are received on any CMFP channel will generate an interrupt request to the processor, even if the current interrupt's service routine has not been completed.

### 3.4.3 Software End-Of-Interrupt

In the software end-of-interrupt mode, the channel's associated interrupt pending bit is cleared and in addition, the channel's in-service bit of in-service register $A$ or $B$ is set when its vector number is passed to the processor during an $\overline{\mathrm{ACK}}$ cycle. A higher priority channel may subsequently reques interrupt service and be acknowledged, but as long as the channel's in-service bit is set, no lowe priority channel may request interrupt service nor pass its vector during an interrupt acknowledge sequence.

While only higher priority channels may request interrupt service, any channel can receive an interrupt and set its interrupt pending bit. Even the channel whose in-service bit is set can receive a second interrupt. However, no interrupt service request is made until its in-service bit is cleared.

The in-service bit for a particular channel can be cleared by writing a zero to its corresponding bit ir ISRA or ISRB and ones to all other bit positions. Since bits in the in-service registers can only be cleared in software and not set, writing ones to the registers does not alter their contents. ISRA anc ISRB may be read at any time.

## SECTION 4 <br> GENERAL PURPOSE INPUT/OUTPUT INTERRUPT PORT

The general purpose interrupt input/output (1/O) port (GPIP) provides eight I/O lines (10 through 17) that may be operated as either inputs or outputs under software control. In addition, these lines may optionally generate an interrupt on either a positive transition or a negative transition of the input signal. The flexibility of the GPIP allows it to be configured as an 8 -bit 1/O port or for bit 1/O. Since interrupts are enabled on a bit-by-bit basis, a subset of the GPIP could be programmed as handshake lines or the port could be connected to as many as eight external interrupt sources, which would be prioritized by the CMFP interrupt controller for interrupt service.

### 4.16800 INTERRUPT CONTROLLER

The CMFP interrupt controller is particularly useful in a system which has many 6800 -type levices. Typically, in a vectored 68000 system, 6800 -type peripherals use the autovector which :orresponds to their assigned interrupt level since they do not provide a vector number in esponse to an $\overline{\text { ACK }}$ cycle. The autovector interrupt handler must then poll all 6800 -type levices at that interrupt level to determine which device is requesting service. However, by ying the $\overline{\mathrm{RO}}$ output from a 6800 -type device to the general purpose I/O interrupt port (GPIP) of - CMFP, a unique vector number will be provided to the processor during an interrupt acknowldge cycle. This interrupt structure will significantly reduce interrupt latency for 6800-type levices and other peripheral devices which do not support vector-by-device.

### 4.2 GPIP CONTROL REGISTERS

The GPIP is programmed via three control registers shown in Figure 4-1. These registers control the data direction, provide user access to the port, and specify the active edge for each bit of the GPIP which will produce an interrupt. These registers are described in detail in the following paragraphs.

### 4.2.1 GPIP Data Register

The general purpose I/O data register is used to input or output data to the port. When data is written to the GPIP data register, those pins which are defined as inputs will remain in the highimpedance state. Pins which are defined as outputs will assume the state (high or low) of their corresponding bit in the data register. When the GPIP is read, data will be passed directly from the bits of the data register for pins which are defined as outputs. Data from pins defined as inputs will come from the input buffers.

### 4.2.2 Active Edge Register

The active edge register (AER) allows each of the GPIP lines to produce an interrupt on either a one-to-zero or a zero-to-one transition. Writing a zero to the appropriate edge bit of the active edge
(a) GPIP Data Register (GPIP)

| Address 01 (Hex) | 76 |  | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | GPIP7 | GPIP6 | GPIP5 | GPIP4 | GPiP3 | GPIP2 | $G P!P 1$ | GPIPO |
| SET a) | PU wri | a one |  |  |  |  |  |  |
| CLEARED a) | MPU writ | a zero |  |  |  |  |  |  |

(b) Active Edge Register (AER)


When a bit is a zero, interrupts will be generated on the falling edge of the associated inpui signal When a bit is a one, interrupts will be generated on the rising edge of the associated input signal
SET a) MPU writes a one
CLEARED a) MPU writes a zero
b) Reset
(c) Data Direction Register (DDR)


When a bit is a zero, the associated I/O line is defined to be an input When a bit is a one, the associated 1/O line is defined to be an output.
SET a) MPU writes a one
CLEARED a) MPU writes a zero
b) Reset

Figure 4-1. GPIP Control Registers
register causes the associated input to generate an interrupt on the one-to-zero transition. Writing one to the edge bit will produce an interrupt on the zero-to-one transition of the correspondin GPIP line.

Note: The transition detector is an exclusive-OR gate whose inputs are the edge bit and the input buffer. As a result, writing the AER may cause an interrupt-producing transition, depending upon the state of the input. So, the AER should be configured before enabling interrupts via the interrupt enable registers (IERA and IERB). Also, changing the edge bit while interrupts are enabled may cause an interrupt on the corresponding channel.

### 4.2.3 Data Direction Register

The data direction register (DDR) allows the programmer to define 10 through 17 as inputs or out puts by writing the corresponding bit. When a bit of the data direction register is written as a zero the corresponding interrupt I/O pin will be a high-impedance input. Writing a one to any bit of th data direction register will cause the corresponding pin to be configured as a push-pull output.

# SECTION 5 <br> TIMERS 

The CMFP contains four 8-bit timers which provide many functions typically required in microprocessor systems. The timers can supply the baud rate clocks for the on-chip serial I/O channel, generate periodic interrupts, measure elapsed time, and count signal transitions. In addition, two timers have waveform generation capability.

All timers are prescaler/ counter timers with a common independent clock input (XTAL1 or XTAL2) and are not required to be operated from the system clock. Each timer's output signal toggles when the timer's main counter times out. Additionally, timers A and B have auxiliary control signals which are used in two of the operation modes. An interrupt channel is assigned to each timer and when the auxiliary control signals are used, a separate interrupt channel will respond to transitions on these inputs.

### 5.1 OPERATION MODES

Timers $A$ and $B$ are full function timers which, in addition to the delay mode, operate in the pulse width measurement mode and the event count mode. Timers $C$ arid $D$ are delay timers only. A brief discussion of each of the timer modes follows.

### 5.1.1 Delay Mode Operation

All timers may operate in the delay mode. In this mode, the prescaler is always active. The prescaler specifies the number of timer clock cycles which must elapse before a count pulse is applied to the nain counter. A count pulse causes the main counter to decrement by one. When the timer has decremented down to 01 (hexadecimal), the next count pulse will cause the main counter to be eloaded from the timer data register and a time out pulse will be produced. This time out pulse is coupled to the timer's interrupt channel and, if the channel is enabled, an interrupt will occur. The ime out pulse also causes the timer output pin to toggle. The output will remain in this new state intil the next time out pulse occurs.
=or example, if delay mode with a divide-by-10 prescaler is selected and the timer data register is oaded with 100 (decimal), the main counter will decrement once every 10 timer clock cycles. After 1,000 timer clocks, a time out pulse will be produced. This time out pulse will generate an interrupt if he channel is enabled (IERA, IERB) and in addition, the timer's output line will toggle. The output ine will complete one full period every 2,000 cycles of the timer clock.
f the prescaler value is changed while the timer is enabled, the first time out pulse will occur at an ndeterminate time no less than one nor more than 200 timer clock cycles. Subsequent time out ulses will then occur at the correct interval.

If the main counter is loaded with 01 (hexadecimal), a time out pulse will occur every time th prescaler presents a count pulse to the main counter. If the main counter is loaded with 00, a tim out pulse will occur every 256 count pulses.

### 5.1.2 Pulse Width Measurement Operation

Besides the delay mode, timers $A$ and $B$ may be programmed to operate in the pulse width mea surement mode. In this mode an auxiliary control input is required; timers $A$ and $B$ auxiliary inpu lines are TAI and TBI. Also, in the pulse width measurement mode, interrupt channels normall associated with 14 and 13 will respond to transitions on TAI and TBI, respectively. General purpos lines 13 and 14 may still be used for I/O. A conceptual circuit of the timers in the pulse width mea surement mode is shown in Figure 5-1.


Figure 5-1. Conceptual Circuit of Timers A and B in Pulse Width Measurement Mode
The pulse width measurement mode functions similarly to the delay mode, with the auxiliary contr signal acting as an enable to the timer. When the control signal is active, the prescaler and mai counter are allowed to operate. When the control signal is negated, the timer is stopped. So, th width of the active pulse on TAI or TBI is measured by the number of timer counts which occl while the timer is allowed to operate.

The active state of the auxiliary input line is defined by the associated interrupt channel's edge bit the active edge register (AER). GPIP4 of the AER is the edge bit associated with TAI and GPIP3 associated with TBI. When the edge bit is a one, the auxiliary input will be active high, enabling th timer while the input signal is at a high level. If the edge bit is low, the auxiliary input will be activ low and the timer will operate while the input signal is at a low level.

The state of the active edge bit also specifies whether a zero-to-one transition or a one-to-zero tranition of the auxiliary input pin will produce an interrupt when the interrupt channel is enabled. In iormal operation, programming the active edge bit to a one will produce an interrupt on the zero-o-one transition of the associated input signal. Alternately, programming the edge bit to a zero will roduce an interrupt on the one-to-zero transition of the input signal. However, in the pulse width neasurement mode, the interrupt generated by a transition on TAI or TBI will occur on the opposite ransition as that normally defined by the edge bit.
or example, in the pulse width measurement mode, if the edge bit is a one, the timer will be illowed to run while the auxiliary input TAl is high. When TAI transitions from high to low, the imer will stop and, if the interrupt channel is enabled, an interrupt will occur. By having the interupt occur on the one-to-zero transition instead of the zero-to-one transition, the processor will be nterrupted when the pulse being measured has terminated and the width of the pulse is available rom the timer. Therefore, the timers act like a divide-by-prescaler that can be programmed by the imer data register and the timers' $A$ and $B$ control register.

After reading the contents of the timer, the main counter must be reinitialized by writing to the timer lata register to allow consecutive pulses to be measured. If the timer is written after the auxiliary inut signal is active, the timer will count from the previous contents of the timer data register until it ounts through 01 (hexadecimal). At that time, the main counter is loaded with the new value from he timer data register, a time out pulse is generated which will toggle the timer output, and an inerrupt may be optionally generated on the timer interrupt channel. Note that the pulse width neasured will include counts from before the main counter was reloaded. If the timer data register s written while the pulse is transitioning to the active state, an indeterminate value may be written nto the main counter.

Ince the timer is reprogrammed for another mode, interrupts will again occur as normally defined iy the edge bit. Note that an interrupt may be generated as the result of placing the timer into the ulse width measurement mode or by reprogramming the timer for another mode. Also, an interupt may be generated by changing the state of the edge bit while in the pulse width measurement node.

## .1.3 Event Count Mode Operation

ר addition to the delay mode and the pulse width measurement mode, timers $A$ and $B$ may be prorammed to operate in the event count mode. Like the pulse width measurement mode, the event ount mode also requires an auxiliary input signal, TAI or TBI, and the interrupt channels normally ssociated with 14 and 13 will respond to transitions on TAI and TBI, respectively. General purpose nes 13 and 14 still function normally.

I the event count mode the prescaler is disabled, allowing each active transition on TAI and TBI to roduce a count pulse. The count pulse causes the main counter to decrement by one. When the mer counts through 01 (hexadecimal), a time out pulse is generated which will cause the output gnal to toggle and may optionally produce an interrupt via the associated timer interrupt channel. he timer's main counter is also reloaded from the timer data register. To count transitions reliably, le input signal may only transition once every four timer clock periods. For this reason, the input gnal must have a maximum frequency equal to one-fourth that of the timer clock.

The active edge of the auxiliary input signal is defined by the associated interrupt channel's ed bit. GPIP4 of the AER specifies the active edge for TAI and GPIP3 defines the active edge for TE When the edge bit is programmed to a one, a count pulse will be generated on the zero-to-one tra sition of the auxiliary input signal. When the edge bit is programmed to a zero, a count pulse will generated on the one-to-zero transition. Also, note that changing the state of the edge bit while $t$ timer is in the event count mode may produce a count pulse.

Besides generating a count pulse, the active transition of the auxiliary input signal will also produ an interrupt on the 13 or 14 interrupt channel, if the interrupt channel is enabled. Typically, in $t$ event count mode, these channels are not enabled since the timer is automatically counting tran tions on the input signal. If the interrupt channel were enabled, the number of transitions could counted in the interrupt routine without requiring the use of the timer.

### 5.2 TIMER REGISTERS

The four timers are programmed via three control registers and four timer data registers. Conti registers TACR and TBCR and timer data registers TADR and TBDR (refer to Figure 5-1) a associated with timers $A$ and $B$ respectively. Timers $C$ and $D$ are controlled by the control regis TCDCR and the data registers TCDR and TDDR (refer to Figure 5-2).
(a) Timer A Data Register (TADK)

| Address $1 F$ <br> (Hex) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| $\begin{array}{ll} \text { SET } & \text { a) } \\ \text { CLEARED } & \text { a) } \end{array}$ | MPU writes a one MPU writes a zero |  |  |  |  |  |  |  |

(b) Timer B Data Register (TBDR)


SET a) MPU writes a one
CLEARED a) MPU writes a zero
(c) Timer C Data Register (TCDR)

| Address 23 <br> (Hex) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| $\begin{array}{ll}\text { SET } & \text { a) } \\ \text { CLEARED } & \text { a) }\end{array}$ | U w | one |  |  |  |  |  |  |

(d) Timer D Data Register (TDDR)

| Address 25 (Hex) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| SET a) | MPU writes a one |  |  |  |  |  |  |  |
| CLEARED a) | MPU writes a zero |  |  |  |  |  |  |  |

Figure 5-2. Timer Data Registers

### 5.2.1 Timer Data Registers

Each timer's main counter is an 8-bit binary down counter. The value of the main counter may be read at any time by reading the timer's data register. The information read is the value of the counter which was captured on the last low-to-high transition of the $\overline{\mathrm{DS}} \mathrm{pin}$.

The main counter is initialized by writing to the timer's data register. If the timer is stopped, data is loaded simultaneously into both the timer data register and the main counter. If the timer data register is written while the timer is enabled, the value is not loaded into the timer until the timer counts through 01 (hexadecimal). Writing the timer data register while the timer is counting through 01 (hexadecimal) will cause an indeterminate value to be loaded into the timer's main counter. The four data registers are shown in Figure 5-2.

### 5.2.2 Timer Control Registers

Bits in the timer control registers select the operation mode, select the prescale value, and disable the timers. Timer control registers TACR and TBCR also have bits which allow the programmer to reset output lines TAO and TBO. These control registers are shown in Figure 5-3.
(a) Timer A Control Register (TACR)

(b) Timer B Control Register (TBCR)


Reset TAO/TBO Timer's A and B output lines (TAO and TBO) may be forced low at any time by writing a one to the reset location in TACR and TBCR, respectively. The output will be held low only during the write operation; at the conclusion of the operation, the output will be allowed to toggle in response to a time-out pulse. When resetting TAO and TBO, the remaining bits in the control register must be written with their previous value to avoid altering the cperating mode.
SET a) End of write cycle which clears the bit
CLEARED a) MPU writes a zero
b) Reset

AC3-ACO, BC3-BCO These bits are decoded to determine the timer operation mode
Figure 5-3. Timer Control Registers (Sheet 1 of 2)

*Regardless of the operation mode, counting is inhibited when the timer is stopped. The contents of the timer's main counter is not affected, although any residual count in the prescaler is lost.
SET
a) MPU writes a one
CLEARED
a) MPU writes a zero
b) Reset
(c) Timers C and D Control Register (TCDCR)

C.C2-CCO, DC2-DCO The bits are decoded to determine the timer operation mode.

| CC2 | CC1 | CCO | Operation Mode |
| :---: | :---: | :---: | :---: |
| DC2 | DC1 | DC0 | Timer Stopped* |
| 0 | 0 | 0 | Delay Mode, $\div 4$ Prescaler |
| 0 | 0 | 1 | Delay Mode, $\div 10$ Prescaler |
| 0 | 1 | 0 | Delay Mode, $\div 16$ Prescaler |
| 0 | 1 | 1 | Delay Mode, $\div 50$ Prescaler |
| 1 | 0 | 0 | Delay Mode, $\div 64$ Prescaler |
| 1 | 0 | 1 | Delay Mode, $\div 100$ Prescaler |
| 1 | 1 | 0 | Delay Mode, $\div 200$ Prescaler |

*When the timer is stopped, counting is inhibited. The contents of the timer's main counter is not affected, although any residual count in the prescaler is lost.
SET
a) MPU writes a one
CLEARED
a) MPU writes a zero
b) Reset

Figure 5-3. Timer Control Registers (Sheet 2 of 2)

## SECTION 6 UNIVERSAL SYNCHRONOUS/ASYNCHRONOUS RECEIVER-TRANSMITTER

The universal synchronous/asynchronous receiver-transmitter (USART) is a single full-duplex serial hannel with a double-buffered receiver and transmitter. There are separate receive and transmit locks and separate receive and transmit status and data bytes. The receive and transmit sections re also assigned separate interrupt channels. Each section has both a normal condition interrupt channel and an error condition interrupt channel. These channels can be optionally disabled from nterrupting the processor and instead, DMA transfers can be performed using the receiver ready and transmitter ready external CMFP signals.

### 3.1 CHARACTER PROTOCOLS

TheCMFP USART supports asynchronous and with the aid of a polynomial generator checker (PGC) jupports byte synchronous character formats. These formats are selected independently of the divide-by-one and divide-by- 16 clock modes.

When the divide-by-one clock mode is selected, synchronization must be accomplished externally. The receiver will sample the serial data on the rising edge of the receiver clock. In the divide-by-16 clock mode, the data is sampled at mid-bit time to increase transient noise rejection.

Also, when the divide-by-16 clock mode is selected, the USART resynchronization logic is enabled. This logic increases the channel's clock skew tolerance. When a valid transition is detected, an inernal counter is reset to state zero. Transition checking is then inhibited until state four. Then at state eight, the previous state of the transition checking logic is clocked into the receive shift egister.

### 3.1.1 Asynchronous Format

Jariable word length and start/stop bit configurations are available under software control for asyn,hronous operation. The word length can be five to eight bits and one, one and one-half, or two top bits can be selected. The user can also select odd, even, or no parity. For character lengths of ess than eight bits, the assembled character will consist of the required number of data bits ollowed by zeros in the. unused bit positions and a parity bit, if parity is enabled.
$n$ the asynchronous format, start bit detection is always enabled. New data is not shifted into the eceive shift register until a zero bit is received. When the divide-by- 16 clock mode is selected, the alse start bit logic is also active. Any transition must be stable for three positive receive clock edges o be considered valid. Then a valid zero-to-one transition must not occur for at least eight addiional positive clock edges.
6.1.1.1 WAKE-UP FEATURE. In a typical serial loop multiprocessor configuration, the software protocol will usually identify the addressee(s) at the beginning of the message. In order to permit uninterested MPUs to ignore the remainder of the message, wake-up feature is included whereby all further USART receiver flag (and interrupt) processing can be inhibited until its data line goes idle. An USART receiver is re-enabled by an idle string of ten consecutive ones or during reset. Software must provide for the required idle string between consecutive messages and prevent it within messages.

### 6.1.2 Synchronous Format

When the synchronous character format is selected, the 8-bit synchronous character loaded ir the synchronous character register is compared to received serial data until a match is found. On synchronization is established, incoming data is clocked into the receiver. The synchronous wo will be continuously transmitted during an underrun condition. All synchronous characters can optionally stripped from the receive buffer. Figure 6-1 shows the synchronous character regist

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address <br> (Hex) | D7 | D6 | D5 | $D 4$ | $D 3$ | D2 | D1 | D0 |

Figure 6-1. Synchronous Character Register (SCR)

The synchronous character is typically written after the data word length is selected, sin unused bits in the synchronous character register are zeroed out. When parity is enable synchronous word length is the data word length plus one. The CMFP will compute and apper the parity bit for the synchronous word when a word length of eight is selected. However, if th word length is less than eight, the user must determine the synchronous word parity and wri it into the synchronous character register along with the synchronous character. The CMFP w then transmit the extra bit in the synchronous word as a parity bit.

### 6.1.3 USART Control Register

The USART control register (UCR) selects the clock mode and the character format for the recei and transmit sections. This register is shown in Figure 6-2.

### 6.2 RECEIVER

As data is received on the serial input line (SI), it is clocked into an internal 8-bit shift register ur the specified number of data bits have been assembled. This character will then be transferred the receive buffer, assuming that the last word in the receiver buffer has been read. This trans produces a buffer full interrupt to the processor.

Reading the receive buffer satisfies the buffer full condition and allows a new data word to transferred to the receive buffer when it is assembled. The receive buffer is accessed by reading $t$ USART data register (UDR). The UDR is simply an 8-bit data register used.when transferring da from the CMFP and the CPU.

Each time a word is transferred to the receive buffer, its status information is latched into t receiver status register (RSR). The RSR is not updated again until the data word in the receive b fer has been read. When a buffer full condition exists, the RSR should always be read before $t$ receive buffer (UDR) to maintain the correct correspondance between data and flags. Otherwise is possible that after reading the UDR and prior to reading the RSR, a new word could be receiv and transferred to the receive buffer. Its associated flags would be latched into the RSR, ov writing the flags for the previous data word. Then when the RSR were read to access the stat information for the first data word, the flags for the new word would be retrieved.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address 29 | CLK | WL. 1 | WLO | ST1 | STO | PE | E/O | WU |

Clock Mode. When this bit is zero, data will be clocked into and out of the receiver and transmitter at the frequency of their respective clocks. When this bit is a one, data will be clocked into and out of the receiver and transmitter at one sixteenth the frequency of their respective clocks. Also, the receiver data transition resynchronization logic will be enabled

```
SET= \div16 a) MPU writes a one
CLEARED= \div1 a) MPU writes a zero
b) Reset
```

WLO, WLI Word Length. These two bits specify the length of the data word exclusive of start bits, stop bits, and parity.

| WLI | WLO | Word Length |
| :---: | :---: | :---: |
| 0 | 0 | 8 Bits |
| 0 | 1 | 7 Bits |
| 1 | 0 | 6 Bits |
| 1 | 1 | 5 Bits |


| SET | a) MPU writes a one |
| :--- | :--- |
| CLEARED | al MPU writes a zero |
|  | b) Reset |

STO. ST1 Start/Stop Bit and Format Control. These two bits select the number of start and stop bits and also sperafy the: character format.

| ST1 | STO | Start Bits | Stop Bits | Format |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Synchronous |
| 0 | 1 | 1 | 1 | Asynchronous |
| 1 | 0 | 1 | $11 / 2$ | Asynchronous* |
| 1 | 1 | 1 | 2 | Asynchronous |

* Only used with divide-by- 16 clock mode

```
SET a) MPU writes a one
CLEARED a) MPU writes a zero
    b) Reset
```

Parity Enable When this bit is zero, no parity check will be made and no parity bit will be computed for transmisston. When this bit is a one, parity will be checked by the receiver and parity will be calculated and inserted during data transmission. Note that parity is not automatically appended to the synchronous character for word lengths of less than eight bits. In this case, the parity should be written into the synchronous character register along with the synchronous word.

```
SET a) MPU writes a one
CLEARED a) MPU writes a zero
    b) Reset
```

Even/Odd Parity. When this bit is zero, odd parity is selected. When this bit is a one, even parrty is selected
SET a) MPU writes a one
CLEARED a) MPU writes a zero
b) Reset

Bit 0 "Wake-up" on idle line. When set, WU enables the wake-up function; it is cleared by ten consecutive ones or during reset. WU will not be set if the line is idle. Refer to 6.1.1.1.

Figure 6-2. USART Control Register (UCR)

### 6.2.1 Receiver Interrupt Channels

The USART receive section is assigned two interrupt channels. One indicates the buffer full cond tion, while the other channel indicates an error condition. Error conditions include overrun, parit error, synchronous found, and break. These interrupting conditions correspond to the $\mathrm{BF}, \mathrm{OE}, \mathrm{PE}$ and $F / S$ or $B$ bits of the receiver status register. These flags will function as described in 6.2. whether the receiver interrupt channels are enabled or disabled.

While only one interrupt is generated per character received, two dedicated interrupt channels allo separate vector numbers to be assigned for normal and abnormal receiver conditions. When received word has an error associated with it and the error interrupt channel is enabled, an interrup will be generated on the error channel only. However, if the error channel is disabled, an interrup for an error condition will be generated on the buffer full interrupt channel along with interrupts pro duced by the buffer full condition. The receiver status register must always be read to determin which error condition produced the interrupt.

### 6.2.2 Receiver Status Register

The receiver status register contains the receive buffer full flag, the synchronous strip enable, th receiver enable, and various status information associated with the data word in the receive buffe The RSR is latched each time a data word is transferred to the receive buffer. RSR flags cannc change again until the data word has been read. The exception is the character in progress fla which monitors when a new word is being assembled in the asynchronous character format. Th receiver status register is shown in Figure 6-3.

| Address 2 BF | OE | PE | FE | $\mathrm{F} / \mathrm{S}$ <br> or B | $\mathrm{M} / \mathrm{CIP}$ | SS | RE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Buffer Full. This bit is set when a received word is transferred to the receive buffer. This bit is cleared when the receive buffer is read by accessing the USART data register (UDR). This bit is read only.
SET a) Received word transferred to buffer
CLEARED a) Receive buffer read
b) Reset

Overrun Error. An overrun error occurs when a received word is due to be transferred to the receive buffer, but the receive buffer is full. Neither the receive buffer nor the RSR is overwritten. The OE bit is set after the receive buffer full condition is satisfied by reading the UDR. This error condition will generate an interrupt to the processor. The OE bit is cleared by reading the RSR. New data words will not be assembled until the RSR is read
$\begin{array}{ll}\text { SET } & \text { a) Incoming word received and receive buffer full } \\ \text { CLEARED } & \text { ai Receiver status register read } \\ & \text { b) Reset }\end{array}$
Parity Error. This bit is set when the word transferred to the receive buffer has a parity error. This bit is cleared when the word transferred to the receive buffer does not have a parity error.
SET a) Word in receive buffer has a parity error
CLEARED a) Word in receive buffer does not have a parity error
b) Reset

Frame Error. A frame error exists when a non-zero data word is not followed by a stop bit in the asynchronous character format. The FE bit is set when the word transferred to the receive buffer has a frame error. The FE bit is cleared when the word transferred to the receive buffer does not have a frame error.
SET a) Word in receive buffer has a firame error
CLEARED a) Word in receive buffer does not have a frame error
b) Reset

Figure 6-3. Receiver Status Register (RSR) (Sheet 1 of 2)

F/S or B Found/Search or Break Detect. In the synchronous character format this bit can be set or cleared in software When the bit is a zero, the USART receiver is placed in the search mode The incoming data is compared to the syn chronous character register (SCR) and the word length counter is disabled. The F/S bit will automatically be set when a match is found and the word length counter will be enabled. An interrupt will also be produced on the receive error channel.
SET a) Incoming word matches synchronous character
CLEARED
a) MPU writes a zero
b) Incoming word does not match synchronous character
c) Reset

In the asynchronous character format, this flag indicates a break condition. A break is detected when an all zero data word with no stop bit is received. The break condition continues until a non-zero data bit is received. The B bit is set when the word transferred to the receive buffer is a break indication. A break condition generates an interrupt to the processor. This bit is cleared when a non-zero data bit is received and the break condition has been acknowledged by reading the RSR at least once. An end of break interrupt will be generated when the bit is cleared SET a) Word in receive buffer is a break
CLEARED a) Break terminates and receiver status register read since beginning of break condition
b) Reset

M or CIP Match/Character in Progress, In the synchronous character format, this flag indicates that a synchronous character has been received. The $M$ bit is set when the word transferred to the receive buffer matches the synchronous character register. The $M$ bit is cleared when the word transferred to the receive buffer does not match the synchronous character register
SET a) Word transferred to receive buffer matches the synchronous character
CLEARED a) Word transferred to receive buffer does not match synchronous character
b) Reset

In the asynchronous character format, this flag indicates that a word is being assembled. The CIP bIt is set when a start bit is detected. The CIP bit is cleared when the final stop bit has been received
SET a) Start bit is detected
CLEARED a) End of word detected
b) Reset

SS Synchronous Strip Enable. When this bit is a one, data words that match the synchronous character register will not be loaded into the receive buffer and no buffer full condition will be produced. When this bit is a zero, data words that match the synchronous character register will be transferred to the receive buffer and a bufferfull condition will be produced.

```
SET a) MPU writes a one
CLEARED a) MPU writes a zero
    b) Reset
```

RE Receiver Enable. When this bit is a zero, the receiver will be immediately disabled. All flags will be cleared When this bit is a one, normal receiver operation is enabled. This bit should not be set to a one until the receiver clock is active.
SET a) MPU writes a one
b) Transmitter is disabled in auto-iurnaround mode

CLEARED a) MPU writes a zero
b) Reset

Figure 6-3. Receiver Status Register (RSR) (Sheet 2 of 2)

### 1.2.3 Special Receive Considerations

Jertain receive conditions relating to the overrun error flag and the break detect flag require further xplanation. Consider the following examples:

1) A break is received while the receive buffer is full.

This does not produce an overrun condition. Only the B flag will be set after the receiver buffer is read.
2) A new word is received and the receive buffer is full. A break is received before the receive buffer is read.

Both the $B$ and OE flags will be set when the buffer full condition is satisfied.

### 6.3 TRANSMITTER

The transmit buffer is loaded by writing to the USART data register (UDR). The data word will b transferred to an internal 8 -bit shift register when the last word in the shift register has bee transmitted. This will produce a buffer empty condition. If the transmitter completes the transmis sion of the word in the shift register before a new word is written to the transmit buffer, an underru error will occur. In the asynchronous character format, the transmitter will send a mark until th transmit buffer is written. In the synchronous character format, the transmitter will. continuousl send the synchronous character.

The transmit buffer can be loaded prior to enabling the transmitter. After the transmitter is enabled there is a delay before the first bit is output. The serial output line (SO) should be programmed to b high, low, or high impedance when the transmitter is enabled to force the output line to the desire state until the first bit is shifted out. Note that a one bit will always be transmitted prior to the wor in the transmit shift register when the transmitter is first enabled.

When the transmitter is disabled, any word currently being transmitted will continue to completion However, any word in the transmit buffer will not be transmitted and will remain in the buffer. So no buffer empty condition will occur. If the buffer is empty when the transmitter is disabled, th buffer empty condition will remain, but no underrun condition will be generated when the word i transmission is completed. If no word is being transmitted when the transmitter is disabled, th transmitter will stop at the next rising edge of the internal shift clock.

In the asynchronous character format, the transmitter can be programmed to send a break. Th break will be transmitted once the word currently in the shift register has been sent. If the shi register is empty, the break command will be effective immediately. An END interrupt will b generated at every normal character boundary to aid in timing the break transmission. The brea will continue until the break command is cleared.

Any character in the transmit buffer at the start of a break will be transmitted when the break is ter minated. If the transmit buffer is empty at the start of a break, it may be written at any time durin the break. If the buffer is still empty at the end of the break, an underrun condition will exist.

Disabling the transmitter during a break condition causes the transmitter to cease transmission o the break character at the end of the current character. No end of break stop bit will be transmitted Even if the transmit buffer is empty, no buffer empty condition will occur nor will an underrun con dition occur. Also, any word in the transmit buffer will remain.

### 6.3.1 Transmitter Interrupt Channels

The USART transmit section is assigned two interrupt channels. One channel indicates a buffe empty condition and the other channel indicates an underrun or end condition. These interruptin conditions correspond to the BE, UE, and END flag bits of the transmitter status register (TSR). Th flag bits will function as described in 6.3.2 whether their associated interrupt channel enabled or disabled.

### 6.3.2 Transmitter Status Register

The transmitter status register contains various transmitter error flags and transmitter control bit for selecting auto-turnaround and loopback mode. The TSR is shown in Figure 6-4.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address 2D | BE | UE | AT | END | B | H | L | TE |

Buffer Empty. This bit is set when the word in the transmit buffer is transferred to the transmit shift register. This bit is cleared when the transmit buffer is reloaded by writing to the USART data register (UDR).
SET
a) Transmit buffer contents transferred to transmit shift register
CLEARED
a) Transmit buffer written

UE Underrun Error. This bit is set when the word in the transmit shift register has been transmitted before a new word is loaded into the transmit buffer. This bit is cleared by reading the TSR or by disabling the transmitter. This bit does not need to be cleared before writing to the UDR

| SET | a) Transmit shift register contents transmitted before transmit buffer written |
| :--- | :--- |
| CLEARED | a) Transmitter status register read |
|  | b) Transmitter disabled |

b) Transmitter disabled

Auto-Turnaround. When this bit is set, the receiver will be enabled automatically after the transmitter has been disabled and the last character being transmitted is completed.
SET
a) MPU writes a one
CLEARED
a) Transmitter disabled

H, L High and Low. These control bits configure the transmitter output (SO) when the transmitter is disabled. These bits also force the transmitter output after the transmitter is enabled until END is cleared.

| $H$ | $L$ | Output State |
| :---: | :---: | :---: |
| 0 | 0 | High Impedance |
| 0 | 1 | Low |
| 1 | 0 | High |
| 1 | 1 | Loopback Mode |

Loopback mode internally connects the transmitter output to the receiver input and the transmitter clock to the receiver clock internally. The receiver clock ( RC ) and the serial input ( S ) are not used. When the transmitter is disabled, SO is forced high
$\begin{array}{ll}\text { SET } & \text { a) MPU writes a one } \\ \text { CLEARED } & \text { a) MPU writes a zero }\end{array}$

Transmitter Enable. When this bit is cleared, the transmitter is disabled. The UE bit will be:cleared and the END bit will be set. When this bit is set, the transmitter is enabled. The transmitter output will be driven according to the H and $L$ bits until transmission begins. A one bit will be transmitted before the transmission of the word in the transmit shift register is begun.
SET a) MPU writes a one
CLEARED a) MPU writes a zero
b) Reset

Figure 6-4. Transmitter Status Register (TSR)

### 6.4 DMA OPERATION

USART error conditions are only valid for each character boundary. When the USART perform block data transfers by using the DMA handshake lines $\overline{\mathrm{RR}}$ (receiver ready) and $\overline{\mathrm{TR}}$ (transmitt ready), errors must be saved and checked at the end of a block. This is accomplished by enablin the error channel for the receiver or transmitter and by masking interrupts for this channel. Once th transfer is complete, interrupt pending register A is read. Any pending receiver or transmitter err indicates an error in the data transfer.

## SECTION 7 <br> ELECTRICAL CHARACTERISTICS

This section contains the electrical specifications and associated timing information for the TS68HC901 multi-function peripheral.

### 7.1 MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to 7.0 | V |
| Input Voltage | $V_{\text {in }}$ | -0.3 to 7.0 | V |
| ```Operatmg Temperature Range TS68HC901 C TS68HC901 V TS68HC901M``` | ${ }^{T}$ A | $\begin{gathered} T L \text { to TH } \\ 0 \text { to }+70 \\ -40 \text { to }+85 \\ -5510+125 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | Tstg | -65 to 150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{\text {D }}$ | 30 | mW |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $V_{C C}$ or GND).

### 7.2 THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Rating |
| :---: | :---: | :---: | :---: |
| Thermal Resistance |  |  |  |
| Ceramic | $\theta J A$ | 40 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic |  | TBD |  |

### 7.3 POWER CONSIDERATIONS

The average chip-junction temperature, $T J$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T J=T A+(P D \bullet \theta J A) \tag{1}
\end{equation*}
$$

Where:
$\mathrm{TA}_{\mathrm{A}}=$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$
$\theta J A=$ Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$
$P_{D}=P_{I N T}+P_{I / O}$
PINT $=I C C \times V_{C C}$, Watts - Chip Internal Power
$\mathrm{P}_{\mathrm{I} / \mathrm{O}}=$ Power Dissipation on Input and Output Pins - User Determined
For most applications PI/O<PINT and can be neglected.
An approximate relationship between $P_{D}$ and $T_{J}$ (if $P_{I / O}$ is neglected) is:
$P D=K+\left(T J+273^{\circ} \mathrm{C}\right)$
jolving equations 1 and 2 for $K$ gives:
$K=P D \bullet\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A P_{D}{ }^{2}$
Where:
$K$ is a constant pertaining to the particular part. $K$ can be determined from equation (3) by measuring PD (at equilibrium) for a known TA. Using this value of $K$ the values of PD and $T J$ can be obtained by solving equations (1) and (2) iteratively for any value of TA.

### 7.4 DC ELECTRICAL CHARACTERISTICS

( $T_{A}=T_{L}$ to $T_{H} \quad V_{C C}=-5 \vee \pm 5 \%$, unless otherwise noted)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage except XTAL1, XTAL2 | $\mathrm{V}_{1 \mathrm{H}}$ | 2.0 | $\mathrm{VOD}^{+03}$ | V |
| Input High Voltage XTAL1, XTAL2 | $V_{\text {IH }}$ | $V_{D D}-1.5$ | $\mathrm{V}_{\mathrm{DD}}+0.3$ | $V$ |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | 0.8 | V |
| Output High Voltage, Except DTACK $(1 \mathrm{OH}=-120 \mu \mathrm{~A})$ | $\mathrm{V}_{\mathrm{OH}}$ | 4.1 | - | V |
| Output Low Voltage. Fxceent $\overline{\text { DTACK }}$ ( $1 \mathrm{OL}=20 \mathrm{~mA}$ ) | $\mathrm{V}_{\text {OL }}$ | - | 0.5 | V |
| Power Supply Current (Outputs Open) | ${ }_{L} \mathrm{LL}$ | - | 3.7 | mA |
| Input Leakage Current ( $\mathrm{V}_{\text {in }}=0$ to $\mathrm{V}_{\mathrm{CC}}$ ) | 1 LI | - | $\pm 10$ | $\mu \mathrm{A}$ |
| Hi-Z Output Leakage Current in Float ( $\mathrm{V}_{\text {Out }}=2.4$ to $\mathrm{V}_{\text {CC }}$ ) | ${ }^{1} \mathrm{LOH}$ | - | 10 | $\mu \mathrm{A}$ |
| HI-Z Output Leakage Current in Float ( $\left.\mathrm{V}_{\text {out }}=05 \mathrm{~V}\right)$ | ${ }^{\mathrm{LOL}}$ | - | - 10 | $\mu \mathrm{A}$ |
| $\overline{\text { DTACK }}$ Output Source Current ( $\mathrm{V}_{\text {Out }}=24 \mathrm{~V}$ ) | ${ }^{1} \mathrm{OH}$ | - | -400 | $\mu \mathrm{A}$ |
| $\overline{\text { DTACK }}$ Output Sink Current ( $\mathrm{V}_{\text {out }}=0.5 \mathrm{~V}$ ) | 1 OL | - | 53 | mA |
| Pull Down Resistor | $\mathrm{R}_{\text {MPX }}$ | 1 | 3 | $\mathrm{M} \Omega$ |

7.5 CAPACITANCE ( $T \mathrm{~A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$, unmeasured pins returned to ground)

|  | Characteristic | Symbol | Min | Max |
| :--- | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ | - | 10 | pF |
| Hi-Z Output Capacitance | $\mathrm{C}_{\text {out }}$ | - | 10 | pF |



Figure 7-1. $\overline{\mathrm{RO}}$ Test Load


Figure 7-2. Typical Test Load

### 7.6 CLOCK TIMING

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Frequency of Operation | $f$ | 1.0 | 4.0 | MHz |
| Cycle Time | ${ }_{\text {cyc }}$ | 250 | 1000 | ns |
| Clock Pulse Width | ${ }^{\mathrm{t}} \mathrm{CL},{ }^{\mathrm{t}} \mathrm{CH}$ | 110 | 250 | ns |
| Rise and Fall Times | ${ }^{\text {C }} \mathrm{Cr},{ }^{\text {t }} \mathrm{Cf}$ | - | 15 | ns |



Figure 7-3. CMFP External Oscillator Components


Figure 7-3-1. CMFP External Clock Connection
7.7 AC ELECTRICAL CHARACTERISTICS $V_{C C}=5.0 V_{D C} \pm 5 \%, V_{S S}=0 V_{D C}, T_{A}=0^{\circ} \mathrm{Ct}$ $70^{\circ} \mathrm{C}$ unless otherwise noted). See figures 7-4 through 7-10.

| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 1 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Width High | 50 | - | 50 | - | - |
| 2 | R/ $\overline{\mathrm{W}}$, A1-A5 Valid to Falling $\overline{\mathrm{CS}}$ (Setup) | 30 | - | 20 | - | ns |
| 3 | Data Valid Prior to Falling CLK | 280 | - | 100 | - | ns |
| 4 (3) | $\overline{\mathrm{CS}}$, $\overline{\mathrm{A} C K}$ Valid to falling Clock (Setup) | 50 | - | 50 | - | ns |
| 5 | CLK Low to $\overline{\text { TTACK }}$ Low | - | 220 | - | 90 | ns |
| 6 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or IACK High to $\overline{\text { DTACK }}$ High | - | 60 | - | 50 | ns |
| 7 | $\overline{\mathrm{CS}}$, $\overline{\mathrm{DS}}$ or IACK High to $\overline{\text { DTACK }}$ Tri-state | - | 100 | - | 100 | ns |
| 8 |  | 0 | - | 0 | - | ns |
| 9 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or I$\overline{\mathrm{ACK}}$ High to Data Tri-state | - | 50 | - | 50 | ns |
| 10 | $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ High to R//ָ, A1-A5 Invalid (Hold Time) | 0 | - | 0 | - | ns |
| $11(3,5)$ | Data Valid from $\overline{\mathrm{CS}}$ Low | - | 310 | - | 180 | ns |
| 12 | Read Data Valid to DTACK Low (Setup Time) | 50 | - | 0 | - | ns |
| 13 | $\overline{\text { DTACK }}$ Low to $\overline{\text { DS }}, \overline{\text { CS }}$ or $\overline{\text { IACK }}$ High (Hold Time) | 0 | - | 0 | - | ns |
| 14 |  | 50 | - | 50 | - | ns |
| 15 (1) | $\overline{\text { IEO }}$ Valid from Clock Low (Delay) | - | 180 | - | 120 | ns |
| 16 | Data Valid from Clock Low (Delay) | - | 300 | - | 180 | ns |
| 17 | $\overline{\overline{E O}}$ Invalid from $\overline{\text { ACK }}$ High (Delay) | - | 150 | - | 100 | ns |
| 18 | $\overline{\text { DTACK }}$ Low from Clock High (Delay) | - | 180 | - | 100 | ns |
| 19 (1) | $\overline{\overline{I E O}}$ Valid from $\overline{\text { EI }}$ Low (Delay) | - | 100 | - | 100 | ns |
| 20 | Data Valid from IEI Low (Delay) | - | 220 | - | 140 | ns |
| 21 | Clock Cycle Time | 250 | 1000 | 125 | 1000 | ns |
| 22 | Clock Width Low | 110 | - | 55 | - | ns |
| 23 | Clock Width High | 110 | - | 55 | - | ns |
| 24 (4) | $\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}$ Inactive to Rising Clock (Setup) | 100 | - | 50 | - | ns |
| 25 | 1/O Minimum Active Pulse Width | 100 | - | 100 | - | ns |
| 26 | $\overline{\text { ACK }}$ Width High/Minimum Delay between two Pulses | 2 | - | 2 | - | CLK |
| 27 | I/O Data Valid from Rising $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ | - | 450 | - | 350 | ns |
| 28 | Receiver Ready Delay from Falling RC | - | 600 | - | 200 | ns |
| 29 | Transmitter Ready Delay from Falling TC | - | 600 | - | 200 | ns |
| 30 (6) | Timer Output Low from Rising Edge of $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ ( $\mathrm{A} \& \mathrm{~B}$ ) (Reset $\mathrm{T}_{\text {OUT }}$ ) | - | 450 | - | 200 | ns |


| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 31 (2) | ${ }^{\text {TOUT }}$ Valid from Internal Timeout | - | $\begin{aligned} & 2 \text { tCLK } \\ & +300 \end{aligned}$ | - | $\begin{aligned} & 2 \mathrm{t} \text { CLK } \\ & +300 \end{aligned}$ | ns |
| 32 | Timer Clock Low Time | 110 | - | 55 | - | ns |
| 33 | Timer Clock High Time | 110 | - | 55 | - | ns |
| 34 | Timer Clock Cycle Time | 250 | 1000 | 125 | 1000 | ns |
| 35 | $\widehat{\text { RESET Low Time }}$ | 2 | - | 1.5 | - | $\mu \mathrm{s}$ |
| 36 | Delay to Falling INTR from External Interrupt Active Transition | - | 380 | - | 250 | ns |
| 37 | Transmitter Internal Interrupt Delay from Falling Edge of TC | 550 | - | 250 | - | ns |
| 38 | Receiver Buffer Full Interrupt Transition Delay from Rising Edge of RC | 800 | - | 400 | - | ns |
| 39 | Receiver Error Interrupt Transition Delay from Falling Edge of RC | 800 | - | 400 | - | ns |
| 40 | Serial In Set Up Time to Rising Edge of RC (Divide by one only) | 80 | - | 50 | - | ns |
| 41 | Data Hold Time from Rising Edge of RC (Divide by one only) | 350 | - | 100 | - | ns |
| 42 | Serial Output Data Valid from Falling Edge of TC ( $\div 1$ ) | - | 440 | - | 200 | ns |
| 43 | Transmitter Clock Low Time | 500 | - | 250 | - | ns |
| 44 | Transmitter Clock High Time | 500 | - | 250 | - | ns |
| 45 | Transmitter Clock Cycle Time | 1.05 | \% | 0.55 | $\%$ | $\mu \mathrm{s}$ |
| 46 | Receiver Clock Low Time | 500 | - | 250 | - | ns |
| 47 | Receiver Clock High Time | 500 | - | 250 | - | ns |
| 48 | Receiver Clock Cycle Time | 1.05 | * | 0.55 | * | $\mu \mathrm{s}$ |
| $49(2)$ | $\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}, \overline{\mathrm{DS}}$ Width Low | - | 80 | - | 80 | TCLK |
| 50 | Serial Output Data Valid from Falling Edge of TC $(\div 16)$ | - | 490 | - | 200 | ns |
| 51 | Cycle Time | 1000 | - | - | - | ns |
| 52 | Pulse Width, E High | 430 | - | - | - | ns |
| 53 | Pulse Width, E Low | 450 | - | - | - | ns |
| 54 | Address, R// ${ }_{\text {W }}$ Setup Time Before E | 80 | - | - | - | ns |
| 55 | $\overline{\mathrm{CS}}$ Setup Time Before E | 80 | - | - | - | ns |
| 56 | Address Hold Time | 10 | - | - | - | ns |
| 57 | $\overline{\mathrm{CS}}$ Hold Time | 10 | - | - | - | ns |
| 58 | Output Data Delay Time (Read) | - | 250 | - | - | ns |
| 59 | Data Hold Time (Read) | 0 | 100 | - | - | ns |


| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 60 | Input Data Setup Time (Write) | 280 | - | - | - | ns |
| 61 | Data Hold Time (Write) | 20 | - | - | - | ns |
| 62 | Cycle Time | 800 | - | - | - | ns |
| 63 | Pulse Width $\overline{\text { DS }}$ Low or RD/ $\overline{W R}$ High | 350 | - | - | - | ns |
| 64 | Pulse Width DS High or RD/ $\overline{W R}$ Low | 340 | - | - | - | ns |
| 65 | Pulse Width AS/ALE High | 100 | - | - | - | ns |
| 66 | Delay AS Fall to $\overline{\mathrm{DS}}$ Rise or ALE Fall to RD/ $\overline{W R}$ Fall | 30 | - | - | - | ns |
| 67 | Delay $\overline{\mathrm{DS}}$ or RD/ $\overline{W R}$ Rise to AS/ALE Rise | 30 | - | - | - | ns |
| 68 | R/ $\bar{W}$ Setup Time to $\overline{\mathrm{DS}}$ | 100 | - | - | - | ns |
| 69 | R/ $\bar{W}$ Hold Time to $\overline{\mathrm{DS}}$ | 10 | - | - | - | ns |
| 70 | Address Setup Time to AS/ALE | 20 | - | - | - | ns |
| 71 | Address Hold Time to AS/ALE | 20 | - | - | - | ns |
| 72 | Data Setup Time to $\overline{\overline{D S}}$ or WR (Write) | 280 | - | - | - | ns |
| 73 | Delay Data to $\overline{\mathrm{DS}}$ or RD (Read) | - | 250 | - | - | ns |
| 74 | Data Hold Time to $\overline{\mathrm{DS}}$ or WR (Write) | 20 | - | - | - | ns |
| 75 | Data Hold Time to $\overline{\mathrm{DS}}$ or RD (Read) | 0 | 100 | - | - | ns |
| 76 | CE Setup Time to AS/ALE Fall | 20 | - | - | - | ns |
| 77 | CE Hold Time to $\overline{\mathrm{DS}}, \mathrm{RD}$ or $\overline{\mathrm{WR}}$ | 20 | - | - | - | ns |

## Notes:

1. $\overline{\mathrm{IEO}}$ only goes low if no acknowledgeable interrupt is pending. If $\overline{\mathrm{IEO}}$ goes low, $\overline{\mathrm{DTACK}}$ and the data bus remain tri-stated.
2. TCLK refers to the clock applied to the CMFP CLK input pin. tCLK refers to the timer clock signal, regardless of whether that signal comes from the XTAL1/XTAL2 crystal clock inputs or the TAI or TBI timer inputs.
3. If the setup time is not met, $\overline{C S}$ or $\overline{\mathrm{ACK}}$ will not be recognized until the next falling CLK.
4. If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.
5. Althrough $\overline{C S}$ and $\overline{\text { DTACK }}$ are synchronized with the clock, the data out during a reed cycle is asynchronous to the clock, relying only on $\overline{\mathrm{CS}}$ for timing.
6. Spec. 30 applies to timer outputs TAO and TBO only.

### 1.7.1 AC ELECTRICAL CHARACTERISTICS - READ CYCLES

$\left(V_{C C}=5.0 V_{D C} \pm 5 \%, V_{S S}=0 V_{D C}{ }^{\top} A=T_{L}\right.$ to $T_{H}$ unless otherwise noted)

| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 1 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Width High | 50 | - | 50 | - | - |
| 2 | R/W, A1-A5 Valid to Falling $\overline{\mathrm{CS}}$ (Setup) | 30 | - | 20 | - | ns |
| 4 (3) | $\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}$ Valid to Falling Clock (Setup) | 50 | - | 50 | - | ns |
| 5 | CLK Low to DTACK Low | - | 220 | - | 90 | ns |
| 6 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\text { IACK }}$ High to $\overline{\text { DTACK }}$ High | - | 60 | - | 50 | ns |
| 7 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\text { ACK }}$ High to $\overline{\text { DTACK }}$ Tri-state | - | 100 | - | 100 | ns |
| 8 | $\overline{\text { DTACK Low to Data Invalid (Hold Time) }}$ | 0 | - | 0 | - | ns |
| 9 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or IACK High to Data Tri-state | - | 50 | - | 50 | ns |
| 10 |  | 0 | - | 0 | - | ns |
| $11(3,5)$ | Data Valid from $\overline{\mathrm{CS}}$ Low | - | 310 | - | 180 | ns |
| 12 | Read Data Valid to $\overline{\text { DTACK }}$ Low (Setup Time) | 50 | - | 0 | - | ns |
| 13 | $\overline{\text { DTACK }}$ Low to $\overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ or $\overline{\mathrm{ACK}}$ High (Hold Time) | 0 | - | 0 | - | ns |
| $24(4)$ | $\overline{\mathrm{CS}}, \overline{\text { IACK }}$ Inactive to Rising Clock (Setup) | 100 | - | 50 | - | ns |

## Jotes:

If the setup time is not met, $\overline{\mathrm{CS}}$ or $\overline{\mathrm{ACK}}$ will not be recognized until the next falling CLK.
If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.

Althrough $\overline{C S}$ and $\overline{\text { DTACK }}$ are synchronized with the clock, the data out during a reed cycle is asynchronous to the clock, relying only on $\overline{\mathrm{CS}}$ for timing.


### 7.7.2 AC ELECTRICAL CHARACTERISTICS - WRITE CYCLES

$\left(V_{C C}=5.0 V_{D C} \pm 5 \%, V_{S S}=0 V_{D C}{ }^{\top} A=T_{L}\right.$ to $T_{H} \quad$ unless otherwise noted)

| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 1 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Width High | 50 | - | 50 | - | - |
| 2 | R/ $\bar{W}, ~ A 1-A 5 ~ V a l i d ~ t o ~ F a l l i n g ~ \overline{C S}$ (Setup) | 30 | - | 20 | - | ns |
| 3 | Data Valid Prior to Falling CLK | 280 | - | 100 | - | ns |
| 4(3) | $\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}$ Valid to Falling Clock (Setup) | 50 | - | 50 | - | ns |
| 5 | $\overline{\text { CLK }}$ Low to $\overline{\text { DTACK }}$ Low | - | 220 | - | 90 | ns |
| 6 | $\overline{C S}, \overline{D S}$ or IACK High to $\overline{\text { DTACK }}$ High | - | 60 | - | 50 | ns |
| 7 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\text { IACK }}$ High to $\overline{\text { DTACK }}$ Tri-state | - | 100 | - | 100 | ns |
| 8 | $\overline{\text { DTACK Low to Data Invalid (Hold Time) }}$ | 0 | - | 0 | - | ns |
| 10 | $\overline{\mathrm{CS}}$ or $\overline{\mathrm{DS}}$ High to R/ $\bar{W}, \mathrm{~A} 1$-A5 Invalid (Hold Time) | 0 | - | 0 | - | ns |
| 13 | $\overline{\text { DTACK }}$ Low to $\overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ or $\overline{\text { IACK }}$ High (Hold Time) | 0 | - | 0 | - | ns |
| 24 (4) | $\overline{\mathrm{CS}}, \overline{\mathrm{ACK}}$ Inactive to Rising Clock (Setup) | 100 | - | 50 | - | ns |

## Notes:

3. If the setup time is not met, $\overline{C S}$ or $\overline{\mathrm{ACK}}$ will not be recognized until the next falling CLK.
4. If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If no met, the hold-off will be two clock cycles.


Figure 7-5. Write Cycle Timing

### 7.7.3 AC ELECTRICAL CHARACTERISTICS - INTERRUPT ACKNOWLEDGE CYCLES

( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}_{\mathrm{DC}} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}_{\mathrm{DC}}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}} \quad$ unless otherwise noted)
See Figures 7-6 and 7-7.

| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 4 (3) | $\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}$ Valid to Falling Clock (Setup) | 50 | - | 50 | - | ns |
| 5 | $\overline{\text { CLK }}$ Low to $\overline{\text { DTACK }}$ Low | - | 220 | - | 90 | ns |
| 6 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\text { IACK }}$ High to $\overline{\text { DTACK }}$ High | - | 60 | - | 50 | ns |
| 7 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\text { ACK }}$ High to $\overline{\text { DTACK }}$ Tri-state | - | 100 | - | 100 | ns |
| 9 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ or $\overline{\mathrm{ACK}}$ High to Data Tri-state | - | 50 | - | 50 | ns |
| 13 | $\overline{\text { DTACK }}$ Low to $\overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ or $\overline{\text { IACK }}$ High (Hold Time) | 0 | - | 0 | - | ns |
| 14 | $\overline{\mid E I}$ Low to Falling CLK (Setup) | 50 | - | 50 | - | ns |
| 15 (1) | $\overline{\text { IEO }}$ Valid from Clock Low (Delay) | - | 180 | - | 120 | ns |
| 16 | Data Valid from Clock Low (Delay) | - | 300 | - | 180 | ns |
| 17 | $\overline{\mathrm{IEO}}$ Invalid from $\overline{\mathrm{IACK}}$ High (Delay) | - | 150 | - | 100 | ns |
| 18 | $\overline{\text { DTACK }}$ Low from Clock High (Delay) | - | 180 | - | 100 | ns |
| 19(1) | $\overline{\text { IEO }}$ Valid from $\overline{\text { EI }}$ Low (Delay) | - | 100 | - | 100 | ns |
| 20 | Data Valid from IEI Low (Delay) | - | 220 | - | 140 | ns |
| 21 | Clock Cycle Time | 250 | 1000 | 125 | 1000 | ns |
| 22 | Clock Width Low | 110 | - | 55 | - | ns |
| 23 | Clock Width High | 110 | - | 55 | - | ns |
| 24 (4) | $\overline{\mathrm{CS}}, \overline{\text { IACK }}$ Inactive to Rising Clock (Setup) | 100 | - | 50 | - | ns |
| 26 | $\overline{\text { IACK }}$ Width High/Minimum Delay between two Pulses | 2 | - | 2 | - | CLK |

## Votes:

$\overline{I E O}$ only goes low if no acknowledgeable interrupt is pending. If $\overline{I E O}$ goes low, $\overline{D T A C K}$ and the data bus remain tri-stated.

If the setup time is not met, $\overline{C S}$ or $\overline{\mathrm{ACK}}$ will not be recognized until the next falling CLK.
If the setup time is met (for consecutive cycles), the minimum hold-off time of one clock cycle will be obtained. If not met, the hold-off will be two clock cycles.


Figure 7-6. Interrupt Acknowledge Cycle (IEI Low)


Note: $\overline{\mathrm{CS}}$ and $\overline{\mathrm{IACK}}$ must be a function of $\overline{\mathrm{DS}}$
Figure 7-7. Interrupt Acknowledge Cycle (IEI High)
7.4 AC ELECTRICAL CHARACTERISTICS - 6800 INTERFACE TIMING (V ${ }_{C C}=5.0 \mathrm{~V}_{\text {DC }}$ $\pm 5 \%, V_{S S}=0 V_{D C} T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ unless otherwise noted). See figure 7-8.

| Num | Characteristic | 4 MHz |  | 8 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 51 | Cycle Time | 1000 | - | - | - | ns |
| 52 | Pulse Width, E High | 430 | - | - | - | ns |
| 53 | Pulse Width, E Low | 450 | - | - | - | ns |
| 54 | Address, R/ $\bar{W}$ Setup Time Before E | 80 | - | - | - | ns |
| 55 | $\overline{\mathrm{CS}}$ Setup Time Before E | 80 | - | - | - | ns |
| 56 | Address Hold Time | 10 | - | - | - | ns |
| 57 | $\overline{\text { CS }}$ Hold Time | 10 | - | - | $\cdots$ | ns |
| 58 | Output Data Delay Time (Read) | - | 250 | - | - | ns |
| 59 | Data Hold Time (Read) | 0 | 100 | - | - | ns |
| 60 | Input Data Setup Time (Write) | 280 | - | - | - | ns |
| 61 | Data Hold Time (Write) | 20 | - | - | - | ns |



Figure 7-8. 6800 Interfacing Timing

### 7.7.5 AC ELECTRICALCHARACTERISTICS - MULTIPLEXED BUS TIMING (VCC $=5.0 \mathrm{~V}$

$\pm 5 \%, V_{S S}=0 V_{D C} T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ unless otherwise noted). See figures 7-9, 7-1C

| Num | Characteristic | 4 MHz |  | 8 MHz |  | Un |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 62 | Cycle Time | 800 | - | - | - | ns |
| 63 | Pulse Width $\overline{\text { DS }}$ Low or RD/WR High | 350 | - | - | - | ns |
| 64 | Pulse Width DS High or RD/WR Low | 340 | - | - | - | ns |
| 65 | Pulse Width AS/ALE High | 100 | - | - | - | ns |
| 66 | Delay AS Fall to $\overline{\mathrm{DS}}$ Rise or ALE Fall to RD/WR Fall | 30 | - | - | - | ns |
| 67 | Delay $\overline{\mathrm{DS}}$ or RD/WR Rise to AS/ALE Rise | 30 | - | - | - | ns |
| 68 | R/WW Setup Time to $\overline{\text { DS }}$ | 100 | - | - | - | ns |
| 69 | R/ $\bar{W}$ Hold Time to $\overline{\mathrm{DS}}$ | 10 | - | - | - | ns |
| 70 | Address Setup Time to AS/ALE | 20 | - | - | - | ns |
| 71 | Address Hold Time to AS/ALE | 20 | - | - | - | ns |
| 72 | Data Setup Time to $\overline{\text { DS }}$ or WR (Write) | 280 | - | - | - | ns |
| 73 | Delay Data to $\overline{\mathrm{DS}}$ or RD (Read) | - | 250 | - | - | ns |
| 74 | Data Hold Time to $\overline{\text { DS }}$ or WR (Write) | 20 | - | - | - | ns |
| 75 | Data Hold Time to $\overline{\text { DS }}$ or RD (Read) | 0 | 100 | - | - | ns |
| 76 | CE Setup Time to AS/ALE Fall | 20 | - | - | - | ns |
| 77 | CE Hold Time to $\overline{\text { DS, }}$, RD or WR | 20 | - | - | - | ns |



Figure 7-9. Multiplexed Bus Tim Motorola Type
(62)


Figure 7-10. Multiplexed Bus Timing - Intel Type


Note: Active edge is assumed to be the rising edge
Figure 7-11. Interrupt Timing


Figure 7-12. Port Timing


Figure 7-13. Receiver Timing


Figure 7-14. Transmitter Timing


Figure 7-15. Timer Timing


Figure 7-16. Reset Timing

### 7.8 TIMER AC CHARACTERISTICS

## Definitions:

Error = Indicated time value - actual time value
$t_{\text {psc }}=$ t $_{\text {CLK }} \times$ Prescale Value
Internal Timer Mode:
Single Interval Error (Free Running) (See Note 2) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $\pm 100 \mathrm{~ns}$
Cumulative Internal Error . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0
Error Between Two Timer Reads ............................................... (tpsc - 4 tCLK)
Start Timer to Stop Timer Error . . . . . . . . . . . . . . . . . . . 2 tCLK +100 ns to $-($ tpsc +6 tCLK +100 ns )
Start Timer to Read Timer Error .................................... 0 to - (tpsc +6 tCLK +400 ns )
Start Timer to Interrupt Request Error (See Note 3) . . . . . . . . . . . . - 2 tCLK to - (4 tCLK +800 ns )
Pulse Width Measurement Mode:
Measurement Accuracy (See Note 1) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 tCLK to - (tpsc +4 tCLK)
Minimum Pulse Width
4 tCLK
Event Counter Mode:
Minimum Active Time of TAI and TBI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 tCLK
Minimum Inactive Time of TAI and TBI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 tCLK
NOTES:

1. Error may be cumulative if repetitively performed.
2. Error with respect to tout or $\overline{\mathrm{RQ}}$ if note 3 is true.
3. Assuming it is possible for the timer to make an interrupt request immediately.

## SECTION 8 <br> MECHANICAL DATA AND ORDERING INFORMATION

This section contains the pin assignments, package dimensions, and ordering information fc the TS68HC901.

PIN ASSIGNMENTS




CB-229


P SUFFIX PLASTIC PACKAGE

ALSO AVAILABLE
C SUFFIX
CERAMIC PACKAGE


CB-522


FN SUFFIX
PLCC 52

ORDERING INFORMATION
STANDARD VERSIONS

| Package Type | Frequency <br> $(\mathbf{M H z})$ | Temperature <br> Range | Part Number |
| :---: | :---: | :---: | :---: |
| Ceramic DIL | 4.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CC4 |
| C Suffix | 5.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CC5 |
| Plastic DIL | 4.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CC8 |
|  | 5.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CP4 |
| P Suffix | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CP5 |
| PLCC | 4.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CP8 |
| FN Suffix | 5.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CFN4 |
|  | 8.0 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68HC901CFN5 |

## Hi-REL VERSIONS

In order to fit more closely to customer specific requirements, THOMSON SEMICONDUCTEURS is proposing different screening levels for its Hi -REL ranges.

G/B screening : Available only from THOMSON SEMICONDUCTEURS, this quality level, very close to the MIL-STD-883, is a cost effective alternative for customers who want to buy Hi-REL devices (low guaranteed AQL). The G/B level is in full accordance with the NFC96883 class G.

B/B screening: Full accordance with the MIL-STD-883 Rev. C class B (US), the CECC 90,000 class B (european) and with the NFC96883 class B (French).

Details on screening procedures for these levels of selection are available on request (please contact our sales representatives).

| Package Type | Frequency <br> $(\mathrm{MHz})$ | Temperature <br> Range | Part Number |
| :---: | :---: | :---: | :---: |
| Ceramic DIL | 4.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS68HC901VC4 |
| C Suffix | 4.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS68HC901MC4 |
|  | 4.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS68HC901VCG/B4 |
|  | 4.0 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS68HC901VCB/B4 |
|  | 4.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS68HC901MCG/B4 |
|  | 4.0 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS68HC901MCB/B4 |

# CHAPTER 5 - MICROCOMPUTER PERIPHERALS 

## MICROCOMPUTER PERIPHERALS SELECTION GUIDE

| Part number | Description | Technology | Alt source | CLK freq. (MHz) | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MK3801-0 <br> MK3801-4 <br> MK3801-6 | Serial Timer Interrupt (STI) Controller Full duplex USART - Two binary delay timers Two full feature timers - Eight general purpose lines - Full control of each interrupt channel | NMOS | 二 | $\begin{gathered} 2.5 \\ 4 \\ 6 \end{gathered}$ | 5-3 |
| $\begin{aligned} & \text { MK3831 } \\ & \text { MK3835 } \end{aligned}$ | MCU - Real time clock - Serial I/O-24×8RAM High speed shift clock - Low power CMOS TTL compatible | cMOS | 二 | 4.19 | 5-19 |

## FEATURES

$\square$ Full duplex USART with programmable DMA control signals
$\square$ Two binary delay timers
$\square$ Two full feature timers with

- Delay to interrupt mode
- Pulse width measurement mode
- Event counter mode
$\square$ Eight general purpose lines with
- Full bi-directional I/O capability
- Edge triggered interrupts on either edge
$\square$ Full control of each interrupt channel
- Enable/disable
- Maskable
- Automatic end-of-interrupt mode
- Software end-of-interrupt mode
- $2.5,4 \mathrm{MHz}$, and 6 MHz versions available


## INTRODUCTION

The MK3801 Z80 STI (Serial Timer Interrupt) is a multifunctional peripheral device for use in $\mathrm{Z8O}$ microprocessor based systems. It is designed to optimize current systems by reducing chip count and system costs. By providing a USART, four timers (two binary and two full function), and eight bi-directional I/O lines with individually programmable interrupts, the MK3801 can make substantial improvement to any Z 80 based system.

Control and operation of the MK3801 are provided by 24 internal registers accessible by the $Z 80$ bus. Sixteen of these registers are directly addressable and accessible; eight are indirectly addressable. Two of the four timers provide full service features, while the other two provide delay timer features only. Serial Communication is provided

## DEVICE PINOUT

Figure 1

by the USART, which is capable of either asynchronous or synchronous operation, optional sync word recognition and stripping, and programmable DMA control handshake lines. Eight bi-directional I/O lines provide parallel I/O capability and individually programmable interrupt capability. The interrupt structure of the device is fully programmable for all interrupts, provides for interrupt vector generation, conforms to the $\mathbf{Z 8 0}$ daisy chain interrupt priority scheme, and supports automatic end of interrupt functions for the Z80.

| SIGNAL NAME | DESCRIPTION |
| :---: | :---: |
| $\mathrm{V}_{\text {SS }}$ | Ground |
| $\mathrm{V}_{\mathrm{cc}}$ | +5 volts'( $\pm 5$ percent) |
| CE | Chip Enable (İnput, active low) |
| $\overline{\mathrm{RD}}$ | Read Enable (Input, active low) |
| $\overline{\mathrm{WR}}$ | Write Enable (Input, active low) |
| $\mathrm{A}_{0}-\mathrm{A}_{3}$ | Address Inputs. Used to address one of the internal registers during a read or write operation |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | Data Bus (bi-directional) |
| RESET | Device Reset (Input, active low). When activated, all internal registers (except for Timer or USART Data registers) will be cleared, all timers stopped, USART turned off, all interruptsdisabled and all pending interrupts cleared, and all I/O lines placed in tri-state input mode. |
| $\frac{1_{0}{ }^{-1} 7}{T r}$ | General purpose I/O and interrupt lines |
| INT | Interrupt Request (Output, active low, open drain) |
| $\overline{\text { ORO }}$ | Input/Output Request from Z80-CPU (input, active low). The IORO signal is used in conjunction with M1 to signal the MK3801 that the CPU is acknowledging its interrupt. |
| \|EI | Interrupt Enable In, active High |
| IEO | Interrupt Enable Out, active High |
| SO | Serial Output |
| SI | Serial Input |
| RC | Receiver Clock Input |
| TC | Transmit Clock Input |
| TAO-TDO | Timer Outputs |
| TCLK | Timer Clock Input |
| $\overline{\mathrm{M1}}$ | Z80 Machine Cycle One (Input, active low) |

## PIN DESCRIPTION

Figure 1 illustrates the pinout of the MK3801. The functions of these individual pins are described above.

## INTERNAL ORGANIZATION

Figure 2 illustrates the MK3801 internal organization, which supports the full set of timing, communications, parallel I/O, and interrupt processing functions available in the device.

## CPU bus I/O

The CPU BUS I/O provides the means of communications between the system and the MK3801. Data, Status, and Control Registers in the MK3801 are accessed by the bus in order to establish device parameters, assert control, and transfer status and data between the system and the MK3801.

Each register in the MK3801 is addressed over the address bus in conjunction with Chip Enable ( $\overline{\mathrm{CE}}$ ), while data is transferred over the eight bit Data bus under control of Read $(\overline{\mathrm{RD}})$ and Write $(\overline{\mathrm{WR}})$ signals.

## REGISTER ACCESSES

All register accesses are independent of any system clock. To read a register, both $\overline{\mathrm{CE}}$ and $\overline{\mathrm{RD}}$ must be active. The internal read control signal is essentially the combination of
both $\overline{\mathrm{CE}}$ and $\overline{\mathrm{RD}}$ active; thus the read operation will begin when the later of these two signals goes active and will end when the first signal goes inactive. The address bus must be stable prior to the start of the operation and must remain stable until the end of the operation. Unless a read operation or an interrupt acknowledge cycle is in progress, the data bus ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) will remain in the tri-state condition.

To write a register, both $\overline{C E}$ and $\overline{W R}$ must be active. The address must be stable prior to the start of the operation and must remain stable until the end of the operation. The data must be stable prior to the end of the operation and must remain stable until the end of the operation. The data presented on the bus will be latched into the register shortly after either $\overline{\mathrm{WR}}$ or $\overline{\mathrm{CE}}$ goes inactive.

## INTERNAL REGISTERS

There are 24 internal registers used to control the operation of the STI. Sixteen of these registers are directly addressable and accessible. Eight registers are indirectly addressable via the Pointer/Vector Register and accessible via the Indirect Data Register.

## DIRECTLY ADDRESSABLE REGISTERS

The Directly Addressable Registers are accessed by placing the address of the desired register on the address lines $\left(\mathrm{A}_{0}-\mathrm{A}_{3}\right)$ during a write or read cycle. Figure 3 lists the Directly Addressable Registers.

## INTERNAL ORGANIZATION

Figure 2


## DIRECTLY ACCESSIBLE REGISTERS

Figure 3

| ADDRESS | ABBREVIATION | REGISTER NAME |
| :---: | :---: | :--- |
| 0 | IDR | Indirect Data Register |
| 1 | GPIP | General Purpose I/O-Interrupt |
| 2 | IPRB | Interrupt Pending Register B |
| 3 | IPRA | Interrupt Pending Register A |
| 4 | ISRB | Interrupt in-Service Register B |
| 5 | ISRA | Interrupt in-Service Register A |
| 6 | IMRB | Interrupt Mask Register B |
| 7 | IMRA | Interrupt Mask Register A |
| 8 | PVR | Pointer/Vector Register |
| 9 | TABCR | Timers A and B Control Register |

DIRECTLY ACCESSIBLE REGISTERS (Continued)
Figure 3

| ADDRESS | ABBREVIATION | REGISTER NAME |
| :---: | :---: | :--- |
| A | TBDR | Timer B Data Register |
| B | TADR | Timer A Data Register |
| C | UCR | USART Control Register |
| D | RSR | Receiver Status Register |
| E | TSR | Transmitter Status Register |
| F | UDR | USART Data Register |

## INDIRECTLY ADDRESSABLE REGISTERS

Figure 4

| INDIRECT ADDRESS | ABBREVIATION | REGISTER NAME |
| :---: | :---: | :--- |
| 0 | SCR | Sync Character Register |
| 1 | TDDR | Timer D Data Register |
| 2 | TCDR | Timer C Data Register |
| 3 | AER | Active Edge Register |
| 4 | IERB | Interrupt Enable Register B |
| 5 | IERA | Interrupt Enable Register A |
| 6 | DDR | Data Direction Register |
| 7 | TCDCR | Timers C and D Control Register |

## INDIRECTLY ADDRESSABLE REGISTERS

Indirectly Addressable Registers are addressed by placing the indirect address in bits IAO-IA2 of the Pointer/Vector Register, as defined in Figure 5. Data may be written to or read from the register indicated by these Indirect Register Address bits by a write or read access of the Indirect Data Register (selected when $\mathrm{A}_{0}-\mathrm{A}_{3}$ are all zero). The indirect address bits of the Pointer/Vector Register will remain unchanged after an indirect access. Repeated accesses of the Indirect Data Register will access the same indirect register as long as the indirect address in the Pointer/Vector Register remains unchanged. The Indirectly Addressable Registers are listed in Figure 4.

## INTERRUPT VECTOR DEFINITION

Each individual function in the MK3801 is provided with a unique interrupt vector that is presented to the system during the interrupt acknowledge cycle. The interrupt vector returned during interrupt acknowledge is formed as shown in Figure 6. There are 16 vector addresses generated internally by the MK3801, one for each of the 16 interrupt channels. The three most significant bits of these vector addresses correspond to the three most significant bits of the Pointer/Vector Register shown in Figure 5. The least significant bit of each vector address is always 0 , thus producing even vector addresses. The remaining 4 bits (IV
through $\mathrm{IV}_{4}$ ) identify each of the 16 interrupt channels individually. The lowest priority channel responds with 0000 for $\mathrm{IV}_{4}-\mathrm{IV} 1$ respectively. The next higher priority channel responds with 0001, and so on in binary order, with the highest priority channel responding with 1111. Figure 7 lists each of the 16 interrupt channels in order of descending priority.

## INTERRUPT CONTROL REGISTERS

The Interrupt Control Registers provide control of interrupt processing for all I/O facilities of the MK3801. These registers allow the programmer to enable or disable any or all of the 16 interrupts, provide masking for any interrupts, and access to the pending or in-service status of the interrupts. Optional End-of-Interrupt modes are available under software control. The format of each of the Interrupt Control Registers is presented in Figure 8.

## INTERRUPT OPERATION

The Interrupt Enable Registers enable or disable the setting of an interrupt in the Interrupt Pending Registers. A O in a bit of the Interrupt Enable Registers disables the interrupt for the associated channel while a 1 enables the interrupt.

Once an interrupt is enabled, the occurrence of an interrupting condition on that channel will cause the


## INTERRUPT VECTOR

Figure 6

corresponding bit in the Interrupt Pending Register to be set. This indicates that an interrupt is pending in the MK3801.

Pending interrupts are presented to the Z80 CPU in order of priority (see Figure 1) unless they have been masked off. This is done by clearing the bit in the Interrupt Mask Register corresponding to the channel whose interrupt is to be masked. The channel's interrupt will remain pending until the mask bit for that channel is set, at which time the interrupt for that channel will be processsed in order of priority.

When an interrupt vector is generated for a pending interrupt and passed to the Z80 CPU, the bit in the Interrupt Pending Register, associated with the channel generating the interrupt, will be cleared. At this time, no history of the
interrupt remains in the MK3801.
In order to retain historical evidence of an interrupt being serviced by the Z80, the In-Service Register may be enabled by setting the S-bit in the Pointer/Vector Register (see Figure 5). If the In-Service Register is enabled, the bit of the In-Service Register corresponding to the interrupting channel will be set when the interrupt vector is passed to the Z80. At the same time, the Interrupt Pending bit will be cleared since the interrupt is now in service. The In-Service bit will be cleared on execution of a Return-from-Interrupt ( $H^{\prime}$ ED4D') instruction. The In-Service Registers are directly addressable, and the In-Service bit for any interrupt may be cleared by writing to the In-Service Register if the Return-from-Interrupt instruction is not used.

## INTERRUPT CONTROL REGISTER DEFINITIONS

Figure 7
There are sixteen interrupt channels on the STI arranged in the following priority:

| PRIORITY | CHANNEL |
| :--- | :--- |
| HIGHEST | 1111 |
|  | 1110 |
|  | 1101 |
|  | 1100 |
|  | 1011 |
|  | 1010 |
|  | 1001 |
|  | 1000 |
|  | 0111 |
|  | 0110 |
|  | 0101 |
|  | 0100 |
|  | 0011 |
|  | 0010 |
|  | 0001 |
|  | 0000 |

## DESCRIPTION

General Purpose Interrupt $7\left(I_{7}\right)$
General Purpose Interrupt $6\left(I_{6}\right)$
Timer A
Receive Buffer Full
Receive Error
Transmit Buffer Empty
Transmit Error
Timer B
General Purpose Interrupt $5\left(I_{5}\right)$
General Purpose Inter rupt $4\left(I_{4}\right)$
Timer C
Timer D
General Purpose Interrupt $3\left(I_{3}\right)$ TB (PW-Event)
General Purpose Interrupt $2\left(\mathrm{I}_{2}\right)$
General Purpose Interrupt $1\left(I_{1}\right)$
General Purpose Interrupt $0\left(l_{0}\right)$

ALTERNATE USAGE

TA (PW-Event)

DMA (TR)TX
DMA (RR)REC

## INTERRUPT CONTROL REGISTERS

Figure 8

## ADDRESS

|  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Indirect <br> Port 5 | $\begin{gathered} \mathbf{A} \\ \text { (IERA) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | TIMER A | RCV Buffer Full | RCV Error | XMIT <br> Buffer <br> Empty | XMIT <br> Error | $\begin{gathered} \text { TIMER } \\ \text { B } \end{gathered}$ |
| Indirect <br> Port 4 | $\begin{gathered} B \\ \text { (IERB) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | TIMER C | TIMER D | GPIP 3 | GPIP 2 | $\begin{gathered} \text { GPIP } \\ 1 \end{gathered}$ | $\begin{aligned} & \text { GPIP } \\ & 0 \end{aligned}$ |
|  |  | INTERRUPT MASK REGISTERS |  |  |  |  |  |  |  |
|  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Port 7 | $\begin{gathered} \mathrm{A} \\ \text { (IMRA) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | $\underset{\mathbf{A}}{\text { TIMER }}$ | RCV Buffer Full | RCV <br> Error | XMIT <br> Buffer <br> Empty | XMIT <br> Error | $\begin{gathered} \text { TIMER } \\ \text { B } \end{gathered}$ |
| Port 6 | $\begin{gathered} \text { B } \\ \text { (IMRB) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | $\begin{aligned} & \text { TIMER } \\ & \text { C } \end{aligned}$ | TIMER D | GPIP 3 | GPIP 2 | $\begin{gathered} \text { GPIP } \\ 1 \end{gathered}$ | $\begin{aligned} & \text { GPIP } \\ & 0 \end{aligned}$ |
|  |  | 1 = UNMASKED, 0 = MASKED INTERRUPT PENDING REGISTERS |  |  |  |  |  |  |  |
|  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Port 3 | $\begin{gathered} \mathbf{A} \\ \text { (IPRA) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | $\begin{gathered} \text { TIMER } \\ \mathbf{A} \end{gathered}$ | RCV Buffer Full | RCV <br> Error | XMIT <br> Buffer <br> Empty | XMIT <br> Error | $\begin{gathered} \text { TIMER } \\ \text { B } \end{gathered}$ |
| Port 2 | $\begin{gathered} \text { B } \\ (\text { IPRB }) \end{gathered}$ | GPIP 5 | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | TIMER C | TIMER D | GPIP 3 | GPIP 2 | GPIP 1 | $\begin{aligned} & \text { GPIP } \\ & 0 \end{aligned}$ |
|  |  | WRITING 0 CLEAR WRITING 1 UNCHANGED |  |  |  |  |  |  |  |

## INTERRUPT SERVICE REGISTERS

| ADDRESS |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Port 5 | $\begin{gathered} A \\ \text { (ISRA) } \end{gathered}$ | $\begin{aligned} & \text { GPIP } \\ & 7 \end{aligned}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | TIMER A | RCV Buffer Full | RCV <br> Error | XMIT <br> Buffer <br> Empty | XMIT <br> Error | $\begin{gathered} \text { TIMER } \\ \text { B } \end{gathered}$ |
| Port 4 | $\begin{gathered} \text { B } \\ \text { (ISRB) } \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | $\begin{gathered} \text { TIMER } \\ \mathbf{C} \\ \hline \end{gathered}$ | $\begin{gathered} \text { TIMER } \\ \mathrm{D} \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 3 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 2 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ \hline \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 0 \end{gathered}$ |

TIMER A and B CONTROL REGISTER (TABCR) Port 9 Figure 9


The four control bits are used to select the timer mode and prescale value, as follows:

## CONTROL BIT DEFINITION

| $\mathbf{C}_{3}$ | $\mathbf{C}_{\mathbf{2}}$ | $\mathbf{C}_{\mathbf{1}}$ | $\mathbf{C}_{\mathbf{0}}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | Timer Stopped |
| 0 | 0 | 0 | 1 | Delay Mode, $\div 4$ Prescale |
| 0 | 0 | 1 | 0 | Delay Mode, $\div 10$ Prescale |
| 0 | 0 | 1 | 1 | Delay Mode, $\div 16$ Prescale |
| 0 | 1 | 0 | 0 | Delay Mode, $\div 50$ Prescale |
| 0 | 1 | 0 | 1 | Delay Mode, $\div 64$ Prescale |
| 0 | 1 | 1 | 0 | Delay Mode, $\div 100$ Prescale |
| 0 | 1 | 1 | 1 | Delay Mode, $\div 200$ Prescale |
| 1 | 0 | 0 | 0 | Event Count Mode |
| 1 | 0 | 0 | 1 | Pulse Width Mode, $\div 4$ Prescale |
| 1 | 0 | 1 | 0 | Pulse Width Mode, $\div 10$ Prescale |
| 1 | 0 | 1 | 1 | Pulse Width Mode, $\div 16$ Prescale |
| 1 | 1 | 0 | 0 | Pulse Width Mode, $\div 50$ Prescale |
| 1 | 1 | 0 | 1 | Pulse Width Mode, $\div 64$ Prescale |
| 1 | 1 | 1 | 0 | Pulse Width Mode, $\div 100$ Prescale |
| 1 | 1 | 1 | 1 | Pulse Width Mode, $\div 200$ Prescale |

TIMER A DATA REGISTER AND TIMER B DATA
REGISTER (TADR, TBDR) Port B \& Port A


## TIMERS

Four timers are available on the MK3801. Two provide full service features including delay timer operation, event counter operation, pulse width measurement operation, and pulse generation. The two other timers provide delay timer features only, and may be used for baud rate generators for use with the USART.

All timers are prescaler/counter timers, with a common independent clock input, and are not required to be operated

TIMER C and D CONTROL REGISTER (TCDCR) Indirect Port 7
Figure 10


Three control bits are used to control each timer, as defined below:

## CONTROL BIT DEFINITION

| $\mathbf{C}_{2}$ | $\mathbf{C}_{1}$ | $\mathbf{C}_{\mathbf{0}}$ |  |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Timer Stopped |
| 0 | 0 | 1 | Delay Mode, $\div 4$ Prescale |
| 0 | 1 | 0 | Delay Mode, $\div 10$ Prescale |
| 0 | 1 | 1 | Delay Mode, $\div 16$ Prescale |
| 1 | 0 | 0 | Delay Mode, $\div 50$ Prescale |
| 1 | 0 | 1 | Delay Mode, $\div 64$ Prescale |
| 1 | 1 | 0 | Delay Mode, $\div 100$ Prescale |
| 1 | 1 | 1 | Delay Mode, $\div 200$ Prescale |

## TIMER C DATA REGISTER and TIMER D DATA REGISTER (TCDR, TDDR) Indirect, <br> Port 2 and Indirect Port 1


from the system clock. In addition, all timers have a time-out output function that toggles each time the timer times out.

## TIMER CONTROL REGISTERS

The 4 timers ( $A, B, C$, and $D$ ) are programmed via 2 control registers and 4 timer data registers. Timers $A$ and $B$ are contull: $d$ by a single register (TABCR) and two timer data : agisters iTADR,TBDR). Timers C and D are controlled by a second control register (TCDCR) and two timer data
registers (TCDR, TDDR). Bits in the control registers allow the selection of operational mode, prescale, and control, while the data registers are used to read the timer or write the time constant register. General Purpose I/O Interrupt pins 3 (TB) and 4 (TA) are used for timer $B$ and $A$ inputs in event and pulse width modes. Figure 9 illustrates the Control and Data Register for timers A and B, while Figure 10 illustrates the Control and Data registers for timers C and D.

## USART

Serial Communication is provided by the USART, which is capable of either asynchronous or synchronous operation. Variable word width and start/stop bit configurations are available under software control for asynchronous operation. For synchronous operation, a Sync Word is provided to establish synchronization during receive operations. The Sync Word will also be repeatedly transmitted when no other data is available for transmission. Operational modes exist to allow stripping of all Sync Words received in synchronous operation, and to allow the operation of DMA control handshake lines by the USART through General Purpose I/O Port lines 0 and 1. Separate receive and transmit clocks are available, and
separate receive and transmit status and data bytes allow independent operation of the transmit and receive sections.

## USART CONTROL REGISTERS

The USART is provided with 3 control/status registers and a data register. The programmer may specify operational parameters for the USART via the Control Register, as shown in Figure 11. Status of both the Receiver and Transmitter sections is accessed by means of the 2 Status Registers, as shown in Figure 12. Data written to the Data Register is passed to the transmitter, while reading the data register will access data received by the USART. The USART Data Register form is illustrated in Figure 13.

## ERROR CONDITIONS

Error conditions in the USART are determined by monitoring the Receive Status Register (Port D) and the Transmitter Status Register (Port E). These error conditions are only valid for each word boundary and are not latched. When executing block transfers of data, it is necessary to save any errors so that they can be checked at the end of a block. In order to save error conditions during data transfer, the STI interrupt controller may be used by enabling error

USART CONTROL REGISTER (UCR) Port C
Figure 11


RECEIVER STATUS REGISTER (RSR) Port D
Figure 12
RSR $_{7}$

| BUFFER <br> FULL | OVERRUN <br> ERROR | PARITY <br> ERROR | FRAME <br> ERROR | FOUND/ $\overline{\text { OEARCH }}$ <br> OR BREAK DETECT | MATCH/CHARACTER <br> IN PROGRESS | SYNC STRIP <br> ENABLE | RECEIVER <br> ENABLE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


*Connects transmitter output to receiver input. In loopback mode, transmitter goes high when disabled. Also connects clocks with TC given priority.

USART DATA REGISTER (UDR) Port F
Figure 13

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

GENERAL PURPOSE I/O CONTROL REGISTERS
Figure 14

| $\begin{aligned} & 1=\text { RISING } \\ & 0=\text { FALLING } \end{aligned}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 3 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 2 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 1 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 0 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DATA DIRECTION REGISTER (DDR) Indirect Port 6 |  |  |  |  |  |  |  |  |
| $\begin{aligned} & 1=\text { OUTPUT } \\ & \mathbf{0}=\text { INPUT } \end{aligned}$ | $\begin{gathered} \text { GPIP } \\ 7 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 6 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 3 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 2 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 1 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 0 \end{gathered}$ |
|  | GENERAL PURPOSE I/O DATA REGISTER (GPIP) Port 1 |  |  |  |  |  |  |  |  |
|  | GPIP | GPIP 6 | $\begin{gathered} \text { GPIP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 4 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 3 \end{gathered}$ | $\begin{gathered} \text { GPIP } \\ 2 \end{gathered}$ | $\begin{aligned} & \text { GPIP } \\ & 1 \\ & \text { (TR) } \\ & \hline \end{aligned}$ | $\begin{gathered} \text { GPIP } \\ 0 \\ \text { (RR) } \\ \hline \end{gathered}$ |
|  |  |  |  | TIMER A INPUT | TIMER B INPUT |  |  |  |

interrupts (Port 5, Indirect) for the desired channel (Receive error or Transmit error) and by masking these bits off (Port 7). Once the transfer is complete, the Interrupt Pending Register (Port 3) can be polled to determine the presence of a pending error interrupt, and therefore an error.

## GENERAL PURPOSE I/O - INTERRUPT PORT

The General Purpose I/O - Interrupt Port provides eight I/O lines that may be operated either as inputs or outputs under software control. In addition, each line may generate an interrupt on either a positive going edge or a negative going edge of the input signal.
Two of the lines in this port provide auxiliary input functions for the timers in the pulse width measurement mode and the event counter mode. Two others serve as auxiliary output lines for the USART, one indicating the Receive

Buffer Full condition (RR) and the other indicating the Transmitter Buffer Empty condition (TR). These may be used as handshake signals for a DMA controller or other external control circuitry.

## GENERAL PURPOSE I/O CONTROL REGISTERS

The General Purpose 1/O and Interrupt Port has 2 control registers. One allows the programmer to specify the Active Edge for each bit that will trigger the interrupt associated with that bit. The other register specifies the Data Direction (input and output) associated with each bit. The third register is the actual data I/O register used to input or output data to the port. When the USART is programmed to use DMA signals, this overrides the GPIP data and the DDR. The General Purpose 1/O Control and Data Registers are illustrated in Figure 14.

## MK3801 ELECTRICAL SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS

Temperature Under Bias . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 5 C to - 100 C
Storage Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 C to - 150 C
Voltage on Any Pin with Respect to Ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 . 3 to +7 V
Power Dissipation
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device This ts a stress rating only and functional operation of the device at these or any other condition above those indicated in the operationat sections of this specafication us not implied Exposure to absolute maximum rating conditions for extended periods may affect device reliability

## D.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| SYM | PARAMETER | MIN | MAX | UNIT | TEST CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+3$ | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}^{\prime}=-120 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low voltage |  | 0.4 | v | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{ILL}^{\text {L }}$ | Power Supply Current |  | 180 | mA | Outputs Open |
| $\mathrm{I}_{1}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathbf{I N}}=0$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LOH}}$ | Tri-State Output Leakage Current in Float |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {Out }}=2.4$ to $\mathrm{V}_{\mathrm{co}}$ |
| LoL | Tri-State Output Leakage Current in Float |  | -10 | $\mu \mathbf{A}$ | $\mathrm{V}_{\text {Out }}=0.4 \mathrm{~V}$ |

All voltages are referenced to ground.

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ unmeasured pins returned to ground.

| SYM | PARAMETER | MAX | UNIT | TEST <br> CONDITION |
| :--- | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 10 | pf | Unmeasured <br> pins |
| $\mathrm{C}_{\text {OUT }}$ | Tri-state Output Capacitance | 10 | pf | returned to <br> ground |

A.C. CHARACTERISTICS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise noted.

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SIGNAL} \& \multirow[b]{2}{*}{SYMBOL} \& \multirow[b]{2}{*}{PARAMETER} \& \multicolumn{2}{|l|}{MK3801-0} \& \multicolumn{2}{|l|}{MK3801-4} \& \multicolumn{2}{|l|}{MK3801-6} \& \multirow[b]{2}{*}{UNIT} \& \multirow[b]{2}{*}{CONDITION} \\
\hline \& \& \& MIN \& MAX \& MIN \& MAX \& MIN \& MAX \& \& \\
\hline \(\mathrm{A}_{0}-\mathrm{A}_{3}\) \& \[
\begin{aligned}
\& T_{\text {SAR }} \\
\& \& \\
\& T_{\text {SAW }} \\
\& T_{\text {HAR }} \\
\& \& \\
\& T_{\text {HAW }}
\end{aligned}
\] \& \begin{tabular}{l}
Address setup time prior to falling edge of \(\overline{\text { CEWR }}\) or \(\overline{\text { CERD }}\) \\
Address hold time after rising edge of \(\overline{\text { CEWR }}\) or CERD
\end{tabular} \& 80
0 \& \& \[
\begin{gathered}
30 \\
0
\end{gathered}
\] \& \& \begin{tabular}{l}
\[
15
\] \\
0
\end{tabular} \& \& \begin{tabular}{l}
ns \\
ns
\end{tabular} \& \\
\hline \(\overline{\text { CEWR }}\) \& \[
\begin{aligned}
\& \mathrm{T}_{\mathrm{WL}} \\
\& \mathrm{~T}_{\mathrm{WW}} \\
\& \mathrm{~T}_{\mathrm{WRD}}
\end{aligned}
\] \& \begin{tabular}{l}
\(\overline{\text { CEWR }}\) pulse width low (write cycle) \\
\(\overline{\text { CEWR }}\) high time between write cycles \\
\(\overline{\text { CEWR }}\) high to \(\overline{\text { CERD }}\) low
\end{tabular} \& \[
\begin{aligned}
\& 360 \\
\& 580 \\
\& 580
\end{aligned}
\] \& \& \[
\begin{aligned}
\& 205 \\
\& 400 \\
\& 400
\end{aligned}
\] \& \& \[
\begin{aligned}
\& 175 \\
\& 300 \\
\& 300
\end{aligned}
\] \& \& \begin{tabular}{l}
ns \\
ns \\
ns
\end{tabular} \& Note 1 \\
\hline \(\overline{\text { CERD }}\) \& \(T_{R D L}\)
\(T_{R R}\)
\(T_{M 1 R D}\)
\(T_{R D W}\) \& \begin{tabular}{l}
\(\overline{\text { CERD }}\) pulse width low (read cycle) \\
\(\overline{\text { CERD high time }}\) between read cycles \\
Rising \(\overline{\mathrm{M} 1 \mathrm{RD}}\) to falling M1RD \\
\(\overline{\text { CERD }}\) high to \(\overline{\text { CEWR }}\) low
\end{tabular} \& \[
\begin{aligned}
\& 400 \\
\& 300 \\
\& 225 \\
\& 125
\end{aligned}
\] \& \& \begin{tabular}{l}
250 \\
200 \\
165 \\
100
\end{tabular} \& \& \begin{tabular}{l}
215 \\
190 \\
95 \\
75
\end{tabular} \& \& \begin{tabular}{l}
ns \\
ns \\
ns
\end{tabular} \& Note 1 \\
\hline \(\overline{\mathrm{M1}}\) \& \({ }^{\text {T SM1 }}\) \& \(\overline{\mathrm{M} 1}\) setup time prior to falling \(\overline{\mathrm{ORO}}\) during interrupt acknowledge \& 800 \& \& 500 \& \& 350 \& \& ns \& \\
\hline \(\overline{\text { ORO }}\) \& TIOL \& IORQ low time \& 300 \& \& 185 \& \& 170 \& \& ns \& \\
\hline IEI \& \[
\mathrm{T}_{\mathrm{SIEI}}
\] \& \begin{tabular}{l}
Setup to falling \(\overline{\mathrm{ORQ}}\) during interrupt acknowledge \\
Setup prior to end of 4D read on RETI
\end{tabular} \& \[
\begin{aligned}
\& 140 \\
\& 100
\end{aligned}
\] \& \& \begin{tabular}{l}
80 \\
50
\end{tabular} \& \& 65
\[
40
\] \& \& ns ns \& \\
\hline \(\mathrm{D}_{0}-\mathrm{D}_{7}\) \& \begin{tabular}{l}
\(\mathrm{T}_{\text {SDM } 1}\) \\
\(\mathrm{T}_{\text {HDM }}\) \\
\(T_{\text {DRD }}\) \\
\(T_{\text {SDW }}\) \\
\(T_{\text {HDW }}\) \\
\(T_{\text {DDI }}\)
\end{tabular} \& \begin{tabular}{l}
Data valid prior to rising \(\overline{\mathrm{RD}}\) ( \(\overline{\mathrm{M} 1}\) cycle) \\
Data hold time after rising \(\overline{\mathrm{RD}}(\overline{\mathrm{M1}}\) cycle) \\
Data output delay from CERD \\
Data setup time to rising edge of \(\overline{\text { CEWR }}\) \\
Data hold time from rising edge of CEWR \\
Data output delay from falling \(\overline{\text { IORQ }}\) during interrupt acknowledge
\end{tabular} \& \[
\begin{gathered}
65 \\
0 \\
350 \\
0
\end{gathered}
\] \& \[
400
\]
\[
300
\] \& \begin{tabular}{l}
50 \\
0 \\
280 \\
0
\end{tabular} \& \[
250
\]
\[
185
\] \& \begin{tabular}{l}
45 \\
0 \\
175 \\
0
\end{tabular} \& 215

170 \& | ns |
| :--- |
| ns |
| ns |
| ns |
| ns |
| ns | \& \[

$$
\begin{aligned}
& \text { Load } \\
& 100 \mathrm{pf} \\
& + \\
& 1 \text { TL load }
\end{aligned}
$$
\] <br>

\hline
\end{tabular}

## A.C. CHARACTERISTICS (Continued)



## A.C. CHARACTERISTICS (Continued)

| SIGNAL | SYMBOL | PARAMETER | MK3801-0 |  | MK3801-4 |  | MK3801-6 |  | UNIT | CONDITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
|  | $\mathrm{T}_{\text {DTCI }}$ | Time delay from Transmit Clock to interrupt from rising or falling edge of TC |  | 1460 |  | 980 |  | 690 | ns |  |
| SI | $\left\lvert\, \begin{gathered} \mathrm{T}_{\mathrm{SS} I} \\ \mathrm{~T}_{\mathrm{HSI}} \end{gathered}\right.$ | Serial in set up time to rising edge of RC (Divide by one only) <br> Data hold time from rising edge of RC <br> (Divide by one only) | $\begin{array}{r} 80 \\ 400 \end{array}$ |  | $\begin{gathered} 80 \\ 350 \end{gathered}$ |  | $\begin{aligned} & 55 \\ & 300 \end{aligned}$ |  | ns ns |  |
| $\begin{aligned} & \mathrm{SO} \\ & \div 1 \end{aligned}$ | T ${ }_{\text {DSO }}$ | Data valid from falling edge of TC |  | 420 |  | 390 |  | 345 | ns | $\begin{aligned} & 100 \mathrm{pf}+1 \mathrm{TL} \\ & \text { load } \end{aligned}$ |
| $\begin{aligned} & \text { SO } \\ & \div 16 \end{aligned}$ | T ${ }_{\text {DSO }}$ | Data valid from falling edge of TC |  | 520 |  | 490 |  | 445 | ns | $\begin{aligned} & 100 \mathrm{pf}+1 \\ & \text { TTL load } \end{aligned}$ |
| TC | $\begin{aligned} & T_{T C L} \\ & T_{T C H} \\ & T_{T C C Y} \end{aligned}$ | Low time High time Cycle time | $\begin{gathered} 650 \\ 650 \\ 1.5 \end{gathered}$ |  | $\begin{aligned} & 500 \\ & 500 \\ & 1.05 \end{aligned}$ |  | $\begin{gathered} 400 \\ 400 \\ .85 \end{gathered}$ |  | ns ns $\mu \mathrm{S}$ |  |
| RC | $\mathrm{T}_{\mathrm{RCL}}$ <br> $\mathrm{T}_{\mathrm{RCH}}$ <br> $T_{\text {RCCY }}$ | Low time High time Cycle time | $\begin{gathered} 650 \\ 650 \\ 1.5 \end{gathered}$ |  | $\begin{aligned} & 500 \\ & 500 \\ & 1.05 \end{aligned}$ |  | $\begin{array}{r} 400 \\ 400 \\ .85 \end{array}$ |  | ns ns $\mu \mathrm{S}$ |  |

## NOTE:

1. One wait state must be inseted when used as a 6 MHz memory mapped device
2. All A.C. measurements are referenced to $\mathrm{V}_{\mathrm{IL}}$ max., $\mathrm{V}_{\mathrm{IH}}$ min., $\mathrm{V}_{08}(0.8 \mathrm{~V})$, or $(2.0 \mathrm{~V})$.

## OUTPUT LOAD CIRCUIT

Figure 15


## TIMING DIAGRAMS

Figure 16
Timing measurements are made at the following voltages, unless otherwise specified:
READ CYCLE


| $" 1 "$ | $" 0 "$ |
| :---: | :---: |
|  |  |
| 2.0 V | 0.8 V |
| 2.0 V | 0.8 V |
| $\Delta \mathrm{~V}$ | 0.5 V |



[^48]Address Setup Time for a Read Cycle
Data Output Delay from CERD
Time to Tri-State Following a Read Cycle
Required Address Hold Time Following a Read Cycle

## WRITE CYCLE

Figure 17


## INTERRUPT ACKNOWLEDGE CYCLE

Figure 18


## TIMER A.C. CHARACTERISTICS

Definitions:

| Error - Indicated Time Value - Actual Time Value |  |
| :---: | :---: |
| tpsc $=\mathrm{t}_{\text {CLK }} \times$ Prescale Value |  |
| Internal Timer Mode |  |
|  | $\mathrm{V}_{\mathrm{CC}}$ |
| Single Interval Error (free running) (Note 2) | . $\pm 100 \mathrm{~ns}$ |
| Cumulative Internal Error |  |
| Error Between Two Timer Reads | $\left.\ldots \ldots \ldots \ldots \ldots . . \begin{array}{l}\text { (tpsc }\end{array}+4 t_{\text {CLK }}\right)$ |
| Start Timer to Stop Timer Error | $2 \mathrm{t}_{\text {CLK }}+100 \mathrm{~ns}$ to -(tpsc $\left.+6 \mathrm{t}_{\text {CLK }}+100 \mathrm{~ns}\right)$ |
| Start Timer to Read Timer Error . . | $\ldots . . . . . . . .0$ to -(tpsc $\left.+6 \mathrm{t}_{\text {CLK }}+400 \mathrm{~ns}\right)$ |
| Start Timer to Interrupt Request Error (Note 3) | $\ldots . . . . . .{ }^{-2} \mathrm{t}_{\text {CLK }}$ to $-\left(4 \mathrm{t}_{\text {CLK }}+800 \mathrm{~ns}\right)$ |

Pulse Width Measurement Mode


## Event Counter Mode

| Minimum Active Time of $I_{3}, I_{4}$ Minimum Inactive Time of $I_{3}$, |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |

## notes:

1. Error may be cumulative if repetitively performed

Error with respect to TOUT or INT if note 3 is true.
3. Assuming it is possible for the timer to make an inteirupt request immediately.

## ORDERING INFORMATION

| PART NO. | DESIGNATOR | PACKAGE TYPE | MAX CLOCK <br> FREQUENCY | TEMPERATURE <br> RANGE |
| :--- | :--- | :--- | :--- | :--- |
| MK3801N-0 | Z80-STI | Plastic | 2.5 MHz | 0 to $70^{\circ} \mathrm{C}$ |
| MK3801N-4 | Z80-STI | Plastic | 4.0 MHz | 0 to $70^{\circ} \mathrm{C}$ |
| MK3801N-6 | Z80-STI | Plastic | 6.0 MHz | 0 to $70^{\circ} \mathrm{C}$ |



## FEATURES

i | Real-time clock counts seconds, minutes, hours, date of the month, day of the week, month, and year. Every 4 th year, February has 29 days.
| | Serial I/O for minimum pin count (8 pins)
|| $24 \times 8$ RAM for scratchpad data storage
| | Simple Microcomputer interface
[ ] High speed shift clock independent of crystal oscillator frequency

I ] Single byte or multiple byte (Burst Mode) data transfer capability for read or write of clock or RAM data
[ ] TTL Compatible $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}\right)$
1] Low-power CMOS
1 ] MK3831 is available with fixed frequency operation ( 4.194304 MHz ) and low power operation due to the disabling of CKO (Pin 1).

## GENERAL DESCRIPTION

Many microprocessor applications require a real-time clock and/or memory that can be battery powered with very low power drain. The MK3835N is specifically designed for these applications. The device contains a real-time clock/calendar, 24 bytes of static RAM, an on-chip oscillator, and it communicates with the microprocessor via a simple serial interface. The MK3835N is fabricated using CMOS technology, thus ensuring very low power consumption.

The real-time clock/calendar provides seconds, minutes, hours, day, date, month, and year information to the microprocessor. The end of the month date is automatically adjusted for months with less than 31 days, including correction for leap year every 4 years. The clock operates in either the 24 hour or 12 hour format with an AM/PM indicator.

The on-chip oscillator provides a real-time clock source for the clock/calendar. It incorporates a programmable divider so that a wide variety of crystal frequencies can be accommodated. The oscillator also has an output


Figure 1. Pin Out

## PIN DESCRIPTION

Table 1

| PIN <br> $3835 N$ | NAME | DESCRIPTION |
| :---: | :---: | :--- |
| 1 | CKO | Buffered System Clock Output |
| 2 | X1/CI | Crystal or External Clock Input |
| 3 | X2 | Crystal Input |
| 4 | GND | Power Supply Pin |
| 5 | $\overline{\text { CE }}$ | Chip Enable for Serial I/O Transfer |
| 6 | I/O | Data Input/Output Pin |
| 7 | SCLK | Shift Clock for Serial I/O Transfer |
| 8 | VCC | Power Supply Pin |

available that can be connected to the microprocessor clock input. A separately programmable divider provides several different output frequencies for any given crystal frequency. This feature can eliminate having to use a separate crystal or external oscillator for the microprocessor, thereby reducing system cost.

Interfacing the CLOCK/RAM with a microprocessor is greatly simplified using synchronous serial communication. Only 3 lines are required to communicate with the CLOCK/RAM: (1) $\overline{C E}$ (chip enable), (2) I/O (data line) and (3) SCLK (shift register clock). Data can be transferred to and from the CLOCK/RAM one byte at a time or in a burst of up to 24 bytes.

## TECHNICAL DESCRIPTION

Figure 2 is a block diagram of the CLOCK/RAM chip. Its main elements are the oscillator and divider circuit, divider control logic, the real-time clock/calendar, static RAM, the serial shift register, and the command and control logic.


* bUFFER DISABLED IN THE MK3831

Figure 2. Block Diagram

The shift register is used to communicate with the outside world. Data on the I/O line is either input or output on each shift register clock pulse when the chip is enabled. If the chip is in the input mode, the data on the I/O line is input to the shift register on the rising edge of SCLK. If in the output mode, data is shifted out onto the I/O line on the falling edge of SCLK.

The command and control logic receives the first byte input by the shift register after $\overline{\mathrm{CE}}$ goes active. This byte must be the command byte and will direct further operations within the CLOCK/RAM. The command specifies whether subsequent transfers will be data input or data output, and which register or RAM location will be involved.

A control register provides programmable control of the divider for the internal clock signal, the external clock signal, the crystal type and mode, and the write protect function.

The real-time clock/calendar is accessed via seven dynamic registers. These registers are seconds, minutes,
hours, day, date, month, and year. Certain bits within these registers also control a run/stop function, 12/24 hour format, and indicate AM or PM (12 hour mode only). These registers can be accessed sequentially in Burst Mode, or randomly in a single byte transfer.

The static RAM is organized as 24 bytes of 8 -bits each. They can be accessed either sequentially in burst mode, or randomly in a single byte transfer.

## POWER UP

A time base on the crystal input pins is necessary for correct power up. This time base can be provided by a crystal or it can be derived from another generated clock source. It should be noted that a delay exists between power up and the correct power up state of the clock and control registers.

## DATA TRANSFER

Data Transfer is accomplished under control of the $\overline{\mathrm{CE}}$
and SCLK inputs by an external microcomputer. Each transfer consists of a single byte ADDRESS/COMMAND input followed by a single byte or multiple byte (if Burst Mode is specified) data input or output, as specified by the ADDRESS/COMMAND byte. The serial data transfer occurs with LSB first, MSB last format.

## ADDRESS/COMMAND BYTE

The ADDRESS/COMMAND Byte is shown below:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | RAM | $\overline{\mathrm{CK}}$ | A4 | A3 | A2 | A1 | AO |

As defined, the MSB (bit 7) must be a logical 1; bit 6 specifies a Clock/Calendar/Control register if logical 0 or a RAM register if logical 1; bits 1-5 specify the designated register(s) to be input or output; and the LSB (bit 0) specifies a WRITE operation (input) if logical 0 or READ operation (output) if logical 1.

## BURST MODE

Burst Mode may be specified for either the Clock/Calendar/Control registers or for the RAM registers by addressing location 31 Decimal (ADDRESS/COM-

MAND bits $1-5=$ logical 1). As before, bit 6 specifies Clock or RAM and bit 0 specifies read or write.

There is no data storage capability at location 31 in either the Clock/Calendar/Control registers or the RAM registers.

## SCLK AND $\overline{C E}$ CONTROL

All data transfers are initiated by $\overline{\mathrm{CE}}$ going low. After $\overline{\mathrm{CE}}$ goes low, the next 8 SCLK cycles input an ADDRESS/COMMAND byte of the proper format. An SCLK cycle is the sequence of a positive edge followed by a negative edge. For data inputs, the data must be valid during the SCLK cycle. If bit 7 is not logical 1 , indicating a valid CLOCK/RAM ADDRESS/COMMAND, the ADDRESS/COMMAND byte is ignored as are all SCLK cycles until $\overline{C E}$ goes high and returns low to initiate a new ADDRESS/COMMAND transfer. See Figure 3.

ADDRESS/COMMAND bits and DATA bits are input on the rising edge of SCLK, and DATA bits are output on the falling edge of SCLK.

A data transfer terminates if $\overline{\mathrm{CE}}$ goes high, and the transfer must be reinitiated by the proper ADDRESS/COMMAND when $\overline{\mathrm{CE}}$ again goes low. The data I/O pin is high impedance when $\overline{C E}$ is high.
I. SINGLE BYTE TRANSFER


## II. BURST MODE TRANSFER



## NOTES

1) Data input sampled while SCLK is high
2) Data output changes on falling edge of clock
3) Rising edge of $\overline{C E}$ terminates operation and resets address/command

| FUNCTION | BYTE <br> N | SCLK <br> $n$ |
| :--- | :---: | :---: |
| CLOCK | 8 | 72 |
| RAM | 24 | 200 |

Figure 3. Data Transfer Summary

## DATA INPUT

Following the 8 SCLK cycles that input the WRITE Mode ADDRESS/COMMAND byte (bit $0=$ logical 0 ), a DATA byte is input on the rising edge of the next 8 SCLK cycles (per byte, if Burst Mode is specified). Additional SCLK cycles are ignored should they inadvertently occur.

## DATA OUTPUT

Following the 8 SCLK cycles that input the READ Mode ADDRESS/COMMAND byte (bit $0=$ logical 1), a DATA byte is output on the falling edge of the next 8 SCLK cycles (per byte, if Burst Mode is specified). Note that the first data bit to be transmitted from the CLOCK/RAM occurs on the falling edge of the last bit of the command byte. Additional SCLK cycles retransmit the data byte(s) should they inadvertently occur, so long as $\overline{\mathrm{CE}}$ remains low. This operation permits continuous Burst Read Mode capability.

## DATA TRANSFER SUMMARY

A data transfer summary is shown in Figure 3.

## REGISTER DEFINITION

## CLOCK/CALENDAR

The Clock/Calendar is contained in 7 writeable/readable registers, as defined below.

| Address | Function | Range (BCD) |
| :---: | :--- | :--- |
| 0 | Seconds +Clock Halt Flag | $00-59$ |
| 1 | Minutes | $00-59$ |
| 2 | Hours/AM-PM/12-24 Mode | $00-23$ or |
| 3 |  | $01-12$ |
|  | Date | $01-28,29$, |
| 4 | Month | 30,31 |
| 5 | Day | $01-12$ |
| 6 | Year | $01-07$ |

Data contained in the Clock/Calendar registers is in binary coded decimal format (BDC).

## CLOCK HALT FLAG

Bit 7 of the Seconds Register is defined as the Clock Halt Flag. Bit $7=$ logical 1 inhibits the 1 Hz input to the Clock/Calendar. Bit 7 is set to logical 1 on power-up to prevent counting, and it may be set high or low by writing to the seconds register under normal operation of the device.

## AM-PM/12-24 MODE

Bit 7 of the Hours Register is defined as the 12 or 24 hour mode select bit. When high, the 12 hour mode is selected. In the 12 -hour mode, bit 5 is the AM/PM bit with logic high being PM. In the 24 -hour mode, bit 5 is the second 10-hour bit (20-23 hours).

## TEST MODE BITS

Bit 7 of the Date Register and Bit 7 of the Day Register are Test Mode Bits utilized in testing the MK3835N. These bits should be logic 0 for normal operation.

## CONTROL REGISTER

The Control Register specifies the crystal mode/frequency to be used, the system clock output frequency, and the WRITE PROTECT Mode for data protection. The Control Register is located at address 7 in the Clock/Calendar/Control address space.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W P$ | $C 1$ | $C 0$ | $X 4$ | $X 3$ | $X 2$ | $X 1$ | $X 0$ |

## CRYSTAL DIVIDER MODE

X4 and X3 specify the Crystal frequency divider mode selected.

| X4 | X3 | Xtal Mode | Primary Frequencies |
| :--- | :--- | :--- | :--- |
| 0 | 0 | Binary | $2^{22,} 2^{21}, 2^{20} \mathrm{~Hz}$ |
| 0 | 1 | Microprocessor | $8,5,4,2.5,2,1.25,1 \mathrm{MHz}$ |
| 1 | 0 | Baud Rate | $7.3728,3.6864,1.8432 \mathrm{MHz}$ |
| 1 | 1 | Color Burst | 3.5795 MHz |

## CRYSTAL DIVIDER PRESCALER

$\mathrm{X} 2, \mathrm{X} 1$, and $\mathrm{X0}$ specify a particular prescaler divider selection necessary to generate a 1 Hz frequency for the Clock/Calendar. Refer to Table 2 for complete definition.

## SYSTEM CLOCK OUTPUT

C 1 and C 0 designate the system clock output frequency selected. The options are $X, X / 2, X / 4$, and -2 kHz . When in the Binary Mode and $\mathrm{C} 1, \mathrm{C} 0=$ ' 1 ', the output frequency is 2048 Hz . In any other mode the output frequency is -2048 Hz . Refer to Table 3 for complete definition.

## WRITE PROTECT

Bit 7 of the Control Register is the WRITE PROTECT

Flag. Bit 7 is set to logical 1 on power-up, and it may be set high or low by writing to the Control Register. When high, the WRITE PROTECT Flag prevents a write operation to any internal register, including the other bits of the Control Register. Further, logic is included such that the WRITE PROTECT bit may be reset to a logic 0 by a Write operation without altering the other bits of the Control Register.

## MK3831 CONTROL REGISTER

The MK3831 operates with the control register bits 0-6 hardwired as shown. This results in the operating frequency being fixed at 4.194304 MHz .

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $W P$ | 0 | 1 | 0 | 0 | 0 | 1 | 0 |

## CLOCK/CALENDAR/CONTROL BURST MODE

Address 31 Decimal of the Clock/Calendar/Control Ad-
dress space specifies Burst Mode operation. In this mode, the 7 Clock/Calendar Registers and the Control Register may be consecutively read or written. Addresses above address 7 (Control Register) are non-existent; only addresses 0-7 are accessible.

## RAM

The static RAM is contained in 24 writeable/readable registers, addressed consecutively in the RAM address space beginning at location 0 .

## RAM BURST MODE

Address 31 Decimal of the RAM address space specifies Burst Mode operation. In this mode, the 24 RAM registers may be consecutively read or written. Addresses above the maximum RAM address location are nonexistent and are not accessible.

## REGISTER SUMMARY

A Register, Data Format summary is shown in Figure 4.


Figure 4. Microcomputer Clock/RAM Address/Command Register, Data Format Summary

## CRYSTAL SELECTION

The wide frequency range of crystals that can be chosen for the Clock/RAM offers the user a large degree of flexibility. To aid in the selection of a suitable crystal, the following suggestions should be considered by the user. First, the MK3835 offers an output pin that will provide a system clock signal at either the crystal frequency, $1 / 2$ the crystal frequency, or $1 / 4$ the crystal frequency. A system that requires a 4 MHz clock initially may operate with an 8 MHz clock in the future. By applying an 8 MHz crystal to the Clock/RAM, a software change
could provide the faster clock. Second, it is well known that, for a CMOS part, power dissipation will increase in direct proportion with frequency. Using a 1 MHz crystal and programming the CKO pin for 2048 Hz will cause the MK3835 to draw a minimum of power. (See Figures 9 and 10). The crystal connection is shown in Figure 5. If a generated clock signal is to be used as a time base, the connection is to Pin 2 (CKI) with Pin 3 left floating.

| Frequency Range | Specification |
| :--- | :--- |
| $1 \mathrm{MHz}-8.4 \mathrm{MHz}$ | Parallel resonance |
|  | Fundamental mode |
|  | $\mathrm{C}_{\mathrm{L}}=20$ pf to 40 pf |
|  | AT cut |

Figure 6. Summary of Crystal Specifications

If it is desirable to "tune" the oscillator to a precise frequency,
oscillator to a precise frequency,
$\mathrm{C}_{2}$ may be a variable capacitor.
$\mathrm{C}_{2}$ should be in the range of
$C_{1} \leq C_{2} \leq 2 C$.

For $C_{L}=20 \mathrm{pf}$ $\mathrm{C}_{1}$ is typically 30 pf .


Figure 5. Crystal Connection


Figure 7. Input Timing Diagram

Table 2

| Crystal Frequency Divider Mode | X4 | X3 | X2 | X1 | X0 | ${ }^{\text {f }}$ XTAL $(M H z)$ Crystal Frequency | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Binary Mode | 0 | 0 | 0 | 0 | 0 | 8.388608 | Power on condition |
|  | 0 | 0 | 0 | 0 | 1 | 8.388608 |  |
|  | 0 | 0 | 0 | 1 | 0 | 4.194304 | Hardwired in the MK3831 |
|  | 0 | 0 | 0 | 1 | 1 | 4.194304 |  |
|  | 0 | 0 | 1 | 0 | 0 | 2.097152 |  |
|  | 0 | 0 | 1 | 0 | 1 | 2.097152 |  |
|  | 0 | 0 | 1 | 1 | 0 | 1.048576 |  |
|  | 0 | 0 | 1 | 1 | 1 | 0.032768 | External Clock on Cl only |
| Microprocessor Mode | 0 | 1 | 0 | 0 | 0 | 8.000000 |  |
|  | 0 | 1 | 0 | 0 | 1 | 5.000000 |  |
|  | 0 | 1 | 0 | 1 | 0 | 4.000000 |  |
|  | 0 | 1 | 0 | 1 | 1 | 2.500000 |  |
|  | 0 | 1 | 1 | 0 | 0 | 2.000000 |  |
|  | 0 | 1 | 1 | 0 | 1 | 1.250000 |  |
|  | 0 | 1 | 1 | 1 | 0 | 1.000000 |  |
|  | 0 | 1 | 1 | 1 | 1 | 0.031250 | External Clock on Cl only |
| Baud Rate Mode | 1 | 0 | 0 | 0 | 0 | 7.372800 |  |
|  | 1 | 0 | 0 | 0 | 1 | 7.372800 |  |
|  | 1 | 0 | 0 | 1 | 0 | 3.686400 |  |
|  | 1 | 0 | 0 | 1 | 1 | 3.686400 |  |
|  | 1 | 0 | 1 | 0 | 0 | 1.843200 |  |
|  | 1 | 0 | 1 | 0 | 1 | 1.843200 |  |
|  | 1 | 0 | 1 | 1 | 0 | 0.921600 |  |
|  | 1 | 0 | 1 | 1 | 1 | 0.028800 | External Clock on Cl only |
| Color Burst Mode | 1 | 1 | 0 | 0 | 0 | 7.159040 |  |
|  | 1 | 1 | 0 | 0 | 1 | 7.159040 |  |
|  | 1 | 1 | 0 | 1 | 0 | 3.579520 |  |
|  | 1 | 1 | 0 | 1 | 1 | 3.579520 |  |
|  | 1 | 1 | 1 | 0 | 0 | 1.789760 |  |
|  | 1 | 1 | 1 | 0 | 1 | 1.789760 |  |
|  | 1 | 1 | 1 | $1$ | 0 | 0.894880 0.027965 |  |
|  |  |  |  |  |  | 0.027965 | External Clock on CI only |

## CLOCK OUTPUT SELECTION

Table 3

| C1 | C0 | CKO <br> Output Frequency | Comments |
| :--- | :--- | :--- | :--- |
| 0 | 0 | $f_{X T A L}$ |  |
| 0 | 1 | $f_{X T A L} \div 2$ | Power on condition. Hardwired in the MK3831 with CKO <br> 1 |
| 1 | 1 | disabled. |  |
|  |  | $=2048 \mathrm{~Hz}$ | Frequency applies for use with Binary Mode only. Other <br> operating modes produce a CKO signal approximately <br> equal to 2000 Hz. |

## ELECTRICAL SPECIFICATIONS MK3835N/MK3831N

ABSOLUTE MAXIMUM RATINGS*
Voltage on $\mathrm{V}_{\mathrm{CC}}$ relative to GND ........................................................... 0.5 V to +7.5 V
Voltage on any pin......................................................................... 0.5 V to $+\mathrm{V}_{\mathrm{cc}}+.5$
Temperature under bias ....................................................................... $-50^{\circ} \mathrm{C}+95^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
"Stresses greater than 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 operational sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability.

DC OPERATING CONDITIONS
MK3835N-00/MK3831N-00 $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}$, MK3835N-10/MK3831N-10 $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | MAX | UNIT | NOTES |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage | 4.5 | 5.5 | V | 1 |
| $\mathrm{~V}_{\text {SB1 }}$ | Supply Voltage for Standby 1 | 3.5 |  | V | 1,7 |
| $\mathrm{~V}_{\text {SB2 }}$ | Supply Voltage for Standby 2 | 2.5 |  | V | $1,7,10$ |

DC ELECTRICAL CHARACTERISTICS
$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, MK3835N-00/MK3831N-00 $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ}$, MK3835N-10/MK3831N-10-40 ${ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MIN | MAX | UNIT | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{Cl} 1}$ | Power Supply Current |  | 6.0 | mA | 2 |
| $\mathrm{I}_{\mathrm{Cl} 2}$ | Power Supply Current |  | 10.0 | mA | 3 |
| $\mathrm{I}_{\mathrm{CC} 3}$ | Power Supply Current |  | 2.0 | mA | 4 |
| $\mathrm{I}_{\mathrm{CC} 4}$ | Power Supply Current |  | 600 | $\mu \mathrm{A}$ | 5 |
| $\mathrm{I}_{\text {CC5 }}$ | Power Supply Current - MK3831 |  | 1.5 | mA | 9 |
| ${ }^{\text {cc6 }}$ | Power Supply Current for Standby 1 |  | 200 | $\mu \mathrm{A}$ | 5 |
| ${ }^{\text {CC7 }}$ | Power Supply Current for Standby 2 |  | 120 | $\mu \mathrm{A}$ | 5 |
| $\mathrm{l}_{\mathrm{LI}}$ | Input Leakage Current, SCLK and CE | -1.0 | 1.0 | $\mu \mathrm{A}$ | 6 |
| Lo | Output Leakage Current, I/O Pin | -10.0 | 10.0 | $\mu \mathrm{A}$ | 6 |
| $\mathrm{V}_{\mathrm{IH}}$ | Logic "1" Voltage, All Inputs except X1. | 2.2 |  | V | 1 |
| $\mathrm{V}_{\mathrm{IL}}$ | Logic " 0 " Voltage, All Inputs |  | 0.8 | V | 1 |
| $\mathrm{V}_{1 \mathrm{HX} 1}$ | Logic "1" Voltage, $\mathrm{X}_{1}$ Input | 3.9 |  |  | 8 |
| $\mathrm{V}_{1 / \mathrm{OH}}$ | Output Logic "1" Voltage, I/O Pin | 2.4 |  | V | $1\left(\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}\right)$ |
| $\mathrm{V}_{\text {IOL }}$ | Output Logic " 0 " Voltage, I/O pin |  | 0.4 | V | $1\left(\mathrm{l}_{\mathrm{OL}}=3.8 \mathrm{~mA}\right)$ |
| $\mathrm{V}_{\text {CKH }}$ | Output Logic " 1 " Voltage, CKO pin | 2.4 |  | V | $1\left(\mathrm{l}_{\mathrm{OH}}=1.0 \mathrm{~mA}\right)$ |
| $\mathrm{V}_{\text {CKL }}$ | Output Logic "0" Voltage, CKO pin |  | 0.4 | V | $1\left(\mathrm{loL}^{\prime}=5.0 \mathrm{~mA}\right)$ |

NOTES:

1. All voltages referenced to GND.
2. Crystal/Clock Input frequency $=8.4 \mathrm{MHz}, \mathrm{f} \mathrm{CKO}=4.2 \mathrm{MHz} \cdot$ with 30 pf load.
3. Crystal/Clock Input frequency $=8.4 \mathrm{MHz}$, f $\mathrm{CKO}=8.4 \mathrm{MHz}$ with 100 pf load.
4. Crystal/Clock input frequency $=8.4 \mathrm{MHz}, \mathrm{f} \mathrm{CKO}=2084 \mathrm{~Hz}$ with 30 pf load.
5. Crystal/Clock Input frequency $=1 \mathrm{MHz}, \mathrm{f}$ CKO $=2048 \mathrm{~Hz}$ with a 30 pf load 6. Measured with $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 0 \leq \mathrm{V}_{1} \leq 5.0 \mathrm{~V}$, outputs in high impedance state 7. Applied to pin 8 to retain data during a power fault.
6. $\mathrm{V}_{\mathrm{IHX}}{ }_{1}$ spec. applies only to the external clock input configuration 9. MK3831 with Crystal/Clock Input frequency $=4.194 \mathrm{MHz}$ 10. $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 50^{\circ} \mathrm{C}$.

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | TYPICAL | MAX | UNIT | TEST <br> CONDITION |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1}$ | Capacitance on Input Pin |  | 10 | pF | Note 1 |
| $\mathrm{C}_{1 / \mathrm{O}}$ | Capacitance on $1 / \mathrm{O}$ pin |  | 12 | pF | Note 1 |
| $\mathrm{C}_{\mathrm{X}}$ | Capacitance on X1/C1 and X2 | 2.5 | 5 | pf | Note 1 |

NOTE:
Measured as $C=\frac{1 \Delta t_{1}}{\Delta V}$ with $V=3 V$, and unmeasured pins grounded

AC ELECTRICAL CHARACTERISTICS
$V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{MK} 3835 \mathrm{~N}-00 / \mathrm{MK} 3831 \mathrm{~N}-000^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ}, \mathrm{MK} 3835 \mathrm{~N}-10 / \mathrm{MK} 3831 \mathrm{~N}-10-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$

| NUM | SYMBOL | PARAMETER | MIN | MAX | UNIT | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $f_{X}$ | Crystal frequency | 800 | 8400 | kHz |  |
| 2 | $t_{\text {css }}$ | $\overline{\mathrm{CE}}$ to SCLK! set up time | 1.0 |  | $\mu \mathrm{S}$ | 1,6 |
| 3 | $\mathrm{t}_{\text {scs }}$ | SCLK low set up time to $\overline{\mathrm{CE}}$ ! | 40 |  | ns | 1, 6 |
| 4 | $\mathrm{t}_{\mathrm{SCH}}$ | SCLK 1 to $\overline{\mathrm{CE}} \uparrow$ hold time | 1.0 |  | $\mu \mathrm{S}$ | 1, 5, 6 |
| 5 | $\mathrm{t}_{\text {DSS }}$ | Input Data to SCLK† set up time | 400 |  | ns | 1, 6 |
| 6 | $\mathrm{t}_{\text {SDH }}$ | Input Data from SCLKI hold time | 200 |  | ns | 1,6 |
| 7 | ${ }^{\text {t }}$ SDD | Output Data from SCLK! delay time |  | 600 | ns | 1, 2, 3, 6 |
| 8 | $t_{\text {cDZ }}$ | $\overline{\mathrm{CE}} 1$ to I/O high impedance |  | 500 | ns | 1, 2, 3, 6 |
| 9 | ${ }^{\text {tswL }}$ | SCLK low time | 1.95 | $\infty$ | $\mu \mathrm{S}$ |  |
| 10 | ${ }^{\text {t SWH }}$ | SCLK high time | 1.95 | $\infty$ | $\mu \mathrm{S}$ |  |
| 11 | ${ }^{\text {f SCLK }}$ | SCLK frequency | DC | 250 | kHz |  |
| 12 | $t_{\text {SR }}, t_{\text {SF }}$ | SCLK Rise and Fall Time |  | 1 | $\mu \mathrm{S}$ | 4, 6 |
| 13 | $\mathrm{t}_{\mathrm{CR}}, \mathrm{t}_{\mathrm{CF}}$ | CKO Rise and Fall Time |  | 50 | ns | 4, 6 |
| 14 | ${ }^{\text {t }}$ CWH | $\overline{\mathrm{CE}}$ high time | 2.0 |  | $\mu \mathrm{S}$ |  |

## NOTES:

1. Measured at $\mathrm{V}_{\mathrm{IH}}=2.0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ and 50 ns rise and fall times on inputs.
2. Measured at $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$.
3. Load Capacitance $=100 \mathrm{pF}$
4. $\mathrm{t}_{\mathrm{r}}$ and $\mathrm{t}_{\mathrm{f}}$ measured from 0.8 V to 2.2 V .
5. ${ }^{\mathrm{S}}{ }^{\text {SCH }}$ must follow the last rising edge of $\mathrm{S}_{\text {CLK }}$ during a write cycle in order to allow time to complete a write to the internal register.
6. All voltages referenced to ground.


Figure 8. Output Timing Diagram


* This curve applies to the operating case where clock output selection is programmed for $\mathrm{C} 1=1, \mathrm{CO}=1$, and is included for comparison purposes to other operating modes.


[^49]
## ORDERING INFORMATION

| Device Order Number | $\mathbf{V}_{\text {cC }}$ | Temp | Package |
| :---: | :---: | :---: | :---: |
| MK3835N-00 | $5 \mathrm{~V} \pm 10 \%$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | Plastic |
| MK3835N-10 | $5 \mathrm{~V} \pm 10 \%$ | $-40^{\circ} \mathrm{C}-85^{\circ} \mathrm{C}$ | Plastic |
| MK3831N-00 | $5 \mathrm{~V}^{\circ} \pm 10 \%$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | Plastic |
| MK3831N-10 | $5 \mathrm{~V} \pm 10 \%$ | $-40^{\circ} \mathrm{C}-85^{\circ} \mathrm{C}$ | Plastic |

MK3835 N-00


CHAPTER 6 - CRT CONTROLLER

## CRT CONTROLLERS SELECTION GUIDE

| Part number | Description | Technology | Alt source | CLK freq. (MHz) | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EF9345 | Single chip alphanumeric and semigraphic display processor - 25/21 rows of 40 or 80 char. - Multipage memory - Color and B/W | HMOS |  | 40 | 6-3 |
| EF9367 | Graphic display coprocessor - Up to $512 \times 1024$ interlaced - $50 / 60 \mathrm{~Hz}$ color and B/W | HMOS |  | 40 | 6-49 |
| EF9369 | "Palette" circuit for selection of 16 colors among 4096 - Compatible with all display cir | HMOS |  | 28 | 6-81 |
| TS68483 | High performance display coprocessor | HMOS |  | 68 | 6-97 |
| TS68494 | Palette and serial port controller | HMOS 2 |  | 48 | 6-143 |

The EF9345, new advanced color CRT controller, in conjunction with an additional standard memory package allows full implementation of the complete display control unit of a color or monochrome low-cost terminal, thus significantly reducing IC cost and PCB space.

- Single chip low-cost color CRT controller
- TV standard compatible ( 50 Hz or 60 Hz )
- 2 screen formats :

25 (or 21) rows of 40 characters
25 (or 21 ) rows of 80 characters

- On-chip 128 alphanumeric and 128 semi-graphic character generator three standard options available for alphanumeric sets.
- Easy extension of user defined alphanumeric or semi-graphic sets (>1K characters).
- 40 characters/row attributes :

Foreground and background color, double height, double width, blinking, reverse, underlining, conceal, insert, accentuation of lower case characters.

- 80 characters/row attributes :

Underlining, blinking, reverse, color select.

- Programmable roll-up, roll down, and cursor display
- On-chip R, G, B, I video shift registers
- Easy synchronization with external video source : on-chip phase comparator.
- Address/data multiplexed bus directly compatible with standard microcomputers such as $6801,6301,8048,8051$.
- Addressing space : $16 \mathrm{~K} \times 8$ of general purpose private memory.
- Easy use of any low cost memory components : ROM, SRAM, DRAM
- Upward compatible with EF9340/41 chip set.



## HMOS2

SINGLE CHIP SEMI-GRAPHIC DISPLAY PROCESSOR




## MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}{ }^{*}$ | -0.3 to 7.0 | V |
| Input voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | -0.3 to 7.0 | V |
| Operating temperature range | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature range | $\mathrm{T}_{\text {stg }}$ | -55 to 150 | ${ }^{\circ} \mathrm{C}$ |
| Max power dissipation | $\mathrm{P}_{\mathrm{Dm}}$ | 0.75 | W |

Stresses above those hereby listed may cause permanent damage to the device. The ratings are stress ones only and functional operation of the device at these or any conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard MOS circuits handling procedure should be used to avoid possible damage to the device.
*With respect to $\mathrm{V}_{\mathrm{SS}}$

## ELECTRICAL OPERATING CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5 | 5.25 | V |
| Input low voltage | $V_{\text {IL }}$ | -0.3 | - | 0.8 | V |
| Input high voltage CLK other inputs | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{gathered} 2.2 \\ 2 \end{gathered}$ | - | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{CC}} \end{aligned}$ | $V$ |
| Input leakage current | $I_{\text {in }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output high voltage ( ${ }_{\text {load }}=-500 \mu \mathrm{~A}$ ) | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V |
| $\begin{array}{rlrl}\text { Output low voltage } & \begin{array}{l}\text { load } \\ \text { log }\end{array} \\ & l_{\text {load }}=1 \mathrm{~mA} ; & \mathrm{AD}(0: 7), \mathrm{ADM}(0: 7), \mathrm{AM}(8: 13) \\ \text { other outputs }\end{array}$ | VOL | 0.4 | - | - | V |
| Power dissipation | $P_{\text {D }}$ | - | 250 | - | mW |
| Input capacitance | $\mathrm{C}_{\text {in }}$ | - | - | 15 | pF |
| Three state (off state) input current | ITSI | - | - | 10 | $\mu \mathrm{A}$ |

## MEMORY INTERFACE

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$.
Clock: $\mathrm{f}_{\text {in }}=12 \mathrm{MHz}$; duty cycle 40 to $60 \% ; \mathrm{tr}_{\mathrm{r}}, \mathrm{tf}_{\mathrm{f}}<5 \mathrm{~ns}$
Reference levels: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$.

| Ident. number | Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Memory cycle time | telel | - | 500 | - | ns |
| 2 | Output delay time from CLK rising edge ( $\overline{A S M}, \overline{O E}, \overline{W E}$ ) | ${ }^{t} \mathrm{D}$ | - | - | 60 | ns |
| 3 | $\overline{\text { ASM }}$ high pulse width | tEHEL | 120 | - | - | ns |
| 4 | Memory access time from $\overline{\text { ASM }}$ low | teldV | - | - | 290 | ns |
| 5 | Output delay time from CLK rising edge ( ADM (0:7), AM(8:13) ) | ${ }^{t} \mathrm{DA}$ | - | - | 80 | ns |
| 6 | Address setup time to $\overline{\text { ASM }}$ | ${ }^{\text {t }}$ AVEL | 30 | - | - | ns |
| 7 | Address hold time from $\overline{\text { ASM }}$ | ${ }^{\text {t ELAX }}$ | 55 | - | - | ns |
| 8 | Address off time | ${ }^{\text {t CLAZ }}$ | - | - | 80 | ns |
| 9 | Memory hold time | ${ }^{\text {tGHDX }}$ | 10 | - | - | ns |
| 10 | Data off time from $\overline{\mathrm{OE}}$ | ${ }^{\text {toz }}$ | - | - | 60 | ns |
| 11 | Memory $\overline{O E}$ access time | ${ }^{\text {t GLDV }}$ | - | - | 150 | ns |
| 12 | Data setup time (write cycle) | ${ }^{\text {t QVWL }}$ | 30 | - | - | ns |
| 13 | Data hold time (write cycle) | ${ }^{\text {t WHOX }}$ | 30 | - | - | ns |
| 14 | $\overline{W E}$ pulse width | tWLWH | 110 | - | - | ns |



|  | ADM(0:7), AM(8:13) <br> AD(0:7) | Other <br> outputs |
| :---: | :---: | :---: |
| $C$ | 100 pF | 50 pF |
| $R_{L}$ | $1 \mathrm{~K} \Omega$ | $3.3 \mathrm{~K} \Omega$ |
| $R$ | $4.7 \mathrm{~K} \Omega$ | $4.7 \mathrm{~K} \Omega$ |

MEMORY INTERFACE TIMING DIAGRAM


## MICROPROCESSOR INTERFACE

EF9345 is MOTEL compatible. It automatically selects the processor type by using AS input to latch to state of the DS input.
No external logic is needed to adapt bus control signals from most of the common multiplexed bus microprocessors.

| EF9345 | 6801/6805CT | INTEL Family |
| :---: | :---: | :---: |
| AS | timing 1 | timing 2 |
|  | AS | ALE |
|  | $\mathrm{DS}, \mathrm{E}, \phi 2$ | $\overline{\mathrm{RD}}$ |
| $\mathrm{R} / \overline{\mathrm{W}}$ | $\mathrm{R} / \overline{\mathrm{W}}$ | $\overline{\mathrm{WR}}$ |

MICROPROCESSOR INTERFACE TIMING AD(0:7), AS, DS, R/ $\bar{W}, \overline{C S}$
$V_{C C}=5.0 \pm 5 \%, T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ on $\mathrm{AD}(0: 7)$
Reference levels: $\mathrm{V}_{I L}=0.8 \mathrm{~V}$ and $\mathrm{V}_{1 H}=2 \mathrm{~V}$ on all inputs; $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ on all outputs.

| Ident. number | Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Cycle time | ${ }^{t} \mathrm{CYC}$ | 400 | - | - | ns |
| 2 | DS low to AS high (timing 1) <br> DS high or R/W high to AS high (timing 2) | ${ }^{\text {t }}$ ASD | 30 | - | - | ns |
| 3 | AS low to DS high (timing 1) <br> AS low to DS low or R/W Iow (timing 2) | ${ }^{\text {t }}$ ASED | 30 | - | - | ns |
| 4 | Write pulse width | tPWEH | 200 | - | - | ns |
| 5 | AS pulse width | ${ }^{\text {t PWWASH }}$ | 100 | - | - | ns |
| 6 | $R / \bar{W}$ to DS setup time (timing 1) | tRWS | 100 | - | - | ns |
| 7 | $R / \bar{W}$ to DS hold time (timing 1) | ${ }^{\text {t }}$ RWH | 10 | - | - | ns |
| 8 | Address and $\overline{\mathrm{CS}}$ setup time | ${ }^{\text {t }}$ ASL | 20 | - | - | ns |
| 9 | Address and $\overline{\mathrm{CS}}$ hold time | ${ }^{\text {ta }}$ AL | 20 | - | - | ns |
| 10 | Data setup time (write cycle) | ${ }^{\text {t }}$ DSW | 100 | - | - | ns |
| 11 | Data hold time (write cycle) | ${ }^{\text {t DHW }}$ | 10 | - | - | ns |
| 12 | Data access time from DS (read cycle) | tDDR | - | - | 150 | ns |
| 13 | DS inactive to high impedance state time (read cycle) | ${ }^{\text {t }}$ DHR | 10 | - | 80 | ns |
| 14 | Address to data valid access time | ${ }^{t} A C C$ | - | - | 300 | ns |

MICROPROCESSOR INTERFACE TIMING DIAGRAM I ( 6801 / 6805CT)


MICROPROCESSOR INTERFACE TIMING DIAGRAM 2 (INTEL type)


VIDEO INTERFACE R, G, B, I, HP, HVS / HS, PC / VS
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$, CLK duty cycle $=50 \%, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$
Reference levels: $\mathrm{V}_{1 \mathrm{~L}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{1 \mathrm{H}}=2.2 \mathrm{~V}$ on CLK input. $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ on all outputs.

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Set up time R, G, B, I to HP | ${ }^{\text {tSU }}$ | 10 | - | - | ns |
| Hold time R, G, B, I from HP | $\mathrm{t}_{\mathrm{HO}}$ | 50 | - | - | ns |
| Output delay from CLK edge | $\mathrm{t}^{\mathrm{D}}$ | - | - | 60 | ns |



Reference level $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\text {IH }}=2.0 \mathrm{~V}$

| Characteristic | Symbol | Min | Unit |
| :--- | :---: | :---: | :---: |
| CLK high pulse width | tPWCH | 30 | ns |
| CLK low pulse width | tPWCL | 30 | ns |

VERTICAL AND HORIZONTAL SYNCHRONIZATION OUTPUTS (CLK $=12 \mathrm{MHz}$ )


## VERTICAL SYNCHRO



## EF9345 PIN DESCRIPTION

All the input/output pins are TTL compatible.

MICROPROCESSOR INTERFACE

| name | $\begin{aligned} & \text { PIN } \\ & \text { TYPE } \end{aligned}$ | $N^{\circ}$ | function | description |
| :---: | :---: | :---: | :---: | :---: |
| AD(0 : 7 ) | I/O | $\begin{aligned} & 17-19 \\ & 21-25 \end{aligned}$ | Multiplexed Address/Data bus | These 8 bidirectional pins provide communication with the microprocessor system bus. |
| AS | 1 | 14 | Address Strobe | The falling edge of this control signal latches the address on the AD (0:7) lines, the state of the Data Strobe (DS) and Chip Select ( $\overline{\mathrm{CS}}$ ) into the chip. |
| DS | 1 | 15 | Data Strobe | When this input is strobed high by AS, the output buffers are selected while DS is low for a read cycle ( $R / \bar{W}=1$ ). <br> In write cycle, data present on $\operatorname{AD}(0: 7)$ lines are strobed by $R / \bar{W}$ low (See Timing Diagram 2). <br> When this input is strobed low by AS, R/W gives the direction of data transfer on $A D(0: 7)$ bus. DS high strobes the data to be written during a write cycle ( $\mathrm{R} / \overline{\mathrm{W}}=0$ ) or enables the output buffers during a read cycle ( $\mathrm{R} / \overline{\mathrm{W}}=1$ ). (See Timing Diagram 1). |
| $\mathrm{R} / \overline{\mathrm{W}}$ | 1 | 16 | Read / Write | This input determines whether the internal registers get written or read. A write is active low (" 0 "). |
| $\overline{\text { CS }}$ | 1 | 26 | Chip Select | The EF9345 is selected when this input is strobed low by AS. |

MEMORY INTERFACE

| ADM(0:7) | I/O | $40-33$ | Multiplexed <br> Address/Data <br> bus | Lower 8 bits of memory address appear on the bus when $\overline{\text { ASM }}$ is <br> high. It then becomes the data bus when $\overline{\text { ASM }}$ is low. |
| :---: | :---: | :---: | :---: | :--- |
| AM(8:13) | 0 | $32-27$ | Memory <br> Address bus | These 6 pins provide the high order bits of the memory address. |
| $\overline{\mathrm{OE}}$ | 0 | 2 | Output Enable | When low, this output selects the memory data output buffers. |
| $\overline{\mathrm{WE}}$ | 0 | 3 | Write Enable | This output determines whether the memory gets read or written. <br> A write is active low (" $\left.O^{\prime \prime}\right)$. |
| $\overline{\mathrm{ASM}}$ | 0 | 4 | Memory <br> Address Strobe | This signal cycles continuously. Address can be latched on its falling <br> edge. |

VIDEO INTERFACE

| NAME | $\begin{aligned} & \text { PIN } \\ & \text { TYPE } \end{aligned}$ | $N^{\circ}$ | FUNCTION | description |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{R} \\ & \mathrm{G} \\ & \mathrm{~B} \end{aligned}$ | $\begin{aligned} & \mathrm{O} \\ & \mathrm{O} \\ & \mathrm{O} \end{aligned}$ | $\begin{aligned} & 7 \\ & 8 \\ & 9 \end{aligned}$ | Red Green Blue | These outputs deliver the video signal. They are low during the vertical and horizontal blanking intervals. |
| 1 | 0 | 10 | Insert | This active high output allows to insert $R: G: B$ in an external video signal for captioning purposes, for example. It can also be used as a general purpose attribute or color. |
| HVS/HS | 0 | 5 | Sync. Out | This output delivers either the composite synchro (bit TGS $4=1$ ) or the horizontal synchro signal (bit TGS $4=0$ ). |
| PC/VS | 0 | 6 | Phase Comparator/ Vertical Sync | When $\mathrm{TGS}_{4}=1$, this signal is the phase comparator output. When $T G S_{4}=0$, this output delivers the vertical synchro signal. |
| SYNCIN | 1 | 13 | Synchro In | This input allows vertical and/or horizontal synchronizing the EF9345 on an external signal. It must be grounded if not used. |
| HP | 0 | 11 | Video Clock | This output delivers a 4 MHz clock phased with the R, G, B, I signals. |

OTHER PINS

| CLK | I | 12 | Clock Input | External TTL clock input. (Nominal value : 12 MHz , duty cycle : <br> $50 \%)$. |
| :--- | :---: | :---: | :--- | :--- |
| $\mathrm{V}_{\mathrm{SS}}$ | S | 1 | Power Supply | Ground. |
| $\mathrm{V}_{\mathrm{CC}}$ | S | 20 | Power Supply | +5 V. |

## GENERAL OPERATION

The EF9345 is a low cost, semigraphic, CRT controller.
It is optimized for use with a low cost, monochrome or color TV type CRT ( $64 \mu$ s per line, 50 or 60 Hz refresh frequency).
The EF9345 displays up to 25 rows of 40 characters or 25 rows of 80 characters.
The on-chip character generator provides a 128 standard, $5 \times 7$, character set and standard semigraphic sets.
More user definable ( $8 \times 10$ ) alphanumeric or semigraphic sets rnay be mapped in the $16 \mathrm{~K} \times 8$ private memory addressing space.
These user definable sets are available only in 40 characters per row format.

## MICROPROCESSOR INTERFACE

The EF9345 provides an 8-bit, address/data multiplexed, microprocessor interface.
It is directly compatible with popular $(6801,6805 \mathrm{CT}$, 8048, 8051, 8035...) microprocessors.

## REGISTERS

The microprocessor directly accesses 8 registers :

- RO: Command/status register
- R1, R2, R3: Data registers
- R4, R5 $\}$ : Each of these register pairs points into the R6, R7 $\}$ private memory.
Through these registers, the microprocessor indirectly accesses the private memory and 5 more registers :
- ROR, DOR : Base address of displayed page memory and of used external character generators.
- PAT, MAT, TGS : Used to select the page attributes and format, and to program the timing generator option.


## PRIVATE MEMORY

The user may partition the $16 \mathrm{~K} \times 8$ private memory addressing space between:

- pages of character codes ( $2 \mathrm{~K} \times 8$ or $3 \mathrm{~K} \times 8$ ),
- external character generators,
- general purpose user area.

Many types of memory components are suitable :

- ROM, DRAM or SRAM,
- $2 \mathrm{~K} \times 8,8 \mathrm{~K} \times 8,16 \mathrm{~K} \times 4$ organizations,
- Modest 500 ns cycle time and 250 ns access time is required.


## 40 CHARACTERS PER ROW : CHARACTER CODE FORMATS AND ATTRIBUTES

Once the 40 characters per row format has been selected, one character code format out of three must be chosen :

- 24-bit fixed format:

All the attributes are provided in parallel.

- 8/24-bit compressed format :

All the attributes are latched.

- 16-bit fixed format :

Some parallel attributes, others are latched.
The 16 -bit fixed format is compatible with EF9340/41 CRT controller.

Character attributes provided:

- Background and foreground color (3 bits each),
- Double height, double width,
- Blinking,
- Reverse,
- Underlining,
- Conceal,
- Insert,
- Accentuation of lower case characters
$-3 \times 100$ user definable character generator in memory
$-8 \times 100$ semi-graphic quadrichrome characters.


## 80 CHARACTERS PER ROW FORMAT : CHARACTER CODE FORMAT AND ATTRIBUTES

Two character code formats are provided :

- Long ( 12 bits) with 4 parallel attributes:
- Blinking,
- Underlining,
- Reverse,
- Color select.
- Short (8 bits) : no attributes.


## TIMING GENERATOR

The whole timing is derived from a 12 MHz main clock input.
The RGB outputs are shifted at 8 MHz for the 40 character/row format and at 12 MHz for the 80 character/row.

Besides, the user may select :

- 50 Hz or 60 Hz vertical sync. frequency,
- Interlaced or not,
- Separated or composite vertical and horizontal sync. outputs.
Furthermore, a composite sync. input allows, when it is required:
- An on-chip vertical,resynchronization,
- An on-chip crude horizontal resynchronization,
- An off-chip high performance horizontal resynchronization by use of a simple external VCXO controlled by the on-chip phase comparator.


## MEMORY ORGANIZATION

LOGICAL AND PHYSICAL ADDRESSING
The physical 16 -Kbyte addressing space is logically partitioned by EF9345 into 40 -byte buffers (Figure 1). More precisely, a logical address is given by an $\mathrm{X}, \mathrm{Y}, \mathrm{Z}$ triplet where :

- $X=(0$ to 39$)$ points to a byte inside a buffer,
- $Y=(0,1 ; 8$ to 31$)$ points to a buffer inside a 1 Kbyte block,
- $Z=(0$ to 15$)$ points to a block.

Obviously, $1 \mathrm{~K}=2^{10}=1024$ cannot be exactly divided by 40 . Consequently, any block holds 25 full buffers and a 24 -byte remainder. Provided that the physical memory is a multiple of 2 Kbytes, the remainders are paired in such a way as to make available :

- a full buffer $(Y=1)$ in each even block,
- a partial buffer ( $Y=1$; $X=32$ to 39 ) in each odd block.

FIGURE 1 - MEMORY ROW BUFFER


- Row buffers lay inside a district.
- At two or three successive block addresses (modulo 4).
- First block address is even.


## POINTERS

Each $\mathrm{X}, \mathrm{Y}$ and Z component of a logical address is binary encoded and packed in two 8-bit registers. Such a register pair is a pointer (Figure 2). EF9345 contains two pointers:

- R4, R5 : auxiliary pointer,
- R6, R7 : main pointer.

R5 and R7 have the same format. Each one holds an X component and the two LSB's of a $\mathbf{Z}$ component. This packing induces a partitioning of $\mathbf{Z}$ in 4 districts of 4 blocks each.

R5, R7 points to a block number in a district. R4 and R6 have a slightly different format : Each one holds a $Y$ component and the LSB of the district number. But R6 holds both district MSB.

Figure 3 gives the logical to physical address transcoding scheme performed on chip.

FIGURE 2 - POINTER AUTO INCREMENTATION


## DATA STRUCTURES IN MEMORY

A page is a data structure displayable on the screen up to 25 rows of characters. According to the character code format, each row on the screen is associated with 2 (or 3) 40-byte buffers. This set of 2 (or 3) buffers constitutes a row buffer (Figure 1). The buffers belonging to a row buffer must meet the following requirements :

- they have the same Y address,
- they have the same district number,
- they lie at 2 (or 3) successive (modulo 4) block addresses in their common district.

Consequently, a row buffer is defined by its first buffer address and its format.
A page is a set of successive row buffers :

- with the same format,
- with the same district number,
- with the same block address of first buffer. This block address must be even.
- lying at successive (modulo 24) Y addresses.

Consequently, a page shouid not cross a district boundary. General purpose memory area may be used but should respect the buffer or row buffer structure. See Figure 2 for pointer incrementation implied by these data structures.

## MEMORY TIME SHARING (See Figure 4)

The memory interface provides a 500 ns cycle time. That is to say a 2 Mbyte/s memory bandwidth. This bandwidth is shared between :

- reading a row buffer from memory to load the internal row buffer (up to 120 bytes once each row),
- reading user defined characters slices from memory (1 byte each $\mu$ s),
- indirect microprocessor read or write operation,
- refresh cycles to allow DRAM use, with no overhead.

A fixed allocation scheme implements the sharing.

## Notes on Figure 4.

1. Dummy cycles are read cycles at dummy addresses.
2. RFSH cycles are read cycles performed by an 8-bit auto-incrementing counter. Low order address byte ADM(0:7) cycles through its 256 states in less than 1 ms .
3. The microprocessor may indirectly access the memory once every $\mu \mathrm{s}$, except during the first and the last line of a row, when the internal buffer must be reloaded.
During these lines, no microprocessor access is provided for $104 \mu \mathrm{~s}$; this hold too when no user defined character slices are addressed.

FIGURE 4 - MEMORY CYCLE ALLOCATION



## SCREEN FORMAT AND ATTRIBUTES

The screen format and attributes are programmed through 5 indirectly accessible registers : ROR, TGS, PAT, MAT and DOR. IND command allows accessing these registers. TGS is also used to select the timing generator options (see Screen Format Table).

## ROW AND CHARACTER CODE FORMAT PAT7 ; TGS(6:7)

Two row formats and 5 character code formats are available but cannot be mixed in a given screen. DOR register interpretation is completely row format dependant and is discussed in the corresponding 40 char/row and 80 char/row section.

## SCREEN PARTITION - PAGE POINTER ROR (See top of the Screen Format Table)

The screen is partitionned into 3 areas :

- the margin,
- the service row,
- the bulk of remaining rows.
$\operatorname{MAT}(0: 3)$ declares the color of the margin and the value $i M$ of its insert attribute.
ROR register points to the page to be displayed and gives the 3 MSB's of the $Z$ address : $Z_{0}=0$ implicitly ; the page block address must be even. YOR gives the first row buffer to be displayed at the top of the bulk area. The next row buffers to be displayed are fetched sequentially by incrementing the Y address (modulo 24). This address never gets out of the origin block. Incrementation of YOR by the microprocessor yields a roll up.


## SERVICE ROW : TGS5-PAT0

The service row is displayed for 10 TV lines on top of the screen and does not roll. Following TGS5, it is fetched from the origin block at either $Y=0$ or $Y=1$. The $Y=1$ is a partial row buffer. It can be used only with variable 40 char./row and an 8 byte attribute file. The service row may be disabled by $\mathrm{PAT}_{0}=0$; it is then displayed as a margin extension.

## BULK : $\mathrm{TGS}_{0}$; PAT(1:2) ; MAT7

It is displayed after the service row for 200 or 240 TV lines according to $\mathrm{TGS}_{0}$. Each row buffer is usually displayed for 10 TV lines. However, $\mathrm{MAT}_{7}=1$ doubles this figure. Then every character appears in double height (double height characters are quadrupled).

PAT $_{1}=0$ and/or PAT $2=0$ disables respectively the upper 120 lines and/or the lower $80 / 120$ lines of the bulk.
When disabled, the corresponding TV lines are displayed as a margin extension.

## CURSOR MAT (4:6)

To be displayed with the cursor attributes, a character must be pointed by the main pointer (R6, R7) and MAT 6 must be set. The cursor attributes are given by $\operatorname{MAT}(4: 5)$ :

- Complementation :
the $R, G$ and $B$ of each pixel is logically negated.
$R, G, B \rightarrow \bar{R}, \bar{G}, \bar{B}$
- Underline:
the underline attribute of this character is negated.
- Flash :
the character is periodically displayed with, then without, its cursor attributes ( $50 \% / 50 \% ; \simeq 1 \mathrm{~Hz}$ ).


## FLASH ENABLE (PAT6) - CONCEAL ENABLE (PAT3)

Any character flashing attribute is a "don't care" when PAT $_{6}=0$. When PAT $6=1$, a character flashes if its flashing attribute is set. It is then periodically displayed as a space ( $50 \% / 50 \% ; \simeq 0.5 \mathrm{~Hz}$ ).
$\mathrm{PAT}_{3}$ is a "don't care" for 80 char./row formats. When any 40 char./row format is in use :

- if $\mathrm{PAT}_{3}=0$, the conceal attribute of any character is a don't care,
- if $\mathrm{PAT}_{3}=1$, the conceal attribute of each character is interpreted : a concealed character appears as a space on the screen.

INSERT MODES : PAT (4:5)
During retrace, margin and extended margin periods, the I output pin delivers the value of the insert margin attribute. $I=\mathrm{i}_{\mathrm{M}}=\mathrm{MAT}_{4}$.

During active line period, the I output state is controlled by the Insert Mode and $\mathbf{i}$, the insert attribute of each character. The I output pin may have several uses: (See figure below) :

- As a margin/active area signal in the active area mark mode.
- As a character per character marker signal in the character mark mode.
- As a video mixing signal in the two remaining modes, provided that EF9345 has been vertically and horizontally synchronized with an external video source : the I pin allows mixing RGB outputs ( $1=1$ ) and the external video signal $(1=0)$. This mixing can be achieve by switching or ORing. It may occur for the complete character window (Boxing Mode) or only for the foreground pixels (Inlay Mode).

Video outputs during active periods

| INSERT MODE | CHAR. LEVEL |  | OUTPUTS |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathbf{i}$ | PIXELS (1) | $\mathbf{I}$ | R,G,B (2) |
| ACTIVE AREA MARK | - | - | 1 | X |
| CHARACTER MARK | 0 | - | 0 | X |
|  | 1 | - | 1 | X |
|  | 0 | - | 0 | BLACK |
| INLAY | 1 | - | 1 | X |

NOTES:
(1) PIXEL TYPE

- : Don't care

FOREGND : A foreground pixel is :

- Any pixel of a quadrichrome character,
- A pixel of a bichrome character generated from a "1" in the character generator cell.


## (2) RGB OUTPUTS

X : Not affected
BLACK : forced to low level.

## TIMING GENERATOR OPTIONS : TGS $(0: 4)$

$\operatorname{TGS}_{(0: 1)}$ select the number of lines per frame :
$\left.\begin{array}{|c|c|c|}\hline \text { TGS }_{\mathbf{1}} & \text { TGS }_{\mathbf{0}} & \text { LINES } \\ \hline 0 & 0 & 312 \\ \hline 0 & 1 & 262 \\ \hline 1 & 0 & 312.5 \\ \hline 1 & 1 & 262.5 \\ \hline\end{array}\right\}$ NON INTERLACED

The composite incoming SYNC IN signal is separated into 2 internal signals :

- Vertical Synchronization In (VSI),
- Horizontal Synchronization In (HSI).

TGS3 enables VSI to reset the internal line count. SYNC IN input is sampled at the beginning of the active area of each line. When the sample transits from 1 to 0 , the line count is reset at the end of the current line.

TGS2 enables HSI to control an internal digital phase lock loop. HSI and on-chip generated HS Out are considered as in phase if their leading edges match at $\pm 1$ clock period.

When they are out of phase, the line period is lengthened by 1 clock period ( $\simeq 80 \mathrm{~ns}$ ).

TGS $_{4}$ controls the SYNC OUT pins configuration :

| TGS $_{\mathbf{4}}$ | HVS / HS | PC / VS |
| :---: | :---: | :---: |
| 1 | COMPOSITE SYNC | PC |
| 0 | HSYNC OUT | V SYNC OUT |



PC is the output of the on-chip phase comparator.
An external VCXO allows a smoother horizontal phase lock than the internal scheme.

## SCREEN FORMAT TABLE

| CURSOR DISPLAY MODE | MAT $_{\mathbf{5}}$ | MAT $_{\mathbf{4}}$ |
| :--- | :---: | :---: |
| FIXED COMPLEMENTED | 0 | 0 |
| FLASH COMPLEMENTED | 1 | 0 |
| FIXED UNDERLINED | 0 | 1 |
| FLASH UNDERLINED | 1 | 1 |



## 40 CHAR/ROW CHARACTER CODES

To display pages in 40 character per row format, one out of three character code formats must be selected :

- Fixed long ( 24 bits) code : all parallel attributes.
- Fixed short ( 16 bits) code : mix of parallel and latched attributes.
- Variable (8/24 bits) code : all latched attributes.

Fixed short and variable codes are translated into fixed long codes by EF9345 during the internal row buffer loading process. The choice of the character code format is obviously a display flexibility/memory size trade off, left up to the user.

## FIXED LONG CODES

This is the basic 40 char./row code. Each 8 pixels $\times 10$ lines character window. on the screen is associated with a

3-byte code in memory, namely the $\mathrm{C}, \mathrm{B}$ and A bytes (Figure 5). A row on the screen is associated with a 120 byte row buffer in memory.

## 3-byte code structure

1. C 7 is a don't care. Up to 128 characters may be addressed in each set. Each user definable set holds only 100 characters : C byte value ranges from 00 to 03 and 20 to $7 F$ (hexa).
2. $B(4: 7)$ give the type and set number of the character.
3. All the bichrome characters have the same attributes except that alphanumerics may be underlined, semigraphics cannot. Accentuated alphanumerics allow orthogonal accentuating of any one of the 32 lower case ROM characters with any of 8 accents (see Figure 19).

FIGURE 5-40 CHAR/ROW FIXED LONG CODES
BICHROME CODE
C BYTE
QUADRICHROME CODE


| TYPE AND SET CODE : B(4:7) |  |  |  | NUMBER OF CHARACTERPER SETC(0:6) | SET NAME | $\begin{aligned} & \text { SET } \\ & \text { TYPE } \end{aligned}$ |  | CELL LOCATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 |  |  |  |  |  |
|  | 0 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | 128 standard mosaics 32 strokes | $\begin{aligned} & \mathrm{G}_{10} \\ & \mathrm{G}_{11} \end{aligned}$ | SEMII-GR. |  |  |
|  | 0 | 0 | $\begin{aligned} & \mathrm{U} \\ & \mathrm{~N} \end{aligned}$ | 128 alphanumerics | $\mathrm{G}_{0}$ |  | B | $\begin{aligned} & \text { ON-CHIP } \\ & \text { ROM } \end{aligned}$ |
| 0 | 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & E \\ & \mathbf{R} \\ & \mathbf{L} \\ & \mathbf{I} \end{aligned}$ | Accentuated lower case alpha | $\begin{aligned} & \mathrm{G}_{20} \\ & \mathrm{G}_{21} \end{aligned}$ | ALPHA | $\begin{aligned} & \mathrm{H} \\ & \mathrm{R} \\ & \mathrm{O} \end{aligned}$ |  |
|  | 0 | 0 | E | 100 alpha UDS | G'0 |  | E |  |
| 1 | 0 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | 100 semi-graphic UDS 100 semi-graphic UDS | $\begin{aligned} & \mathrm{G}^{\prime} 10 \\ & \mathrm{G}^{\prime} 11 \end{aligned}$ | SEMI-GR. |  | EXTERNAL |
|  | 1 | X | X | 8 sets of 100 <br> quadrichrome character | $\begin{aligned} & \mathrm{Q}_{0} \\ & \text { to } \\ & \mathrm{Q}_{7} \end{aligned}$ | QUADRIC | OME |  |

NOTA : Programming bit value
$1=$ True
$0=$ False
4. Bichrome and quadrichrome characters use two different coloring schemes.

For bichrome characters, character code byte A defines a two color set by giving directly two color values ( Fi gure 6). The negative attribute exchanges the two values. Each bit of the slice byte selects one color value out of two.

The " A " byte in a quadrichrome character code defines an ordered 4 color set (Figure 7). When more than 4 bits are set, higher ranking bits are ignored. When less than 4 bits are set, the color set is completed with implicit "white" value. The slice byte is shifted 2
bits at once at half the dot frequency ( $\simeq 4 \mathrm{MHz}$ ). Each bit pair designates one color out of the 4 color sets.

Quadrichrome characters allow displaying up to 4 different colors (instead of 2 ) in any $8 \times 10$ window at the penalty of an halved horizontal resolution.
By programming the $R$ attribute in byte B, one may chose to keep the full vertical resolution (1 slice per line) or to halve it (each slice is repeated twice). In any case, it is possible to change the color set freely from window to window and to mix freely all the character types. So, fairly complex pictures may be displayed at low memory cost.

FIGURE 6 - COLORING WITH BICHROME CHARACTERS

| B | G | R | COLOR VALUE |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | BLACK |
| 0 | 0 | 1 | RED |
| 0 | 1 | 0 | GREEN |
| 0 | 1 | 1 | YELLOW |
| 1 | 0 | 0 | BLUE |
| 1 | 0 | 1 | MAGENTA |
| 1 | 1 | 0 | CYAN |
| 1 | 1 | 1 | WHITE |



FIGURE 7 - COLORING WITH QUADRICHROME CHARACTERS


## Handling long codes

The KRF command allows an easy $\mathrm{X}, \mathrm{Y}$ random access or an X sequential access to/from the microprocessor from/to a memory row buffer (Figure 8).

FIGURE 8 - FIXED LONG CODES IN MEMORY 120 BYTE ROW BUFFER

## KRF COMMAND

| $R 1$ | $C$ |
| :---: | :---: |
| R2 | $B$ |
| R3 | $A$ |
| R4 | - |
| R5 | - |
| R6 | $D, Y$ |
| R7 | $B, X$ |



## VARIABLE CODES

In many cases, successive characters on screen belong to the same character set and have the same attributes. Variable codes achieve memory saving by storing B and A bytes only when it is required by exploiting the C 7 bit.

## $C 7=1$ This is a long 3-byte code.

Character set and attribute values are completely redefined by $B$ and $A$ bytes.

C7 $=0$ This is a short 1 -byte code.
Character set and attributes value are identical to the previous code.

A further saving comes from the fact that an accentuated alphabetic character is, more often than not, followed by a not accentuated alphabetic character.
So, $\mathrm{G}_{20}$ or $\mathrm{G}_{21}$ sets are processed as one-shot escape with return to $\mathrm{G}_{0}$. For normal operation, variable codes should obey the following rules:

- the first character code of any row $(X=0)$ should be long,
- a character code may be short when it has the same attributes as the previous character code and belongs to the same set.

However:

- any code belonging to $\mathrm{G}_{20}$ or $\mathrm{G}_{21}$ must be long and must be repeated if the character is double width,
- a code belonging to $G_{0}$ following a $G_{20}$ or $G_{21}$ code may be short.


## Handling the variable codes

During the display process, a row of variable code should be laid in an 80/120 byte row buffer. The first buffer holds the C bytes. The second buffer holds the B, A file providing up to 20 long codes per row. (Figure 10). In the exceptionnal case when this is not enough, the second buffer overflows in the third one. Every code may then be long. Variable codes can almost always achieve a memory saving over long fixed codes and can never be worse.
The KRV command gives a very easy sequential access to/ from a row buffer from/to the microprocessor. This command automatically updates the C byte and the B, A file pointers (the last one when C 7 is set).

| EXP and CMP |
| :---: |
| commands |


| R1 | - |
| :---: | :---: |
| R2 | - |
| R3 | - |
| R4 | ZW, YW |
| R5 | BF, XF |
| R6 | D, Y |
| R7 | B, X |



Random access to a variable code is obviously not as easy. The EXP, KRE are CMP commands are designed to facilitate this task (Figure 9).

The EXP command translates a full row of variable codes into a row of expanded codes. Expanded codes are generally not displayable but very similar to the long codes.

KRE gives a random access to an expanded code and makes it appear as a regular long code.

The CMP command translates a full row of expanded code into a row of variable codes and minimizes the file size in the process.

These commands use a buffer pair as working area.


## FIXED SHORT CODES

These fixed 16-bit codes are compatible with EF9340/41 display controllers. They achieve memory saving by another way. They may be easier to handle than variable codes. The penalty is in lesser display capabilities :

- accentuated character sets are no longer available : accentuated characters must be individually provided by the character generators,
- G'11 and quadrichrome sets cannot be reached,
- some attributes are latched and can be changed only while displaying a space (delimitor code).
The KRG command allows an easy access from/to an 80 -byte row buffer in memory to/from the microprocessor (Figure 11). Figure 12 gives the fixed short to fixed long translation process which occurs for each row - while loading the internal row buffer - before display.

FIGURE 11 - FIXED SHORT CODES IN MEMORY 80 BYTE ROW BUFFER

KRG COMMAND

| $R 1$ | $A^{*}$ |
| :---: | :---: |
| $R 2$ | $B^{*}$ |
| $R 3$ | $W$ |
| $R 4$ | - |
| $R 5$ | - |
| $R 6$ | $D, Y$ |
| $R 7$ | $B, X$ |




## NOTES

## 1/ Translation process

The translation process operates through 3 elementary operations :

- Field-to-field : a character code or an attribute value (i.e : $\mathrm{C}_{0}$, flashing) is directly loaded from short to long code.
- Field-to-constant the decoding of a short code forces the value of the equivalent long code attribute. For example, semigraphic short characters forces normal size ( $H=0, L=0$ ) attributes.
- Latched attributes : at the beginning of each row, these attributes are reset (no underline, not concealed, no insert, black background). Then, they keep their current value until modified by either a field to field or field to constant operation.


## 2/ EF9340/41 compatibility

It is binary code compatible with few exceptions :

- flashing attribute is negated
- A7 is negated in delimitors.

It is also display compatible with 2 exceptions concerning the underlining :

- an alphanumeric belonging to $\mathrm{G}^{\prime} 0$ may be underlined,
- any alphanumeric following a semigraphic cannot be underlined.

USER DEFINED CHARACTER GENERATOR IN ME. MORY : DOR REGISTER
With 40 char./row, the elementary window dimensions on the screen are 10 slices $\times 8$ pixels. Thus, a character cell holds 10 bytes in memory and 4 character cells are packed
in one 40 -byte buffer (Figure 13). However, 5 bytes of a low resolution quadrichrome cell are enough to fill up the window. In this case, 8 character cells can be packed in one 40 -byte buffer.

FIGURE 13 - PACKING UDS CELLS IN MEMORY


The cells of one given character set should be layed in one block.
Up to 100 character cells may be addressed in each set (or 200 for low resolution quadrichrome only). The location in memory, where to fetch the sets in use, are declared by

DOR register (Figure 14). For each type of set, it gives the MSB(s) of the Z block address. EF9345 reads the Z LSB(s) in the $B$ byte of the (equivalent) long code. As usual, the character code is read in the C byte. NT is derived from the TV line rank in the row and the double height status.

FIGURE 14 - UDS FETCH TO DISPLAY


## LOADING USER DEFINED CHARACTER SET

Before loading a character set into RAM, the user must :

- Assign a name to the set :
- $\mathrm{G}^{\prime} 0, \mathrm{G}^{\prime} 10$ or $\mathrm{G}^{\prime} 11$ for bichrome characters.
- From 00 to 07 for quadrichrome characters.
- Assign a character number to each character belonging to this set . character numbers range from 0 to 3 and 32 to 127.
It is binary coded into 7 bits $\mathrm{C}(0: 6)-\mathrm{C}(0: 6)$ will be loaded later on into a C byte character code in order to display the character.
- A pointer to a character slice in memory is then manufactured from :
- the character number $\mathrm{C}(0: 6)$
- the slice number NT(0:3)
- the block number assigned to the set $\mathrm{Z}(0: 3)$.

Figure 15 shows how to proceed with the auxiliary pointer and the OCT command.

## Note :

The main pointer may be also used. When sequentially accessing slices of a given character, auto incrementation is helpless.


## ON-CHIP CHARACTER GENERATOR

- $\mathrm{G}_{0}$ set is common to 40 and 80 char./row modes ( Fi gure 16 and Figure 25).
- $\mathrm{G}_{10}$ is the standard mosaïc set for videotex (Figure 17).
- $\mathrm{G}_{11}, \mathrm{G}_{20}$ and $\mathrm{G}_{21}$ cannot be reached from the 16-bit short fixed codes (Figure 18 and Figure 19).


## DISPLAYING THE ATTRIBUTES

1. For normal operation, a double height and/or double width character must be repeated in memory in two successive Y and/or X positions. The user may otherwise freely mix any character size.
2. The attributes are logically processed in the following order :

- Underline or underline cursor : foreground forced on the last slice ( $\mathrm{NT}=9$ ).
- Flash : background periodically forced on the whole window ( $\simeq 0.5 \mathrm{~Hz}$ ). The phase depends on the negative attribute.
- Conceal : background forced permanently on the whole window. A concealed character neither blinks nor is underlined.
- Negative : exchange the background and foreground color values when set.
- Coloring.
- Complemented cursor mode.
- Insert : black color forced when required.

3. Basic pixel shift frequency: $f C L K \times 2 / 3=8 \mathrm{MHz}$.

| C6 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C5 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| C4 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| C3 | c2 | c1 | co |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



| C6 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $C 5$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| $C 4$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| C3 | C2 | C1 | co |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



| C6 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C5 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| C4 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| C3 | C2 | C1 | co |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



MOSAIC Semi-graphic SEPARATED Semi-graphic

| C6 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C5 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| C4 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| C3 | C2 | C1 | co |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



|  |  |  |  | C5 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | c4 | 0 | 1 |
| C3 | C2 | C1 | CO |  |  |  |
| 0 | 0 | 0 | 0 |  |  |  |
| 0 | 0 | 0 | 1 |  |  |  |
| 0 | 0 | 1 | 0 |  |  |  |
| 0 | 0 | 1 | 1 |  | 嫌: |  |
| 0 | 1 | 0 | 0 |  |  |  |
| 0 | 1 | 0 | 1 |  |  |  |
| 0 | 1 | 1 | 0 |  |  |  |
| 0 | 1 | 1 | 1 |  |  |  |
| 1 | 0 | 0 | 0 |  |  |  |
| 1 | 0 | 0 | 1 |  |  |  |
| 1 | 0 | 1 | 0 |  |  |  |
| 1 | 0 | 1 | 1 |  |  |  |
| 1 | 1 | 0 | 0 |  |  |  |
| 1 | 1 | 0 | 1 |  |  |  |
| 1 | 1 | 1 | 0 |  |  |  |
| 1 | 1 | 1 | 1 |  |  |  |

FIGURE $19-\mathbf{G}_{20}$ and $\mathbf{G}_{\mathbf{2 1}}$ ACCENTUED CHARACTER SETS FOR 9345


## Example :


$X=$ bits defined by user.

| C3 | C2 | C1 | co |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | $\cdots$ |
| 0 | 0 | 0 | 1 |  |
| 0 | 0 | 1 | 0 |  |
| 0 | 0 | 1 | 1 |  |
| 0 | 1 | 0 | 0 |  |
| 0 | 1 | 0 | 1 |  |
| 0 | 1 | 1 | 0 |  |
| 0 | 1 | 1 | 1 |  |
| 1 | 0 | 0 | 0 |  |
| 1 | 0 | 0 | 1 |  |
| 1 | 0 | 1 | 0 |  |
| 1 | 0 | 1 | 1 |  |
| 1 | 1 | 0 | 0 |  |
| 1 | 1 | 0 | 1 |  |
| 1 | 1 | 1 | 0 |  |
| 1 | 1 | 1 | 1 |  |




Example:


| C3 | c2 | c1 | co |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



FIGURE 19 ter $-\mathbf{G}_{20}$ and $\mathbf{G}_{21}$ ACCENTUED CHARACTER SETS FOR 9345-R005


Example :

$X=$ bits defined by user.



To display pages in 80 character per row format, one of two character code formats must be selected :

- Long ( 12 bits) code : 4 parallel attributes and large onchip 1024 semigraphic character set,
- Short (8 bits) code : no attribute, no semigraphic set.

Both formats address the on-chip $\mathrm{G}_{0}$ set ( 128 characters $6 \times 10$ ). None allows UDS addressing.

## LONG CODES

Each 6 pixels $\times 10$ lines character window on the screen is associated with a 12 -bit code in memory, namely a C byte and an attribute nibble A (Figure 10). C7 bit designates the set.

- Alphanumeric set : C7 $=0$.
$\mathrm{C}(0: 6)$ designates one out of 128 alphanumeric characters in the $\mathrm{G}_{0}$ on-chip set. This set is common to the 40 char/row format, with the 2 right most columns truncated (see Figure 25).
$A(0: 3)$ gives 4 parallel attributes.
- Mosaïc set : $C 7=1$.
$A(1: 3)$ and $C(0: 6)$ address a dedicated mosaïc character. Each of these address bits controls the foreground/background status of a 3 pixels $\times 2$ lines sub-window : foreground when the bit is set.

AO provides a color select attribute.

FIGURE 20-80 CHAR/ROW CHARACTER CODE


## ALPHANUMERIC CHAR CODE

$\mathrm{N}=$ Negative
$\mathrm{F}=$ Flash
$\mathrm{U}=$ Underline
$\mathrm{D}=$ Color set

## 128 ALPHANUMERICS

In $\mathrm{G}_{0}$ set.

## SHORT CODES

They are derived from the long code by giving a 0 implicit value to each bit of the A nibble : positive, not underlined, not flashing.

## PACKING THE CODES IN MEMORY

Long codes are paired. A pair is packed in a 3-byte word. Therefore, the 80 codes of a row fill a 120 -byte row buffer (Figure 21). The left most position on the screen is even. Its corresponding $C$ byte is at the beginning of the first buffer. The next position on the screen is odd. Its corresponding C byte is at the beginning of the second buffer. Both nibbles are packed in the third buffer. With short codes, the same scheme yields 80 -byte row buffers.


## MOSAIC CHAR CODE



## ACCESS TO THE CODES IN MEMORY

KRL command transfers 12 bits from/to the R1 and R3 registers to/from memory. The read modify write operation, necessary to write the A nibble in memory, is automatically performed provided that the $A$ nibble is repeated in the R3 register (Figure 22). Dedicated autoincrementation is also performed when required.

KRC command does a similar job for the short codes ( Fi gure 23).

A very simple scheme allows the microprocessor to transcode an horizontal screen location into a pointer (Figure 24). The joint use of this scheme with the dedicated command alleviates all the packing/unpacking troubles.


FIGURE 22 - KRL COMMAND : SEQUENTIAL ACCESS TO LONG CODES


FIGURE 23 - KRC COMMAND SEQUENTIAL ACCESS TO SHORT CODES


FIGURE 24 - TRANSCODING AN HORIZONTAL SCREEN LOCATION INTO A R7 POINTER


## DISPLAYING THE ATTRIBUTES - DOR REGISTER

Short code and mosaïc characters are not flashing, not underlined and "positive".
The attributes are processed in the following order :

- Underline or underlined cursor : foreground is forced on the last slice ( $\mathrm{NT}=9$ ).
- Flash : background is periodically $(0.5 \mathrm{~Hz}-50 \%)$ forced on all the window. The phase depends on the negative attribute.


The pixel shift frequency is f CLK $(12 \mathrm{MHz})$.

- Color select : a "positive" character is displayed with a background color same as the margin color. The foreground color is selected in DOR register by the D attribute.
- Negative : when the character is negative, background and foreground colors are exchanged. In complemented CURSOR position, these colors are complemented.
- Insert : the D attribute selects one insert value in DOR register. This attribute is then processed up to the current insertion mode (see screen format and attribute insert section).

| $\mathbf{D}$ | $\mathbf{N}$ | BACKGND <br> COLOR | FOREGND <br> COLOR | $\mathbf{i}$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $\mathrm{C}_{\mathrm{M}}$ | $\mathrm{C}_{0}$ | i |
| 0 | 1 | $\mathrm{C}_{0}$ | $\mathrm{C}_{\mathrm{M}}$ | io |
| 1 | 0 | $\mathrm{C}_{\mathrm{M}}$ | $\mathrm{C}_{1}$ | $\mathrm{i1}$ |
| 1 | 1 | $\mathrm{C}_{1}$ | $\mathrm{C}_{\mathrm{M}}$ | $\mathrm{i1}$ |


| C7 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C6 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| C5 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| C4 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| $\rightarrow$ | $\rightarrow$ | - | $\rightarrow$ | $\rightarrow$ | $\rightarrow$ | $\rightarrow$ | $\rightarrow$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | む |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\sim$ | - | $\rightarrow$ | $\cdots$ | 0 | 0 | 0 | $\bigcirc$ | $\rightarrow$ | $\rightarrow$ | $\rightarrow$ | $\sim$ | $\bigcirc$ | 0 | 0 | $\bigcirc$ | $\Omega$ |
| $\rightarrow$ | $\cdots$ | 0 | 0 | $\cdots$ | $\sim$ | 0 | 0 | $\cdots$ | $\rightarrow$ | $\bigcirc$ | 0 | $\rightarrow$ | $\rightarrow$ | 0 | $\bigcirc$ | 9 |
| - | 0 | - | 0 | - | 0 | $\cdots$ | 0 | $\cdots$ | 0 | $\cdots$ | 0 | - | 0 | - | $\bigcirc$ | 8 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\cdots ⿻ \# \# \# \# \#$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

FIGURE 25 bis - G ${ }_{0}$ ALPHANUMERIC CHARACTER SET IN 80 CHARACTER/ROW MODE - EF9345 R003

| C7 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C6 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| C5 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| C4 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| C3 | C2 | C1 | CO |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



FIGURE 25 ter - $\mathbf{G}_{0}$ ALPHANUMERIC CHARACTER SET IN 80 CHARACTER/ROW MODE - EF9345 R005

| C7 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C6 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| C5 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| C4 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |


| C3 | C2 | C1 | CO |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |



[^50]A microprocessor bus cycle may transfer one byte from/ to the microprocessor to/from a directly addressable register. These registers provide an indirect access :

- to/from 5 on-chip indirect registers : ROR, DOR, MAT, PAT and TGS.
- to/from the private memory.

Due to address/data multiplexing, a bus cycle is a 2 phase process (see Timing diagram 1 or Timing diagram 2).

- $\mathrm{A} 8=\overline{\mathrm{LCS}}$

This is the latched value of $\overline{\mathrm{CS}}$ input pin.
EF9345 is selected when the following condition is met : ASN $=2$ (Hexa) and $\overline{L C S}=0$.

Therefore, EF9345 is mapped in the hexadecimal microprocessor addressing space from XX20 to XX2F, where $X X$ is up to the user. When EF9345 is not selected, its AD bus pins float and no register can be modified.

## ADDRESS PHASE

The falling edge of $A S$ latches to $A D(0: 7)$ bus state and $\overline{\mathrm{CS}}$ signal into the temporary A address register ( F igure 26).

- $A(0: 2)=i$

This register index designates one out of 8 direct access registers $\mathrm{R}_{\mathrm{i}}$.

- $A 3=X Q R$

This is the execution request bit.

- $\mathrm{A}(4: 7)=\mathrm{ASN}$

This is the Auto-Selection Nibble.


FIGURE 26 - DIRECT ACCESS REGISTERS


## DATA PHASE-REGISTERS

When EF9345 is selected and while AS input is low, the $R_{\text {; }}$ register is accessed.
RO designates a write-only COMMAND register or a readonly STATUS register.
R1 to R7 hold the arguments of a command. They are read/write registers.
R1, R2, R3 are used to transfer the data.
R4, R5 hold the Auxiliary Pointer (AP).
R6, R7 hold the Main Pointer (MP).
(See memory organization ; Pointer section for pointer structure).

## COMMAND REGISTER

This register holds a 4 -bit command type and 4 bits of orthogonal parameters (see COMMAND TABLE).

## Type

There are 4 grouips of command:

- The IND command which gives access to on-chip resources,
- The fixed format character code transfer commands,
- The variable character code handling commands,
- The general purpose commands.


## Parameters

R/W : Direction
1 : to DATA registers ( $\mathrm{R} 1, \mathrm{R} 2, \mathrm{R} 3$ )
0 : from DATA registers.
$r$ : Internal ressource index (see Figure 27)
I: Auto-incrementation
1 : with post auto-incrementation
0 : without auto-incrementation.
p: Pointer select
1 : auxiliary pointer
0 : main pointer
$\mathrm{s}, \overline{\mathrm{s}}$ : Source, destination select
01 : source : MP ; destination : AP
10 : source : $A P$; destination : MP
$\bar{a}, \mathrm{a}$ : Stop condition
01 : stop at end of buffer
10 : no stop.

## STATUS REGISTER

This is a read-only, direct access register.
S7 : BUSY BUSY is set at the beginning of any command execution. It is reset at completion.
S6 : AI $\mid \quad \mathrm{LX} \mathrm{I}_{\mathrm{m}}$ or $\mathrm{LX} \mathrm{X}_{\mathrm{a}}$ is set when respectively the main pointer or the auxiliary pointer holds $X=39$ before a possible incrementation.
The alarm bit S 6 is set when $L X_{m}$ or $L X_{a}$ is set and an incrementation is performed after access.

S3: $\quad$ Gives the MSB value of $R_{1}$.
S2: Gives the vertical synchronization signal state.
This is maskable by the VRM command.
$\mathrm{S} 1=\mathrm{S} 0=0 \quad$ Not used.
S3 to S6 are reset at the beginning of any command.
The COMMAND TABLE shows every command able to set, each of these status bits, after completion.

FIGURE 27 - INDIRECT ON-CHIP RESOURCE ACCESS


* Note: A slice in 40C only can be read from the internal character generator. The slice address must be initialized in R6, R7.

| $\mathrm{B4}, \mathrm{B5}, \frac{\mathrm{NT}}{3,2,1}, \mathrm{O}, \mathrm{C}_{1}, \mathrm{C}_{0}$ |
| :---: | :---: | :---: |

## NOTES ON COMMAND EXECUTION

1. The execution of any command starts at the trailing edge of DS when (and only when) :

- EF9345 has been selected,
- XQR has been set,
at the previous AS falling edge.
This scheme allows loading a command and its argument in any order. For instance, a command, once loaded, may be re-executed with new or partly new arguments.

2. At power on, the busy state is undeterminated.

It is recommanded to load first a dummy command with $X Q R=1$ before any effective command.
3. While Busy is set, the current command is under execution. Register access is then restricted.

## Register access with $\mathrm{XQR}=0$

- Read STATUS is effective.
- Write COMMAND or any other register access are ineffective.
That is to say, the microprocessor reads undetermined values and may not modify a register.

Register access with $X Q R=1$

- Read STATUS or write COMMAND are effective,
- Access to other registers is ineffective.

However, the previous command is aborted and the new command execution launched (with an initial state undetermined for registers and memory locations handled by the aborted command).

## 4. Execution suspension

The execution of any command (except VRM, VSM) is suspended during the last and first TV line of an active row. This is because the memory bus cannot be allocated for microprocessor access during this $104 \mu$ s period.
This holds too for internal resource access because onchip data transfer uses internal data memory bus.

## IND COMMAND (See figure 27)

This command transfers one byte between R1 and an internal resource. The $r$ parameter designates one on-chip indirect register.

## FIXED FORMAT CHARACTER CODE ACCESS : KRF, KRG, KRL KRC

Each of these commands is dedicated to transfer one complete character code between DATA registers and memory. MP is exclusively used.
KRF transfers 24 bits.
KRG transfers 16 bits.
KRL transfers 12 bits.
KRE transfers 8 bits.
Code packing, pointer and data structures are explained in the corresponding character code section.

When auto-incrementation is enabled, MP is automatically updated after access so as to point to the next location. This location corresponds to the next right position on screen. When last position $(X=39)$ is accessed, $L X_{m}$ is set. When last position is accessed with auto-incrementation, alarm is also set. MP is then pointing back at the beginning of the row : there is no automatic $Y$ incrementation.

VARIABLE CODE HANDLING COMMANDS: KRV
EXP, CMP, KRE
An overview on these commands is given in "handling the variable codes" (40 char./row section).

KRV uses R5 to point the attribute file. $L X_{a}$ is set when this file is full (the last attribute pair has been accessed).

EXP and CMP use MP and R5 in the same way as KRV. Furthermore, R4 points to a working double buffer. These two commands process a whole row buffer and stop either at the end of the row buffer or when the file overflows. In the last case, the alarm bit is set.

KRE uses MP to point to a buffer and R4 to point to a working double buffer. R5 is unused. In other respects, KRE is identical to KRL.

For these commands, R4(5:7) hold the LSB's block address of the working buffer $W$.


## GENERAL PURPOSE ACCESS TO A BYTE - OCT

This command uses either MP or AP pointer.
When MP is in use, an overflow yields to a $Y$ incrementation.

## MOVE BUFFER COMMANDS : MVB, MVD, MVT

These are memory to memory commands which use R1 as working register.
MVB transfers a byte from source to destination, post-increments the 2 pointers and iterates until the stop condition is met. MVD and MVT are similar but work respectively with 2 byte word and 3 byte word. That is to say, MVB works on buffers, MVD on double buffers and MVT on triple buffers. If the parameter $a=1$, the process stops when either source or destination buffer end is reached. If the parameter $a=0$, the process never stops until aborted. In this case, main pointer overflow yields to a $Y$ incrementation in MP. So, a whole block or page may be initialized.

## MISCELLANEOUS COMMANDS : INY, VRM and VSM

 INY command increments $Y$ in MP.VRM and VSM respectively reset and set a vertical synchronization status mask. When the mask is set, status bit S2 remains at 0 . When the mask is reset, status S2 follows the vertical sync. state : it is reset for 2 TV lines per frame and stays at 1 during the remaining period. It becomes readable by the microprocessor from the status register. After power on, the mask state is undetermined.

COMMAND TABLE

| TYPE | MEMO | CODE |  |  |  | PARAMETER |  |  |  | STATUS |  |  |  | ARGUMENTS |  |  |  |  |  |  | EXECUTION TIME (1) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7 | 6 | 5 | 4 |  | 2 | 1 | 0 | AI $\mathrm{LX}_{\mathrm{m}} \mathrm{LX}_{\mathrm{a}} \mathrm{R} 1_{7}$ |  |  |  | R1 | R2 | R3 | R4 | R5 | R6 | R7 | WRITE | READ |
| INDIRECT | IND | 1 | 0 | 0 | 0 | $R / \bar{W}_{1} \quad{ }^{\text {r }}$ |  |  |  | $0,0,0,0$ |  |  |  | D $1-1-$ |  |  | $-1-1$ |  | MP |  | 2 | 3.5 |
| 40 CHARACTERS $\cdot 24$ BITS | KRF | 0 | 0 | 0 | 0 | $R / \bar{W}$ | 0 | 01 |  | X | $x$ | 0 | 0 | C | B A |  | $-\quad-1$ |  | MP |  | 4 | 7.5 |
| 40 CHARACTERS - 16 BITS | KRG | 0 | 0 | 0 | 0 | $R / \bar{W}$ | 0 | 1 | 1 | X | $x$ | 0 | 0 | A* | B* | W | - | -1 | M | P | 5.5 | 7.5 |
| 80 CHARACTERS - 8 BITS | KRC | 0 | 1 | 0 | 0 | $R / \bar{W}$ | 0 | 0 | 1 | X | $x$ | 0 | 0 | C | - | - | - | - 1 | M | P | 9 | 9.5 |
| 80 CHARACTERS - 12 BITS | KRL | 0 | 1 | 0 | 1 | $R / \bar{W}$ | 0 | 0 | 1 | X | x | 0 | 0 | C | - | A | - | - | M | P | 12.5 | 11.5 |
| 40 CHARACTERS VARIABLE | KRV | 0 | 0 | 1 | 0 | R/产 | 0 | 0 | 1 | X | X | x | X | C | B | A | - | XF | M | P | (2) $3+3+j$ | $3.5+6 *$ j |
| EXPANSION | EXP | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | x | 0 | x | 0 | C | B | A | PW | XF\| |  | PP | (3) $<247$ | - |
| COMPRESSIION | CMP | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | $x$ | 0 | X | 0 | C | B | A | PW | XF |  | P | (3) $<402$ | - |
| EXPANDED CHARACTERS | KRE | 0 | 0 | 0 | 1 | $R / \bar{W}$ | 0 | 0 | 1 | $x$ | $\times$ | 0 | 0 | C | B | A | PW | - |  | MP | 4 | 7.5 |
| BYTE | OCT | 0 | 0 | 1 | 1 | R/W | p | 0 | 1 | X | x | $\times$ | 0 | D | - | - |  | P | M | P | 4 | 4.5 |
| MOVE BUFFER | MVB | 1 | 1 | 0 | 1 | s | $\bar{s}$ | $\overline{\mathrm{a}}$ | a | 0 | 0 | 0 | 0 | W | - | - |  |  | M | P | (2) $2+4 . n$ | - |
| MOVE DOUBLE BUFFER | MVD | 1 | 1 | 1 | 0 | s | $\bar{s}$ | $\overline{\mathrm{a}}$ | a | 0 | 0 | 0 | 0 | w | - | - |  |  | M | MP | (2) $2+8 . n$ | - |
| MOVE TRIPLE BUFFER | MVT | 1 | 1 | 1 | 1 | s | $\bar{s}$ | $\overline{\mathrm{a}}$ | a | 0 | 0 | 0 | 0 | w | - | - |  | P | M | MP | (2) $2+12 . n$ | - |
| CLEAR PAGE (4) - 24 BITS | CLF | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | $x$ | $x$ | 0 | 0 | C | B | A | - | - | M | P | $<4700$ (1 K code) | - |
| CLEAR PAGE (4)-16 BITS | CLG | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | $x$ | $\times$ | 0 | 0 | A* | B* | W | - | - | M | MP | $<5800$ (1 K code) | - |
| VERTICAL SYNC MASK SET | VSM | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | - | - | - | - | - | - | - | 1 | - |
| VERTICAL SYNC MASK RESET | VRM | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | - | - | - | - | - | - | - | - | - | - | - | 1 | - |
| INCREMENT Y | INY | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | - | - | - | - | $Y$ | - | 2 | - |
| NO OPERATION | NOP | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | - | - | - | - | - | - | - | - | $-1$ | - |  | 1 | - |

p : Pointer select
1 : auxiliary pointer
0 : main pointer.
$\mathbf{s}, \overline{\mathbf{s}}$ : Source, destination
01 : source $=$ MP ; destination $=A P$
10 : source = AP ; destination = MP
$\overline{\mathrm{a}}, \mathrm{a}$ : Stop condition
01 : stop at end of buffer
10 : no stop
r : Indirect register number

- : Not affected
$W$ : Used as working register PW (ZW, YW) : Working buffer $X$ : Set or Reset
XF : X File
Pointer incrementation
D : Data
MP : Main pointer
AP : Auxiliary pointer
(1) Unit : 12 clock periods ( $\simeq 1 \mu$ s) without possible suspension
(2) n : total number of words $\leqslant 40 ; \mathrm{j}=1$ for long codes, $\mathrm{j}=0$ for short codes.
(3) Worst case ( 20 long codes +20 short codes)
(4) These commands repeat KRF or KRG with $Y$ incrementation when $X$ overflows. When the last position is reached in a row $Y$ is incremented and the process starts again on the next row These commands stop only with abort.


MINIMUM APPLICATION WITH 2K $\times 8$ MEMORY
One page memory terminal in 16-bit fixed format or 24-bit compressed format.


## TYPICAL APPLICATION WITH 8K $\times 8$ DYNAMIC OR PSEUDO-STATIC RAM

Multipage terminal with possibility of multiple user definable character sets.


MAXIMUM APPLICATION WITH 16K x 8 MEMORY
Multipage terminal with user definable character sets and buffer areas.



CB-182


P SUFFIX PLASTIC PACKAGE


ORDERING INFORMATION


CB-521



## ADVANCE INFORMATION

This GDP is a true high resolution graphic display processor，which con－ tains all the functions required to process vector generation at a very high speed and to generate all the timing signals required for interfacing interlaced or non interlaced video data on a raster scan CRT display compatible with 525 line or the CCIR 625 line standards．

The GDP＇s main features are ：
－Selectable resolutions in black and white or color ：
Vertical resolution ： 525 line monitor（208 or 416）． 625 line monitor （256 or 512）．
Horizontal resolution：256，320＊，384＊，512，640＊，768＊，1024，full screen．（＂）with external PROM．
－High speed vector plot well suited to animation－ 4 types of lines．
－Multiplexed address and refresh for 16 K or 64 K dynamic RAMs．
－No limitation on the number of selectable memory planes（colors，grey levels or any other attributes）
－Multipage application capability
－On－chip full ASCII character generator（96）－maximum alphanumeric screen density ： $170 \times 57$－programmable sizes and orientations
－Direct interfacing with the monitor through the composite synchro and blanking signals
－Automatic allocation of display memory in refresh，write，dump，and display cycles
－Light pen registers and control signals
－Three types of interrupt requests
－Fully static design
－TTL compatible I／O
－Single +5 volt supply．

## TYPICAL APPLICATION



## MOS

（N CHANNEL，SILICON－GATE）

## GRAPHIC DISPLAY PROCESSOR（GDP）



PIN ASSIGNMENT

| CK | $1 \longrightarrow$ | 40 |  | $V_{C C}$ |
| :---: | :---: | :---: | :---: | :---: |
| DAD5 | 2 | 39 | $\square$ | DAD1 |
| DAD4－ | 3 | 38 | 曰 | DAD2 |
| DAD3 | 4 | 37 | $\square$ | DADO |
| DAD6 | 5 | 36 | 曰 | MSL1 |
| MSLO | 6 | 35 | 曰 | MSL3 |
| MSL2 | 7 | 34 | ص | SYNC |
| FMAT | 8 | 33 | $\square$ | D0 |
| AO 5 | 9 EF9367 | 32 | $\square$ | D1 |
| A1－ | $10^{\text {EF9367 }}$ | 31 | $\square$ | D2 |
| A2 | 11 | 30 | 7 | D3 |
| A3 | 12 | 29 | $\square$ | D4 |
| IRQ | 13 | 28 | $\square$ | D5 |
| DW－ | 14 | 27 |  | D6 |
| DIN | 15 | 26 |  | D7 |
| VB | 16 | 25 |  | BLK |
| $\bar{E}$ | 17 | 24 |  | MW |
| R／W－ | 18 | 23 |  | WO |
| X9 | 19 | 22 |  | $\overline{A L L}$ |
| $V_{S S}$ | 20 | 21 |  | LPCK |

BLOCK DIAGRAM


## GENERAL DESCRIPTION

Developed using NMOS technology, the GDP is an intelligent raster scan video display controller, fully programmable via an eight-bit microprocessor bus. Besides all the timing logic functions required to generate the video, sync and blanking signals, the GDP includes two hardwired display processors : a vector and a character generator.

This unique feature allows an ultrafast screen writing speed (the 1024 dot diagonal may be written in less than 1.4 ms ) at almost no microprocessor processing cost.

The GDP is particularly well-suited to all applications in which the display memory is not directly addressed by the MPU. This feature allows a total asynchronism between the MPU and the GDP memory cycles and preserves the whole MPU memory addressing space.

Nevertheless, where direct exchange between the microprocessor and the memory is necessary, the on-chip allocation controller will allow this exchange without display interference.

The GDP is programmable using 11 internal registers occupying 16 consecutive addresses. These registers can also be modified by the GDP's hardwired processors while a command is being executed.

Note: A summary of data codes and registers is given in the Register address table. Hexadecimal values are subscripted 16 and the register bits are numbered as follows:


MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

The GDP inputs are protected against high static voltages and electric fieids; nevertheless, normal precautions should be taken to avoid voltages above the limit values on this high impedance circuit.

STATIC ELECTRICAL CHARACTERISTICS (VCC $=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$ unless otherwise noted)

| Characterist ic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input high voltage except CK | $\mathrm{V}_{1} \mathrm{H}$ | $\mathrm{V}_{\text {SS }}+2.2$ | - | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input high voltage CK | $V_{\text {IHCK }}$ | $\mathrm{V}_{\mathrm{SS}}+3.5$ | - | $V_{C C}$ | V |
| Input low voltage | $V_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | - | $\mathrm{V}_{\mathrm{SS}}+0.8$ | V |
| Input leakage current ( $\mathrm{V}_{\text {in }}=0$ to $5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=$ max ) | 1 in | - | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| Output high voltage ( $1_{\text {load }}=-100 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{min}$ ) | V OH | $\mathrm{V}_{\text {SS }}+2.4$ | - | - | V |
| Output low voltage ( $1_{\text {load }}=1.6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{min}$ ) | VOL | - | - | $\mathrm{V}_{\mathrm{SS}}+0.4$ | V |
| Supply current | ICC | - | 80 | - | mA |
| Capacitance $\left(\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | $\mathrm{C}_{\text {in }}, \mathrm{C}_{\text {out }}$ | - | - | 12 | pF |

## TEST LOADS



DYNAMIC OPERATING CONDITIONS
( $V_{D D}=5,0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ unless otherwise noted)

| Time (ns) | Symbol | Min | Max |
| :---: | :---: | :---: | :---: |
| Clock period | tCK | 560 |  |
| CK pulse width, low | ${ }^{\text {t }}$ CKL | 330 |  |
| CK pulse width, high | ${ }^{\text {t CKH }}$ | 190 |  |
| CK low to valid DAD | CKLDAD |  | 320 |
| CK high to valid DAD | CKHDAD |  | 180 |
| CK low to valid SYNC | CKLSYNC |  | 300 |
| CK low to valid BLK | CKLBLK |  | 310 |
| CK low to valid VB | CKLVB |  | 500 |
| CK low to valid $\overline{\text { ALL }}$ | CKLALL |  | 300 |
| CK low to valid MSL | CKLMSL |  | 300 |
| CK low to valid DW | CKLDW |  | 310 |
| CK low to valid MFREE low | CKLMFRL |  | 330 |
| CK low to valid MFREE high | CKLMFRH |  | 500 |
| CK low to valid DIN | CKLDIN |  | 310 |
| CK low to valid $\overline{\mathrm{RQQ}}$ | CKLIRQ |  | 1500 |
| CK low to valid WHITE | CKLWHI |  | 530 |
| $\bar{E}$ pulse width, low | tEL | 450 |  |
| $\bar{E}$ pulse width, high | tEH | 430 |  |
| Address pre-setup time | ${ }^{\text {t }}$ AS | 160 |  |
| Address hold time | ${ }^{\text {t }} \mathrm{AH}$ | 10 |  |
| Data pre-setup time (write) | tDSW | 195 |  |
| Data setup time (read) | tDDR |  | 320 |
| Data hold time (read) | tDHR | 10 |  |
| $\overline{\mathrm{RQ}}$ release time | t/R |  | 1600 |
| LPCK high to WHITE high (if command 08 $1_{16}$ ) | LPHW |  | 1600 |
| LPCK high to $\overline{\mathrm{RQ}}$ low | LPHIRQ |  | 1600 |
| LPCK high hold time | tLPCKH | 150 |  |
| CK and $\bar{E}$ rise times | $\mathrm{t}_{\mathrm{r}}$ |  | 20 |
| CK and $\overline{\mathrm{E}}$ fall times | $t_{f}$ |  | 20 |

CLOCK AND OUTPUT CHARACTERISTICS

$\overline{\text { IRO RELEASE TIME }}$


MICROPROCESSOR BUS, WRITE ACCESS


MICROPROCESSOR BUS, READ ACCESS


SYNCHRONOUS SIGNALS WITH CK INPUT


LIGHT PEN SIGNALS


## PIN DESCRIPTION


*This pin outputs two items of data multiplexed by signal ALL.

POWER SUPPLY, CLOCK AND OPERATING PARAMETERS

| NAME | $\begin{aligned} & \text { PIN } \\ & \text { TYPE } \end{aligned}$ | $\mathrm{N}^{\circ}$ | FUNCTION | description |
| :---: | :---: | :---: | :---: | :---: |
| VSS | S | 20 | Power supply | Ground |
| $V_{C C}$ | S | 40 | Power supply | + 5 V |
| CK | 1 | 1 | Clock | Master clock. All internal processor states are modified on the falling edge of this signal. The whole circuit logic is static and the cycle of this clock needs only to be ajusted according to the shape and accuracy the synchronizing signals should feature. <br> DAD memory address multiplexing signal. If CK is low, low addresses (or row addresses for the memory) are those that are output on DAD. The frequency of CK is a multiple of the image refresh frequency : - interlaced scanning: $f(C K)=f(1 / 2$ frame $) \times(625$ or 525) $\times 96$ <br> - non-interlaced scanning : $\mathrm{f}(\mathrm{CK})=\mathrm{f}($ frame $) \times(312$ or 262$) \times 96$. |
| FMAT | 1 | 8 | Format | This pin is connected to $V_{C C}, V_{S S}, C K$ or $\overline{C K}$ and sets the number of monitor and image lines: <br> $V_{C C}: 625$ line monitor, interlaced synchronization, 512 lines displayed CK : 525 line monitor, interlaced synchronization, 416 lines displayed <br> $\overline{\mathrm{CK}}: 525$ line monitor, non-interlaced synchro, 208 lines displayed <br> $\mathrm{V}_{\text {SS }}$ : 625 line monitor, non-interlaced synchro, 256 lines displayed. |
| wo | 1 | 23 | Write only | When WO is high, memory refresh nor display no longer exist. The hard wired write processors may operate without being interrupted. The $\overline{\text { ALL }}$ signal is always high. |

## SYNCHRONIZING AND BLANKING SIGNALS

| SYNC | 0 | 34 | Video monitor <br> synchronizing | Video monitor line and frame synchronization signal. For example, if <br> CK is at 1.5 MHz and FMAT is high, signal SYNC is to CCIR 625 line <br> 50 Hz standard. <br> This output is independent of input WO and of register CTRL1. |
| :---: | :---: | :---: | :---: | :--- |
| BLK | 0 | 25 | Blanking | This signal is high apart from the display window (writing or refresh). <br> It is always high if bit 2 in register CTRL1 is high, but it is not affected <br> by the WO input. |
| VB | 0 | 16 | Vertical blanking | This signal is not affected by WO and register CTRL1. High during <br> vertical blanking. |

DISPLAY MEMORY ADDRESSING SIGNALS

| DADO <br> to <br> DAD6 | 0 | 37,39, <br> 38,4 <br> $3,2,5$ | Display address | Addresses that are multiplexed by the CK signal. Provided for the <br> automatic refresh of the 16 K or 64 K dynamic memories. |
| :---: | :---: | :---: | :--- | :--- |
| X9 | 0 | 19 | Memory address | Horizontal pointer extension bit for write operations (horizontal resolu- <br> tions greater than 512). |
| MSL0 <br> to <br> MSL3 | 0 | 6,36 | Memory select | Pixel write select signals (see section : Display memory configuration.) |
| $\overline{\text { ALL }}$ | 0 | 22 | Access to all <br> memory units | This signal makes it possible to discriminate between the collective <br> memory accesses to all chips (display, refresh or erase), and the memory <br> accesses to a single pixel for vector or character writing purposes. <br> This signal is low for collective access. |

DISPLAY MEMORY CONTROL SIGNALS

| NAME | $\begin{aligned} & \text { PIN } \\ & \text { TYPE } \end{aligned}$ | $N^{\circ}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| DIN | 0 | 15 | Display in | Selection of the memory data code corresponding to the display screen in the 'off' condition (active when high). For a black-and-white display (1 bit per pixel), DIN may directly be the storage entry data. |
| $\overline{\text { DW }}$ | 0 | 14 | Display write | Display memory write signal. Active when low. |
| $\overline{M W}$ | 0 | 24 | Memory available | This pin outputs MFREE and $\overline{\text { WHITE signals which are externally de- }}$ multiplexed by signal $\overline{\mathrm{ALL}}: \overline{\mathrm{MFREE}}=\overline{\mathrm{MW}}+\mathrm{ALL} ; \overline{\mathrm{WHITE}}=\overline{\mathrm{MW}}+\overline{\mathrm{ALL}}$ <br> Memory free (MFREE) : <br> Signal low during the next memory idle period following the $0 F_{16}$ command. <br> This signal allows exchanges between the microprocessor and the X and Y flagged memory segment without affecting the display. <br> Forcing to white level ( $\overline{\mathrm{WHITE}}$ ) : <br> Forces white level on video signal, for use of the light pen. Active when low. |

MICROPROCESSOR BUS SIGNALS

| DO-D7 | I/O | 33 <br> to <br> 26 | Data bus | $1 / O$ buffers opening is controlled through $\bar{E}$, and the related direction <br> through $R / \bar{W}$. |
| :---: | :---: | :---: | :---: | :--- |
| AO-A3 | 1 | 9 <br> to <br> 12 | Address bus | Address of the register involved in microprocessor access. |
| $R / \bar{W}$ | 1 | 18 | Read/write signal | Read/write signal. Write when low. |
| $\bar{E}$ | 1 | 17 | Enable | Bus exchange synchronizing and enabling signal. |
| $\overline{I R Q}$ | 0 | 13 | Interrupt request | Interrupt request towards the microprocessor, programmable through <br> register CTRL1. Open drain output. |

## LIGHT PEN OPERATING SIGNALS

| LPCK | 1 | 21 | Light pen <br> strobe | Light pen input. When the mechanism is set, a rising edge loads into <br> registers XLP and YLP the current display address and sets the XLP <br> register's LSB high. |
| :--- | :--- | :--- | :--- | :--- |

## REGISTER DESCRIPTION

X AND Y REGISTERS (Addresses : $8_{16}, \mathbf{9}_{16}, \mathrm{~A}_{16}, \mathrm{~B}_{16}$ )
The $X$ and $Y$ registers are 12-bit read-write registers. They indicate the position of the next dot to be written into the display memory. They have no connection at all with the video signal generating scan, but they point the write address, in the same way as the pen address on a plotter.

These 2 registers are incremented or decremented, prior to each write operation into the display memory, by the internal vector and character generators, or they may be directly positioned by the microprocessor.

This $2 \times 12$ bit write address covers a $4096 \times 4096$ point addressing space. Only the LSBs are used here, since the maximum definition of the picture actually stored is $512 \times$ 1024 pixels (picture elements).

In practice, the GDP assumes that it has a memory space of $1024 \times 512$ (FMAT $=V_{C C}$ or CK) or $1024 \times 256$ (FMAT $=\mathrm{V}_{\text {SS }}$ or $\overline{\mathrm{CK}}$ ) and disables writing outside this space, unless bit 3 of CTRL 1 is set.

The above features along with the relative mode description of all picture component elements make it possible to automatically solve the great majority of edge cut-off problems.

DELTAX AND DELTAY REGISTERS (Addresses : $\mathbf{5}_{16}$, $7{ }_{16}$ ).

The DELTAX and DELTAY registers are 8-bit read-write registers. They indicate to the vector generator the projections of the next vector to be plotted, on the $X$ and $Y$ axes respectively. Such values are unsigned integers. The plotting of a vector is initiated by a write operation in the command register (CMD).

## CSIZE REGISTER (Address: $\mathbf{3}_{\mathbf{1 6}}$ )

The CSIZE register is an 8-bit read-write register. It indicates the scaling factors of $X$ and $Y$ registers for the symbols and characters. 98 characters are generated from a $5 \times 8$ pixel matrix defined by an internal ROM. In the standard version, it contains the alphanumeric characters in the ASCII code which may be printed, together with a number of special symbols.

MSB


LSB

Each symbol can be increased by a factor $P(X)$ or $Q(Y)$. These factors are independent integers which may each vary from 1 to 16 and which are defined by the CSIZE register. The symbol generation sequence is started after writing the ASCII code of the symbol to be represented in the CMD register.

CTRL1 REGISTER (Address: $\mathbf{1}_{16}$ ).
The CTRL 1 register is a 7 -bit read-write register, through which the general circuit operation may be fed with the required parameters.
Bit 0 : When low, this bit inhibits writing in display memory (equivalent to pen or eraser up).
When high, this bit enables writing in display memory (pen or eraser down).
This bit controls the DW output.
Bit 1 : When low, this bit selects the eraser.
When high, this bit selects the pen.
This bit controls the DIN output.
Bit 2 : When low, this bit selects normal writing mode (writing apart from the display and refresh periods, which are a requirement for the dynamic storages) in display memory.
When high, this bit selects the high speed writing mode : the display periods are deleted. Only the dynamic storage refresh periods are retained.

Bit 3 : When low, this bit indicates that the $4096 \times 4096$ space is being used (the 12 X and Y bits are significant) When high, this bit selects the cyclic screen operating mode.
Bit 4 : When low, this bit inhibits the interrupt triggered by the light pen sequence completion. When high, this bit enables the interrupt.

Bit 5 : When low, this bit inhibits the interrupt release by vertical blanking.
When high, this bit enables the interrupt.
Bit 6 : When low, this bit inhibits the interrupt indicating that the system is ready for a new command. When high, this bit enables the interrupt.

Bit 7 : Not used. Always low in read mode.

## CTRL2 REGISTER (Address : $\mathbf{2}_{\mathbf{1 6}}$ )

The CTRL2 register is a 4-bit read/write register, through which the plotting of vectors and characters may be denoted by parameters.

Bit 0, 1 : These 2 bits define 4 types of lines (continuous, dotted, dashed, dash-dotted).

Bit 2 : When low, this bit defines straight writing. When high, it defines tilted characters.

Bit 3 : When low, this bit defines writing along an horizontal line.
When high, this bit defines writing along a vertical line.

Bit 4, 5, 6, 7 : Not used. Always low in read mode.

## CMD COMMAND REGISTER (Address : $0_{16}$ )

The CMD register is an 8 -bit write-only register. Each write operation in this register causes a command to be executed, upon completion of the time necessary for synchronizing the microprocessor access and the GDP's CK clock.

Several types of command are available :

- vector plotting
- character plotting
- screen erase
- light pen circuitry setting
- access to the display memory through an external circuitry.
- indirect modification of the other registers (commands that make it possible for the $X, Y, D E L T A X, ~ D E L T A Y$, CTRL1, CTRL2 and CSIZE registers to be amended or scratched).


## STATUS REGISTER (Address $0_{16}$ or $\mathrm{F}_{16}$ )

The STATUS register is an 8 -bit read-only register. It is used to monitor the status of the executing statements entered into the circuit, and more specifically to avoid the need for modifying a register that is already used for the command currently executing.
Bit 0 : When low, this bit indicates that a light pen sequence is currently executing.
When high, it indicates that no light pen sequence is currently executing.
Bit 1: This bit is high during vertical blanking. It is the VB signal recopy.
Bit 2 : When low, this bit indicates that a command is currently executing.
When high, this bit indicates that the circuit is ready for a new command.
Bit 3 : This bit when low indicates that registers X and Y are pointing within the assumed memory space.
This bit is obtained by applying the logical OR function to the unused most significant bits of registers $X$ and $Y$.
If FMAT $=V_{C C}$ or CK, the assumed memory space is $1024 \times 512$.
If FMAT $=\mathrm{V}_{\mathrm{SS}}$ or $\overline{\mathrm{CK}}$, the assumed memory space is $1024 \times 256$.

Bit 4 : When high, this bit indicates that an interrupt has been initiated by the completion of a light pen running sequence and that this interrupt has been enabled by bit 4 in CTRL1 register.

Bit 5 : When high, this bit indicates that an interrupt has been initiated by vertical blanking and that this interrupt has been enabled by bit 5 in CTRL 1 register.
Bit 6 : When high, this bit indicates that an interrupt has been initiated by the completion of execution of a command and that this interrupt has been enabled by bit 6 in CTRL1 register.
Bit 7 : When high, this bit indicates that an interrupt has been initiated. It is the logic OR of bits 4,5 and 6 in STATUS register. The IRQ output state is always the opposite of the status of this bit.

Note : Bits 4, 5, 6 and 7 are reset low by reading the STATUS register at address $\mathrm{O}_{16}$. Reading at address $\mathrm{F}_{16}$ does not modify their state.

## XLP AND YLP REGISTERS (Addresses $\mathrm{C}_{16}$ and $\mathrm{D}_{16}$ )

The XLP and YLP registers are read-only registers, with 7 and 8 bits respectively. Upon completion of a light pen running sequence, they contain the display address sampled by the first edge appearing rising on the LPCK input. The use of such registers is discussed in section: Use of light pen circuitry.

## NOTES :

1. All internal registers may be read or written at any time by the microprocessor. However, the precautions outlined below should be observed :

- Do not write into the CMD register if execution of the previous command is not completed (bit 2 of STATUS register).
- Do not alter any register if it is used as an input parameter for the internal hardwired systems (e. g. : modifying the DELTAX register while a vector plotting sequence is in progress).
- Do not read a register that is being asynchronously modified by the internal hardwired systems (e.g. :reading the X register while a vector plotting sequence is in progress may be erroneous if CK and $\overline{\mathrm{E}}$ are asynchronous).

2. On powering up, the writing devices may have any status. Before entering a command for the first time, it is necessary to wait until all functions currently underway are completed, which information can be derived from the STATUS register.

## SYSTEM OPERATING PRINCIPLE

DISPLAY MEMORY CONFIGURATION

Assume a $V \times H$ pixel picture. Assume that each pixel is able to adopt $2^{b}$ different states. $A V \times H \times b$ bit display memory is thus required.

In those applications where $H$ features a high value, the video signal frequency exceeds the maximum frequency of memory read access.

Example : $H=512$ with a television line frequency: the pixel succession period on the video signal is 83 ns .

It is mandatory that a line of $\mathbf{H}$ dots be cut into $\mathbf{h}$ adjoining segments of $n$ bits each, read at the same time in the display memory, and thereafter converted to serial form to produce the video signal. $h$ memory accesses per line are necessary. Each access loads $\mathbf{b} \boldsymbol{n}$-bit shift registers. The memory contains $\mathbf{V} \mathbf{x} \mathbf{h} \times \mathbf{b} \mathbf{n}$-bit words.


The EF9367 is designed for the following stored image formats :
$V=512$ or $256(50 \mathrm{~Hz})$
$V^{\prime}=416$ or $208(60 \mathrm{~Hz})$
$H=h \times n$
$H=1024$ or lower multiples of 64
$h=64$
$\mathrm{n}=16,8,4,2,1$ (or any value below 16 using external PROM encoding)
b = any value (addressing is same for all memory planes, management of these planes is external to the GDP).
In so far as the overflow tests are concerned, the circuit assumes that it still has the maximum memory space for
$X$ (1024). The test for $Y$ is effected in the following memory spaces :

512 if $\mathrm{FMAT}=\mathrm{V}_{\mathrm{CC}}$ or $\underline{C K}$
256 if $\mathrm{FMAT}=\mathrm{V}_{\mathrm{SS}}$ or $\overline{\mathrm{CK}}$

512 or $\mathbf{2 5 6}$ vertical resolution : the displayed space is identical to the space in memory (unless a greater memory capacity is deliberately selected).
416 or 208 vertical resolution : the displayed space is smaller than the memory space.

Lines not displayed are displayable using an external adder to dejustify the display addresses (this arrangement may be used for smooth roll-up/roll down.

## DAD AND MSL OUTPUT STATUS TABLES

The internal counters which address the display memory are made up of :

- 6 horizontal address bits ( $\mathrm{h}=64$ )

$$
h_{0}, h_{1}, h_{2}, h_{3}, h_{4}, h_{5} \quad\left(h_{0}=L S B\right)
$$

- 9 vertical address bits ( $\mathrm{V} \leqslant 512$ )
$\mathrm{t}, \mathrm{V}_{0}, \mathrm{~V}_{1}, \mathrm{~V}_{2}, \mathrm{~V}_{3}, \mathrm{~V}_{4}, \mathrm{~V}_{5}, \mathrm{~V}_{6}, \mathrm{~V}_{7}$
$t$ is here the LSB. It denotes the line parity and changes every frame because of interlaced scan. Within a same frame, $\mathrm{V}_{0}$ denotes the LSB.

The write address is made up of the LSBs of the $X$ and $Y$ internal registers.

$$
\begin{aligned}
& X_{0}, X_{1}, X_{2}, X_{3}, X_{4}, X_{5}, X_{6}, X_{7}, X_{8}, X_{9} \\
& Y_{0}, Y_{1}, Y_{2}, Y_{3}, Y_{4}, Y_{5}, Y_{6}, Y_{7}, Y_{8}
\end{aligned}
$$

The GDP produces addressing signals in the sequences shown in the tables opposite :

FMAT $=V_{C C}$ or $C K$

|  |  | MSL |  |  |  | $\mathrm{X}_{9}$ | DAD |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { ALL }}$ | CK | 0 | 1 | 2 | 3 |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 |
| 0 | 0 | $\mathrm{X}_{0}$ | $\mathrm{X}_{1}$ | $\mathrm{X}_{2}$ | $V_{1}$ | $\mathrm{X}_{9}$ | $\mathrm{h}_{5}$ | $\mathrm{h}_{4}$ | $\mathrm{h}_{3}$ | $\mathrm{h}_{2}$ | $\mathrm{h}_{1}$ | $\mathrm{h}_{0}$ | $\mathrm{V}_{0}$ |
| 0 | 1 |  |  |  |  |  | $V_{7}$ | $V_{6}$ | $V_{5}$ | $V_{4}$ | $V_{3}$ | $V_{2}$ | t |
| 1 | 0 | $\mathrm{X}_{0}$ | $\mathrm{X}_{1}$ | $\mathrm{X}_{2}$ | $\mathrm{Y}_{2}$ | $\mathrm{X}_{9}$ | $\mathrm{X}_{8}$ | $\mathrm{X}_{7}$ | $\mathrm{X}_{6}$ | $\mathrm{X}_{5}$ | $\mathrm{X}_{4}$ | $\mathrm{X}_{3}$ | $Y_{1}$ |
| 1 | 1 |  |  |  |  |  | $Y_{8}$ | $\mathrm{Y}_{7}$ | $Y_{6}$ | $Y_{5}$ | $Y_{4}$ | $\mathrm{Y}_{3}$ | $Y_{0}$ |

FMAT $=V_{S S}$ or $\overline{C K}$

|  |  | MSL |  |  |  | X, | DAD |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { ALL }}$ | CK | 0 | 1 | 2 | 3 |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 |
| 0. | 0 | $\mathrm{X}_{0}$ | $\mathrm{X}_{1}$ | $\mathrm{X}_{2}$ | 1 | $\mathrm{X}_{9}$ | $\mathrm{h}_{5}$ | $\mathrm{h}_{4}$ | $\mathrm{h}_{3}$ | $\mathrm{h}_{2}$ | $\mathrm{h}_{1}$ | $\mathrm{h}_{0}$ | $\mathrm{V}_{0}$ |
| 0 | 1 |  |  |  |  |  | $V_{7}$ | $\mathrm{V}_{6}$ | $V_{5}$ | $V_{4}$ | $V_{3}$ | $\mathrm{V}_{2}$ | $V_{1}$ |
| 1 | 0 | $\mathrm{X}_{0}$ | $\mathrm{X}_{1}$ | $\mathrm{X}_{2}$ | 1 | $\mathrm{X}_{9}$ | $\mathrm{X}_{8}$ | $\mathrm{X}_{7}$ | $\mathrm{X}_{6}$ | $\mathrm{X}_{5}$ | $\mathrm{X}_{4}$ | $\mathrm{X}_{3}$ | $\mathrm{Y}_{0}$ |
| 1 | 1 |  |  |  |  |  | $\mathrm{Y}_{7}$ | $\mathrm{Y}_{6}$ | $\mathrm{Y}_{5}$ | $Y_{4}$ | $Y_{3}$ | $Y_{2}$ | $Y_{1}$ |

## DESCRIPTION OF DISPLAYABLE FORMATS

## NON INTERLACED SCANNING

$\mathbf{2 5 6} \times 512$ or $208 \times 512$ pixel formats ( $\mathbf{H}=\mathbf{5 1 2}, \mathrm{n}=8$ ) Input FMAT must be low or connected to $\overline{\mathrm{CK}}$.
The memory is made up of 16 K bytes per memory plane. The byte address is made up of 14 bits which are output on two runs on the DAD pins. The three MSLO, MSL1, MSL2 outputs are used to select one pixel out of the eight featuring the same address. They issue the number of the pixel, encoded on three bits. MSL3 is high, and is not used.
$\mathbf{2 5 6 \times 3 8 4}$ or $\mathbf{2 0 8 \times 3 8 4}$ pixel formats ( $\mathbf{H}=\mathbf{3 8 4}, \mathbf{n}=\mathbf{6}$ )
Input FMAT must be low or connected to $\overline{\mathrm{CK}}$.
The memory is organized as 16 K words $\times 6$ bits.
The signals produced by the chip in the sequence indicated for the $256 \times 512$ format are transcoded externally as shown in the opposite diagram.
$\mathbf{2 5 6} \times \mathbf{3 2 0}$ or $\mathbf{2 0 8} \times \mathbf{3 2 0}$ pixel formats ( $\mathbf{H}=\mathbf{3 2 0}, \mathbf{n}=\mathbf{5}$ )
The same schematic as for 384 horizontal resolution should be used with a memory organized in 5 bit words.

$\mathbf{2 5 6} \times \mathbf{2 5 6}$ or $\mathbf{2 0 8} \times \mathbf{2 5 6}$ pixel formats ( $\mathbf{H}=\mathbf{2 5 6}, \mathrm{n}=\mathbf{4}$ ) Input FMAT must be low or connected to ČK.
The memory is made up of 16 K words $\times 4$ bits. The word address is made up of 14 bits which are output in two runs on the DAD pins. One of the four chips is selected by decoding pins MSL1 and MSL2 (that leads to ignore $X_{0}$ : the $X$ computation space is changed to 2048 pixels and horizontal overflow detected at 512 pixels).

## INTERLACED SCANNING

$512 \times 1024$ or $416 \times 1024$ pixel formats $(H=1024, n=16)$ Input FMAT must be connected to $V_{C C}$ or CK.
The memory comprises 32 K words $\times 16$ bits, organized in two blocks of 16 K words each.
The signals produced by the circuit in the sequence indicated for the $512 \times 512$ format are combined externally as shown at the end of the data sheet.
$512 \times 768$ or $\mathbf{4 1 6 \times 7 6 8}$ pixel formats ( $H=768, n=12$ )
Input FMAT must be connected to $V_{\text {CC }}$ or CK.
The memory comprises 32 K words $\times 12$ bits, organized in two blocks of 16 K words each.

The signals produced by the chip in the sequence indicated for the $512 \times 512$ format are transcoded externally as shown in the diagram below.
$512 \times 640$ or $\mathbf{4 1 6 \times 6 4 0}$ pixel formats $(H=640, n=10)$
The same schematic as below should be used with a memory organized in 10 bit words.

## $512 \times 512$ or $416 \times 512$ pixel formats $(H=512, n=8)$

The FMAT input should be tied to $V_{C C}$ or CK. The memo$r y$ is made up of $V x h$ bytes $=32 \mathrm{~K}$ bytes per memory plane.
The byte address is made up of 15 bits :

- 14 are output in 2 runs on the DAD pins for the purpose of using $16 \mathrm{~K} \times 1$ bit dynamic RAMs,
- the 15 th one is output on pin MSL3.

The 3 MSLO, 1 and 2 outputs allow to select one pixel out of the 8 featuring the same address, for pixel-to-pixel write applications. They issue the number of the involved pixel, encoded on 3 bits.


## MEMORY OPERATION SEQUENCE

## ALONG ONE FRAME

Apart from the window where the memory is used for display purposes exclusively, write operations may be performed, except during 3 refresh periods.


The three period types, D, W and R, respectively, are indicated outside the circuit through the BLK and ALL signals :

|  | BLK | $\overline{A L L}$ |
| :---: | :---: | :---: |
| $D$ | 0 | 0 |
| $W$ | 1 | 1 |
| $R$ | 1 | 0 |

The refresh of dynamic RAMs is automatically performed by the GDP. During display, the memory is entirely refreshed each 4 lines ( 256 accesses).
During vertical blanking, 3 refresh cycles of 4 lines each are executed.

## Exceptions:

- If bit 2 in register. CTRL1 is high (high speed write), the display period is suppressed and 19 refresh cycles of 4 lines each are executed during one frame.
- As long as the WO input is high, the circuit is set to write mode, and BLK retains the same outline as it has under normal operating conditions.
In these two cases, executing codes $04_{16}, 06_{16}, 07_{16}$ and $\mathrm{OC}_{16}$ triggers a complete D sequence for a highspeed scan of all addresses. This lasts two frames if FMAT is high (or tied to CK) and one frame if FMAT is low (or tied to $\overline{\mathrm{CK}}$ ).


Note : $\overline{A L L}$ signal high denotes write periods.


Nore : $\overline{A L L}$ signal high denotes write periods.

T:CK input period ( 667 ns in typical application where TV line duration is $64 \mu \mathrm{~s}$ )


Note : If FMAT is low or tied to $\overline{\mathrm{CK}}$, the pattern of the second line is repeated for each frame.

## dETAILED LINE DIAGRAM



## HARDWIRED WRITE PROCESSOR OPERATION IN DISPLAY MEMORY

The hardwired write processors are sequenced by the master clock CK. They receive their parameters from the microprocessor bus. They control the $\mathrm{X}, \mathrm{Y}$ write address, and the DIN, $\overline{\mathrm{DW}}, \overline{\mathrm{MW}}$ and $\overline{\mathrm{RO}}$ outputs.

These harwired processors operate in continuous mode. In the event of conflicting access to the display memory, the display and refresh processors have priority.

Since command decoding is synchronous with the CK master clock, any write operation into the (CMD) command register triggers a synchronizing mechanism which engages the circuit for a maximum of 2 CK cycles when the $\bar{E}$ input returns high. The circuit remains engaged throughout command execution.

No further command should be entered as long as bit 2 in STATUS register is low.

## VECTOR PLOTtING

The internal vector generator makes it possible to modify, within the display memory, all the dots which form the approximation of a straight line segment. All vectors plotted are described by the origin dot and the projections on the axes.

The starting point co-ordinates are defined by the $\mathrm{X}, \mathrm{Y}$ register value, prior to the plotting operation.
Projections onto the axes are defined as absolute values by the DELTAX and DELTAY registers, with the sign in the command byte that initiates the vector plotting process.

The vector approximation achieved here is that established by J. F. BRESENHAM ("Algorithm for computer control of a digital plotter"). This algorithm is executed by a hardwired processor which allows for a further vector component dot to be written in each CK clock cycle.

During plotting, the display memory is addressed by the $X, Y$ registers, which are incremented or decremented.

On completion of vector plotting, they point to the end of this vector.

All vectors may be plotted using any of the following line patterns : continuous, dotted, dashed, dash-dotted, according to the 2 LSBs in register CTRL2.

Irrespective of such patterns, the plotting speed remains unchanged. The "pen down-pen up"' statement required for plotting non-continuous lines is controlled by the $\overline{D W}$ output.

For a specified non-continuous line plotted vector, defined by DELTAX, DELTAY, CTRL2, CMD, the DW sequencing during the plotting process is always the same, irrespective of vector origin and of the nature of previous plots. This feature guarantees that a specified vector can be deleted by plotting it again after moving $X$ and $Y$ to the starting point, and complementing bit 1 in register CTRL1.

Since the vector plotting initiation command defines the sign of the projections onto the axes, all vectors may be plotted using 4 different commands.

For increased programming flexibility, the system incorporates 16 different commands, supplemented by a set of 128 commands which make it possible to plot small size vectors by ignoring the DELTAX and DELTAY registers.

Such commands are as follows :

- Basic commands

- Commands which allow ignoring the DELTAX or DELTAY registers by considering them as of zero value.


Note : Bits 1 and 2 always have the same sign meaning.
These 8 codes may be summarized by the following diagram :


- Commands which allow ignoring the smaller of the two DELTAX and DELTAY registers, by considering it as being equal to the larger one, which is the same as plotting vectors parallel to the axes or diagonals, using a single DELTA register.


Same direction codes as above.

- Commands in which the two registers DELTAX and DELTAY may be ignored by specifying the projections through the CMD register ( 0 to 3 steps for each projection).


| Origin: $\left\{\begin{array}{l}X=47_{10} \\ Y=75_{10}\end{array}\right.$ | $C M D=13_{16}$ | Corresponding to <br> - Basic command, <br> - DELTAX $<0$ <br> - DELTAY $>0$ |
| :---: | :---: | :---: |
|  | CTRL1 $=03_{16}$ | Pen down |
| $\text { Projections: }\left\{\begin{array}{l} \text { DELTAX }=17_{10} \\ \text { DELTAY }=13_{10} \end{array}\right.$ | CTRL2 $=1{ }_{16}$ | Dotted vector : <br> 2 dots on, <br> 2 dots off. |

Plotting cycle sequence : (It is assumed that the vector generator is not interrupted by the display or refresh cycle).



Display shows :

- unmodified dot

O dot on

## Note :

Plotting a vector with DELTAX $=$ DELTAY $=0$ writes the dot $\mathrm{X}, \mathrm{Y}$ in memory. It occupies the vector generator for synchronization, initialization and one write cycle.

## CHARACTER AND SYMBOL GENERATOR

The character generator operates in the same way as the vector generator, i.e. through incrementing or decrementing the $\mathrm{X}, \mathrm{Y}$ registers, in conjunction with a $\overline{\mathrm{DW}}$ output control.

It receives parameters from the CSIZE, CTRL2 and CMD registers. The characters plotted are selected, according to the CMD value, out of 98 matrices ( 978 -dot high $\times 5$-dot wide rectangular matrices, and one 4 dot $\times 4$ dot matrix) defined in an internal ROM. Two scaling factors may be applied to the characters plotted using X and Y defined by the CSIZE register. The characters may be tilted, according to the content of register CTRL2.

## Basic matrix

Upon completion of a character writing process, the X and Y registers are positioned for writing a further character next to the previous one, with a 1 dot spacing, i.e. $Y$ is restored to its original value and $X$ is incremented by 6 .

Origin

- Unchanged
$\odot$ Altered dots


Computed dots, not defined into the ROM (not modifiable).

## Scaling factors

Each individual dot in the $5 \times 8$ basic matrix may be replaced by a $P \times Q$ size block.
$P: X$ co-ordinate scaling factor
$\mathrm{Q}: \mathrm{Y}$ co-ordinate scaling factor
The character size becomes $5 P \times 80$. Upon completion of the writing process, $X$ is incremented by $6 P$. The CK clock cycle count required is $6 \mathrm{P} \times 8 \mathrm{Q}$.
$P$ and $Q$ may each take values from 1 through 16. They are defined by the CSIZE register. Each value is encoded on 4 bits, value 16 being encoded as $0_{16}$.

In register CSIZE, $P$ is encoded on the 4 MSBs and $Q$ on the 4 LSBs.

Among the 97 rectangular matrices available in the standard ROM, 96 correspond to CMD values ranging from $20_{16}$ to $7 \mathrm{~F}_{16}$, and the 97 th matrix to $0 \mathrm{~A}_{16}$. In the standard version, these values correspond to the 96 printable characters in the ASCII set. The 97th character is a $5 P \times 8 Q$ block which may be used for deleting the other characters.

The 98th code $\left(0 \mathrm{~B}_{16}\right)$ is used to plot a $4 \mathrm{P} \times 4 \mathrm{Q}$ graphic block. It locates $\mathrm{X}, \mathrm{Y}$, without spacing for the next symbol. Such a block makes it possible to pad uniform areas on the screen.

$\odot$ Modified dots
$\times$ Computed dot not defined in ROM (not modifiable)

## Tilted characters

All characters may bemodified to produce tilted characters or to mark the vertical co-ordinate with straight or tilted type symbols. Such changes may be achieved using bits 2 and 3 in register CTRL2.

Note : Scaling factors $P$ and $Q$ are always applied within the co-ordinates of the character before conversion.

## Character deletion

A character may be deleted using either the same command code or command code $0 A_{16}$. In either case, bit 1 in register CTRL1 should be inverted, the origin should be the same as prior to a character plotting operation, as should the scaling factors.

Note: Vector generator and character generator operate in similar ways:

|  | VECTOR | CHARACTER |
| :---: | :---: | :---: |
| Dimensions | DELTAX, DELTAY | CSIZE, tilting |
| $\overline{\text { DW }}$ modulation | Type of line | Character code |

## USE OF LIGHT PEN CIRCUITRY

A rising edge on the LPCK input is used to sample the current display address in the XLP and YLP registers, provided that this edge is present in the frame immediately following loading of the $08_{16}$ or $09_{16}$ code into the CMD register.

Here, the frame origin is counted starting with the VB falling edge. With code $08_{16}$, the $\overline{\mathrm{MW}}$ output recopies the BLK signal from the frame origin up to the rising edge on the LPCK input, or when VB starts rising again, if the LPCK input remains low for the entire frame. With code
$09_{16}$, the $\overline{\mathrm{MW}}$ output is not activated.
The YLP address is 8 -bit coded since there are 256 display lines in each frame. The XLP address is 6 -bit coded since there are 64 display cycles in each line.

These 6 bits left-justified in register XLP indicate the number of the segment ( $\mathrm{h}=0$ to 63 ) to which the point indicated by the light pen belongs.

The address sampled into XLP corresponds to the current memory cycle. Dots detected by the light pen were addressed in the memory during the previous cycle. Hence, 1 should be subtracted from bit 2 in XLP register where the light pen electronic circuitry does not produce any additional delay.

If the rising edge on input LPCK occurs while VB is low, then the LSB in XLP is set high. This bit acts as a status signal which is reset to the low state by reading register XLP or YLP.

The rising edge first received (LPCK or VB) sets bit 0 in STATUS register high. An interrupt is initiated if bit 4 in CTRL1 is high.

When commands $08_{16}$ or $09_{16}$ have been decoded, bit 2 of the status register goes high (circuit ready for any further command) and bit 0 goes low (light pen operating sequence underway).

## SCREEN BLANKING COMMANDS

Three commands ( $04_{16}, 06_{16}, 07_{16}$ ) will set the whole display memory to a status corresponding to a "black display screen" condition. Another command ( $\mathrm{OC}_{16}$ ) may be used to set the whole memory to a status other than black (this condition being determined by bit 1 in register CTRL1).

The 4 commands outlined above use the planned scanning of the memory addresses achieved by the display stage. The $X$ and $Y$ registers are not affected by commands $04_{16}$ and $\mathrm{OC}_{16}$. Hence, the time required is that corresponding to one frame (FMAT $=0$ or $\overline{\mathrm{CK}}$ ) or two frames (FMAT $=$ 1 or CK). The time corresponding to the completion of the
frame currently executing when the CMD register is loaded, should be added to the above time.

For the screen blanking process, the frame origin is counted starting with the VB falling edge.
The only signals affected here are the $\overline{\mathrm{DW}}$ output, which remains low when VB is low, and the DIN output which is forced high where the $04_{16}, 06_{16}$ and $07_{16}$ commands are entered.

Such commands are activated without requiring action by WO input or bit 2 in register CTRL1. While these commands are executing, bit 2 in STATUS register remains low.

## EXTERNAL REQUEST FOR DISPLAY MEMORY ACCESS (MW OUTPUT)

On writing code $0 F_{16}$ into the CMD register, the MW output is set low by the circuitry, during the next free memory cycle.

Apart from the display and refresh periods, this cycle is the first complete cycle that occurs after input $\bar{E}$ is reset high.

During this cycle, those addresses output on DAD and MSL correspond to the X and Y register contents : $\overline{\mathrm{DW}}$ is high, $\overline{A L L}$ is high.

Should the memory be engaged in a display or refresh operation, (which is the case when $\overline{A L L}$ is low), then this cycle is postponed to be executed after $\overline{A L L}$ is reset high. The maximum waiting time is thus 64 cycles.

The $\overline{\mathrm{MW}}$ signal may be used e. g. for performing a read or write operation into a register located between the display memory and the microprocessor bus.

## INTERRUPTS OPERATION

An interrupt may be initiated by three situations denoted by internal signals :

- Circuit ready for a further command
- Vertical blanking signal
- Light pen sequence completed.

These three signals appear in real time in the STATUS register (bits $0,1,2$ ). Each signal is cross-referenced to a mask bit in the register CTRL1 (bits $4,5,6$ ).

If the mask bit is high, the first rising edge that occurs on the interrupt initiating signal sets the related interrupt flip-flop circuit high.

The outputs from these three flip-flop circuits appear in the STATUS register (bits $4,5,6$ ). If one flip-flop circuit
is high, bit 7 in the STATUS register is high, and pin $\overline{\mathrm{RO}}$ is forced law.

A read operation in the STATUS register at address $\mathrm{O}_{16}$ resets its 4 MSBs low, after input $\bar{E}$ is reset high (a read at address $F_{16}$ maintains their value).

The three interrupt control flip-flops are duplicated to prevent the loss of an interrupt coming during a read cycle of the STATUS register.

The status of bits 4,5 and 6 corresponds to the interrupt control flip-flop circuit output, before input $\bar{E}$ goes low.

An interrupt coming during a read cycle of the STATUS register does not appear in bits 4,5 and 6 during this read sequence, but during the following one. However, it may appear in bits $0,1,2$ or on pin $\overline{\mathrm{RQ}}$.

TABLE 1 - REGISTER ADDRESS

| ADDRESS REGISTER |  |  |  |  | REGISTER FUNCTIONS |  | Number <br> of bits |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Binary |  |  |  | Hexa | $\begin{gathered} \text { Read } \\ R / \bar{W}=1 \end{gathered}$ | Write$R / \bar{W}=0$ |  |
| A3 | A2 | A1 | AO |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | STATUS | CMD | 8 |
| 0 | 0 | 0 | 1 | 1 | CTRL 1 (Write control and interrupt control) |  | 7 |
| 0 | 0 | 1 | 0 | 2 | CTRL 2 (Vector and symbol type control) |  | 4 |
| 0 | 0 | 1 | 1 | 3 | CSIZE (Character size) |  | 8 |
| 0 | 1 | 0 | 0 | 4 | Reserved |  | - |
| 0 | 1 | 0 | 1 | 5 | DELTAX |  | 8 |
| 0 | 1 | 1 | 0 | 6 | Reserved |  | - |
| 0 | 1 | 1 | 1 | 7 | DELTAY |  | 8 |
| 1 | 0 | 0 | 0 | 8 | $\times \mathrm{MSBs}$ |  | 4 |
| 1 | 0 | 0 | 1 | 9 | $\times \quad$ LSBs |  | 8 |
| 1 | 0 | 1 | 0 | A | $Y$ MSBs |  | 4 |
| 1 | 0 | 1 | 1 | B | $Y$ LSBs |  | 8 |
| 1 | 1 | 0 | 0 | C | XLP (Light-pen) | Reserved | 7 |
| 1 | 1 | 0 | 1 | D | YLP (Light-pen) | Reserved | 8 |
| 1 | 1 | 1 | 0 | E | Reserved |  | - |
| 1 | 1 | 1 | 1 | F | STATUS | Reserved | 8 |

Reserved: These addresses are reserved for future versions of the circuit. In read mode, output buffers Do-D7 force a high state on the data bus.

TABLE 2 - COMMAND REGISTER


## OTHER REGISTERS

## STATUS REGISTER (Read only)



## CONTROL REGISTER 1 (Read/Write)



CONTROL REGISTER 2 (Read/Write)


## C-SIZE REGISTER (Read/Write)



P and Q may take any value between 1 and 16 . This value is given by the leftmost or rightmost 4 bits for $P$ and $Q$ respectively. Binary value ( 0 ) means 16.

X AND Y REGISTERS (Read/Write)


The 4 leftmost MSBs are always 0 .

## XLP and YLP REGISTERS



ASCII CHARACTER GENERATOR ( $5 \times 8$ matrix)

| b7 | 0 | 0 | 0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| b6 | 0 | 0 | 1 | 1 | 1 | 1 |
| b5 | 1 | 1 | 0 | 0 | 1 | 1 |
| b4 | 0 | 1 | 0 | 1 | 0 | 1 |



$\begin{aligned} \text { Note : } & \text { FMAT }=V_{C C}: 512 \times 512 \text { resolution }-50 \mathrm{~Hz} 625 \text { line interlaced scanning } \\ & \text { FMAT }=C K: 416 \times 512 \text { resolution }-60 \mathrm{~Hz} 525 \text { line interlaced scanning. }\end{aligned}$

EXAMPLE OF A COLOR APPLICATION : $\mathbf{2 0 8 \times 5 1 2}$ or $\mathbf{2 5 6 \times 5 1 2}$
Eight colours may be obtained from the three basic colours red (R), green (G), blue (B)


Note: $F M A T=V_{\text {SS }}: 256 \times 512$ resolution $\mathbf{5 0 ~ H z ~} 625$ line non interlaced scanning FMAT $=\overline{C K}: 208 \times 512$ resolution -60 Hz 525 line non interlaced scanning.
(See page 30 for MUX command law)


Note: FMAT $=V_{C C}: 512 \times 1024$ resolution -50 Hz 625 line interlaced scanning
FMAT $=$ CK : $416 \times 1024$ resolution -60 Hz 525 line interlaced scanning.
(See page 30 for PROM encoding)


Note: $F$ MAT $=V_{C C}: 512 \times 640$ resolution -50 Hz 625 line interlaced scanning.
FMAT $=$ CK $: 416 \times 640$ resolution -60 Hz 525 line interlaced scanning.

## MUX COMMAND LAW

Following table indicates MUX command principles.

| Selected MUX input |  |  |  | Output | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read cycles |  | Write cycles |  | Address bit |  |
| $\overline{\text { RAS }}$ | $\overline{\text { CAS }}$ | $\overline{\text { RAS }}$ | $\overline{\text { CAS }}$ |  |  |
| DAD6 | DAD6 | DAD6 | DAD6 | $\mathrm{A}_{0}$ | No MUX |
| DAD5 $\left(\mathrm{h}_{0}\right)$ | DAD5 | DAD4 $\left(X_{4}\right)$ | DAD5 | $\mathrm{A}_{1}$ |  |
| DAD4 $\mathrm{h}_{1}$ ) | DAD4 | DAD3( $\mathrm{X}_{5}$ ) | DAD4 | $\mathrm{A}_{2}$ |  |
| DAD3 $\left(\mathrm{h}_{2}\right)$ | DAD3 | DAD2 $\mathrm{X}_{6}$ ) | DAD3 | $\mathrm{A}_{3}$ |  |
| DAD2 $\left(\mathrm{h}_{3}\right)$ | DAD2 | DAD1 $\left(X_{7}\right)$ | DAD2 | $\mathrm{A}_{4}$ |  |
| DAD1 $\left(h_{4}\right)$ | DAD1 | DADO( $\mathrm{X}_{8}$ ) | DAD1 | $\mathrm{A}_{5}$ | identically |
| DADO $\left(h_{5}\right)$ | DADO | X | DADO | $\mathrm{A}_{6}$ | 1 |
| MSL3 | PAGE | MSL3 | PAGE | $\mathrm{A}_{7}$ | Driven by CMD2 |

## PROM CODING PRINCIPLES

The PROM coding consists in the use of the 10 horizon: tal address bits ( $\mathrm{X}_{0}, \cdots, X_{9}$ ) to access the 640 pixels (organized in 64 segments of 10 pixels each).

The 4 bits ( $b_{0}, b_{1}, b_{2}, b_{3}$ ) are coding decimal numbers. Parity is maintained by BCD coding ; $X_{0}$ signal is therefore not coded inside the PROM and provides directly $b_{0}$.

Example : Considering the pixel with decimal abscissa $X=378$ (17A in hexadecimal). This pixel is inside the 38th segment ( $h=37 \mathrm{dec}$. or 25 hex.) with an abscissa $x=8$.

The binary number 0101111010 (17A hex.) must be encoded into 1001011000 (258 hex.).
This principle allows transcoding of all horizontal address values. Transcoding must only be active (PROM selection) during write cycles ( $\overline{\mathrm{A} L \mathrm{~L}}=1$ ) when horizontal addresses are output ( $\overline{\mathrm{RAS}}$ ).

Note : This transcoding system may be adapted to other horizontal resolutions as $320,384,768$. Horizontal resolutions are multiples of 64 .


## PHYSICAL DIMENSIONS

CB-182


C SUFFIX
CERAMIC PACKAGE


P SUFFIX
PLASTIC PACKAGE



The EF9369 single chip palette provides a low cost, yet remarkable enhancement for any low to mid-range color graphics application. It allows displaying up to 16 different colors, each of these colors being freely selected out of 4096 preset values. EF9369 contains a 16 register color look-up table, three 4-bit D/A converters and a microprocessor interface for color loading.

- On chip color look-up table
- 4096 color palette ( 16 colors selected from 4096)
- On-chip three 4 -bit resolution video DACs with $\gamma$ law correction
- Dot rate up to 30 Megadots per second
- Marking bit for inlay purpose
- Versatile microprocessor interface :
- directly compatible with address/data multiplexed 8-bit microprocessor bus such as 6801, EF6805CT, 8051...
- directly compatible with non-multiplexed 8 or 16-bit microprocessor bus (6809, 6502, 68008...).
- Single 5 V supply
- HMOS 2 technology.


## HMOS2

SINGLE CHIP COLOR PALETTE


CB-520


FN SUFFIX PLCC 28

## PIN ASSIGNMENT



MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}{ }^{*}$ | -0.3 to 7.0 | V |
| Input voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | -0.3 to 7.0 | V |
| Operating temperature range | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature range | $\mathrm{T}_{\text {stg }}$ | -55 to 150 | ${ }^{\circ} \mathrm{C}$ |
| Max power dissipation | $\mathrm{P}_{\mathrm{Dm}}$ | 0.45 | W |

Stresses above those hereby listed may cause permanent damage to the device. The ratings are stress ones only and functional operation of the device at these or any conditions bey. ond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard MOS circuits handling procedure should be used to avoid possible damage to the device.
*With respect to $V_{\text {SS }}$

## ELECTRICAL OPERATING CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $V_{\text {cc }}$ | 4.75 | 5 | 5.25 | V |
| A nalog supply voltage | VDDC | - | $V_{\text {cc }}$ | TBD | $V$ |
| Analog supply current | IDDC | - | 20 | - | mA |
| Input low voltage | $V_{\text {IL }}$ | -0.3 | - | 0.8 | V |
| Input high voltage RESET All other inputs | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & 3 \\ & 2 \\ & \hline \end{aligned}$ | $-$ | VCC <br> VCC | V |
| Input leakage current | 1 in | - | - | 20 | $\mu \mathrm{A}$ |
| Output high voltage ( 1 load $=-500 \mu \mathrm{~A}$ ) | V OH | 2.4 | - | - | V |
| Output low voltage ( ${ }_{\text {load }}=1.6 \mathrm{~mA}$ ) | VOL | - | - | 0.4 | V |
| Power dissipation | $P_{\text {D }}$ | - | 250 | - | mW |
| Input capacitance | $\mathrm{C}_{\text {in }}$ | - | - | 15 | pF |
| Three state (off state) input current | ITSI | - | - | 10 | $\mu \mathrm{A}$ |

Test load for digital output

Test point


Test load for analog output


|  | $A D(0: 7)$ | $M$ |
| :---: | :---: | :---: |
| $C$ | 100 pF | 50 pF |
| $\mathrm{R}_{\mathrm{L}}$ | $1 \mathrm{~K} \Omega$ | $3.3 \mathrm{~K} \Omega$ |
| $R$ | $4.7 \mathrm{~K} \Omega$ | $4.7 \mathrm{~K} \Omega$ |

MICROPROCESSOR INTERFACE TIMING AD(0:7), AS, DS, R/ $\bar{W}, \overline{C S}$, CSO
$V_{C C}=5.0 \pm 5 \%, T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ on $\mathrm{AD}(0: 7)$
Reference levels: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}$ on all inputs; $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ on all outputs.

| Ident. number | Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Cycle time | ${ }^{t} \mathrm{CYC}$ | 400 | - | - | ns |
| 1 b | DS pulse width high time | tPWEX | 200 | - | - | ns |
| 1c | DS pulse width low time (Timing 3) | tPWEL | 100 | - | 10000 | ns |
| 2 | DS low to AS high (timing 1) DS high or R/W high to AS high (timing 2) | ${ }^{\text {t }}$ ASD | 30 | - | - | ns |
| 3 | AS low to DS high (timing 1) <br> AS low to DS low or R/W low (timing 2) | ${ }^{\text {t ASE D }}$ | 30 | - | - | ns |
| 4 | Write pulse width | tPWEH | 200 | - | - | ns |
| 5 | AS pulse width | tPWASH | 100 | - | - | ns |
| 6 | $\mathrm{R} / \overline{\mathrm{W}}$ to DS setup time (timing 1) | trwS | 100 | - | - | ns |
| 6b | $\mathrm{R} / \overline{\mathrm{W}}, \mathrm{AS}, \overline{\mathrm{CS}}, \mathrm{CS}$, to DS setup time (timing 3) |  | 100 | - | - |  |
| 7 | R/W to DS hold time (timing 1) | ${ }^{\text {t RWW }}$ | 10 | - | - | ns |
| 8 | Address and $\overline{\mathrm{CS}}$, CSO setup time | ${ }_{\text {t }}^{\text {ASL }}$ | 20 | - | - | ns |
| 9 | Address and $\overline{\text { CS, }}$, CSO hold time | ${ }^{\text {t } A H L}$ | 20 | - | - | ns |
| 10 | Data setup time (write cycle) | ${ }^{\text {t DSW }}$ | 100 | - | - | ns |
| 11 | Data hold time (write cycle) | ${ }^{\text {t DHiW }}$ | 10 | - | - | ns |
| 12 | Data access time from DS (read cycle) | ${ }^{\text {t DDR }}$ | - | - | 150 | ns |
| 13 | DS inactive to high impedance state time (read cycle) | ${ }^{\text {t }}$ DHR | 10 | - | 80 | ns |
| 14 | Address to data valid access time | tacc | - | - | 300 | ns |

TIMING DIAGRAM 1 - MULTIPLEXED MODE - MOTOROLA TYPE (SMI = VSS)




DIGITAL VIDEO SIGNALS - HP, P(0:3), BLK, M, RESET
$\mathrm{V}_{\mathrm{CC}}=5.0 \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ on M .
Reference levels: $\mathrm{V}_{\text {IL }}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$ on all inputs;
$\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{VOH}_{\mathrm{OH}}=2.4 \mathrm{~V}$ on all outputs.

| Characteristic | Symbol | EF9369 |  | EF9369-30 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| HP clock period | tp | 58 | 1000 | 33 | 1000 | ns |
| HP high pulse width | tPWEH | 25 | - | 13 | - | ns |
| HP low pulse width | tPWEL | 25 | - | 13 | - | ns |
| BLK and $P(0: 3)$ set up time to HP | tSU | 5 | - | 5 | - | ns |
| BLK and $P(0: 3)$ hold time from HP | tho | 10 | - | 10 | - | ns |
| M output delay from HP | tD | - | 45 | - | 30 | ns |
| RESET high pulse width | tPWRL | 400 | - | 400 | - | ns |

TIMING DIAGRAM 4


## ANALOG VIDEO OUTPUTS - CA, CB, CC

$V_{D C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ}$ to $+70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=\mathbf{2 0} \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=100 \mathrm{k} \Omega$

TABLE 1

| Binary input |  | Analog output (V) |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |
| Low level | 0000 | - | 0.8 | - |
|  | 0001 | - | 1.18 | - |
|  | 0010 | - | 1.28 | - |
|  | 0011 | - | 1.36 | - |
|  | 0100 | - | 1.42 | - |
|  | 0101 | - | 1.47 | - |
|  | 0110 | - | 1.52 | - |
|  | 0111 | - | 1.56 | - |
|  | 1000 | - | 1.60 | - |
|  | 1001 | - | 1.63 | - |
|  | 1010 | - | 1.66 | - |
|  | 1011 | - | 1.69 | - |
|  | 1100 | - | 1.72 | - |
|  | 1101 | - | 1.75 | - |
|  | 1110 | - | 1.78 | - |
| High level | 1111 | - | 1.80 | - |

## Note:

The internal A/D converters deliver on CA, CB and CC outputs 16 levels with $\gamma$ law correction ( $\gamma=2.8$ ). The typical transfer characteristic is given by :

$$
V=\left(\frac{N}{15}\right) \frac{1}{2.8} \cdot \frac{V_{D D C}}{5}+0.16 V_{D C C}
$$

Where $N$ is the binary input value.
The typical analog video output impedance is $300 \Omega$ for EF9369-30 and $400 \Omega$ for EF9369.

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CA, CB, CC outputs from HP | tDA | - | 80 | - | ns |

TIMING DIAGRAM 5



## PIN DESCRIPTION

## MICROPROCESSOR INTERFACE

All the input/output pins are TTL compatible.

| NAME | $\begin{aligned} & \text { PIN } \\ & \text { TYPE } \end{aligned}$ | $\mathrm{N}^{\circ}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| AD(0:7) | 1/0 | $\begin{gathered} 8-11-14 \\ 15-17 \end{gathered}$ | Multiplexed address/data bus | These 8 bidirectional pins are to be connected to the microprocessor system bus. |
| SMI | 1 | 3 | Interface mode select | When this input is connected to $\mathrm{V}_{\mathrm{C}}$, the EF9369 is in the non multiplexed mode. <br> When this input is connected to $\mathrm{V}_{\mathrm{SS}}$ (ground), the EF9369 is in a multiplexed mode to provide a direct interface with either Motorola or Intel type microprocessor. |
| AS | 1 | 22 | Address strobe | In non-multiplexed mode, this input selects either the address register ( $\mathrm{AS}=1$ ) or the data register $(\mathrm{AS}=0)$ to be accessed. <br> In multiplexed mode, the falling edge of this control signal latches the address on the $A D(0: 7)$ lines, the state of the Data Strobe (DS) and Chip Select lines ( $\overline{\mathrm{CS}}, \mathrm{CSO}$ ). When using Intel type microprocessor, this input must be connected to the ALE control line. |
| DS | 1 | 20 | Data strobe | In non-multiplexed mode, this active high control signal enables the $A D(0: 7)$ input/output buffers and strobes data to/from the EF9369. This signal is usually derived from the processor E ( $\phi 2$ ) clock. <br> In multiplexed mode, the input is strobed by the falling edge of AS. The strobe value selects either Motorola or Intel type. When using an Intel type microprocessor, DS must be connected to the $\overline{\mathrm{RD}}$ control line. With a Motorola type microprocessor, DS must be connected to $\mathrm{E}(\phi 2)$ clock. |
| $\mathrm{R} / \overline{\mathrm{W}}$ | 1 | 21 | Read/Write | This control signal determines whether the EF9369 is read ( $R / \bar{W}=1$ ) or written ( $R / \bar{W}=0$ ). When using Intel type microprocessor, this input must be connected to the $\overline{W R}$ control line. |
| $\begin{gathered} \overline{\mathrm{CS}} \\ \mathrm{CSO} \end{gathered}$ | 1 | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | Chip Select | $\overline{\mathrm{CS}}$ must be low and CS0 must be high to select the EF9369. In non-multiplexed mode, the EF9369 remains selected as long as the selection condition is met. <br> In multiplexed mode, the selection condition is latched when AS is low. |


| NAME | $\begin{aligned} & \text { PIN } \\ & \text { TYPE } \end{aligned}$ | $\mathbf{N}^{\circ}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $P(0: 3)$ | 1 | 24-27 | Pixel inputs | These four TTL compatible inputs are strobed by HP into the color index register to address the color look-up table. |
| HP | 1 | 28 | Dot clock | The rising edge of this input latches the $\mathrm{P}(0: 3)$ and BLK inputs into the EF9369 and the data out of the color look-up table into the output registers. |
| M | 0 | 7 | Marking | This output is synchronised by HP and delivers the marking bit value from the color look-up table. |
| CA <br> CB <br> CC | 0 | $\begin{aligned} & 5 \\ & 6 \\ & 4 \end{aligned}$ | Color outputs | These three analog high impedance outputs deliver the color signal levels from the internal D/A converters (DAC). The delay between CA, CB, CC outputs and the latched value $P(0: 3)$ is one HP clock period plus tDA (see Timing Diagram 5). |
| BLK | 1 | 23 | Blanking | A high level on this input forces the CA, CB, CC and M outputs to low level. |
| RESET | 1 | 10 | Reset | This active high input forces the CA, CB, CC, outputs to low level until the next microprocessor access to the device. |

OTHER PINS

| $V_{C C}$ | $S$ | 9 | Power supply | +5 V. |
| :--- | :--- | :--- | :--- | :--- |
| $V_{D D C}$ | S | 2 | Analog power <br> supply | Power supply for the internal DACs. This input can be con- <br> nected to $V_{C C}$. |
| $V_{S S}$ | S | 1 | Power supply | Ground. |

EF9369 contains a 16 register Color-Look Up Table (CLUT). Each of these 13 -bit register holds three 4 -bit color fields CA (0:3), CB $(0: 3)$ and $C C(0: 3)$ and a marking bit M.

These registers can be accessed (read or write) by the microprocessor through the microprocessor interface. These registers are also read by the video process : a 4-bit pixel value and a clock must be provided at pixel rate to the $P(0: 3)$ and $H P$ input pins. These signals may be delivered either by 4 video shift registers and the shifting clock of a bit map CRT controller or by an alphanumeric or semigraphic CRT controller. The pixel value, after clock resynchronisation, is used as a color index : it selects one out of the 16 CLUT registers. Each color field of the selected register is converted to an analog signal and delivered to one of the CA, CB or CC output. The marking bit is directly routed to the M output. When the CA, CB and CC outputs are used as RGB analog signals, one color out of 4096 is associated to each pixel value. In short this process freely maps a 16 color index set into a 4096 color set.

## MICROPROCESSOR INTERFACE

The 8 -bit microprocessor interface gives access (read or write) to the CLUT which is addressed as a 32 byte table. The 13 -bit color register \# $N(N=0$ to 15$)$ is accessed at address $2 N$ and $2 N+1$. Even address holds CA ( $0: 3$ ) and $C B(0: 3)$, odd address holds $C C(0: 3)$ and $M$ (see fig. 1).
EF9369 provides two bus modes through the SMI programming pin :

- Multiplexed mode for address/data multiplexed 8-bit microprocessor bus.
- Non-multiplexed mode for non-multiplexed 8 or 16 bit microprocessor bus.


## MULTIPLEXED MODE (SMI connected to VSS)

In this mode, EF9369 can be directly connected to popular address/data multiplexed microprocessor, either Motorola type (6801, EF6805CT...) or Intel type (8048, 8051, 8088..). In this last case the EF9369 AS, DS and $\mathrm{R} / \overline{\mathrm{W}}$ inputs must be connected respectively to the ALE, $\overline{\mathrm{RD}}$ and $\overline{W R}$ microprocessor control lines.
figure 1 - clut addressing


[^51]In this mode, EF9369 maps into the microprocessor addressing space as 32 CLUT byte address. Random access to one byte takes one cycle : on the falling edge of the AS input, EF9369 latches AD (0:7) into the on-chip address register, the DS and chip select lines into dedicated flip-flops. The strobed value of DS allows recognition of Intel or Motorola type for further processing. (See pin description section and microprocessor timing diagrams for details). When the EF9369 chip select lines enable selection, the addressed byte is accessed during the data phase of the cycle.

## NON MULTIPLEXED MODE (SMI connected to VCC)

In this mode EF9369 can be directly connected to any 8 or 16-bit, non multiplexed, microprocessor bus (6800, $6809,6502,68008 \ldots$...).

This mode provides an indirect, auto-incremented addressing scheme. EF9369 maps into the microprocessor addressing space as 2 byte address only. AS is used to select one out of 2 registers :

- the write only address register ( 5 bits) addressed when $A S=1$.
- the read/write data register ( 8 bits) addressed when $A S=0$.
Random access to a CLUT byte takes two bus cycles:
1 Load the CLUT address into the address register. 2/ Access (read or write) the value in the data register.
After each access to the data register, the address register is automatically incremented modulo 32. This scheme allows sequential addressing to the CLUT without address reioading, the complete CLUT can so be reloaded in 33 bus cycles.


## VIDEO PROCESS

The CRT controller sends to EF9369 a pixel value on pins $P(0: 3)$, a pixel rate clock on HP input and a blanking signal on pin BLK. The pixel value is latched into the color index register by the rising edge of HP. The color index register selects one register in the CLUT. The color fields of the selected register are routed to 3 DACs and $M$ is directly routed to the $M$ digital output.

After impedance matching, the CA, CB, and CC outputs can be used to drive a RGB analog color monitor. Alternatively one of these outputs can be used to drive a monochrome monitor thus providing up to 16 gray levels. The marking digital output can be used to drive analog video switches, thus providing video overlay facility on a color per color basis.
The blanking input forces the analog outputs and the $M$ output to low level thus allowing the beam to be switched off during retrace intervals.

## NOTES

1. Each $4 \mathrm{bit}-\mathrm{D} / \mathrm{A}$ converter is $\gamma$ corrected in order to linearize the luminance driven on the screen versus the digital value. The typical digital to voltage conversion law is given table 1. The output voltages are proportionnal to the analog supply voltage VDDC. When required, setting $V_{D C C}$ allows a gain adjustment. But in most applications, VDDC and VDD can be derived from the same supply through independent decoupling.
2. $\mathrm{CA}, \mathrm{CB}$ and CC are high impedance outputs ( $500 \Omega$ typical) which require proper adaptation in most applications. THOMSON SEMICONDUCTORS TEA 5114 provides such a $1 \mathrm{~V}-75 \Omega$ low cost adaptation. (See fig. 2).
3. As the CLUT is shared between microprocessor access and video access, a low level is forced on the CA, CB, $C C$ and $M$ outputs during any chip select periods. To avoid to spoil the screen with black strokes it is recommended to access the CLUT from the microprocessor only during the retrace periods.
4. RESET - This input forces CA, CB, CC and $M$ outputs to a low level until the next microprocessor access. At power on or at the beginning of a session RESET allows to keep a clean black screen until proper initialization.


INTERFACE WITH EF6B05CT



NOTE : Each digital or analog ground must be separately connected to EF9369 pin 1. (See AN-059).


P SUFFIX PLASTIC PACKAGE



## ADVANCE INFORMATION

The TS68483 is an advanced color graphic processor that drastically reduces the CPU software overhead for all graphic tasks in medium and high range graphic applications such as business and personal computer, industrial monitoring system and CAD systems.

- Fully programmable timing generator.
- Alphanumeric and graphic drawing capability.
- Easy to use and powerful command set:
- VECTOR, ARC, CIRCLE with dot or pen concept and programmable line style,
- Flexible area fill command with tiling pattern,
- Very fast block move operation,
- Character drawing command, any size and fonts available.
- Large frame buffer addressing space ( 8 megabyte) up to 16 planes of $2048 \times 2048$.
- Up to 256 color capabilities.
- Mask bit planes for general clipping purpose.
- Frame buffer can be built with standard 64 K or 256 K DRAM or Dual-Port-Memories (Video-RAM).
- External Synchronization capability.
- On chip video shift registers for Dot rate lessthan 15 Megadots/s.
- 8 or 16-bit bus interface compatible with market standard microprocessors.
- HMOS 2 technology.
- 68-pin PLCC package.


HMOS2

## ADVANCED GRAPHIC AND ALPHANUMERIC CONTROLLER

CASES
CB-523


FN SUFFIX
PLCC 68
CB-710


E SUFFIX
LCCC 68


## SECTION 1 GENERAL OPERATION

### 1.1 INTRODUCTION

THOMSON SEMICONDUCTEURS TS68483 is an advanced color graphics controller chip. It is directly compatible with most popular 8 or 16-bit microprocessors.
Its display memory, containing the frame buffer and the character generators, may be assembled from standard dynamic RAM components.
On-chip video shift registers and fully programmable Video Timing Generator allow the TS68483 to be used in a wide range of terminals or computer design.


DISPLAY MEMORY INTERFACE

## MICROPROCESSOR INTERFACE

| Name | PIN <br> Type | $N^{\circ}$ | Function | Description |
| :---: | :---: | :---: | :---: | :---: |
| D(0:15) | 1/O | $\begin{aligned} & 6-18 \\ & 22-24 \end{aligned}$ | Data bus | These sixteen bidirectional pins provide communication with either an 8 or 16 -bit host microprocessor data bus. |
| $A(0: 7)$ | I | 37-30 | Address bus | These eight pins select the internal register to be accessed. The address can be latched by AE for direct connection to address/data multiplexed microprocessor busses. |
| $A E$ | 1 | 29 | Address Enable | When TS68483 is connected to a non-multiplexed microprocessor bus, this input must be wired to VCC. <br> For direct connection to a multiplexed microprocessor bus, the falling edge of AE latches the address on $\mathrm{A}(0: 7)$ pins and the $\overline{\mathrm{CS}}$ input. With an Intel type microprocessor $A E$ is connected to the processor Address Latch Enable (ALE) signal. |
| $\overline{\mathrm{DS}}$ | 1 | 26 | Data strobe | Active low <br> - In non-multiplexed bus mode, $\overline{\mathrm{DS}}$ low enables the bidirectionnal data buffers and latches the $\mathrm{A}(0: 7)$ lines on its high to low transition. Data to be written are latched on the rising edge of this signal. <br> - In multiplexed bus mode, this signal low enables the output data buffers during a read cycle. With Intel microprocessors, this pin is connected to the RD signal. |
| R/ $\bar{W}$ | I | 28 | Read/Write | - In non-multiplexed bus mode, this signal controls the direction of data flow through the bidirectional data buffers. <br> - In multiplexed bus mode, this signal low enables the input data buffers. The entering data are latched on its rising edge. With Intel microprocessors, this pin is connected to the $\overline{W R}$ signal. |
| $\overline{\mathrm{CS}}$ | 1 | 25 | Chip select | This input selects the TS68483 registers for the current bus cycle. A low level corresponds to an asserted chip select. In multiplexed mode, this input is strobed by AE. |
| $\widehat{\text { RQ }}$ | 0 | 38 | Interrupt Request | This active-low open drain output acts to interrupt the microprocessor. |

## MEMORY INTERFACE

| Name | PIN <br> Type | $N^{\circ}$ | Function | Description |
| :--- | :--- | :--- | :--- | :--- |
| ADM $(0: 15)$ | $1 / \mathrm{O}$ | $44-51$ <br> $53-60$ | Address/Data <br> Memory | These multiplexed pins act as address and data bus for display memory interface. |
| CYS | O | 65 | Memory Cycle Start | The falling edge of this output indicates the beginning of a memory cycle. |
| $\mathrm{Y}(0: 2)$ | O | $62-64$ | Memory Address | These outputs provide the least significant bits of the Y logical address. |
| $\mathrm{B}(0: 1)$ | O | $66-67$ | Bank number | These outputs provide the number of the memory bank to be accessed during the <br> current memory cycle. |
| $\mathrm{CYF}(0: 1)$ | O | 68.1 | Memory Cycle Status | These outputs indicate the nature of the current memory cycle (Read. Write. Refresh. <br> Display). |

## VIDEO INTERFACE

| Name | PIN <br> Type | $N^{\circ}$ | Function | Description |
| :--- | :--- | :--- | :--- | :--- |
| P(0:3) | 0 | $39-42$ | Video Shift Register <br> Outputs | These four pins correspond to the outputs of the internal video shift registers. |
| PC/HS | 0 | 5 | Phase comparator/ <br> Horizontal sync. | This output can be programmed to provide either the phase comparator output or the <br> horizontal sync. signal. |
| HVS/VS | 0 | 4 | Composite or <br> Vertical sync. | This output can be programmed to provide either the composite sync. signal or the <br> vertical sync. signal. |
| SYNC IN | 1 | 3 | External Sync <br> Input | This input receives an external composite sync. signal to synchronize TS68483. <br> This input must ge grounded if not used. |
| BLK | 0 | 2 | Blanking | This output provides the blanking interval information. |

## OTHER PINS

| Name | PIN <br> Type | $\mathbf{N}^{\mathbf{o}}$ | Function |  |
| :--- | :--- | :--- | :--- | :--- |
| VCC | S | 52 | Power supply | +5 V supply |
| VSS | S | 19 | Ground | Ground |
| CLK | 1 | 43 | Clock | Clock input |

### 1.2 TYPICAL APPLICATION BUILDING BLOCKS (See figure 1.1.)

In a typical application using TS68483, a host processor drives a display unit which drives in turn a color CRT monitor. The display unit consists of four hardware building blocks:

- an TS68483 advanced graphics controller,
- a display memory (dynamic RAM).
- a display memory interface, comprising a few TTL parts,
- a CRT interface or CRT drivers.

For enhanced graphics, the CRT interface may include a color look-up table circuit such as EF9369. For high pixel rate (over $15 \mathrm{Mpixels} / \mathrm{s}$ ), the CRT interface must include high speed video shift registers.
The display memory interface and organization are discussed in full details in the User's Manual.

### 1.3 TS68483 FUNCTIONS

All the TS68483 functions are under the control of the host microprocessor via 24 directly accessible 16 -bit registers. These registers are referred to by their decimal index (R0-R23). See figure 1.2


FIGURE 1.2. - REGISTER MAP

1. Video timing and display processor (R4 to R10)

The video timing generator is fully programmable: any popular horizontal scanning period from $20 \mu \mathrm{~s}$ to $64 \mu \mathrm{~s}$ may be freely combined with any number of lines per field (up to 1024). The address of the display viewport (this part of the display memory to be actually displayed on the screen) is fully programmable. The display processor provides the display dynamic RAM refresh (see video timing generator section for details).
2. Drawing and access commands (RO to F3, R12 to R23)

The 16 remaining registers are used to specify a comprehensive set of commands. The highly orthogonal drawing command set allows the user to "draw" in the display memory such basic patterns as lines, arcs, polylines, polyarcs, rectangles and characters. Efficient procedures are available for either area filling and tiling or line drawing and texturing. Lines may be drawn with a PEN in order to get thick strokes. Any drawing is specified in a $2^{13} \times 2^{13}$ drawing coordinate system.

To access the display memory, the host microprocessor has an indirect, sequential access to any "window". Access commands can be used to load the character generators as well as to load or save arbitrary windows stored in the frame buffer.

### 1.4 DATA TYPE DEFINITIONS

PIXEL: this is the smallest color spot displayable on the CRT.
PEL: a Picture Element is the coding of a PIXEL in the display memory. The TS68483 can handle 4 different PEL formats:

| -4 color bits | - short |
| :--- | :--- |
| -4 color bits +1 mask bit | - short masked |
| -8 color bits | long |
| -8 color bits +1 mask bit | - long masked |

DRAWING COORDINATES: (See figure 1.3.)
The drawing commands are specified and computed in a $2^{13} \times 2^{13}$ cyclical coordinate system. The drawing coordinates are clipped and mapped into the $2^{11} \times 2^{11}$ display memory addressing space. Further clipping to the actual frame buffer size may be performed by the user designed memory interface.



FIGURE 1.3. - CYCLICAL DRAWING COORDINATES TO DISPLAY MEMORY MAPPING

DISPLAY MEMORY:
This is the private memory dedicated to the display unit. This memory is addressed as four banks of 4-bit plane each.

## BIT PLANE:

Each bit plane has a maximum capacity of $2^{11} \times 2^{11}$ bits. A byte wide organization of each bit plane is required.

MEMORY ADDRESS: (See figure 1.4.)
In order to address one bit in the display memory, the user must specify:

- A bank number (2 bits) $\quad B=0$ to 3
- A bit plane number (2 bits)
$Z=0$ to 3
- A $Y$ address (11 bits)
$Y=0$ to 2047
- An $X$ address (11 bits) $X=0$ to 2047

MEMORY WORD: (See figure 1.4.)
A 32-bit memory word can be either read or written during each memory cycle (8 CLK periods), one byte at a time in each bit plane in the addressed bank. The memory bandwidth is in the 6 to $8 \mathrm{Mbytes} / \mathrm{s}$ range.


THE MEMORY WORD



BANK 1


BANK 2


BANK 3

4 BANKS OF 4-BIT PLANES EACH

FIGURE 1.4. - THE DISPLAY MEMORY ADDRESSING SPACE

## VIEWPORT:

This is any rectangular array of pels located in the display memory.

## FRAME BUFFER:

This is the biggest viewport which can be held in the display memory. The frame buffer maps a window at the origin of the drawing coordinates. A short pel frame buffer may be located in any bank. A long pel frame buffer must be located in the "bank 0, bank 1" pair.
DISPLAY VIEWPORT:
This is the viewport which is displayed on screen.

## MASK BIT PLANE:

When masked pels are used, a mask bit plane must be associated to a frame buffer. Mask bit planes may be located in any plane of bank 3.
CELL:
A CELL is any pattern stored in the display memory as a rectangular array of bit mapped elements. The drawing of any CELL may be specified with a scaling factor.

## CHARACTER:

This is a one bit per element CELL. It may be stored in any bit plane, then colored and drawn in a frame buffer by use of PRINT CHARACTER command.

## OBJECT:

This is a one short pel per element CELL. It may be drawn or loaded in a frame buffer. A source mask bit may be associated to each element. An OBJECT may then be printed in another location by use of a PRINT OBJECT command. PEN:
This is the pattern which is repeatedly drawn along the coordinates defined by either a LINE or an ARC command. The PEN may be a DOT (single pel), a CHARACTER or an OBJECT.

## SECTION 2

## COMMANDS

### 2.1. INTRODUCTION

The command set is strongly organized in five subset or command types
DRAWING COMMANDS:

- LINEAR (line, arc)
- AREA (rectangle, trapezium, polygon, polyarc)
- PRINT CELL (print character, print object)


## ACCESS COMMANDS

CONTROL COMMANDS (move cursor, abort)
The commands are parametered; this means that any command can be executed with options freely selected out of a given option set. This option set is common for any command of a given type. For example, any drawing command may be parametered for destination mask bit use.

COMMAND SET STRUCTURE

| Command | Drawing mode | Type | Group |
| :--- | :--- | :--- | :--- |
| Line <br> Arc | Up to the pen | Linear |  |
| Rectangle <br> Trapezium <br> Polygon <br> Polyarc | Monochrome | Area | Drawing |
| Print char <br> Print object | Bichrome <br> Polychrome | Cell |  |
| Load viewport <br> Save viewport <br> Modify viewport | - | Access |  |
| Move cursor <br> Abort | - | Control |  |

FIGURE 2.1. - COMMAND SET STRUCTURE

The command code also defines the command type and its parameters. A command is completely defined when a value has been set for each of its arguments.
These arguments are:

- the geometric arguments given in the drawing coordinate system for every drawing command. They are automatically mapped into the destination frame buffer;
- the parametric values are the values required by the selected parameters;
- the attribute values are the other values required by a drawing command; colors or scaling factors for example;
- the display memory addresses.

The command code is specified in register RO. Before initiating a command execution, each argument must be specified in its dedicated register: - an Xd, Yd drawing coordinate pair for example, is always located in registers R14, R15.
The monitoring of a command execution is done by reading the status register R12 or using the $\overline{\mathrm{RQ}}$ signal.

### 2.2. POINTERS AND GEOMETRIC ARGUMENTS

Pointers are used to specify main geometric arguments and display memory addresses.

### 2.2.1. Display memory address

A bit in the display memory is addressed by:

- a bank number $B=0$ to 3
- a plane number $\quad Z=0$ to 3
- an $X$ address $\quad X=0$ to 2047
- a $Y$ address $\quad Y=0$ to 2047


### 2.2.2. Destination pointer: registers R14 to R17

This pointer gives the coordinate ( $\mathrm{Xd}, \mathrm{Yd}$ ) and dimension (DXd, DYd) of either a line or a window in the drawing coordinate system. These drawing coordinates are easily mapped into a PEL DISPLAY MEMORY address.
( $\mathrm{X}, \mathrm{Y}$ ) coordinates are clipped to 11 bits in order to get the Xd, Yd destination pel addresses.
A bank number Bd must be explicitly provided to address a destination frame buffer. When long pels are used, Bd must be even.
When masked pels are used, the destination mask plane number Zd (implicitly in bank 3) must also be provided.

### 2.2.3. Source pointer: registers R20 to R23

A source cell such as a character, a pen or an object, is addressed by the source pointer in the display memory.
A source pointer specifies:

- a bank number $\mathrm{Bs}=0$ to 3
- a $Y$ S address $Y s=0$ to 2047
- an Xs address; this address is a byte address so that the 3 LSBs are not specified $\mathrm{Xs}=0$ to 255
- a cell dimension DXs, DYs
- a bit plane address Zs.

When a character is addressed, Zs gives the plane number into the bank Bs . When an object is addressed Zs gives the source mask plane number in the bank B3.

FIGURE 2.2. - POINTERS


NOTE: Sign value: $\bullet S=0$ : positive

- $S=1$ : negative + absolute value


### 2.2.4. Notes

1. The TRAPEZIUM command makes a special use of R21. In this case. R21 holds an X1 drawing coordinate which has the same format as $X d$.
2. The ARC and POLYARC commands require two extra geometric parameters (RAD and STOP). They are specified in the drawing coordinates system and stored in registers R18, R19.
3. Any drawing command may be parametered to use short incremental dimensions, DXY in register R13 instead of the standard DXd, DYd in the "R16, R17" register pair. (See figure 2.3).
4. The access commands use the destination pointer location as a data buffer. The memory addresses and dimension of the access viewport are then specified in the source pointer, independently of the data transfer.
5. DXd, DYd and DYs may specify a negative value. In this case, they must be coded by a sign ( $0=$ positive, $1=$ negative) and an 11-bit absolute value.


FIGURE 2.3. - SHORT DIMENSION REGISTER R13

### 2.3. DESTINATION MASK AND SOURCE MASK

A mask bit may be associated to any pel stored in the display memory.

### 2.3.1. Destination mask use (DMU)

Any drawing command may be parametered for destination mask use. In this case, any destination pel cannot be modified when its mask bit is reset.

In other words:
When the destination mask use (DMU) parameter is set:

- a pel may be modified when its mask bit is set
- a pel cannot be modified when its mask bit is reset.

When the destination mask use (DMU) parameter is cleared:

- a pel may be modified, independently of its mask bit value.

This provides a very flexible clipping mechanism not restricted to rectangular windows. (See destination pointer section for destination mask bit addressing).

### 2.3.2. Source mask use (SMU)

A PRINT OBJECT command may be parametered for source mask use. In this case, the source mask bit associated with any source pel is read first. When its mask bit is cleared, a source pel is considered as transparent. (See source pointer section for source mask bit addressing).
In other words:
When the SMU parameter is set, the color of a destination pel, mapped by a given source pel, may take this source color value only when this source bit mask is set. The destination pel keeps its own color value when the source bit mask is cleared.
When the SMU parameter is cleared, a source pel color may be mapped into destination pel color independently of the source bit mask value.

The source bit mask acts as a TRANSPARENCY/OPACITY flag which is enabled by SMU. A PRINT OBJECT command may be independently parametered by both SMU and DMU. This provides a very powerful tiling, print object or meve mechanism.

### 2.4. DRAWING ATTRIBUTES

The general drawing attributes are the colors, the drawing mode, and the scaling factor.

### 2.4.1. Colors: registers R1 and R2 (See figure 2.4.)

Two 8-bit color values, C0 and C1, may be specified in registers R1 and R2. The low order 4-bit nibble of a color value is drawn in an even bank. The high order color nibble is drawn in an odd bank. When long pels are used, banks 0 and 1 are generally addressed as the frame buffer. When short pels are used, any bank may hold a frame buffer. In this case, the bank parity selects the color nibble used. (See destination pointer section for bank addressing).


FIGURE 2.4. - COLOR REGISTER

### 2.4.2. Drawing mode: register RO

The drawing mode defines the transforms to be applied to the pels designated by the drawing commands. There are three drawing modes.

### 2.4.3. Monochrome mode

Any AREA drawing command, RECTANGLE for instance, defines through its geometric arguments an active set of destination pels, that is to say a set of pels to be modified.
When $D M U=1$, this active set is further reduced by the masking mechanism to only these destination pels with a bit mask set.
The active destination pels are then modified according to two elementary transforms coded in RO.

COLOR TRANSFORM:
The color value $C$ of each active pel is modified according to one color transform selected out of four:

- 00 - printed in $\mathrm{CO}: \mathrm{C} \leftarrow \mathrm{CO}$
- 01 - printed in $\mathrm{C} 1: \mathrm{C} \leftarrow \mathrm{C} 1$
- 10 - printed in "transparent": $C \leftarrow C$
- 11 - complemented: $\mathrm{C} \leftarrow \overline{\mathrm{C}}$.

This yields to a reversible marker mode.
MASK BIT TRANSFORM:
The destination mask bit of each active pel is modified according to one mask transform selected out of four:

- 00 - reset bit mask: $M \leftarrow 0$
- 01 - set bit mask: $\mathrm{M} \leftarrow 1$
- 10 - no modification: $\mathrm{M} \leftarrow \mathrm{M}$
- 11 - complement bit mask: $M \leftarrow \bar{M}$.

This scheme allows the color bits and the mask bit of any pel belonging to the active set to be modified independently. The color transform is performed first.

### 2.4.4. Bichrome mode

A PRINT CHARACTER command is more complex because it involves two different active sets: FOREGROUND and BACKGROUND.

The FOREGROUND is that set of destination pels printed from set elements in the character cell. The BACKGROUND is made of all the remaining pels belonging to the destination window

When $D M U=1$, the FOREGROUND and BACKGROUND are further reduced by the destination masking mechanism. (See figure 2.6).
A bichrome drawing mode is defined by 4 elementary and independent transforms: (see figure 2.5)

- a color transform
- a mask transform

For the FOREGROUND PELS

- a color transform
- la mask transform

For the BACKGROUNG PELS


FIGURE 2.5. - DRAWING MODE REGISTER RO


SUMMARY


FIGURE 2.6. - PRINT CHARACTER COMMAND

### 2.4.5. Polychrome mode

A print object command defines a source window through the source pointer:
When $\mathrm{SMU}=0$, any pel of this window is active, mapped and clipped to the destination window dimension.
When $S M U=1$, only pels which have a source mask bit set are active, mapped and clipped to the destination window dimension.

In both cases, when $\mathrm{DMU}=1$, the active source pels are further reduced by the destination masking mechanism. Both mask transforms must be programmed at "NO MODIFICATION" for correct operations. (See figure 2.5).

### 2.4.6. The linear drawing command case

A LINE or ARC drawing command may be executed in any drawing mode depending on the PEN.
When the pen is a DOT, this pel is printed at each active coordinate according to monochrome mode.
When the pen is a CELL, this cell is printed at each active coordinate. In the bichrome mode when the cell is a character, and in the polychrome mode when the cell is an object.
For each active coordinates, the active destination set is defined by the cell dimensions (DXs, DYs).
NOTE: when the cell is an object, SMU is not programmable and is implicitly set. A calculated coordinate is active when the rotated LSB linear texture bit in (R3) is set.

### 2.4.7. Scaling factor and cell mapping: (See figure 2.7 et 2.8).

Any cell may be printed with a scaling factor.
This scaling factor is an integer pair $S x, S y=1$ to 16 ,
This scaling factor is interpreted with the PRINT CHARACTER, PRINT OBJECT and LINEAR commands when the pen is a cell. The AREA or ACCESS or LINEAR (DOT) commands are never scaled.
The LINEAR (PEN) command should be used with a scaling factor of 1 because the pen is clipped at DXs, DYs.
The scaling factor is first applied to the source cell before mapping and drawing. The drawing and mapping is processed with sign bit of DYd and DYs values. (See figure 2.8).


| SX or | SY | S |
| :---: | :---: | :---: |
| 0 | 0 | 0 | 1



FIGURE 2.7. - SCALING FACTOR

FIGURE 2.8 - CELL MAPPING VERSUS DYd, DYs SIGN

## Note:

- DXs is always positive
- The DYs sign mirrors the cell
- DXd must be positive with a PRINT CELL command
- DXd and DYd may get any sign with a LINEAR DRAWING command. If a pen is used, these signs are then irrelevant to the pen drawing. The pen is mapped with positive increment values.



### 2.5. COMMAND SET OVERWIEW

### 2.5.1. Linear drawing

LINE (Xd, Yd, DXd, DYd). ARC (Xd, Yd, DXd, DYd, RAD, STOP).
The curve may be drawn with any pen and with any linear texture (register R3). For each set of computed coordinates, R3 is right rotated and the pen is printed when the shifted bit is set.

### 2.5.2. Area drawing

RECT (Xd, Yd, DXd, DYd)
TRAPEZIUM (Xd, Yd, DXd, DYd, X1)
POLYGON (Xd, Yd, DXd, DYd)
POLYARC (Xd, Yd, DXd, DYd, RAD, STOP)
Either RECT or TRAPEZIUM allows to draw directly all the pels inside the boundary.
Any other closed boundaries may be filled by a 3 -step process:

1. The mask bits inside a boundary box must be reset by a RECT command.
2. A sequence of mixed POLYGON and POLYARC commands describing the closed boundary sets the mask bits of the pels inside this boundary.
3. This area may then be painted by a RECTANGLE command defined for a bounding box, with destination masking. It may also be tiled by use of a PRINT CELL command.

Note: the mask bit of any pel lying on the boundary itself is not guaranteed to be set by step 2 .

### 2.5.3. Print cell commands

PRINT CELL (Xd, Yd, DXd, DYd; Xs, Ys, DXs, DYs)
The cell addressed by $X$ s, $Y s, D X s, D Y s$ is scaled then printed at location $X d, Y d$ and clipped at the $d X d, d Y d$ dimensions. When $d X d$, dYd is much larger than DXs, DYs the command may be parametered for repeat drawing.
These commands may also be parametered for destination mask use.
Further more the PRINT OBJECT command may be parametered for source mask use.
These commands have a wide range of applications: text drawing, area tiling, print or move objects, scale and move viewports.

Note: an underlined cell is drawn when the MSB of R23 is set.

### 2.5.4. Access commands

- LOAD VIEWPORT (Xs, Ys, DXs, DYs).
- SAVE VIEWPORT (Xs, Ys, DXs, DYs).
- MODIFY VIEWPORT (Xs, Ys, DXs, DYs).

These commands provide sequential access to a viewport in a frame buffer from the microprocessor data base.
Data are transferred to/from the display memory, word sequentially.
The R14 to R17 registers are used as a two memory word FIFO (memory word is 8 short pels, i.e. 4 bytes).
The source pointer (R20 - R23) is used to address the viewport for all access commands.
When long pels are used, the command must be executed once more when the bank number in R20 has been updated.

### 2.5.5. Command execution

Each on-chip 16-bit register has four addresses. One address is used for plain read or write. The other addresses are used to initiate command execution automatically on completion of the register access.
This scheme allows the command code and its arguments to be loaded or modified in any order. An incremental line drawing command, for example, may be executed again and again with successive incremental dimensions and whithout need to reload the command code itself.

As soon as a command execution is started, the FREE bit is cleared in the STATUS register. This bit is automatically set when the execution is completed.
The commands are generally executed only during retrace intervals. However full time execution is possible when either the display is disabled or video RAM components are used.

### 2.5.6. Status register (See figure 2.9).

This register holds four read-only status bits:

- FREE: this status bit is set when no execution is pending
- VS: vertical synchronisation state
- SEM: this status bit is set when the FIFO memory word is inaccessible to the microprocessor dusing a viewport transfer
- NSEM: this status bit is set when the FIFO memory word is accessible to the microprocessor during a viewport transfer.
Each of these status bits is maskable. The masked status bits are NORed to the $\overline{\mathrm{IRO}}$ output pin.


FIGURE 2.9. - STATUS REGISTER

## SECTION 3 MICROPROCESSOR INTERFACE

### 3.1. INTRODUCTION

The TS68483 is directly compatible with any popular 8 or 16 -bit host microprocessor; either Motorola type ( 6809 . 68008, 68000) or Intel type (8088, 8086).
The host microprocessor has direct access to any of the twenty four 16 -bit on-chip registers through the microprocessor interface pins:

- $D(0: 15)$ : 16 bidirectional data pins.
- $A(0: 7): 8$ address inputs.
- $\overline{\mathrm{AE}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{CS}}: 4$ control inputs.

The twenty four registers are mapped in the host addressing space as 256 byte addresses. (See figure 3.2)

- $A(1: 5)$ select one out of 24 registers.
- AO selects the low order byte $(A O=1)$ or the high order byte $(A O=0)$ of the selected register.
- $\mathrm{A}(6: 7)$ provide the command execution condition.

The host microprocessor bus may be either 8 or 16 -bits wide and may be address/data multiplexed or not.
The two flags MB and BW in the CONFIGURATION register R10 allow the data bus size and multiplexed/non-multiplexed organization to be specified. (See figure 3.1).

| TYPE OF MPU BUS |  | CONF. REG. |  | TS68483 PINS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | BW | MB | AE | $\overline{\mathrm{DS}}$ | $R / \bar{W}$ | AO | $\mathrm{A}(1: 7)$ | $D(8: 15)$ |
| $\begin{aligned} & \text { NON } \\ & \text { MUX } \end{aligned}$ | 16-bit (68000) | 0 | 0 | 1 | $\begin{aligned} & \text { UDS or } \\ & \text { LDS } \end{aligned}$ | R/W | 0 | A(1:7) | $D(8: 15)$ |
|  | 8-bit (68008) | 1 | 0 | 1 | $\overline{\mathrm{DS}}$ | $R / \bar{W}$ | AO | A(1:7) | D(0:7) |
| MUX | 16-bit (8086) | 0 | 1 | ALE | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | 0 | AD(1:7) | AD(8:15) |
|  | 8-bit (8088) | 1 | 1 | ALE | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\text { ADO }}$ | AD(1:7) | AD(0:7) |

FIGURE 3.1. - MPU SELECTION


FIGURE 3.2. - ON-CHIP ADDRESS AND BYTE PACKING

### 3.2. HARDWARE RECOMMENDATIONS (See timing diagrams 1 and 2).

AO-PIN:

1. When using a 16 -bit data bus, the $A 0$ input pin must be grounded. No single byte access can be performed.
2. In order to conform with the high byte/low byte on-chip packing, the $A 0$ input pin must be inverted when using an 8 -bit bus Intel type microprocessor ( 8088 for example).
$A(1: 7), D(0: 7), D(8: 15)$ pins:
3. With any 8 -bit data bus, the $D(0: 7)$ and $D(8: 15)$ pins must be paired in order to demultiplex the low order data bytes. and the high order data bytes.
4. When using address/data multiplexed bus, the $D(0: 7)$ pins are paired with $A(0: 7)$ in order to demultiplex data from address.
$\overline{\mathrm{AE}}, \overline{\mathrm{DS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{CS}}:$
See pin description.

### 3.3. SOFTWARE RECOMMENDATIONS

1. The CONFIGURATION register R10 must be first initialized.

The BW 15 flag is interpreted by the bus interface to recognize an 8-bit/16-bit data bus.
The MB and BW 15 flags are used to decide when to initiate a command execution.
2. Each register byte has 4 addresses in the microprocessor memory map. These 4 addresses differ only by $A(6: 7)$. This scheme allows a 68008 programmer to read or write any data type (byte, word, long word) and automatically initiate or not a command execution at the end of this transfer. The transfer lasts one, two or four bus cycles.
A 68000 programmer is restricted to only word and long word data types. (See figure 3.3).

| ADDRESS |  | EXECUTION CONDITION | DATA TYPE TRANSFER |  |
| :---: | :---: | :---: | :---: | :---: |
| A7 | A6 |  | 8-bit data bus | 16-bit data bus |
| 0 | 0 | No Exec | Any type | Any type |
| 0 | 1 | Exec after a bus cycle | 1 byte | 1 word |
| 1 | 0 | Exec after 2 bus cycles | 1 word | 1 long word |
| 1 | 1 | Exec after 4 bus cycles | 1 long word* | ILLEGAL |

NOTE: Word transfer must respect word boundary.
Long word transfer must respect long word boundary.
*Not available with 8088 MPU type.

FIGURE 3.3. - COMMAND EXECUTION CONDITION


FIGURE 3.4. - INTERFACE WITH EF68000/68008 MPU


FIGURE 3.5. - INTERFACE WITH 8086/8088 MPU

## SECTION 4 <br> THE VIDEO TIMING GENERATOR RAM REFRESH AND DISPLAY PROCESS

### 4.1. INTRODUCTION

The Video Timing Generator is completely synchronous with the CLK input, which provides a pixel shift frequency ( 12 to 15 MHz ). The Video Timing Generator:

- delivers the blanking signal (BLK), the horizontal (HS) and vertical (VS) synchronization signals on respective ouput pins.
- schedules the memory time allocated to the display process, dynamic RAM refresh and command execution,
- is fully programmable
- can be synchronized with an external composite video sync signal connected to the SYNC IN input.


### 4.2. SCAN PARAMETERS (See table 1 and timing diagram 5)

### 4.2.1. Timing units

The time unit of any vertical parameter is the scan line.
The time unit of any horizontal parameter is the memory cycle, which is 8 periods of the CLK input signal.
These two parameters are internally programmed:

- Horizontal sync pulse duration $=7$ cycles
- Vertical sync pulse duration $=2.5$ lines.


### 4.2.2. Blanking interval

The blanking interval starts:

- at the leading edge of the vertical sync pulse. Vertical blanking interval actual duration is 2.5 lines more than the programmed value.
- two cycles before the leading edge of the horizontal sync pulse. The actual horizontal blanking interval duration is 3
cycles more than the programmed value.
NOTE: During the programmed blanking interval, the video output pins $P(0: 3)$ are forced low.


### 4.2.3. Porch and margin color

During the porch interval, the programmable margin color is displayed on the $P(0: 3)$ outputs.
The display process may be disabled by setting DPD flag. This will be interpreted as a porch extension.

### 4.2.4. Memory time sharing (See figure 4.1)

The Video Timing Generator allocates memory cycles to either the display process, RAM refresh or command execution. In this respect, the scan lines per field are split between:

- the DWY displayable lines.

When VRE $=0$, Video RAMs are not used.
The DWY $\times$ DWX cycles in the display interval are allocated to the display process when it is enabled (DPD $=0$ ). When the display process is disabled, these cycles are allocated as for non displayable lines.
When VRE $=1$, one cycle per display line is allocated to the display process. Other cycles are allocated as for non displayable lines. The last period of the BLKX signal may be used to load the internal video RAM shift register.

- the non displayable lines. In one out of nine non displayable lines, DWX cycles are allocated to the refresh process when it is enabled (RFD $=0$ ).
- In Float cycle, an external $X$ address must be provided. The $Y$ address is still provided on $A D M(0: 7)$ and $Y(0: 2)$, while ADM)8:15) are in high impedance state.



### 4.2.5. Command access ratio

This allocation scheme leaves about $50 \%$ of the memory bandwidth for command access when programming a standard TV scan. This ratio drops to the $30 \%$ range when a better monitor is in use ( $32 \mu \mathrm{~s}$ out of $43 \mu \mathrm{~s}$ displayable per line, 360 lines out of 390 for a 60 Hz field rate). The higher resolution means more memory accesses in order to edit a given percentage of the screen area. In this case Video RAMs are very helpful to keep $90 \%$ of the memory bandwidth available for command access.

### 4.3. DISPLAY PROCESS

The Video Timing Generator allocates memory cycles to the Display Processor in order to read the Display Viewport from memory. The Display Viewport upper left corner address is programmable through DIB, YOR and XOR. The display viewport dimensions are related to the display interval of DWY lines by DWX cycles per field.

### 4.3.1. $Y$ addresses

When INE $=0$, the fields are not interlaced. The $Y$ Display Viewport address is initialized with $Y O R$ at the first displayable line then decremented by 1 at each scan line. The Display Viewport is thus DWY pel high.
When INE = 1, the fields are interlaced. The $Y$ Display Viewport address is initialized as shown in the table below. It is then decremented by two at each scan line. The viewport is thus $2 \times$ DWY pel high

|  | EVEN FIELD | ODD FIELD |
| :--- | :---: | :---: |
| YOR EVEN | YOR | YOR +1 |
| YOR ODD | YOR -1 | YOR |

Y Display Viewport address initialization when INE $=1$.

### 4.3.2. $X$ addresses and MODX flags

The X Display Viewport address is initialized with XOR at the first displayable cycle of each displayable line. It is then incremented at each subsequent cycle according to MODX flags.

| MODX1 | MODXO | X INCR | VIDEO SHIFT REGISTER | MEMORY CYCLE TYPE |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | +1 | INTERNAL | READ |
| 0 | 1 | +1 | EXTERNAL | DUMMY READ |
| 1 | 0 | +2 | EXTERNAL | DUMMY READ |
| 1 | 1 | - | EXTERNAL | FLOAT |

- In internal mode, the Display Viewport is 8. DWX pel wide. The on-chip video shift register are used.
- In Dummy read, the memory is read but the on-chip video shift registers are not loaded, instead they retain their margin color. External video shift registers are presumed to be loaded by either 8 pels or 16 pels per cycle according to the programmed increment value.
- In Float cycle, an extenal $X$ address must be provided. The $Y$ address is still provided on ADM(0:7) and $Y(0: 2)$, while $\operatorname{ADM}(8: 15)$ are in high impedance state.
NOTE: See Memory Organization and Memory Timing for further details on the memory cycles.


### 4.3.3. The Video RAM case (VRE $=1$ )

In this case, the last cycle of the horizontal blanking interval is systematically allocated to the display process for DWY scan lines per field.
This cycle bears the scan line address, the bank number and the $X$ address which is always XOR.
MODX must be programmed to use external shift register (Dummy read).

### 4.3.4 PAN and TILT

The host can tilt or pan the Display Viewport through the frame buffer by modifying YOR or XOR arguments. Panning is performed on 8 pel boundaries.

### 4.4. DYNAMIC RAM REFRESH

No memory cycles are explicity allocated to the RAM refresh when RFD $=1$.
When VRE $=0$ and DPD $=0$, the Display Process is supposed to be able to over-refresh dynamic components. This can be done by careful logical to component address mapping. During the remaining non displayable lines, the Display Viewport address continues to be incremented: $Y$ address on each line according to INE, $X$ address initialized by XOR then incremented according to MODX. This Display viewport address is allowed to address the memory for DWX cycles in only one line out of nine for refresh purposes.

When VRE $=1$ or DPD $=1$, any line is processed as a non displayable line with respect to the refresh process.

### 4.5. CONFIGURATION AND EXTERNAL SYNCHRONIZATION

The R10 register holds eight configuration flags. Six of these flags are dedicated to the Video Timing Generator.

- SSP: this flag selects the synchronization output pin configuration:
- NPC, NHVS, NBLK: these three flags invert the PC/HS, HVS/VS and BLK outputs respectively. (Ex.: When NBLK = 1 blanking is active high).

The SYNC IN input pin provides an external composite synchronization signal input from which a Vertical Sync In (VSI) signal is extracted. The SYNC IN signal is sampled on-chip at CLK frequency. Its rising sampled edge is compared to the leading edge of HS. A PC comparison signal is externally available (see SSP and NPC flags).
VSIE: this flag enables VSI to reset the internal line count.
HSIE: this flag enables the rising edge of SYNC IN to act directly on the Video Timing Generator. When the leading edge of HS does not match at 1 clock period a rising edge of SYNC IN, one extended cycle is performed (nine clock periods instead of eight).

| FLAG | OUTPUT PINS |  |
| :---: | :---: | :---: |
|  | PC/HS | HVS/VS |
| SSP $=1$ | HS | VS |
| SSP $=0$ | PC | HVS |


| NAME | NUMBER OF BITS | MINIMUM VALUES | REGISTER | DESCRIPTION | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DWY <br> INE <br> BKY <br> FPY <br> BPY | 10 <br> 1 <br> 5 <br> 5 <br> 8 | $\begin{gathered} 1 \\ - \\ 1 \\ 1 \\ 3 \end{gathered}$ | $\begin{aligned} & \text { R9 } \\ & \text { R8 } \\ & \text { R8 } \\ & \text { R7 } \\ & \text { R6 } \end{aligned}$ | Number of display lines per field Interlace Enable when INE = 1 <br> Number of lines in vertical blanking - 2.5 <br> Number of lines in vertical front porch <br> Number of tines in vertical back porch +2.5 | Vertical scan |
| $\begin{gathered} H \\ \text { FPX } \\ \text { BKX } \\ \text { DWX } \end{gathered}$ | 6 <br> 4 <br> 4 <br> 7 | 19 <br> 3 <br> 4 <br> 3 | $\begin{aligned} & \text { R6 } \\ & \text { R8 } \\ & \text { R8 } \\ & \text { R7 } \end{aligned}$ | Number of double cycles per line <br> Number of cycles in horizontal front porch <br> Number of cycles in horizontal blanking - 3 <br> Number of cycles of the display window | Horizontal scan |
| XOR <br> YOR <br> DIB <br> MODX <br> MC | 8 <br> 11 <br> 2 <br> 2 <br> 4 |  | $\begin{aligned} & \text { R4 } \\ & \text { R5 } \\ & \text { R4 } \\ & \text { R9 } \\ & \text { R4 } \end{aligned}$ | $\mathrm{X}, \mathrm{Y}$ and bank logical address in the display memory of the display viewport upper left corner. <br> Selection of the $X$ addressing mode <br> Margin color | Display process |
| RFD <br> DPD <br> VRE | 1 1 1 |  | R7 <br> R7 <br> R8 | RAM refresh disable when RFD $=1$ <br> Display process disable when DPD $=1$ <br> Video RAM enable when VRE $=1$ | Memory time sharing |

NOTE: One cycle $=8$ periods of CLK clock.
TABLE 1.

## SECTION 5 <br> MEMORY ORGANIZATION

### 5.1. INTRODUCTION

The display memory is logically organized as four banks of 4-bit planes. Thus a bit address in the display memory is given by the quadruplet:
$-B=$ bank number, from 0 to 3
$-Z=$ plane number, from 0 to 3

- $X=$ bit address into the plane. from 0 to 2047
- $\mathrm{Y}=$ bit address into the plane, from 0 to 2047.

In one memory cycle ( 8 CLK periods), the controller can access a memory word. This 32-bit memory word holds one byte from each plane in a given bank. In order to address this memory word, the controller supplies:
$-\mathrm{B}(0: 1)$ : binary value of the bank number

- X(3:10): binary value of the word address
- $\mathrm{Y}(0: 10)$ : binary value of the word address.

Z and $\mathrm{X}(0: 2)$ are not supplied. They give only a bit address in a memory word.

### 5.2. MEMORY CYCLES

24 pins are dedicated to the memory interface.

- ADM $(0: 15)$ : these 16 bidirectional pins are multiplexed three times during a memory cycle (see Timing Diagram 3):
- TA: address period. Output of the $X(3: 11)$ and $Y(3: 11)$ address
- TO: even data period. The even $Z$ bytes are either input or output
- T1: odd data period. The odd $Z$ bytes are either input or output.
- Y(0:2): three LSB $Y$ address output pins (non-multiplexed)
- $\mathrm{B}(0: 1)$ : two bank address output pins (non-multiplexed)
- CYS: Cycle start strobe output (non-multiplexed).

CYS is at CLK/8 frequency. A CYS pulse is delivered only when a command, display or refresh cycle is performed.

- CYF(0:1): Two cycle status outputs (non-multiplexed). Four cycle types are defined:
- Command read
- Command write
- RAM refresh
- Display access.

Because several options may be selected for RAM refresh and display access by the MODX and VRE flags (see Video Timing Section), there are more than four memory cycle types (see Timing Diagram 3 and Table 2).

### 5.3. DISPLAY MEMORY DESING OVERVIEW

The display memory implementation is application dependant. The basic parameters are:

- the number of pixels to be displayed $N x . N y$
- the number of bits per pel
- the vertical scanning frequency, which must be picked in the 40 Hz to 80 Hz range (non interlaced) or in the 60 Hz to 80 Hz range (interlaced).

This yields a rough estimate of the pixel frequency. When the pixel frequency is in the 12 to 15 MHz range and 4 bits per pixel or least are required, the on-chip video registers and standard dynamic RAM components may be used. When higher pixel rates or up to 8 bits per pixel are required, the designer must provide external shift registers. Video RAM components may also be considered.
In either case, the user must design:

- A memory block. This is the hardware memory building block. It includes the video shift registers if on-chip VSR cannot be used. It implies a RAM component choice.
- An Address Mapper, which maps the logical address into hardware address: block selection, Row Address (RAD). Column Address (CAD).
- A memory cycle controller. This controller monitors the CYF and CYS output pins from TS68483 and block address from the Mapper. It provides:
- The CLK signal to the TS68483 and a shift clock SCLK when external video shift registers are used
- $\overline{\mathrm{RAS}}, \overline{\mathrm{CAS}}, \overline{\mathrm{OE}}, \mathrm{R} / \overline{\mathrm{W}}$ signals to the memory blocks
- RAD and CAD Enable signals to the Mapper.


### 5.3.1. Frame buffer (See figure 5.1.)

A byte wide organization of each bit plane is required. Obviously a bit plane must contain the Display Viewport size. A straight organization implements only one bit plane per block.
It may be cost effective to implement several bit planes per block. Two basic schemes may be used:

- One block, one $Z$ : several bit planes, belonging to different banks, but addressed by the same $Z$, share a given block. There is little time constraint if any.
- One block, two Z: two bit planes, belonging to the same bank share a given block. In this case, this block must be accessed twice during a memory cycle. This can be solved by two successive page mode accesses.


ONE BLOCK-ONE Z


ONE BLOCK-TWO Z

| TYPICAL BLOCK SIZE | $16 \mathrm{~K} \times 8$ | $32 \mathrm{~K} \times 8$ | $64 \mathrm{~K} \times 8$ | $256 \mathrm{8} \times 8$ |
| :--- | :---: | :---: | :---: | :---: |
| ONE BLOCK-ONE BIT PLANE | $512 \times 256$ | $512 \times 512$ | $1024 \times 512$ | $2048 \times 1024$ |
| ONE BLOCK-TWO BIT PLANES | $256 \times 256$ | $512 \times 256$ | $512 \times 512$ | - |

COMPONENTS:
64 K BITS: $16 \mathrm{~K} \times 4$ or $64 \mathrm{~K} \times 1$
256 K BITS: $32 \mathrm{~K} \times 8.64 \mathrm{~K} \times 4,256 \mathrm{~K} \times 1$
VIDEO RAM: $64 \mathrm{~K} \times 1,64 \mathrm{~K} \times 4$
FIGURE 5.1. - FRAME BUFFER ORGANIZATION

| OUTPUT PINS |  | FUNCTION | MODX <br> FLAGS <br> 10 | MULTIPLEXED ADM |  |  | CYCLE TYPE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CYF1 | CYFO |  |  | TA | TO | T1 |  |
| 1 | 0 | COMMAND READ | - | Y, X | Z0, Z2 | Z1, Z 3 | READ |
| 1 | 1 | COMMAND WRITE | - | Y, X | Z0, Z2 | Z1. 23 | WRITE |
| 0 | 1 | DISPLAY | $\begin{array}{ll} 0 & 0 \\ 0 & 1 \end{array}$ | $\begin{aligned} & Y, X \\ & Y, X \end{aligned}$ | $\text { ZO. } 7.2$ | $\mathrm{Z1}, \mathrm{Z3}$ | $\begin{gathered} \text { READ } \\ \text { DUMMY READ + } 1 \end{gathered}$ |
| 0 | 0 | REFRESH | $\begin{array}{ll} 1 & 0 \\ 1 & 1 \end{array}$ | $\begin{gathered} \text { Y, X } \\ \mathrm{Y}, \mathrm{Hi}-\mathrm{Z} \end{gathered}$ | - | - | $\begin{aligned} & \text { DUMMY READ }+2 \\ & \text { FLOATX } \end{aligned}$ |

Refresh: dummy read cycle is performed.


TABLE 2. - MEMORY CYCLE TYPES


HIGHER BYTES
LOWER BYTES

FIGURE 5.2. - THE MULTIPLEXING SCHEME

### 5.3.2. Masking planes

Masking planes are very useful for general purpose area filling or clipping. It may be practical to use one or two planes smaller than the color bit plane if they cyclically cover a frame buffer.
The masking planes must be in bank 3.

### 5.3.3. Objects and characters

Objects may be located in unused parts of the frame buffer.
Character generators can be implemented in any plane of any bank. They can also be implemented in ROM. In this case, plane $Z=1$ or 3 offer relaxed access time requirements.

### 5.4. EXAMPLES

Figure 5.3. gives the schematic for a $512 \times 384$ non interlaced application. A CLK signal in the 13 to 15 MHz range should produce a 50 to 60 Hz refresh rate. The on-chip video shift registers may be used if no more than four bits per pixel are required. One $64 \mathrm{~K} \times 8$ memory block may be implemented using either eight $64 \mathrm{~K} \times 1$ or two $64 \mathrm{~K} \times 4$ components. One memory block holds two $512 \times 384$ color bit planes.



FIGURE 5.3. - MEMORY ORGANIZATION FOR $512 \times 384$ APPLICATION

## SECTION 6

TIMING DIAGRAM

### 6.1. MICROPROCESSOR INTERFACE

TS68483 has an eight bit address bus and a sixteen bit data bus. Little external logic is needed to adapt bus control signals from most of the common multiplexed or non-multiplexed bus microprocessors.
Microprocessor interface timing: $A(0: 7), D(0: 15), A E, \overline{D S}, \overline{C S}, R \bar{W}$
$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T A=T L$ to $T H, C L=100 \mathrm{pF}$ on $\mathrm{D}(0: 15)$
Reference levels: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}$ on all inputs
$\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{VOH}=2.4 \mathrm{~V}$ on all outputs

UNMUX MODE

| Id. numb. | Characteristic | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 | Address set up time from $\overline{\mathrm{CS}}$ | 30 | - | ns |
| 2 | Data strobe width (High) | 150 | - | ns |
| 3 | $\overline{\mathrm{AS}}$ set up time from $\overline{\mathrm{CS}}$ | 0 | - | ns |
| 4 | Data strobe width-low (Read cycle) | 240 | - | hs |
| 5 | Address hold time from $\overline{\mathrm{DS}}$ | 0 | - | ns |
| 6 | Data access time from $\overline{\mathrm{CS}}$ (Read cycle) | - | 210 | ns |
| 7 | $\overline{\text { DS }}$ inactive to high impedance state (Read cycle) | 10 | 100 | ns |
| 8 | R//W set up time from $\overline{\text { DS }}$ | 20 | - | ns |
| 9 | $\overline{\mathrm{DS}}$ width-low (Write cycle) | 110 | - | ns |
| 10 | $\overline{\mathrm{CS}}$ set up time from $\overline{\mathrm{DS}}$ active (Write cycle) | 0 | - | ns |
| 11 | Data in set up time from $\overline{\mathrm{DS}}$ active (Write cycle) | 10 | - | ns |
| 12 | Data in hold time from $\overline{\mathrm{DS}}$ inactive (Write cycle) | 30 | - | ns |

UNMUX MODE


WRITE CYCLE

Microprocessor interface timing: $\mathrm{A}(0: 7), \mathrm{D}(0: 15), \mathrm{AE}, \overline{\mathrm{DS}}, \overline{\mathrm{CS}}, \mathrm{R} / \bar{W}$
$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}$ to $T H, C L=100 \mathrm{pF}$ on $\mathrm{D}(0: 15)$
Reference levels: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}$ on all inputs

$$
\mathrm{VOL}=0.4 \mathrm{~V} \text { and } \mathrm{VOH}=2.4 \mathrm{~V} \text { on all outputs }
$$

MUX MODE

| Id. numb. | Characteristic | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 | AE width high | 90 | - | ns |
| 2 | Address set up time to $A E$ inactive | 55 | - | ns |
| 3 | Address and $\overline{C S}$ hold time to $A E$ inactive | 55 | - | ns |
| 4 | $\overline{C S}$ set up time to $A E$ inactive | 40 | - | ns |
| 5 | $\overline{\mathrm{DS}}$ and $\mathrm{R} / \overline{\mathrm{W}}$ high | 150 | - | ns |
| 6 | $\overline{\mathrm{DS}}$ width-low (Read) | 240 | - | ns |
| 7 | R/ $\bar{W}$ width-low (Write) | 110 | - | ns |
| 8 | Data access time from $\overline{\mathrm{DS}}$ (Read) | - | 210 | ns |
| 9 | Data in set up time from R/W inactive (Write) | 150 | - | ns |
| 10 | $\overline{\mathrm{DS}}$ inactive to high impedance state (Read) | 10 | 100 | ns |
| 11 | Data in hold time from $\mathrm{R} / \overline{\mathrm{W}}$ inactive (Write) | 30 | - | ns |
| 12 | $A E$ inactive to $\overline{D S}$ active | 20 | - | ns |
| 13 | $A E$ inactive to $R / \bar{W}$ active | 20 | - | ns |
| 14 | $\overline{\mathrm{DS}}$ inactive to $A E$ active | 10 | - | ns |
| 15 | $R / \bar{W}$ inactive to $A E$ active | 10 | - | ns |
| 16 | $\mathrm{R} / \overline{\mathrm{W}}$ inactive to next address valid | 100 | - | ns |
| 17 | $\overline{\mathrm{DS}}$ inactive to next address active | 100 | - | ns |
| 18 | Data in set up time from $\mathrm{R} / \overline{\mathrm{W}}$ active (Fast write cycle) | 10 | - | ns |

MUX MODE


### 6.2. MEMORY INTERFACE

ADM(0:15), B(0:1), CYF(0:1), Y(0:2), CYS
$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}$ to $T_{H}$
CLK duty cycle $=50 \%$, period $T$
Reference levels: $\mathrm{VIL}=0.8 \mathrm{~V}$ and $\mathrm{V} \mathrm{IH}=2 \mathrm{~V}, \mathrm{VOL}=0.4 \mathrm{~V}$ and $\mathrm{VOH}=2.4 \mathrm{~V}$

| IDENT <br> NUMBER | CHARACTERISTIC | MIN | MAX | UNIT |
| :---: | :--- | :---: | :---: | :---: |
| 1 | TCLK clock period | 66 | 166 | ns |
| 2 | Memory cycle time $(T=8 \times$ TCLK) | - | - | ns |
| 3 | Output delay time from CLK | - | 40 | ns |
| 4 | Output data HI-Z time from CLK | - | 40 | ns |
| 5 | Output hold time from CLK | 20 | - | ns |
| 6 | Input data hold time from CLK (read cycle) | 30 | - | ns |
| 7 | Input data set up time from CLK (read cycle) | - | ns |  |
| 8 | Input data HI-Z time from CLK |  | - | TCLK |

[^52]

### 6.3. VIDEO INTERFACE

P0, P1, P2, P3, BLK, HVSNS, PC/HS
$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T A=T L$ to $T H . C L K$ duty cycle $=50 \%$
Reference levels: $\mathrm{VI} . \mathrm{L}=0.8 \mathrm{~V}$ and $\mathrm{VIH}=2 \mathrm{~V}, \mathrm{VOL}=0.4 \mathrm{~V}$ and $\mathrm{VOH}=2.4 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}$

TIMING DIAGRAM 4.


| IDENT <br> NUMBER | CHARACTERISTIC | MIN | TYP | MAX | UNIT |
| :---: | :--- | :---: | :---: | :---: | :---: |
| 1 | TCLK : CLK period | 66 | 83 | 166 | ns |
| 2 | CLK high pulse width | 28 | - | - | ns |
| 3 | Output delay from CLK rising edge | - | - | 40 | ns |
| 4 | CLK low pulse width | 28 | - | - | ns |
| 5 | Output hold time | 10 | - | - | ns |

SYNCHRONIZATION SIGNAL OUTPUTS


## MAXIMUM RATINGS

Stresses above those hereby listed may cause permanent damage to the device. The ratings are stress ones only and functional operation of the device at these or any conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard MOS circuits handling procedure should be used to avoid possible damage to the device.

| RATING | SYMBOL | VALUE | UNIT |
| :---: | :---: | :---: | :---: |
| Supply voltage | $V_{\text {cc }}$ * | -0.3 to 7.0 | V |
| Input voltage | $V_{\text {in* }}$ | -0.3 to 7.0 | $\checkmark$ |
| Operating temperature range TS68483C <br> TS68483V <br> TS68483M | TA | $\begin{gathered} T L \text { to } T_{H} \\ 0 \text { to } 20 \\ -40 \text { to }+85 \\ -55 \text { to }+125 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature ran'ge | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Max power dissipation | $P_{\text {Dm }}$ | 1.5 | W |

*With respect to VSS

## ELECTRICAL CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T A=T_{L}\right.$ to $T H$ (unless otherwise specified)

| CHARACTERISTIC | SYMBOL | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $V_{C C}$ | 4.75 | 5 | 5.25 | V |
| Input low voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | 0.8 | $V^{\prime}$ |
| Input high voltage | $V_{I H}$ | 2 | - | $V_{C C}$ | V |
| Input leakage current | $\mathrm{I}_{\text {in }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output high voltage ( $\left.\mathrm{l}_{\text {load }}=-500 \mu \mathrm{~A}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V |
| Ouput low voltage $\begin{aligned} & I_{\text {load }}=4 \mathrm{~mA} ; \text { ADM }(0: 15) \\ & \text { Ioad }^{\text {load }}=1 \mathrm{~mA} ; \text { other outputs } \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V |
| Power dissipation | $P_{D}$ | - | 800 | - | mW |
| Input capacitance | $\mathrm{C}_{\text {in }}$ | - | - | 15 | pF |
| Three state (off state) input current | ${ }^{\text {TSSI }}$ | - | - | 10 | $\mu \mathrm{A}$ |

## SECTION 7

### 7.1. REGISTER MAP


: Don't care.

- : Used or not, according to the command

| TYPE |  |  | MNEM | CODE |  |  | PARAMETERS |  |  |  |  | ARGUMENTS |  |  |  |  |  |  | POINTERS |  |  |  |  |  |  |  | END COMMAND CURSOR POSITION |  | EXECUTION TIME |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | RO | R1 | R2 | R3 | R13 | R18 | R19 | R14 | R15 | R16 | R17 | R20 | R21 | R22 | R23 | INIT |  |  | LOOP | Per |
| DRA$W$INGS | $\begin{gathered} \mathrm{L} \\ \mathrm{I} \\ \mathrm{~N} \\ \mathrm{E} \\ \mathrm{~A} \\ \mathrm{R} \end{gathered}$ | DOT LINE |  | DLI | 0 | 0 | 0 | 0 | 0 | DMU | SP | SRU | X | $\times$ | x | x | $x$ |  |  | $x$ | X | X | X |  |  |  |  | Xd+DXd | Yd+DYd | 5 T | 4 T | DOT |
|  |  | PEN LINE | PLI | 0 | 0 | 0 | POL | PEN | DMU | SP | SRU | $x$ | X | X | $x$ | X |  |  | X | X | X | $x$ | X | X | X | X | Xd+DXd | Yd+DYd | 5 T | CELL +4 T | CELL |
|  |  | DOT ARC | DAR | 0 | 0 | 1 | 0 | 0 | DMU | SP | SRU | $x$ | x | $x$ | $x$ | x | $x$ | $x$ | x | x | x | $x$ |  |  |  |  | XF | YF | 15 T | 10 T | DOT |
|  |  | PEN ARC | PAR | 0 | 0 | 1 | POL | PEN | DMU | SP | SRU | $x$ | X | X | X | $x$ | X | X | X | $x$ | $x$ | $x$ | X | X | X | X | XF | YF | 15 T | CELI+10T | CELL |
|  | $\begin{aligned} & A \\ & \text { R } \\ & \text { E } \\ & \text { A } \end{aligned}$ | RECTANGLE | REC | 1 | 1 | 1 | 1 | 0 | DMU | SP | SRU | X | x | x |  | X |  |  | X | X | $x$ | $x$ |  |  |  |  | Xd | Yd+DYd | 10 T | 4 T |  |
|  |  | TRAPEZIUM | TRA | 0 | 1 | 0 | 1 | 0 | DMU | SP | SRU | $x$ | X | X |  | X |  |  | $x$ | $x$ | X | $x$ |  | X |  |  | Xd+DXd | Yd+DYd | 10 T |  |  |
|  |  | POLYGON | FLL | 0 | 1 | 0 | 0 | BEG | DMU | SP | SRU | $x$ | X | X |  | X |  |  | X | $x$ | X | $x$ |  |  |  |  | Xd+DXd | Yd+DYd | 10 T | $\begin{gathered} 4 \mathrm{~T} \\ \text { INOTE } 1 . \end{gathered}$ | $\left\|\begin{array}{c} \text { MEMORY } \\ \text { WORD } \end{array}\right\|$ |
|  |  | POLYARC | FLA | 0 | 1 | 1 | 0 | BEG | DMU | SP | SRU | x | x | x |  | X | X | X | X | $x$ | X | $x$ |  |  |  |  | XF | YF | 15 T |  |  |
|  | $\begin{aligned} & \mathrm{C} \\ & \mathrm{E} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | PRINT CHARACTER | PCA | 1 | 0 | 1 | 1 | REP | DMU | SP | SRU | x | x | x |  | $x$ |  |  | X | $x$ | x | $x$ | $x$ | $x$ | $x$ | $x$ | $X d+D X d$ | Yd |  |  |  |
|  |  | PRINT OBIECT | PVS | 1 | 0 | 0 | SMU | REP | DMU | 1 | SRU | $x$ | X |  |  | X |  |  | X | X | X | $x$ | $x$ | $x$ | X | $x$ | Xd+DXd | Yd | 4 T | 6 T | MEMORY WORD |
|  |  | PRNT OBJECT | PVF | 1 | 0 | 1 | 0 | REP | DMU | 1 | SRU | X | X |  |  | X |  |  | X | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ | $X d+D X_{d}$ | Yd |  |  |  |
| ACCESS |  | LOAD VIEWPORT | LDV | 1 | 1 | 1 | 0 | XFT | 0 | 0 | INC |  |  |  |  |  |  |  | X | $x$ | X | $x$ | $x$ | $x$ | $x$ | $x$ | Xs | Ys | 2 T | 5 T |  |
|  |  | SAVE VIEWPORT | SAV | 1 | 1 | 1 | 0 | XFT | 0 | 1 | INC |  |  |  |  |  |  |  | X | X | X | X | $x$ | $x$ | X | X | Xs | Ys | 2 T | 4 T | $\begin{gathered} \text { MEMORY } \\ \text { WORD } \end{gathered}$ |
|  |  |  | RMV | 1 | 1 | 1 | 0 | XFT | 1 | 0 | INC |  |  |  |  |  |  |  | $x$ | X | $x$ | X | x | x | X | x | Xs | Ys | 2 T | 10 T |  |
| CURSOR |  | UP-DOWN MOVE | UDM | 1 | 1 | 0 | 0 | 0 | 1 | DWN | SRU |  |  |  |  | $x$ |  |  | $x$ | $x$ | X |  |  |  |  |  | Xd | Yd+DYd | 3 T |  |  |
|  |  | LEFT-RIGHT MOVE | LRM | 1 | 1 | 0 | 1 | LEF | 0 | 0 | SRU |  |  |  |  | $x$ |  |  | X | $x$ |  | $x$ |  |  |  |  | Xd+DXd | Yd | $3 T$ |  |  |
|  |  |  | CDM | 1 | 1 | 0 | 1 | LEF | 1 | DWN | SRU |  |  |  |  | X |  |  | X | X | X | X |  |  |  |  | Xd+DXd | Yd+DYd | 4 T |  |  |
| CONTROL |  | NO OPERATION ABORT | NOP | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 T |  |  |
|  |  | BRT | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 T |  |  |

DMU = 1 : Destination mask use
$S P=1^{10} \quad$ : Short pel; long pel when $S P=0$
SRU =1 : Short relative register use (R13).
PEN $=0 \quad$ : The pen is a single pel.
PEN =1 : POL=0: the pen is the character cell addressed by the source pointer. $\mathrm{POL}=1$ : the pen is the object associated with a source mask addressed by the source pointer.
$B E G=1$ : Initiate a polygon or polyarc filling
This parameter should be reset only when the second drawing is not identical to the first one (Ex: first polygon, then polyarc)
INC=0 $\quad$ : The source pointer is not auto-incremented.
INC $=1 \quad: X F T=1$ : the source pointer is auto-incremented, $X$ direction first
$X F T=0$ : The source pointer is auto-incremented or auto-decremented, $Y$ direction first
REP $=1$ : The cell is stepped and repeated through the destination window. When REP $=0$, only one cell is printed.
$\mathrm{SMU}=1 \quad$ : The source mask is used
DWN =1 : The cursor is moved down (up if DWN $=0$ ).
$L E F=1 \quad$ : The cursor is moved left (right if $L E F=0$ )

NOTE: With PVF command, any pel with color different from 0 has its source mask implicitly set and used. In other words, pels with color value 0 are transparent.

- DXd, DYd, and DYs are signed values.
- DXs is always positive.
- $\mathrm{T}=$ memory cycle $=8$ CLK clock periods
- For execution time, add to the short pel loop in the table
- 1 T if $\mathrm{DMU}=1$
$2 T$ if long pen are used
- $2 T$ if long pen are used

Command execution is performed only out of the display periods.
NOTE 1: for FLL and FLA commands, add 4 T and 8 T respectively per pel belonging to the boundary

## SECTION 8

## MECHANICAL DATA AND ORDERING INFORMATION

8.1. MECHANICAL DATA



CB-710


E SUFFIX LCCC68

### 8.2. ORDERING INFORMATION

| PACKAGE TYPE | TEMPERATURE RANGE | PART NUMBER |
| :---: | :---: | :---: |
| PLCC <br> FN Suffix | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68483 CFN |
| LCCC <br> E Suffix | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | TS684483VE <br> TS 684483ME |

## ADVANCE INFORMATION

The TS68494 single chip color palette can be used in any low to mid range color graphics application to provide up to $\mathbf{2 5 6}$ colors freely selected between 4096 values.

Moreover, the TS68494 integrates a serial port controller for dual port video-RAM.

Powerful and cost effective graphics and text application may be achieved with THOMSON-SEMICONDUCTEURS Graphics processor family (TS68483/68493) and TS68494 chip set.

Main features :

- One chip color look-up table
- 256 colors 8 bits/pixel) between 4096
- Up to 35 Mpixels/sec
- Three on-chip 4-bit video DACs
- RS-343A compatible video outputs
- Serial port controller for dual port video-RAM
- Logical operation between pixel value and programmable masks
- Horizontal zoom and panning capability
- Standard microprocessor interface, TS68000 compatible
- Single 5V supply
- 44 pin PLCC and 48 DIL packages


## TYPICAL APPLICATION




PLASTIC PACKAGE


| PIN ASSIGNMENT |  |
| :---: | :---: |
| GND $\sqrt{1}$ | NC |
| GND $\square_{2}$ | B |
| DO 0 | R |
| D1 04 | G |
| D2 0 | 0 HVS |
| D3 0 | $1{ }^{\text {BLK }}$ |
| D4 0 | DCLK |
| D5 $0^{8}$ | S Sco |
| D6 $0^{19}$ | SC1 |
| D7 $\square^{\text {DTACK }}$ | $\square$ SOEO |
| DTACK ${ }^{11}$ | $\underline{\text { SOE } 1}$ |
| AO $\$_{12}$ | $\overline{\text { SOE } 2}$ |
| $\overline{\text { DS }} \mathrm{q}^{13}$ | $\overline{\text { SOE }}$ |
| R/W ${ }^{\text {c/4 }}$ | NC |
| GND ${ }^{15}$ | HP |
| VCC ${ }^{\text {d }} 16$ | TMB7 |
| $V_{\text {cc }}{ }^{17}$ | TMB6 |
| TMA7 ${ }^{18}$ | $\square$ TMB5 |
| TMA6 19 | TMMB4 |
| TMA5 ${ }^{20}$ | $\underline{\text { tmb3 }}$ |
| TMA4 ${ }^{21}$ | TMB2 |
| TMA3 ${ }^{22}$ | ] тмв 1 |
| TMA2 ${ }^{23}$ | тмво |
| TMA1 ${ }_{2}$ | tmao |

BLOCK DIAGRAM


## FRAME BUFFER INTERFACE

| Name | Pin <br> type | $\begin{aligned} & \text { No. } \\ & \text { PLCC } \end{aligned}$ | No. DIP | Function | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{SCO} \\ & \mathrm{SC} 1 \end{aligned}$ | 0 | $\begin{aligned} & 38 \\ & 37 \end{aligned}$ | $\begin{aligned} & 41 \\ & 40 \end{aligned}$ | Serial port <br> Shift clock | These two clocks, with inverted phase, shift data out of video-RAM serial ports during the active display period. <br> Shift rate can be programmed at HP/8, HP/4 or HP/2 according to the Mode Register programming. |
| $\overline{\mathrm{SOE}} 0$ SOE 1 $\overline{\mathrm{SOE}} 2$ SOE 3 | 0 | $\begin{aligned} & 36 \\ & 35 \\ & 34 \\ & 33 \end{aligned}$ | $\begin{aligned} & 39 \\ & 38 \\ & 37 \\ & 36 \end{aligned}$ | Serial output Enable | These signats are used to control the video-RAM serial port outputs in order to multiplex one to four outputs to the same bus. |
| TMA (0:7) <br> TMB(0:7) | 1 | $\begin{aligned} & 23.16 \\ & 24.31 \end{aligned}$ | $\begin{aligned} & 25-18 \\ & 26-33 \end{aligned}$ | Pixel value Inputs | In non multiplexed mode the 8 bit pixel value is fed to TMA (4:7), (Respectively pixel bit 6, 4, 2, 0 ) and TMB (4:7) (Respectively pixel bit $7,5,3,1$ ) at pixel clock rate (HP) <br> In multiplexed mode, TMA $(0: 7)$ and $\operatorname{TMB}(0: 7)$ are multiplexed in order to load the internal shift registers. During each cycle of eight HP clock periods, these sixteen lines are multiplexed four times to provide the value of eight pixels. |

## VIDEO INTERFACE

| Name | Pin <br> type | No. <br> PLCC | No. <br> DIP | Function | Description |
| :---: | :---: | :---: | :---: | :---: | :--- |
| HP | 1 | 32 | 34 | Pixel clock | This clock controls the internal shift registers operation and the <br> internal Timing Generator. |
| DCLK | 0 | 39 | 42 | HP/8 | This clock is the pixel clock HP divided by eight. It can be used as a basic <br> clock by a Video Timing Generator of a graphics processor. |
| $\overline{\text { BLK }}$ | 1 | 40 | 43 | Blanking | This active low input forces the R,G,B analog output to blank level. |

## MICROPROCESSOR INTERFACE

| Name | Pin <br> type | No. <br> PLCC | No. <br> DIP | Function | Description |
| :---: | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{D}(0: 7)$ | $1 / O$ | $3-10$ | $3-10$ | Data bus | These eight bidirectionnal lines are connected to the microprocessor <br> data bus. |
| $A 0$ | 1 | 12 | 12 | Address | During a microprocessor access, this line selects the higher byte $(A 0=0)$ <br> or the lower byte $(A 0=1)$ of a register. |
| $\overline{D S}$ | 1 | 13 | 13 | Data Strobe | This active low input selects the TS68494 for a microprocessor access. |

## OTHER PINS

| Name | Pin <br> type | No. <br> PLCC | No. <br> DIP | Function | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {CC }}$ | S | 15 | $16-17$ | Power supply | +5 V. |
| $V_{\text {DDC }}$ | S | 1 |  | Analog power <br> supply | Power supply for the internal DACs. <br> +5 V for RS-343A standard. |
| GND | S | 2 | $1-2-15$ | Ground |  |

NOTE : Pin No. 35 in DIP package in not connected.

## FUNCTIONAL DESCRIPTION

## MICROPROCESSOR INTERFACE

The TS68494 is directly compatible with TS68000 microprocessor family and can be easily interfaced with most of the other standard microprocessor families such as 6809, 8086 (Figure 1).
Data transfer between the TS68494 and the microprocessor is made by logical 16 -bit words through an 8 -bit data bus. The microprocessor has access to seven internal registers.

## Write access

During a write operation, a 16 -bit word contains a 12 -bit data field and 3 -bit address field. The address field selects the register to be accessed (Figure 2).
As the higher byte ( $\mathrm{AO}=0$ ) contains the address, it must be loaded first.

Data written to the color register is loaded into the color look-up memory at the location pointed by the Color Address Pointer (CAP). When bit IW is set in the Mode Register, the CAP is automatically incremented after each access to the lower byte ( $A 0=1$ ).

## Read access

Before any read operation, the Read Address Register (RAR) must be initialized.
When the contents of RAR is different from 0 , the register pointed by RAR can be read by the microprocessor at address $A 0=1$.
When RAR $=0$, the color look-up memory location pointed by the Color Address Pointer (CAP) can be read by the microprocessor. Each 12 -bit word of the color look-up memory can be read at address AO $=0$ and $A O=1$. When bit IR is set in the mode register, the CAP is auto-incremented after each access to address $A O=1$, thus allowing sequential access to the color look-up memory.


FIGURE 1 - INTERFACE WITH TS68000 FAMILY

REGISTER ADDRESSING - Write operation


COLOR REGISTER ADDRESSING - Write operation


REGISTER ADDRESSING - Read operation


COLOR REGISTER ADDRESSING - Read operation


FIGURE 2 - REGISTER ADDRESSING

## REGISTER DESCRIPTION

MODE REGISTER-MR


AND/OR REGISTERS
PIXEL VALUE REGISTER


## READ ADDRESS REGISTER-RAR



## PAN REGISTER-PR



POSITION OF THE FIRST DISPLAYED PIXEL (MODULO 8)

COLOR ADDRESS POINTER-CAP


## COLOR REGISTER



## VIDEO PROCESS

The pixel value received by the TS68494 is logically ANDed and ORed with the AND and OR registers. The result is used to address the color look-up memory.
The 12 -bit word at the output of the memory is latched into the color output register. Each 4 -bit field is fed to the respective DAC which delivers the analog signal conforming to RS-343A standard (Figure 3).


## Zoom operation

The zoom mode is active when bit MR3 is set in the mode register. Except for the DCLK signal, all the clocks generated by the TS68494 Timing Generator are divided by two.

## Pan operation $($ MR2 $=1)$

This mode allows horizontal scrolling from 0 to 7 pixels, through the Pan Register PR.


FIGURE 3 - RS343-A COMPATIBLE VIDEO INTERFACE

## OPERATING MODES

The TS68494 provides four different operating modes, depending on the frame buffer organization.

## Non multiplexed mode (MR1 = 1, MR0 = 1)

In this mode, the 8 -bit pixel value present on TMA(4:7) and TMB(4:7) inputs is latched on the rising edge of HP clock. After AND and OR operations, it addresses the color look-up memory (Figure 8).

## Memory organization

With the three multiplexed modes, the frame buffer must be organized into blocks of video-RAMs. Each block provides eight serial ports outputs, which deliver after each shift operation the information for eight consecutive pixels, one bit/pixel.
According to the memory type used and the size of the screen, a memory block may contain one, two or four memory bit planes. For example, a block made of two $64 \mathrm{~K} \times 4$ video-RAMs can contains one plane of $1024 \times 512$, two planes of $512 \times 512$ or four planes $512 \times 256$ (Figure 4).
The timing generator outputs $\operatorname{SC}(0: 1)$, $\operatorname{SOE}(0: 3)$ are enabled by the BLK signal.

## Multiplexed mode $0(M R 1=0, M R 0=0)$

In this mode, each memory block contains only one memory bit plane. The serial outputs of the four memory blocks holding the even planes are multiplexed to TMA $(0: 7)$ lines. Those of the memory blocks holding the odd planes are multiplexed to $\operatorname{TMB}(0: 7)$ lines (Figure 5).

During each cycle of eight pixel clock periods, the TMA and TMB inputs are multiplexed four times. The multiplexing process is achieved through the Shift Output Enable signals $\overline{\operatorname{SOE}}(0: 3)$ provided by the TS69494. The Serial Shift Clocks for the video-RAM serials ports SCO and SC1 are provided by the TS68494 by dividing the pixel clock by eight.

## Multiplexed mode $1($ MR1 $=0, M R 0=1)$

Each memory block contains two memory bit planes. Only $\overline{\text { SOE }}$ and $\overline{\text { SOE }} 1$ are used to multiplex two blocks. The shift clocks SC0 and SC1 delivered by the TS68494 are obtained by dividing the pixel clock by four (Figure 6).

## Multiplexed mode $2(M R 1=0, M R 0=0)$

Each memory block contains four memory bit planes. Only SOEO signal is used. The Shift Clock SCO is obtained by dividing the pixel clock by two (Figure 7).

ONE BLOCK/ONE PLANE

ONE BLOCK/TWO PLANES

ONE BLOCK/FOUR PLANES


FIGURE 4 - MEMORY BLOCK ORGANIZATION


FIGURE 5 - MULTIPLEXED MODE 0


FIGURE 6 - MULTIPLEXED MODE 1




FIGURE 7 - MULTIPLEXED MODE 2


SCO:1
$\overline{S O E}(0: 3)$

FIGURE 8 - NON MULTIPLEXED MODE

## MAXIMUM RATINGS

Stresses above those hereby listed may cause permanent damage to the device. The ratings are stress ones only and functional operation of the device at these or any conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard MOS circuits handling procedure should be used to avoid possible damage to the device.

| Rating | Symbol | Value |  |
| :--- | :---: | :---: | :---: |
| Supply voltage | $V_{\mathrm{CC}}{ }^{*}$ | +0.3 to +7.0 |  |
| Input voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | -0.3 to +7.0 | V |
| Operating temperature range | $\mathrm{TA}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature range | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Maximum power dissipation | $\mathrm{PDm}^{\mathrm{Cm}}$ | +1.5 | W |

* With respect to GND


## ELECTRICAL OPERATING CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% . \mathrm{V}_{\mathrm{SS}}=0 . \mathrm{T}_{\mathrm{A}}=0\right.$ to $+70^{\circ} \mathrm{C}$ ) (Unless otherwise specified)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | Vcc | 4.75 | 5 | 5.25 | $\checkmark$ |
| Analog supply voltage | VDDC | - | 5 | - | $\checkmark$ |
| Input low voltage | VIL | 0.3 | - | 0.8 | V |
| Input high voltage | $V_{1 H}$ | 2 | - | $\mathrm{V}_{\mathrm{CC}}$ | $\checkmark$ |
| Input leakage current | $V_{10}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output high voltage ( $/$ load $=-500 \mu \mathrm{~A}$ ) | VOH | 2.4 | - | - | V |
| Output low voltage $l_{\text {load }}=4 \mathrm{~mA}$ | VOL | - | - | 0.4 | V |
| Power dissipation | $P_{\text {D }}$ | - | 700 | - | mW |
| Input capacitance | $\mathrm{C}_{\text {in }}$ | - | - | 15 | pF |
| Three state (off state) input current | ITSI | - | - | 10 | $\mu \mathrm{A}$ |

## MICROPROCESSOR INTERFACE

Microprocessor interface timing:
$\mathrm{VCC}=5.0 \mathrm{~V} \pm 5 \% \mathrm{~T}_{\mathrm{A}}=0^{\circ}$ to $70^{\circ} \mathrm{C} . \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ on $\mathrm{D}(0: 7), \mathrm{CL}=130 \mathrm{pF}$ and $\mathrm{RL}=500 \Omega$ on $\overline{\text { DTACK }}$
Reference levels: $\mathrm{V}_{1 \mathrm{~L}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{1 H}=2 \mathrm{~V}$ on all inputs.
$\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ on all outputs

| No. | Characteristic | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 | $\overline{\mathrm{DS}}$ Iow (write cycle) | 60 | - | ns |
| 2 | $\overline{\mathrm{DS}}$ high | 60 | - | ns |
| 3 | AO set up time to $\overline{D S}$ | 0 | - | ns |
| 4 | AO hold time from $\overline{D S}$ | 10 | - | ns |
| 5 | R/W set up time to $\overline{\text { DS }}$ | 0 | - | ns |
| 6 | $R / \bar{W}$ hold time from $\overline{\text { DS }}$ | 10 | - | ns |
| 7 | Data set up time (write) | 50 | - | ns |
| 8 | Data hold time (read) | 0 | - | ns |
| 9 | $\overline{\text { DTACK }}$ delay from $\overline{\text { DS }}$ | $\begin{gathered} 50+ \\ \text { PP(6THP } \\ -(2)) \end{gathered}$ | - | ns |
| 10 | $\overline{\text { DTACK }}$ high from $\overline{\text { DS }}$ | 110 | - | ns |
| 11 | $\overline{\mathrm{DS}}$ low (read cycle) | 120 | - | ns |
| 12 | $\overline{\text { DTACK }}$ low from $\overline{\text { DS }}$ (read) | $100+5 \mathrm{HP}$ | - | ns |
| 13 | Data delay from $\overline{\text { DTACK }}$ (read) | - | 30 | - |
| 14 | Data hold time from $\overline{\mathrm{DS}}$ | 10 | - | ns |
| 15 | Cycle time | $70+8 \mathrm{HP}$ |  |  |



WRITE CYCLE
(15)


READ CYCLE

## DIGITAL VIDEO SIGNALS

$V_{C C}=5.0 \pm 5 \% . \quad T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C} . \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ on $\operatorname{DCLK}, \operatorname{SC}(0: 1), \overline{\operatorname{SOE}}(0: 3)$
Reference levels: $\mathrm{V}_{1 \mathrm{~L}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{I H}=2 \mathrm{~V}$ on all inputs.
$\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{CH}}=2.4 \mathrm{~V}$ on all outputs.

| No. | Characteristic | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 | HP clock period | 33 | 125 | ns |
| 2 | HP high pulse width | 10 | - | ns |
| 3 | HP low pulse width | 10 | - | ns |
| 4 | HP rise and fall time | - | 5 | ns |
| 5 | Timing generator output delay from HP | - | 28 | ns |
| 6 | $\overline{\text { SOE }}$ low puise width | THP | - | ns |
| 7 | $\overline{\text { BLK }}$, $\overline{H V S}$ set up time to DCLK | 60 | - | ns |
| 8 | TMA, TMB set up time to $\overline{S O E}$ | -2 | - | ns |
| 9 | TMA, TMB hold time from $\overline{S O E}$ | 12 | - | ns |
| 10 | TMA(4:7), TMB(4:7) set up time to HP | 5 | - | ns |
| 11 | TMA(4:7), TMB(4:7) hold time from HP | 5 | - | ns |

TIMING DIAGRAM 2 - DIGITAL VIDEO SIGNALS


MULTIPLEXED MODES 0,1,2,


NON MULTIPLEXED MODE 3
$V_{D D C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$



TIMING DIAGRAM 3

| No. | Characteristic | Min. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| 1 | delay from HP $(50 \%)$ | - | 30 | ns |
| 2 | $1 / 2$ LSB settling | - | 15 | ns |
| 3 | Rise and fall time (10\%-90\%) | - | 10 | ns |

Test load


## PHYSICAL DIMENSIONS

CB-521

PLCC44


## CHAPTER 7 - DIGITAL SIGNAL PROCESSING ICs

## DIGITAL SIGNAL PROCESSING ICs SELECTION GUIDE

| Part number | Description | Technology | Number <br> of pins | Page |
| :--- | :--- | :--- | :---: | :--- |
| TS68930 | High speed general purpose digital signal <br> and arithmetic processor with on-chip RAM <br> ROM, multiplier, alu. accumulators and I/O | HMOS | 48 | $7-3$ |
| TS68931 | ROMless version of TS68930 | HMOS | 84 | $7-3$ |
| TS68950 | Modem transmit analog interface | CMOS | 28 | $7-55$ |
| TS68951 | Modem receive analog interface | CMOS | 28 | $7-69$ |
| TS68952 | Modem transmit/receive clock generator | CMOS | 28 | $7-93$ |



## ADVANCE INFORMATION

The TS68930/1 (Programmable Signal Processor) is a high-speed general purpose signal and arithmetic processor with on-chip memory, multiplier, ALU, accumulators and I/Os. It is organized in a parallel/pipeline structure to execute simultaneously one ALU, function, multiplication, two reads and one write operation and associated address calculation every 160 ns .

- Parallel/pipeline Harvard architecture
- 3 data-bus structure
- 3 data types : 16 -bit real, 32 -bit real
: $16+16$-bit complex number
- 2 versions : TS 68930 (internal ROMs) 48-pin
: TS68931 (external ROMs) 84-pin
- Pipeline complex multiplier
- $2 \times 128 \times 16$-bit RAM
- $512 \times 16$-bit coefficient ROM
- 32-bit instruction bus
- $64 \mathrm{k} \times 32$-bit external program space
- 68000 family compatibility
- Dual external buses: local/system


## TYPICAL APPLICATIONS

- Adaptive processing
- Complex numbers
- Digital filtering
- Fast Fourier transform
- Voice grade communication systems
- High-speed modems
- Speech processing
- Audio Frequencies
- Sonar/radar
- Image processing
- Robotics
- Graphics processing




## TABLE OF CONTENTS

| Paragraph Number | Titie | Page Number |
| :---: | :---: | :---: |
| 1.1 | Section 1 Block diagram | 5 |
| 2.1 | Section 2 <br> Pin description | 7 |
| 3.1 | Section 3 Summary of besic hardware | 8 |
|  | Section 4 Architecture | 10 |
| 4.1 | Internal architecture | 10 |
| 4.1.1 | Parallel processing | 10 |
| 4.1.2 | Three-bus structure | 10 |
| 4.1.3 | Wide instruction word | 10 |
| 4.1.4 | Pipeline . ............ | 10 |
| 4.2 | External architecture ...... | 13 |
| 4.2.1 | System bus | 13 |
| 4.2.2 | Local bus.. | 13 |
|  | Section 5 <br> Functional description | 14 |
| 5.1 | Operating modes | 14 |
| 5.2 | Control block | 14 |
| 5.2 .1 | Instruction ROM | 14 |
| 5.2.2 | Program Counter | 14 |
| 5.2 .3 | Sequencer ........ | 14 |
| 5.2 .4 | Retum Address Register | 15 |
| 5.2.5 | Loop Counter ......... | 15 |
| 5.3 | Processing block .. | 16 |
| 5.3.1 | Multiplier | 16 |
| 5.3.2 | Barrel shifter | 17 |
| 5.3.3 | Alu | 17 |
| 5.3.4 | Saturation mode | 17 |
| 5.3.5 | Status register . | 18 |
| 5.3.6 | Accumulators | 19 |
| 5.3.7 | Fifo ..... | 19 |
| 5.3.8 | Replace Code register | 20 |
| 5.3.9 | Transfer register ..... |  |
| 5.4 | Memory block ........ | 21 |
| 5.4.1 | Data memories | 21 |
| 5.4 .2 | Addressing modes | 21 |
| 5.4.3 | Address calculation units | 21 |
| 5.4 .4 | Pointers | 22 |
| 5.4.5 | Circular addressing mode | 22 |
| 5.4.6 | Odd/even address ..... | 23 |
| 5.5 | Access mode register | 23 |
| 5.6 | Reset | 25 |
| 5.7 | Halt | 25 |


|  | TABLE OF CONTENTS |  |
| :---: | :---: | :---: |
|  | (Continued) |  |
| Paragraph <br> Number | Title | Page |
| Number |  |  |

Section 6 Input-Output ..... 26
6.1 Dual-bus interface ..... 26
6.2 Master/slave ..... 28
6.3 Local bus ..... 28
6.4 System bus and mailbox ..... 29
6.5 Mailbox protocol ..... 30
Instruction bus ..... 31
6.7 Application examples ..... 32
Section 7
Instruction set ..... 36
7.1 Operating code formats ..... 37
Alu codes ..... 41
Test conditions ..... 42
Section 8
Performance evaluation
Section 9Electrical specifications44
9.1 Maximum ratings ..... 44
9.2 DC electrical characteristics ..... 44
AC electrical specifications - clock and control pins timing ..... 44
AC electrical specifications - Local bus timing ..... 46
AC electrical specifications - System bus timing ..... 47
AC electrical specifications - Instruction bus timing ..... 48
Section 10
Pin assignments afd ..... 49
mechanical data
Pin assignment ..... 50
0.
Package dimensions ..... 51
Section 11Ordering information52


## SECTION 2 <br> PIN DESCRIPTION

LOCAL INTERFACE

| Name | Pin <br> Type | Pin $\mathbf{n b}$ <br> TS68930 | Pln $\mathbf{n b}$ <br> TS68931 | Function | Description |
| :--- | :---: | :---: | :---: | :--- | :--- |
| D (0:15) | $1 / \mathrm{O}$ | $45-48$ <br> $1-11$ | $6-21$ | Data bus | Can be concatenated or separate D (0:7), D (8:15) |
| A (8:11) | 0 | $35.37,39$ | $45-48$ | Address bus | High order addresses for local interface |
| $\overline{\text { DS }}$ | 0 | 17 | 27 | Data Strobe | Synchronizes the transfer |
| R/ $\bar{W}$ | 0 | 18 | 28 | Read/write | Indicates the current bus cycle state |
| CLKOUT | 0 | 16 | 26 | Clock output | The frequency of CLKOUT is one half the frequency of the input clock or <br> crystal |

## SYSTEM INTERFACE

| Name | $\begin{gathered} \text { Pin } \\ \text { Type } \end{gathered}$ | Pin nb. TS68930 | Pin nb. TS68931 | Function | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AD (0:7) | 1/O | 27-34 | 35-42 | System data bus or local address bus | The data exchanges between the processor and a master via a mailbox is the function of this bus. It is also used to generate the addresses of an external RAM. |
| CS | 1 | 21 | 31 | Chip Select | Used by a master to gain access to the mailbox and system bus |
| $\overline{\mathrm{RS}}$ | 1 | 22 | 32 | Register Select | Used by a master to gain access to the mailbox and system bus |
| $\overline{\text { SDS }}$ | 1 | 20 | 30 | System Data Strobe | Synchronizes the transfer on the system bus |
| SR/W | 1 | 19 | 29 | System Read/Write | Indicates the current system bus cycle state |
| DTTACK | 0 | 25 | 43 | Data Transfer Acknowledge | Indicates that the processor has recognized it is being accessed |
| BA | 0 | 26 | 44 | Bus Available | Indicates availability of system bus to master |
| IRO | 0 | 24 | 34 | Interrupt Request | Handshake signal sent to the master to gain access to the mailbox |

## EXTERNAL BRANCH CONDITIONS

| Name | Pin Type | Pin nb. TS68930 | Pin nb. TS68931 | Function | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| BS (0:2) | 1 | 42.40 | 49-51 | Branch on State | External conditions. Can be programmed on a high or low state |
| BE (3:6) | 1 | $\begin{aligned} & 44 \\ & 43 \\ & 26 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 53 \\ & 52 \\ & 44 \\ & 43 \\ & \hline \end{aligned}$ | Branch on Edge | External conditions. Falling edge is memorised and reset when tested. $B E 5$ shares pin with $\overline{B A}$ <br> BE6 shares pin with DTACK |

## OTHER PINS

| Name | Pin <br> Type | Pin nb. <br> TS68930 | Pin nb. <br> TS68931 | Function | Description |
| :--- | :---: | :---: | :---: | :--- | :--- |
| EXTAL | 1 | 15 | 25 | Clock | Crystal input pin for internal oscillator or input pin for external oscillator |
| XTAL | 1 | 14 | 24 | Clock | Together with EXTAL it is used for the external 25 MHz crystal |
| VDD | 1 | 38 | $23-65$ | Power supply |  |
| VSS | 1 | 13 | $22-64$ | Ground |  |
| $\overline{\text { RESET }}$ | 1 | 23 | 33 | Reset |  |

INSTRUCTION INTERFACE (TS68931 only)

| Name | Pin <br> Type | Pin <br> nb. | Function | Description |
| :--- | :---: | :---: | :--- | :--- |
| $110: 311$ | $1 / 0$ | $1-5$ <br> $56-63$ <br> $56-84$ | Instruction <br> Address/data bus <br> Coefficient ROM <br> address bus | Instruction bus - 32-bit data <br> Instruction address - (116 - 131$)$ <br> External coefficient ROM address - (16 - 115) 10-bit <br> (9-bit address + output enable signal) |
| HALT | 1 | 54 | Halt Signal | Halts the processor. This signal freezes the program counter and loop counter |
| INCYCLE | 0 | 55 | Instruction <br> cycle clock | 160 ns in REAL mode <br> 320 ns in CPLX/DBPR Mode |

## SECTION 3

SUMMARY OF BASIC HARDWARE

OPERATING MODES

| Resource | Paragraph <br> $\mathbf{N}^{\circ}$ | Symbol | Function |
| :--- | :---: | :---: | :---: |
| Mode register | 5.1 | MODE | 2-bit register defining the operating mode (real/complex/double precision). |

CONTROL BLOCK

| Resource | $\mid \underset{N^{\circ}}{\text { Paragraph }}$ | Symbol | Function |
| :---: | :---: | :---: | :---: |
| Instruction ROM Instruction register | 5-2-1 | IROM IR | $1280 \times 32$-bit word read-only-memory containing program code and immediate data. <br> 32 -bit register containing instruction. |
| Program Counter | 5-2.2 | PC | 16 -bit register containing address of program memory. |
| Sequencer | 5-2.3 | SEO | The sequencer can test directly 16 conditions programmed on a high or low state. |
| Return Address Register | 5-2-4 | RAR | 16-bit register for saving program counter in case of subroutine call. |
| Loop Counter | 5-2-5 | LC | 15 -bit register containing a control word for automatic loop. It is divided as follows |
|  |  | $\begin{aligned} & \mathrm{LCl} \\ & \mathrm{LCR} \\ & \mathrm{LCD} \end{aligned}$ | 4 -bit register containing the number of instructions to be executed in the loop. <br> 8 -bit register containing the number of loops. <br> 3 -bit register containing the number of instructions between declaration and start of the loop. |

PROCESSING BLOCK

| Resource | $\underset{\mathbf{N}^{\circ}}{ }$ | Symbol | Function |
| :---: | :---: | :---: | :---: |
| Pipeline Multiplier | 5-3-1 | MULT | $16 \times 16 \rightarrow 32$ parallel pipeline multiplier +16 -bit adder/substractor to execute complex multiplications. |
|  |  | M, N | $2 \times 16$-bit registers containıng muitiplier operands. |
|  |  | P | $2 \times 16$-bit register containing multiplier result. |
| Barrel Shitter | 5-3-2 | BS | Variable 0-15-bit right shift, left shift, right rotation barrel shifter. |
| Afithmetic Logic Unit | 5-3-3 | ALU | 2 port 16 -bit arithmetic logic unit. <br> 5 possible sources, 4 possible destinations, 27 -functions Works on 32 -bit in 2 cycles. |
|  |  | D | ALU output register. |
| Saturation | 5-3-4 | SAT | Flag. indicates saturation mode |
| Status | 5-3-5 | STA | 15 -bit register containing status of ALU, mode, status of address calculation units |
| Accumulators | 5-3-6 | A | $2 \times 16$-bit accumulator. |
|  |  | B | $2 \times 16$-bit accumulator. |
| Fifo Empty Fifo | 5-3-7 | $\begin{aligned} & \hline \mathrm{F} \\ & \mathrm{EF} \end{aligned}$ | $4 \times 16$-bit first in first out register. <br> Flag. Indicates that the fifo is empty; can be set by software |
| Replace Code register | 5-3-8 | RC | 6 -bit register allowing replacement of ALU operation code by a data coming from L-BUS. |
| Transfer register | 5-3-9 | T | $2 \times 16$-bit register providing direct transfer between L-BUS and Z-BUS. |

MEMORY BLOCK

| Resource | $\underset{\mathcal{N}^{\circ}}{ } \left\lvert\, \begin{gathered} \text { Paragraph } \\ \hline \end{gathered}\right.$ | Symbol | Function |
| :---: | :---: | :---: | :---: |
| Data RAMs | 5-4-1 | $\begin{aligned} & \text { XRAM } \\ & \text { YRAM } \end{aligned}$ | $2 \times 128 \times 16$-bit word random access memories containing data. |
| Data ROM |  | CROM | $512 \times 16$-bit word read only memory containing coefficients or constants. |
| Address Calculation Units | 5-4.3 | $\begin{aligned} & \text { XACU } \\ & \text { YACU } \end{aligned}$ | $2 \times 7$-bit arithmetic units providing incrementation, decrementation, automatic loop of address. <br> XACU is dedicated to XRAM. <br> YACU is dedicated to YRAM. |
|  |  | ECACU | 12 -bit arithmetic unit providing incrementation, decrementation of address. Shared between CROM and ERAM (external RAM). |
| Pointers | 5-4.4 | $\begin{aligned} & x 0, \times 1 \\ & \times \\ & \hline \end{aligned}$ | $2 \times 7$-bit registers used for indirect addressing of XRAM Supplementary register used for circular addressing. |
|  |  | $Y 0, Y 1$ | $2 \times 7$-bit registers used for indirect addressing for YRAM. Supplementary register used for circular addressing. |
|  |  | $\mathrm{CO}, \mathrm{Cl}$ | $2 \times 9$-bit registers used for indirect addressing of CROM. |
|  |  | E0, E1 | $2 \times 12$-bit registers used for indirect addressing of ERAM. |
| XRAM Circular Flag YRAM Curcular Flag | 5-4-5 | $\begin{aligned} & X C \\ & Y C \\ & \hline \end{aligned}$ | Flag. Indicates the circular addressing mode for XRAM. <br> Flag. Indicates the circular addressing mode for YRAM. |

## INPUT/OUTPUT BLOCK

| Resource | Paragraph <br> $\mathbf{N}^{\circ}$ | Symbol | Function |
| :--- | :---: | :--- | :--- |
| Access Mode Register | $5-5$ | AMR | 7 -bit register defining the access mode on the 2 external buses (local and <br> system). |
| Input Register | $6-4$ | RIN | $3 \times 8$-bit shift register. <br> Mailbox input. <br> $3 \times 8$-bit shift register. <br> Mailbox output. |
| Ready Out Internal | ROUT | 6-5 | RDYOIN | | Flag used in the protocol to indicate which processor has access to the mailbox. |
| :--- |

## SECTION 4 ARCHITECTURE

### 4.1. INTERNAL ARCHITECTURE

### 4.1.1. Parallel processing

The processor internal architecture is organized around the following blocks :

- the arithmetic logic unit and its associated working registers
- the multiplier
- the 3 memories and their associated address calculation units
- the transfer register
- the $1 / O$ unit.

All these blocks can work simultaneously and independently.

### 4.1.2. Three-bus structure

To avoid memory access bottlenecks the processor architecture includes 3 data buses. Two read buses (L-BUS and R-BUS) continuously feed the operating units. Thus making it possible to load the ALU and the multiplier with the two operands simultaneously. The write bus (Z-BUS) is used to transfer the results back into the RAMs (internal or external).

### 4.1.3. Wide instruction word

The 32 -bit wide instruction format allows the processor to execute the following operations in 1 instruction cycle:

- Read two operands (from internal or external memories)
- Execute an ALU operation
- Start a multiplication
- Use the result of the multiplication started 2 cycles before
- Write a result in internal/external memory
- Post-modify 3 pointers independently
- Store data into the transfer register.


### 4.1.4. Pipeline (cf. fig. 4.1.)

The figure 4.1. outlines the overlap of the instruction prefetch and execution as well as the pipelined data operation.
By using a pipeline structure, the processor performs efficiently on all digital signal processing algorithms. For example the result of a multiplication started at instruction $\mathbb{N}$ will be available at $\mathbb{N}+2$. That will not prevent from starting a new multiplication at $\mathbb{I N}+1$ which in turn will be available at $\mathbb{I N}+3$, etc... in effect, giving a multiplier throughput of 1 multiplication every cycle.
instruction cycle

PROGRAM COUNTER

INSTRUCTION

XRAM ADDRESS

CROM ADDRESS
A.BUS DATA
L.BUS DATA

MULTIPLIER INPUT M

MULTIPLIER INPUT N

MULTIPLIER OUTPUT P

ALU OUTPUT

YRAM ADDRESS

Z•BUS DATA


Figure 4.1.A. - pipeline delay

Example: READ AIXRAM), READ KICROMI, MULTIPLY A and K, ADD BIACCUMULATORI, WRITE RESULT A.K + B INTO YRAM.

INSTRUCTION CYCLE

PROGRAM COUNTER

INSTRUCTION

XRAM ADDRESS

CROM ADDRESS

R-BUS DATA

L-BUS DATA

MULTIPLIER INPUT M

MULTIPLIER INPUT N

MULTIPLIER OUTPUT P

ALU OUTPUT

YRAM ADDRESS

Z-BUS DATA


FIGURE 4.1.B. - PIPELINE THROUGHPUT

Example: The operation $A . K+B$ (described in fig. 4.1.A.) is executed every cycle.

### 4.2. EXTERNAL ARCHITECTURE

The TS68930 is provided with two external buses:

- the system bus: ADO-AD7
- the local bus: DO-D15.

The processor is a slave on the system bus.
The processor is a master on the local bus.


## SYSTEM BUS

The main use of the system bus is for the processor to exchange information with a general purpose microprocessor or another TS68930 in a multiprocessor environment.
The informations are exchanged through a mailbox with a flag ( ( $\overline{\mathrm{R} C})$ indicating to the master (the other processor) that it can gain access to the mailbox.

## LOCAL BUS

The main use of the local bus is for the processor to exchange information with an external memory, a peripheral, a data converter or another TS68930 in a multiprocessor environment. All these external circuits are defined as slaves.

The processor is the master of its local bus, i.e it generates the address and control signals which direct the exchange on the local bus. This bus is a direct extension of the internal structure and all external circuits connected on it, work in exactly the same way as the internal operating units.

## SECTION 5 FUNCTIONAL DESCRIPTION

### 5.1. OPERATING MODES

The processor provides three operating modes set by programming, each mode representing a different data type:

- REAL $=16$-bit data
- COMPLEX $(C P L X)=2 \times 16$-bit data
- DOUBLE PRECISION (DBPR) $=32$-bit data

The modes are made transparent to the programmer as all operating units and all working registers are provided with the right length.
Main differences between real mode and complex or double precision mode:
a) In complex and double precision mode the memory space is reduced by half as all operands are 32 -bit long (cf. format below).
b) The instruction cycle time is doubled ( 320 ns instead of 160 ns ) as all operations are made sequentially.


### 5.2. CONTROL BLOCK

### 5.2.1. Instruction ROM: IROM

The instruction ROM has a capacity of $1280 \times 32$-bit in the MCU version. It can be extended to $64 \mathrm{~K} \times 32$-bit in the MPU version.

### 5.2.2. Program counter: PC

The program counter is 16 -bit wide, 11 bits are used in the MCU version.

### 5.2.3. Sequencer: SEQ

The sequencer increments the program counter except in case of sequence jump which are listed below:
a) immediate branch
b) computed branch
c) jump to subroutine
d) return from subroutine
(cf 5.2.4.)
e) automatic loop
(cf 5.2.5.)
In case of immediate branch the PC is loaded with an immediate value whereas in case of computed branch the PC is loaded with a value coming from the accumulators (A, B), the FIFO (F) or the transfer register (T).

The sequencer can test directly 16 conditions programmed on a high or low state:

BRANCH NEVER/ALWAYS
STATUS CONDITIONS

- SR Sign (Real)
- SI Sign (Imaginary)
- CR Carry (Real)
- Cl Carry (Imaginary)
- Z Zero
- OVF Overflow
- MOVF Memorized overflow

The memorized overflow (MOVF) is reset when tested by the branch instruction.

## EXTERNAL CONDITIONS

$\left.\begin{array}{l}\text { - BS0-BS2 } \\ \text { - BE3-BE6 }\end{array}\right\}$ External pins
The falling edges of BE3-BE6 are memorized internally and reset when tested by the branch instruction.
The external test conditions are used to synchronise different processes or as a ready input flag in multiprocessor system.

## MAILBOX FLAG

- RDYOIN Internal mailbox flag


### 5.2.4. Return address register : RAR

The JSR instruction allows one level of subroutine nesting with automatic saving of the PC on to the return address register (RAR).
Multiple level of subroutine nesting can be implemented in RAM using either of the two pointers as stack pointer. In this case the RAR is used as the last level of nesting.

### 5.2.5. Loop counter: LC

a) The efficiency of executing repeated calculations often encountered in Digital Signal Processing is considerably improved by using the loop counter since the instructions for counter increment and range check are no longer needed. This counter can implement a loop of up to 16 instructions repeated 256 times with a delay of up to 8 instructions.

## b) DESCRIPTION:

LCI : Instruction Loop Counter: 4-bit
Counts the number of instructions to be executed in the loop
LCR : Repeat Loop Counter: 8-bit.
Gives the number of times the loop will be repeated.
LCD: Delay Loop Counter: 3-bit.
Gives the delay between the declaration and the start of the loop.

## c) USE:

A loop is declared by loading the instruction loop counter and the delay loop counter with a constant (INI Instruction) and LCR with a constant or a variable (INI or OPDI instruction).
The loop counter contents can be saved (SVR instruction) with the following format:


Asserting HALT will freeze the state of the LC.
Asserting $\overline{\text { RESET }}$ will reset the LC.

### 5.3. PROCESSING BLOCK

### 5.3.1. Multiplier

a) The multiplier executes a $16 \times 16 \rightarrow 32$-bit signed multiplication every instruction cycle with a delay of 2 cycles independently of the operating mode.
The number representation is signed 2's complement and the result format for the 3 modes is shown in figure 5.3.1.
b) USE:

The multiplier is always active. To start a multiplication the two operands are loaded into the two input registers(M, N).
The multiplication will be repeated every cycle until one or both operands are changed. The processor offers the possibility of loading the two input registers independently.
The result is available in the product register ( $P$ ) two cycles later.
c) COMPLEX MULTIPLICATION:

The processor executes a complex multiplication:
$(A+j B) .(C+j D)=A C-B D+j(A D+B C)$
every 320 ns thanks to an internal 80 ns clock.
As it can be seen from the equation the complex multiplication can generate an overflow. In this case the multiplier overflow (OVFM) is memorised inside the status register.
d) NOTES:

No provision is made for the operation $8000 \times 8000$ (hexadecimal).
If this condition arises the product will be 8000 (hexadecimal).
After changing modes the product $P$ is calculated following the new mode.
The signal HALT (cf. Input/output) will inhibit the loading of the product register $P$.


REAL MODE $16 \times 16 \rightarrow 16$


ROUNDING ladding 1 TO BIT 14

AND TRUNCATION)
gives 16-BIT RESULT

COMPLEX MODE $16 \times 16 \rightarrow 16$ real
$16 \times 16 \rightarrow 16$ imaginary


REAL PART after rounding


IMAGINARY PART
after rounding

FIGURE 5.3.1. - MULTIPLICATION OUTPUT REGISTER (P) FORMATS

### 5.3.2. Barrel Shifter (BS)

All shift and rotation operations are performed at the L-side (left) ALU input. The operand can come from two sources: - LBUS

- P (product register)

There are two types of shift and rotate operations:

1) The operations which are part of the ALU code:

- arithmetic shift right by 1 (ASR)
- logical shift right by 1 (LSR)
- arithmetic shift left by 1 (ASL)
- logical shift left by 1 (LSL)
- logical shift right by 8 (LSRB)
- logical shift left by 8 (LSLB)
- rotate right by 1 (ROR)

2) The operations which are implemented through dedicated instructions:

- ASR $(0 \rightarrow 15)$ arithmetic shift right by $N \quad 0 \leqslant N \leqslant 15$
- LSR $(0 \rightarrow 15)$ logical shift right by $N$
- LSL $(C \rightarrow 15)$ logical shift left by $N$
- ROR $(0 \rightarrow 15)$ rotation right by $N$

Note:
In double precision the shift operations are not executed on 32 bits, but on $2 \times 16$-bit as the barrel shifter is a 16 -bit unit. in complex mode the shift operations are executed on the real and imaginary parts.

### 5.3.3 ALU

The ALU inputs are called L-Side (Left) and R-Side (Right).
There are two possible sources on the L-Side:

- L BUS
- $P$ (multiplier output).

There are two possible sources on the R-Side:

- R BUS
- Accumulators A or B.

The selection between $A$ or $B$ is made by the field ALU destination (refer to operating codes). If the ALU destination field is B then the ALU source is B. In all other cases A will be used.
The ALU output is called D.
There are four possible destinations for $D$ :

- Accumulator A
- Accumulator B
- FIFO
- Z-BUS (no working registers are modified).


## ALU CODES

There are 27 ALU codes. The list is shown in figure 7.9.

### 5.3.4. Saturation mode (SAT)

If the saturation mode is set (SAT flag) the circuit will behave as follows :

- Positive overflow = ALU result is forced to 7FFF (hexadecimal)
- Negative overflow = ALU result is forced to 8000 (hexadecimal)

The saturation mode does not apply to the double precision mode.

### 5.3.5. Status register: STA

a) DESCRIPTION


## CONDITION CODE REGISTER (CCR):

| SR | Sign (real) |
| :--- | :--- |
| SI | Sign (imaginary) |
| CR | Carry (real) |
| CI | Carry (imaginary) |
| Z | Zero |
| OVF | Overflow |

Set if the msb of the ALU result is 1 . Cleared otherwise.
Set if the msb of ALU imaginary result is 1 . Cleared otherwise.
Set if a carry is generated out of the msb of the operand for arithmetic and shift operations. Cleared otherwise.

|  |  | This implies that the result is not representable in the operand size. In complex mode it is equivalent to the overflow of the imaginary or real part. |
| :---: | :---: | :---: |
| MOVF | Memorised overflow | Set as overflow. Reset when tested by a branch instruction. |
| AOVF | Advanced overflow | Exclusive or of bit 14 and bit 15 of the ALU. <br> Set if there was an arithmetic overflow on half capacity ( 15 bits in real/complex mode, 31 bits in double precision mode). Cleared otherwise. |
| OVFM | Overflow (Multiplier) | Set if the multiplier adder/substractor has overflowed. Only meaningful for complex multiplication. Cleared otherwise. |

## STATE REGISTER

| EF | Empty FIFO | Set if the FIFO is empty. <br> Cleared otherwise. |
| :--- | :--- | :--- |
| SAT | Saturation mode flag | Set if the PSI is in saturation mode. <br> Cleared otherwise. |
| MODE <br> (2 bits) | Operating mode | Real, complex or double precision. |
| XC | XRAM | Circular addressing mode flag. |
| YC | YRAM | Circular addressing mode flag. |

b) USE

The status can be saved (instruction SVR).
The condition code register can be read (in OPIN instruction) and it can be loaded from a RAM via L-BUS (ALU code LCCR) without passing through the ALU.
The stàte register can be programmed by an $\mathbb{N} \mathbb{I}$ instruction.

### 5.3.6. Accumulators: $A, B$

a) The processor provides two distinct accumulators (A and B). In real mode they are 16-bit long. In complex and double precision mode they are 32-bit long.
b) Changing modes, changes the length of the accumulator and the relation between the words described below.


It must be noted that the imaginary (respectively lower) part of the word remains unmodified when switching to real mode.

### 5.3.7. FIFO: F

## a) FUNCTION

Highly pipelined algorithms require a series of pipeline registers between the ALU output and the memories in order to store intermediate results.

This is precisely the function of the $4 \times 16$-bit first-in first-out (FIFO) register.
b) DESCRIPTION

It is a $4 \times 16$-bit deep register that becomes $2 \times 32$-bit in complex and double precision modes (cf. format below).
c) USE

When the FIFO is full it becomes impossible to write into it.
When the FIFO is empty a status bit (EF) is set.
This bit can also be set by programmation.
d) NOTE

In real mode, a result loaded at instruction $\mathbb{N}$ into an empty FIFO will be available for transfer to the RAM at $\mathbb{N}+2$. In all other cases it will be at $\mathbb{N}+1$.

| REAL |
| :---: |
| REAL |
| REAL |
| REAL |
| I |
| REAL |



### 6.3.8. Replace code register: RC

## a) FUNCTION

The function of this register is to control the ALU by a data coming from the memories via L-BUS instead of an instruction. In other words it allows the data to take control of program sequencing without using test instructions.
For this reason it can be said that the instructions are data controlled.
b) DESCRIPTION

It is a 6-bit register with the following format :


BIT 1-5 = ALU code is substituted by this value
BIT $0=0$ Destination of ALU output $=$ accumulator A

$$
=1 \text { Destination of ALU output }=\text { accumulator } B
$$

c) USE

This register is controlled by three ALU codes :

| ALU code |  |
| :--- | :--- |
| RCR | Function |
| RCE | Load ALU control code in RC <br> RCER |
| Execute ALU control code contained in RC ALU control code contained in RC <br> Load new ALU control code in RC |  |

### 5.3.9. Transfer register: $\mathbf{T}$

## a) FUNCTION

It is a bidirectionnal register standing between L-BUS, and Z-BUS.
It can be a source and a destination to both buses.
Among its numerous uses, it can perform the function of :

- Loop back to the multiplier in one cycle
- Temporary register between memory and ALU
- Temporary register between memory and multiplier
- Operations between accumulators
- Memory to memory transfer.
- Saving program counter
b) DESCRIPTION

It is a 16 -bit register extended to 32 bits in complex and double precision mode.
c) USE

The relation between the 32 -bit and the 16 -bit word in case of mode switching is identical to the accumulators relation. In branch instruction the register can be used to save the PC.
When the mode is complex the PC (16-bit) is saved into the real part of the register, when the mode is DBPR the $P C$ is saved into the upper part of the register.
$T$ can also be used as a source of the PC:
When the mode is complex the PC is loaded with the real part of the register, when the mode is DBPR the PC is loaded with the upper part of the register.

### 5.4. MEMORY BLOCK

### 5.4.1. Data memories : XRAM, YRAM, CROM

The processor architecture allows the connection of four memories:

- 2 internal RAMs

XRAM $128 \times 16$-bit
YRAM $128 \times 16$-bit

- 1 internal data ROM separated from the program ROM

CROM $512 \times 16$-bit
In the microprocessor version this ROM is external.

- 1 external memory

ERAM $4 \mathrm{~K} \times 16$-bit
This external memory is accessed in a single cycle ( 160 ns ) in exactly the same way as the internal memories. Moreover it does not require any "glue" parts to be connected to the processor.

## Notes :

1. In complex and double precision modes all data are 32 -bit long. Hence the available memory space is divided by two.
2. The instruction set allows any combinations of simultaneous use of these memories ; the only restraints are :

- Reading and writing in the same RAM in the same cycle.
- Accessing CROM and ERAM simultaneously.


### 5.4.2. Addressing modes

The processor provides four addressing modes:

- Indirect addressing with post modification.
- Direct addressing.
- Immediate addressing.
- Circular addressing mode (also called virtual shift mode).


### 5.4.3. Address calculation units: ACU

Combining these four addressing modes and the processor 3-bus structure implies the need to generate at each instruction cycle three different addresses. To realise these functions each memory is associated with an address calculation unit:

- XRAM with XACU
- YRAM with YACU
- CROM or ERAM with ECACU.
5.4.4. Pointers: X0, X1, YO, Y1, CO, C1, EO, E1, X, Y

Indirect addressing is the most commonly used addressing mode in vector or signal processing. For this reason the processor offers a large number of pointers (10): $\mathrm{XO}, \mathrm{X1}, \mathrm{YO}, \mathrm{Y} 1, \mathrm{CO}, \mathrm{C1}, \mathrm{EO}, \mathrm{E} 1+\mathrm{X}$ and Y for circular mode.
Each memory can be addressed by two pointers and pointers can be increased $(+1)$ decreased $(-1)$ or held $(+0)$ independently.
They can also be loaded with new addresses (constants or computed values) and saved in case of context switching (cf.format below).


### 5.4.5. Circular adressing mode

a) FUNCTION

This feature is used to simulate the function of a shift register without moving the data stored. It is particularly useful in filtering and convolution functions.
b) DESCRIPTION

X0 : lower limit
X1: upper limit
$X$ : current address
(respectively YO, Y1, Y for YRAM)
The algorithm can be described as follows:

1. ADDRESS: ADDRESS +1 (post-incrementation)

IF ADDRESS GREATER THAN UPPER LIMIT THEN ADDRESS $=$ HOWER LIMIT
2. ADDRESS: ADDRESS - 1 (post-decrementation)

IF ADDRESS SMALLER THAN LOWER LIMIT THEN ADDRESS = UPPER LIMIT
c) USE

Programming the circular addressing mode is done independently of the operating modes (real, complex or double precision), in the following way. With reference to the instruction OPCODE: example XRAM.

1. Initialization instruction (INI)

Circular addressing bit set (K7 = 1)
Load X0 with lower limit.
2. Initialization instruction (INI)

Circular addressing bit set (K7 = 1)
Load X1 with upper limit.
3. INI or OPDI instruction

Load $X$ with current address (a value between $X 0$ and $X 1$ ).
After the first instruction the circular addressing mode is effective.
From now on the programmer has access only to pointer $X$ and $X 1$. All instructions referencing pointer $X 0$ will now physically reference pointer $X$.

To gain access again to pointer $X 0$ the programmer goes back to the normal mode by an initialisation instruction.
d) FLAGS

When a RAM is in the circular addressing mode, a flag ( $X C, Y C$ ) is set inside the status.

### 5.4.6. ODD/EVEN addresses

a) In complex and double precision modes the processor automatically generates the two addresses of the word (even then odd).

|  | COMPLEX WORD |
| :--- | :--- | DBPR WORD

The processor offers the possibility to inverse this order by writing a 1 into the ADOF bit (refer to OPCODE). ADOF
0 even followed by odd
1 odd followed by even.
b) USE

This feature is made available independently or simultaneously for XRAM and YRAM.
With reference to OPCODE.

## XRAM

Initialization instruction (INI)

- select complex or double precision mode
- select pointer X0 or X1 and load it with J constant
- select ADOF bit as wanted ( 0 or 1 ).


## YRAM

Initialization instruction (INI)

- select complex or double precision mode
- select pointer Y0 or Y 1 and load it with K constant
- select ADOF bit as wanted (0 or 1 ).


### 5.5. ACCESS MODE REGISTER: AMR

## a) DESCRIPTION

This register defines the processor external access modes.
Its contents can be initialized with a constant and saved into memory, (cf. format below).
It is a 7-bit register each bit being defined as shown below:
$\overline{F E} / \mathrm{SE} \quad$ :Fast exchange/slow exchange on local bus
SL/PS :Slave/pseudo-Slave on system bus
$\overline{\mathrm{S}} / \mathrm{CB} \quad$ :Concatenated or separate local bus
IT/M :Local bus control signal types
$\overline{\text { DTACK/BE6 : BE6 pin redefinition }}$
BA/BE5 :BE5 pin redefinition
MASK : Allows the AMR to be masked by the external halt (microprocessor version only).

| 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MASK | BA | $\overline{\text { DTACK }}$ | $i$ | $\overline{S B}$ | $\overline{S L}$ | $\overline{\mathrm{FE}}$ |
|  | BE5 | BE6 | M | CB | PS | SE |



BIT 0: $\overline{\mathrm{FE}} / \mathrm{SE}$
0 FAST EXCHANGE = external access in $160 \mathrm{~ns}(1$ cycle)
1 SLOW EXCHANGE = external access in 320 ns (2cycles).
The slow exchange mode:

- Can only be used in the real mode.
- The circuit automatically repeats the instruction which defines the external transfer.
- The control of the multiplier, ALU, ACUs, loop counter is the responsibility of the programmer who must take into account the repetition of the instruction.


## BIT 1: SL/PS

$0=$ Slave
$1=$ Pseudo Slave.
A pseudo-slave processor can address an external RAM using the system bus (ADO-AD7) as address lines for its own local bus. Consequently the system bus is no more available for exchanging data between the pseudoslave processor and the bus master.
The pseudo-slave processor behaves differently from a slave processor since in case of exchange it must relinquish this bus to the master following an exchange protocol. (Reference to I/O)

## BIT 2: $\overline{\text { SB }} / C B$

$0=$ Separate bus
$1=$ Concatenated bus.
The local bus can be used as two independent 8 -bit buses (D0-D7), (D8-D15) or a single 16 bit-bus (D0-D15).
BIT 3: $\overline{\mathrm{I}} / \mathrm{M}$
$0=$ Control pulses Read $(\overline{R D})$ and Write ( $\overline{W R}$ ) are generated
$1=$ Control pulses data strobe ( $\overline{\mathrm{DS}}$ ) and Read/Write $(\mathrm{R} / \overline{\mathrm{W}})$ are generated.
The local bus supports the two main types of interchange signal:

- A slave processor, a data converter such as the MAFE, a 68000 peripheral, etc. requiring a data strobe and a read/write pulse.
- The standard bytewide RAM requiring a read and a write pulse.

BIT 4: $\overline{\text { DTACK/BE6 }}$
$0=\overline{\text { DTACK }}$ Indicates transfer acknowledge on the system bus to insure $\mathbf{6 8 0 0 0}$ family compatibility.
$1=$ BE6 External test condition.
BIT 5: BA/BE5
$0=B A \quad B U S$ available. Indicates to the master that the pseudo-slave is not using the system bus for generating addresses on local bus.
$1=$ BE5 External test condition.

## BIT 6: MASK (TS68931 only)

$0=A M R \quad$ is not masked. When an external halt is applied to the processor the AMR register does not change.
$1=$ AMR is masked. When an external halt is applied to the processor the AMR register changes to the following state: FAST EXCHANGE, PSEUDO-SLAVE,CONCATENATED BUS, $\overline{R D}$ and WR control pulses.
This bit can be modified by the programmer even while the HALT is asserted.

### 5.6 RESET

The reset signal has the following effects on the different blocks on the circuit :
SEQUENCER
PC, LC cleared to zero.
IR loaded with NOP instruction.
STATUS:

- REAL mode
- no saturation
- empty FIFO (EF = 1)
- memorised overflow (MOVF) $=0$.
$X$ or YRAM
- no circular addressing mode.

AMR

- Fast exchange
- Slave
- Concatenated bus
- $\overline{R D}$ and $\overline{W R}$
- BE6
- BE5.

RESET must be maintained for a minimum of 3 clock cycles ( 480 ns ) to be effective.

### 5.7 HALT (TS68931 only)

The external halt signal will freeze the program counter and the loop counter. The instruction register can then be loaded from an external source. This signal is used for system development. If the MASK bit = $\mathbf{1}$ it will force the AMR into the following state: FAST EXCHANGE, SLAVE, SEPARATE BUS, RD and WR control pulses.

## SECTION 6 INPUT/OUTPUT

### 6.1. DUAL-BUS INTERFACE

In order to permit a maximum versatility the processor interface provides two buses :

- the system Bus ADO-AD7
- the local Bus DO-D5.

This dual-bus interface allows the processor to be used in the following ways :
a) a microprocessor peripheral (fig. 6.A.)
b) a slave of another processor (fig. 6.B.)
c) a stand-alone unit connected to a peripheral or a data converter (fig. 6.C.)
d) a processor and its external memory (fig. 6.D.)
e) an intelligent peripheral connected to a general purpose microprocessor (fig. 6.E.)

These are some examples of the possibilities offered by the dual-bus interface. In addition very sophisticated multiprocessor machines can be built based on the principle of tree hierarchy (fig. 6.F.). In effect each processor becomes nested in the multiprocessor machine in the same way as subroutines are nested in a program tree.


FIGURE 6.A. - HOST/TS68930
FIGURE 6.B. - TS68930/TS68930


FIGURE 6.C. - TS68930/PERIPHERAL


FIGURE 6.D. - TS68930/RAM


FIGURE 6.E. - TEMPORARY MASTER/PSEUDO-SLAVE


FIGURE 6.F. - MULTIPROCESSING MACHINE

### 6.2. MASTER/SLAVE

The processor is a master on its local bus and a slave on its system bus. There are times where the processor needs to access an external RAM and for that purpose will use the system bus to generate the addresses.
In this case this circuit prevents the master from using the bus freely and for that reason is called a pseudo-slave. Since the master can only gain access to the bus temporarily it is now defined as a temporary master.
It is the programmer who decides whether the processor should behave as a slave or a pseudo-slave.
This is done by programming the Access Mode Register.
That gives four different types of processor configurations:

| PSI type | Definition |
| :--- | :--- |
| SLAVE (SL) | Its system bus is used to exchange data with a full master. <br> Its system bus is also used to generate addresses for its local exter- <br> nal memory. |
| FULL-MASTER (FM) |  |
| TEMPORARY-MASTER (TM) | It has complete mastership of its local bus. <br> Its local bus is shared with another processor which uses it to <br> generate addresses. |

These exchange type can be summarized to three possible connections:

1) Full master $\leftrightarrow$ slave
2) Full master $\leftrightarrow$ memories or peripherals
3) Temporary master $\leftrightarrow$ pseudo-slave.

Connection 1 (with reference to fig. 6.A., 6.B.):
The data is exchanged through a mailbox and the exchange follows the mailbox protocol.
Connection 2 (example 6.C., 6.D., 6.E.):
The exchange is equivalent to reading and writing of data into locations or registers.
Connection 3 (example 6.E.):
The data is exchanged through a mailbox and the exchange follows the mailbox protocol.

### 6.3. LOCAL BUS PIN DESCRIPTION


$\overline{D S}=$ data strobe. Synchronizes the transfer.
$R / \bar{W}=$ indicates the direction of data.
$\overline{R D}=$ read clock pulse.
$\overline{W R}=$ write clock pulse.
The bus can take the form of two independent 8 -bit buses or a single 16 -bit bus.
There are four address bits (A8-A11) which are sufficient to address many slaves without requiring additionnal circuitry. The address bus can be extended to 12 bits (ADO-AD7) to access an external memory.
If a peripheral is too slow to answer in one instruction cycle the processor can be programmed into a slow exchange mode. This mode is particularly useful for peripherals such as data converters, or the dedicated analogue interface circuit fabricated by THOMSON for modem applications. (The MAFE: Modem Analog Front-End).

## SEPARATION OF LOCAL BUS

The processor offers the possibility of dividing the local bus D0-D15 into two independent 8 -bit buses. This is used when a pseudo-slave monopolizes the bus to generate its own RAM addresses (fig. 6.3.) on D0-D7. By separating the bus, the processor can remain a full-master on D8-D15 even while being a temporary master on DO-D7, and it does not require the use of a bus transceiver on DO-D7.

The selection between the $2 \times 8$-bit buses is made by the addresses A10-A11.


FIGURE 6.3. - SEPARATE LOCAL BUSES

### 6.4. SYSTEM BUS AND MAILBOX



AD0-AD7 $=8$-bit data bus.
$\left.\frac{\overline{C S}}{\text { RS }}\right\} \quad=$ Mailbox control signal. Also used by master to gain access to bus.
$\left.\begin{array}{ll}\text { SR/ } \bar{W} & =\text { System Read/Write } \\ \overline{\text { SDS }} & =\text { System data strobe. }\end{array}\right\}$ Generated by external circuit (master)
IRO = Handshake signal. Used by the master to gain access to mailbox (and bus).
$\overline{\text { DTACK }}=$ Data acknowledge. Compatibility with 68000 family.
BA $\quad=$ Bus available. The PSI is not currently using the system bus to generate addresses.

## MAILBOX

The mailbox is comprised of two sets of registers: RIN and ROUT.
RIN ( $3 \times 8$-bit shift register).
This register is read internally on the upper byte of L-BUS (L8-L15) and written externally from the system bus. After each write operation (commanded by the external master) or slave read operation the data is shifted by 1. ROUT ( $3 \times 8$-bit shift register).
This register is written internally with the upper byte of the Z-BUS (Z8-15) and read externally on the system bus by the external master. After each master read operation or slave write operation the data is shifted by 1.

### 6.5. MAILBOX PROTOCOL



This protocol is hardwired on the slave side and programmed on the master side. The mailbox is included in the slave. The two slave address pins ( $\overline{\mathrm{CS}}, \overline{\mathrm{RS}})$ are directly connected to two master address lines.
Therefore, the slave is seen as two external memory locations by the master which will address it by generating an external address directly or indirectly (pointer E0 or E1).
By addressing the location 00 the master echoes the $\overline{\mathrm{RQ}}$ to the slave and accesses the mailbox.
By addressing the location 01 the master releases the bus.
The complete protocol is explained below.
MASTER SLAVE
MAILBOX IS AVAILABLE
Asserts IRO, RDYOIN


## SIGNAL MEANING

## RDYOIN

Internal flag indicating the property of the mailbox.
$0=$ Slave has access to the mailbox
$1=$ Master has access to the mailbox.
a) RDYOIN is set by the slave and reset by the master. That means that the slave gives the mailbox to the master when it finishes using it and vice-versa. In no case can the master or the slave request the mailbox, it can only wait for the other to give it back.
b) From the slave point of view, RDYOIN is a flag:

- tested by a branch instruction
- set by an initialization instruction.


## $\overline{\text { IRQ }}$

Handshake signal used by the master to gain access to the mailbox;
a) IRO is asserted by the slave to indicate the availability of the mailbox (at the same time as RDYOIN).
b) The master (after testing $\overline{\mathrm{R} Q}$ ) knows that it can access the mailbox but does not know if it has access to the bus (since it does not know if the slave is behaving as a pseudo-slave).
It requests the bus by generating the address $\overline{C S}=0, \overline{\mathrm{RS}}=0$.
c) The slave internal I/O sequencer answers back by negating IRO. The master has now full control of the bus and the mailbox.
When the master has completed the exchange it generates the address $C S=0, \overline{R S}=1$ and the slave internal I/O sequencer resets RDYOIN.

## HALT (internal)

The internal halt has the following effects on the circuit :

- the program is stopped at the end of the current instruction; the program and loop counters are frozen
- a NOP is generated on the instruction bus
- no more addresses are generated on the system bus.


### 6.6. INSTRUCTION BUS (TS68931 only)

For the TS68931, CROM ( $512 \times 16$-bit) and IROM ( $64 \mathrm{k} \times 32$-bit) are external. They are read using the I-BUS, on which are multiplexed:

- the 16-bit instruction ROM address
- the 9 -bit coefficient ROM address +1 Output Enable bit (ENCROM)
- the 32-bit instruction code.

In order to synchronize the exchanges, an additional signal is generated: INCYCLE.
It is the internal instruction clock.
Data from CROM are read on the local bus.

### 6.7. APPLICATION EXAMPLES



FIGURE 6.7.A. - CONFIGURATION EXAMPLE: TS 68930 + RAM + MAFE


| A11 | A10 | A9 | A8 |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | $0 / 1$ | 1 | TS68930 <br> $(1)$ |
| 0 | 1 | 1 | $0 / 1$ | TS68930 <br> $(2)$ |
| 1 | 0 | $X$ | $X$ | RAM |

FIGURE 6.7.B. - CONFIGURATION EXAMPLE: 3 TS68930 + RAM


FIGURE 6.7.C. - CONFIGURATION EXAMPLE: 4 TS68930 + MAFE + RAM


FIGURE 6.7.D. - I-BUS INTERFACE (TS68931)

## SECTION 7 <br> INSTRUCTION SET

| Type | Mnemonic | Operation | Number of cycies |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | REAL | CPLX <br> DBPR |
| Calculation, instruction with indirect addresing | OPIN | This instruction refers to operands indirectly addressed | 1 | 2 |
| Calculation, instruction with direct addressing | OPDI | The operand sourcing the L.BUS is directly addressed | 1 | 2 |
| Calculation, instruction with immediate operand | OPIM | An immediate operand is read on R-RUS | 1 | 2 |
| General shift instruction | $\begin{aligned} & \text { ASR } \\ & \text { ASL } \\ & \text { LSR } \\ & \text { ROR } \end{aligned}$ | The operand sourcing the L-BUS can be shifted/rotated by $0 \rightarrow 15$ bits | 1 | 2 |
| Immediate branch Instruction | BRI | Conditional / unconditional branch to direct address | 2 | 2 |
| Computed branch Instruction | BRC | Conditional / unconditional branch to computed address | 2 | 2 |
| Data transfer instruction | SVR | This instruction is used to save register contents in external or internal RAM | 1 | 2 |
| Initialization and control instruction | INI | Pointers, access mode register, loop counter, mode initialization | 1 | 2 |

## INSTRUCTION SET LANGUAGE DEFINITIONS

| LDT | Load L-BUS source into transfer register T |
| :--- | :--- |
| R SRC | R-BUS source |
| LSRC | L-BUS source |
| SL. | ALU input selection - left side |
| SR | ALU input selection - right side |
| ALU DST | ALU output destination |
| ALUCODE | ALU codes |
| LDM | Load L-BUS source into multiplier input M |
| LDN | Load R-BUS source into multiplier input N |
| ZSRC | Z-BUS source |
| ZDST | Z-BUS destination |
| ZT | Load Z-BUS into transfer register T |
| ACE | Post incrementation: pointers CROM or ERAM |
| AY | Post incrementation: pointers YRAM |
| AX | Post incrementation: pointers XRAM |
| BRA | Branch address source |
| FT | False / True condition |
| SVPC | Save program counter |
| JDST | Destination register for J constant |
| KDST | Destination register for K constant |
| MODE | Operating mode |
| SAT | Saturation flag |
| ADOF | Even / odd flag |
| J7 | YRAM crrcular addressing mode flag |
| J COnstant | 8-bit constant used to initialize registers |
| K7 | XRAM circular addressing mode flag |
| K constant | 12-bit constant used to initialize registers |

7.1. OPERATING CODE FORMATS

| Bit | Field | Operations and codes |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | OP CODE | 00 |  |  |  |  |  |
| 2 | LDT | O-NO LOAD, 1-LBUS $\rightarrow$ T |  |  |  |  |  |
| $\begin{aligned} & 3 \\ & 4 \\ & \hline \end{aligned}$ | R SRC | 00 01 10 11 <br> $[X 0]$ [E0] [Y0] [Y1] |  |  |  |  |  |
| $\begin{aligned} & 5 \\ & 6 \\ & 7 \end{aligned}$ | L SRC | 000 001 010 011 <br> $[X 0]$ $[X 1]$ $[Y 0]$ RIN |  | $\begin{aligned} & 101 \\ & \text { [E1] } \end{aligned}$ | $\begin{aligned} & 110 \\ & {[C 0]} \end{aligned}$ |  |  |
| 8 | SL | 0-LBUS / 1-P |  |  |  |  |  |
| 9 | SR |  |  |  |  |  |  |
| $\begin{aligned} & 10 \\ & 11 \\ & 12 \\ & 13 \\ & 14 \end{aligned}$ | ALU CODE | CF. SPECIAL TABLE |  |  |  |  |  |
| $\begin{aligned} & 15 \\ & 16 \\ & \hline \end{aligned}$ | ALU DST | $\begin{array}{cccc} \hline 00 & 01 & 10 & 11 \\ \mathbf{D} & \text { F } & \text { A } & \mathbf{B} \\ \hline \end{array}$ |  |  |  |  |  |
| $\begin{aligned} & 17 \\ & 18 \\ & 19 \end{aligned}$ | Z SRC | 000 001 010 011 <br> $\mathbf{D}$ F A B | $\begin{gathered} 100 \\ \mathbf{T} \end{gathered}$ | $\begin{gathered} 101 \\ \text { CCR } \end{gathered}$ | $110$ | $111$ |  |
| 20 | LDM | O-NO LOAD / 1-LBUS $\rightarrow \mathrm{M}$ |  |  |  |  |  |
| 21 | LDN | O-NO LOAD / 1-RBUS $\rightarrow \mathrm{N}$ |  |  |  |  |  |
| $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | ACE | $\begin{array}{cccc} 00 & 01 & 10 & 11 \\ +0 & +1 & - & -1 \\ \hline \end{array}$ |  |  |  |  |  |
| $\begin{aligned} & 24 \\ & 25 \end{aligned}$ | AY | $\begin{array}{cccc} 00 & 01 & 10 & 11 \\ +0 & +1 & - & -1 \\ \hline \end{array}$ |  |  |  |  |  |
| $\begin{aligned} & 26 \\ & 27 \end{aligned}$ | AX | $\begin{array}{llll} 00 & 01 & 10 & 11 \\ +0 & +1 & - & -1 \end{array}$ |  |  |  |  |  |
| $\begin{aligned} & 28 \\ & 29 \\ & 30 \\ & \hline \end{aligned}$ | Z DST | 000 001 010 <br> NONE ROUT [Y0] | $\begin{aligned} & 011 \\ & {[\mathrm{Y} 1]} \end{aligned}$ | $\begin{aligned} & 100 \\ & {[E 0]} \end{aligned}$ | $\begin{aligned} & 101 \\ & \text { [E1] } \end{aligned}$ | $\begin{gathered} 110 \\ {[\times 0]} \end{gathered}$ | $\begin{gathered} 111 \\ {[\times 1]} \end{gathered}$ |
| 31 | 27 | O-NO LOAD / 1-ZBUS $\rightarrow$ T |  |  |  |  |  |

FIGURE 7.1. - OPIN: CALCULATION INSTRUCTION WITH INDIRECT ADDRESSING


FIGURE 7.2. - OPDI: CALCULATION INSTRUCTION WITH DIRECT ADDRESSING

OPERATING CODE FORMATS (Continued)


FIGURE 7.3. - OPIM: CALCULATION INSTRUCTION WITH IMMEDIATE OPERAND

| Bit | Fiold | Operations and codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | OP CODE | 01111 |  |  |  |  |  |  |
| $\begin{aligned} & 5 \\ & 6 \\ & 7 \end{aligned}$ | L. SRC | $\begin{gathered} 000 \\ \mathbf{X} \end{gathered}$ | $001$ | $\begin{gathered} 010 \\ Y \end{gathered}$ | $\begin{aligned} & 011 \\ & \text { RIN } \end{aligned}$ | $\stackrel{100}{\mathbf{T}}$ |  | $\begin{gathered} 111 \\ \mathbf{C} \end{gathered}$ |
| 8 | SL | 0-LBUS / 1-P |  |  |  |  |  |  |
| $\begin{gathered} \hline 9 \\ 10 \\ \hline \end{gathered}$ | ALU CODE | $\begin{array}{r} 00 \\ \text { AS } \\ \hline \end{array}$ | $\begin{array}{r} 01 \\ \text { LSL } \\ \hline \end{array}$ | $\begin{gathered} 10 \\ \text { LSR } \end{gathered}$ | $\begin{array}{r} 11 \\ \text { ROR } \\ \hline \end{array}$ |  | NOTE: When LSR, ASR, ROR shift value is complemented to 2 |  |
| $\begin{aligned} & 11 \\ & 12 \\ & 13 \\ & 14 \end{aligned}$ | SHIFT Value | 0000 0 | $\begin{gathered} 0001 \\ 1 \end{gathered}$ | ...... | $\begin{gathered} 1111 \\ 15 \end{gathered}$ |  |  |  |
| 15 | ALU DST | O-F/1-A |  |  |  |  |  |  |
| $\begin{aligned} & 16 \\ & 17 \\ & 18 \\ & 19 \\ & 20 \\ & 21 \\ & 22 \\ & 23 \\ & 24 \\ & 25 \\ & 26 \\ & 27 \\ & \hline \end{aligned}$ | LBUS DIRECT ADDRESS | MS |  |  |  |  |  |  |
| 28 29 30 31 |  |  |  |  |  |  |  |  |

FIGURE 7.4. - ASR, LSL, LSR, ROR: SHIFT INSTRUCTIONS

OPERATING CODE FORMATS (Continued)

| Bit | Field | Operations and codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 1 \\ & 2 \end{aligned}$ | OP CODE | 100 |  |  |  |  |
| 3 | BRA | 0-IR, 1-RAR |  |  |  |  |
| 4 | FT | O-FALSE, 1-TRUE |  |  |  |  |
| $\begin{aligned} & 5 \\ & 6 \\ & 7 \\ & 8 \end{aligned}$ | COND | REFER TO SPECIAL TABLE |  |  |  |  |
| 9 | SVPC | O-NO SVPC, 1-PC $\rightarrow$ RAR |  |  |  |  |
| 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | BRANCH ADDRESS | MSB |  |  |  |  |
| $\begin{aligned} & 26 \\ & 27 \end{aligned}$ | AX | $\begin{array}{cccc} 00 & 01 & 10 & 11 \\ +0 & +1 & - & -1 \\ \hline \end{array}$ |  |  |  |  |
| $\begin{aligned} & 28 \\ & 29 \\ & 30 \\ & \hline \end{aligned}$ | Z DST | $\begin{array}{cccc} 000 & 001 & 010 & 011 \\ \text { NONE } & - & {[Y 0]} & {[Y 1]} \end{array}$ | $\begin{gathered} 100 \\ \hline \end{gathered}$ | $101$ | $\begin{gathered} 110 \\ {[\times 0]} \end{gathered}$ | $\begin{gathered} 111 \\ {[\mathrm{X} 1]} \end{gathered}$ |
| 31 | ZT | $0-N O L O A D, 1-Z B U S ~ \rightarrow T$ |  |  |  |  |

FIGURE 7.5. - BRI: IMMEDIATE BRANCH INSTRUCTION


FIGURE 7.6. - BRC: COMPUTED BRANCH INSTRUCTION

OPERATING CODE FORMATS (Continued)

| Bit | Fiold | Operations and codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | OP CODE | 011000 |  |  |  |  |  |  |  |
| $\begin{aligned} & 6 \\ & 7 \\ & 8 \\ & 9 \end{aligned}$ | Z SRC | $\begin{gathered} 0000 \\ \text { X0 } \\ 1000 \\ \text { AMR } \end{gathered}$ | $\begin{gathered} 0001 \\ \times 1 \\ 1001 \\ \text { LC } \\ \hline \end{gathered}$ | $\begin{gathered} 0010 \\ Y 0 \\ 1010 \end{gathered}$ | $\begin{gathered} \hline 0011 \\ Y 1 \\ 1011 \\ F \\ \hline \end{gathered}$ | $\begin{gathered} 0100 \\ E 0 \\ 1100 \\ D \end{gathered}$ | $\begin{gathered} \hline 0101 \\ \text { E1 } \\ 1101 \\ \text { STA } \\ \hline \end{gathered}$ | $\begin{gathered} 0110 \\ \text { CO } \\ 1110 \end{gathered}$ | 0111 C1 <br> 1111 <br> - |
| $\begin{aligned} & 10 \\ & 11 \\ & 12 \\ & 13 \\ & 14 \\ & 15 \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & 16 \\ & 17 \\ & 18 \\ & 19 \\ & 20 \\ & 21 \\ & 22 \\ & 23 \\ & 24 \\ & 25 \\ & 26 \\ & 27 \\ & \hline \end{aligned}$ | ZBUS DIRECT ADDRESS | MSB <br> LSB |  |  |  |  |  |  |  |
| $\begin{aligned} & 28 \\ & 29 \\ & 30 \end{aligned}$ | Z DST | $\begin{aligned} & 000 \\ & \text { NONE } \end{aligned}$ | $\begin{gathered} 001 \\ \text { ROUT } \end{gathered}$ | $\begin{gathered} 010 \\ \mathbf{Y} \end{gathered}$ | $011$ | $\begin{gathered} 100 \\ \mathbf{E} \end{gathered}$ | 101 | $\begin{gathered} 110 \\ \mathrm{X} \end{gathered}$ | $111$ |
| 31 | ZT | O-NO L | D, 1-2B | $\rightarrow$ T |  |  |  |  |  |

FIGURE 7.7. - SVR: DATA TRANSFER INSTRUCTION


FIGURE 7.8. - INI: INITIALIZATION AND CONTROL INSTRUCTION

## 7．2．ALU CODES

| MNEMO－ | Function | SR | SI | CR | Cl | 2 | $\left\lvert\, \begin{gathered} o v \\ F \end{gathered}\right.$ | $\left\lvert\, \begin{gathered} \mathbf{M O} \\ \mathbf{V F} \end{gathered}\right.$ | $\begin{gathered} \mathbf{A O} \\ \mathbf{V F} \end{gathered}$ | CODE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | $\mathbf{A}+\mathbf{B}$ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 00010 |
| ADDC | A＋B＋CARRY | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 00011 |
| ADDS | $B+A / 16$ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 00001 |
| ADDX | $B+A^{*}$（COMPLEX CONJUGATE） | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 01010 |
| AND | A．B | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 01110 |
| ASL | CARRY | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | － | ＊ | 01011 |
| ASR |  | ＊ | ＊ | ＊ | ＊ | ＊ | 0 | － | ＊ | 01111 |
| CLR | CLEAR | 0 | 0 | 0 | 0 | 1 | 0 | － | 0 | 10011 |
| COM | COMPLEMENT A | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 10110 |
| COM | COMPLEMENT B | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 11000 |
| LCCR | LBUS $\rightarrow$ CCR | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 01001 |
| LSL | CARRY | ＊ | ＊ | ＊ | ＊ | ＊ | 0 | － | ＊ | 11011 |
| LSLB | LSL BYTE | ＊ | ＊ | ＊ | ＊ | ＊ | 0 | － | ＊ | 11001 |
| LSR | $0 \rightarrow \square \text { CARRY }$ | ＊ | ＊ | ＊ | ＊ | ＊ | 0 | － | ＊ | 00111 |
| LSRB | LSR BYTE | ＊ | ＊ | ＊ | ＊ | ＊ | 0 | － | ＊ | 11010 |
| NOP |  | － | － | － | － | － | － | － | － | 00000 |
| OR | A ${ }^{\text {a }}$ B | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 01101 |
| RCE | EXECUTE RC | ＊ | ＊ | 米 | ＊ | ＊ | ＊ | ＊ | ＊ | 10001 |
| RCER | EXECUTE RC／LOAD NEW CODE | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 10000 |
| RCR | LOAD RC |  |  |  |  |  |  |  |  | 10010 |
| ROR |  | ＊ | ＊ | ＊ | ＊＊ | ＊ | 0 | － | ＊ | 10111 |
| SBC | A＋ $\bar{B}+$ CARRY | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 米 | ＊ | 00101 |
| SBCR | $\bar{A}+B+C A R R Y$ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | ＊ | 01000 |
| SET |  | ＊ | ＊ | 0 | 0 | 0 | 0 | － | 0 | 11100 |
| SUB | $A+\bar{B}+1$ | ＊ | ＊ | ＊ | 米 | ＊ | ＊ | ＊ | ＊ | 00100 |
| SUBR | $\bar{A}+B+1$ | ＊ | 米 | ＊ | 米 | 类 | 米 | 米 | ＊ | 00110 |
| TRA | TRANSFER A | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 10100 |
| TRA | TRANSFER B | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 10101 |
| XOR | $\mathbf{A} \oplus \mathbf{B}$ | ＊ | ＊ | 0 | 0 | ＊ | 0 | － | ＊ | 01100 |

Affected bit．
Notes：
1）$A / B$ refer to ALU inputs（RESP．LSIDE／RSIDE）not to accumulators $A / B$
2）In ASL the Carry bit is equivalent to exclusive－or of bit 14 and 15.
7.3. TEST CONDITIONS

| TRUE CONDITION | FALSE CONDITION | CODE |
| :---: | :--- | :--- |
| BE3 | NO BE3 | 0100 |
| BE4 | NO BE4 | 0010 |
| BE5 | NO BE5 | 0011 |
| BE6 | NO BE6 | 0001 |
| ALWAYS | BRANCH NEVER | 0000 |
| BS1 | NO BSO | 1100 |
| BS2 | NO BS1 | 1101 |
| CI | NO BS2 | 1110 |
| MOVF | NO CI | 1010 |
| OVF | NO MOV | 0110 |
| RDYOIN | NO OVF | 1011 |
| SI | NO RDYOIN | 0111 |
| SR | NO SI | 1111 |
| $Z$ | NO SR | 1001 |
|  | NO Z | 0101 |

SECTION 8 PERFORMANCE EVALUATION

|  | TIME ( $\mu \mathrm{S}$ ) |
| :---: | :---: |
| TRANSVERSAL FILITER (N COEFFICIENTS) (1) |  |
| REAL COMPLEX ADAPTIVE REAL ADAPTIVE CMPLX | $\begin{aligned} & 0.160 \times N \\ & 0.320 \times N \\ & 0.320 \times N \\ & 0640 \times N \end{aligned}$ |
| BIQUAD FILTER - 4 COEFF | 0960 |
| LATTICE FILTER - 10 STAGE (1) | 6.4 |
| AUTOCORRELATION 10 th ORDER (2) <br> (240 samples) <br> (32-bit result) | $8 \mu \mathrm{~s} /$ sample 1.8 ms total |
| ```FFT (RADIX 2 DIF algorithm) (2) (3)``` |  |
| 64 . POINT COMPLEX <br> 128. POINT REAL <br> 256. POINT COMPLEX | $\begin{aligned} & 265 \\ & 270 \\ & 2000 \end{aligned}$ |
| COSINE CALCULATION | 2.4 |

Notes
(1) Excluding initialization, context switching, pipeline
(2) Usirfg external RAM.
(3) Including loading/unloading, scaling, bit reserve

## SECTION 9 <br> ELECTRICAL SPECIFICATIONS

### 9.1. MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}} \cdot$ | -0.3 to 7.0 | V |
| Input voltage | $\mathrm{V}_{\text {In }}{ }^{*}$ | -0.3 to 7.0 | V |
| Operating temperature range | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature range | $\mathrm{T}_{\text {stg }}$ | -55 to 150 | ${ }^{\circ} \mathrm{C}$ |
| Max. power dissipation | $\mathrm{P}_{\text {Dmax }}$ | 3 | W |

- With respect to $V_{S S}$

Stresses above those hereby listed may cause permanent damage to the device. The ratings are stress ones only and functional operation of the device at these or any conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard MOS circuits handling procedure should be used to avoid possible damage to the device.

### 9.2. DC ELECTRICAL CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, \mathrm{~T}_{A}=0$ to $+70^{\circ} \mathrm{C}$ (Unless otherwise specified)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5 | 5.25 | V |
| Input low voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | 0.8 | V |
| Input high voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input leakage current | $\mathrm{I}_{\mathrm{In}}$ | - | - | 10 | $\mu \mathrm{~A}$ |
| Output high voltage (lload $=-300 \mu \mathrm{Al}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.7 | - | - | V |
| Output low voltage (lload $=32 \mathrm{~mA})$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.5 | V |
| Power dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 1.5 | - | W |
| Input capacitance | $\mathrm{C}_{\mathrm{in}}$ | - | 10 | - | pF |
| Three state loff state) input current | $\mathrm{I}_{\mathrm{TSI}}$ | - | - | 10 | $\mu \mathrm{~A}$ |

### 9.3. AC ELECTRICAL SPECIFICATIONS - CLOCK AND CONTROL PINS TIMING

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ}\right.$ to $+70^{\circ} \mathrm{C}$; see figure 9.1.)
OUTPUT LOAD $=50 \mathrm{pF}+\mathrm{DC}$ characteristics I load
$\begin{array}{rll}\text { REFERENCE LEVELS: } \\ V_{I L}: 0.8 \mathrm{~V} & \mathrm{~V}_{\mathrm{IH}}: 2.4 \mathrm{~V} & \text { tr, } \mathrm{tf} \leqslant 5 \mathrm{~ns} \text { for input signals } \\ \mathrm{V}_{\mathrm{OL}}: 0.8 \mathrm{~V} & \mathrm{~V}_{\mathrm{OH}}: 2.4 \mathrm{~V} & \end{array}$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| External clock cycle time | tcex | 40 |  | 160 | ns |
| External clock fall time | tfex |  |  | 5 | ns |
| External clock rise time | trex |  |  | 5 | ns |
| EXTAL to CLKOUT high delay | tcoh |  | 25 |  | ns |
| EXTAL to CLKOUT low delay | tcol |  | 25 |  | ns |
| CLKOUT rise time | tcor |  |  | 10 | ns |
| CLKOUT fall time | tcof |  |  | 10 | ns |
| CLKOUT to $\overline{\mathrm{DS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ low | tds 1 |  | 5 |  | ns |
| CLKOUT to DS, RD, WR high | tdsh |  | 5 |  | ns |
| Control inputs set-up time (BSO . BS2, BE3...BE6, Reset, halt) | tsc | 20 |  |  | ns |
| Control inputs hold time (BSO BS2, BE3 . BE6, $\overline{\text { Reset, }}$, halt) | the | 10 |  |  | ns |
| CLKOUT to control output low ( $\overline{\mathrm{RQ}}, \mathrm{BA}$ ) | tdic |  |  | 50 | ns |
| CLKOUT to control output high (BA) | tohe |  |  | 50 | $n \mathrm{~s}$ |



FIGURE 9.1. - CLOCK AND CONTROL PINS TIMING

INTERNAL CLOCK OPTION
A crystal oscillator can be connected across XTAL and EXTAL. The frequency of CLKOUT: tc/ 2 is half the crystal fundamental frequency.

9.4. AC ELECTRICAL SPECIFICATIONS - LOCAL BUS TIMING
$\left(V_{C C}=5.0 \vee \pm 5 \%, T_{A}=0^{\circ}\right.$ to $+70^{\circ} \mathrm{C}$; see figure 9.2.)

| Characteristic | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\overline{R D}}, \overline{\mathrm{WR}}, \overline{\mathrm{AS}}$ pulse width | tPW | 1/2 tc - 15 | 1/2 tc | ns |
| address hold time | ${ }^{\text {t }}$ A ${ }^{\text {d }}$ | 10 | - | ns |
| data set-up time, write cycle | ${ }^{\text {t }}$ ( ${ }^{\text {d }}$ W | 25 | - | ns |
| data hold time, write cycle | ${ }^{\text {t }}$ DHW | 10 | - | ns |
| data set-up time, read cycle | ${ }^{\text {t DSR }}$ | 20 | - | ns |
| data hold time, read cycle | ${ }^{\text {D }}$ DHR | 5 | - | ns |
| address valid to $\overline{W R}, \overline{A S}, \overline{\mathrm{RD}}$ low | tarw | 1/2 tc-40 | - | ns |



FIGURE 9.2. - LOCAL BUS TIMING DIAGRAM

### 9.5. AC ELECTRICAL SPECIFICATIONS - SYSTEM BUS TIMING

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{A}=0^{\circ}\right.$ to $+70^{\circ} \mathrm{C}$; see figure 9.3.)

| Characteristic | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { SDS }}$ pulse width | ${ }^{\text {t }}$ SPW | 60 | - | ns |
| SR/产, $\overline{\mathrm{CS}}, \overline{\mathrm{RS}}$ set-up time | ${ }^{\text {' }}$ SAW | 20 | - | ns |
|  | ${ }^{\text {' }}$ SAH | 5 | - | ns |
| data set-up time, read cycle | ${ }^{\text {t }}$ SDSR | 20 | - | ns |
| data hold time, read cycle | ${ }^{\text {t }}$ SDHR | 5 | - | ns |
| data sei-up time, write cycle | 'SDSW | - | 35 | ns |
| data hold time, write cycle | ${ }^{\text {' }}$ SDHW | 10 | 50 | ns |
| $\overline{\text { SDS }}$ low to $\overline{\text { DTACK }}$ low | ${ }^{\text {t }}$ DSLDT | - | 50 | ns |
| $\overline{\text { SDS high to DTACK high* }}$ | ${ }^{\text {t DSHDT }}$ | - | 50 | ns |
| $\overline{\text { SDS }}$ high to $\overline{\mathrm{IRQ}}$ high | ${ }^{\text {t }}$ DSHIR |  | 50 | ns |

* DTACK is an open drain output test load include $R_{L}=820 \Omega$ at $V_{C C}$


FIGURE 9.3. - SYSTEM BUS TIMING DIAGRAM

## 9.6. - AC ELECTRICAL SPECIFICATIONS - INSTRUCTION BUS TIMING

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ}\right.$ to $+70^{\circ} \mathrm{C}$; see figure 9.4.)

| Characteristic | Symbol | Min | Max | Unit |
| :--- | :---: | :---: | :---: | :---: |
| CLKOUT high to INCYCLE high | $\mathrm{t}_{\text {INCH }}$ | 5 | 15 | ns |
| CLKOUT low to INCYCLE low | $\mathrm{t}_{\text {INCL }}$ | 5 | 15 | ns |
| CLKOUT high to address valid | $\mathrm{t}_{\text {IASW }}$ |  | 40 | ns |
| I-BUS address hold | $\mathrm{t}_{\text {IAHW }}$ | 20 | 40 | ns |
| Instruction valid | $\mathrm{t}_{\text {IISR }}$ | 20 |  | ns |
| Instruction hold | $\mathrm{t}_{\text {IIHR }}$ | 10 |  | ns |
| CROM data set-up time | $\mathrm{t}_{\mathrm{DSR}}$ | $\mathrm{tc}_{\mathrm{tc} / 2-40}$ |  | ns |
| CROM data hold time | $\mathrm{t}_{\text {DHR }}$ | 5 |  | ns |



FIGURE 9.4. - I-BUS TIMING DIAGRAM

## SECTION 10 PIN ASSIGNMENTS AND MECHANICAL DATA

10.1. - PIN ASSIGNMENTS



84-Terminal Chip Carrier (LCCC)


TABLE 10-1 PIN ASSIGNMENTS

| A1 | 122 | 811 | B50 | F9 | BE6/ $\overline{\text { DTACK }}$ | K2 | D6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A2 | 120 | C1 | 126 | F10 | AD4 | K3 | D7 |
| A3 | 119 | C2 | 124 | F11 | BE5/BA | K4 | D10 |
| A4 | 117 | C5 | 116 | G1 | 13 | K5 | D13 |
| A5 | 114 | C6 | VSS | G2 | 14 | K6 | D15 |
| A6 | VCC | C7 | 113 | G3 | 12 | K7 | EXTAL |
| A7 | 112 | C10 | BE4 | G9 | AD7 | K8 | R/ $\bar{W}$ |
| A8 | 19 | C11 | BS1 | G10 | AD5 | K9 | $\overline{\mathrm{CS}}$ |
| A9 | 17 | D1 | 128 | G11 | AD6 | K10 | RESET |
| A10 | 16 | D2 | 127 | H1 | DO | K11 | ADO |
| A11 | BE3 | D10 | BS2 | H2 | D1 | L1 | D5 |
| B1 | 125 | D11 | A11 | H10 | AD2 | L2 | D8 |
| B2 | 123 | E1 | 131 | H11 | AD3 | L3 | D9 |
| B3 | 121 | E2 | 130 | J1 | D2 | L4 | D11 |
| B4 | 118 | E3 | 129 | J2 | D4 | L5 | D14 |
| 85 | 115 | E9 | A10 | J5 | D12 | L6 | CLKOUT |
| B6 | 110 | E10 | A9 | J6 | VSS | L7 | XTAL |
| B7 | 111 | E11 | A8 | $J 7$ | VCC | L8 | $\overline{\mathrm{DS}}$ |
| B8 | 18 | F1 | 15 | $J 10$ | $\overline{\text { IRO }}$ | L9 | SR/W |
| B9 | INCYCLE | F2 | 10 | J11 | AD1 | L10 | SDS |
| B10 | HALT | F3 | 11 | K1 | D3 | Li1 | $\overline{\mathrm{RS}}$ |




## SECTION 11 <br> ORDERING INFORMATION

| Package Type | Temperature Range | Part Number |
| :---: | :---: | :---: |
| Plastic DIL | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68930CP |
| P Suffix | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS68930VP |
| Ceramic DIL | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68930CC |
| C Suffix | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS68930VC |
| LCCC | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68931CE |
| E Suffix | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | TS68931VE |
| PGA | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | TS68931CR |
| R Suffix |  |  |

As the TS68930 is a programmable circuit, a special ordering procedure has to be used. In order to get information about this procedure as well as the customer ordering sheet, please contact our sales representatives.

TS68950 MODEM TRANSMIT ANALOG INTERFACE

The TS68950 is a transmit (Tx) analog front-end circuit designed to implement high speed voice-grade modems up to 19200 bps according to the CCITT V.22, V.26, V.27, V.29, V. 32 and V. 33 recommendations or the BELL 212A, 208 and 209 standards. This circuit is particularly suited to work with the TS68951 receive (Rx) analog front-end circuit, the TS 68952 clock generator and the TS68930/31 digital signal processors (DSPs).

## Main features

- Two-channel digital to analog converter (DAC) for Tx and echocancelling signals.
- 6th-order low-pass filter (switched-capacitor filter with output continuous-time smoothing cell).
- Programmable attenuation over a 22 dB range with 2 dB steps.
- Direct interface with MPU standard 8 bit bus.


## CMOS

MODEM TRANSMIT ANALOG INTERFACE


PIN ASSIGNMENT



WฤษOVIO >כOา1

## PIN DESCRIPTION

| Name | No. | Function |
| :---: | :---: | :---: |
| D5-D7 | $1-3$ | 8 bit data bus inputs giving access to $\mathrm{T}_{\mathrm{x}}$, estimated echo, control and address registers. (With pins 20-24). |
| $\overline{\mathrm{E}}$ | 4 | Enable input. Data are strobed on the positive transitions of this input. |
| R/W | 5 | Read/write selection input. Internal registers can be written when R/W $=0$. Read mode is not used. |
| $\overline{\text { CSO-CS1 }}$ | 6.7 | Chip select inputs. The chip set is selected when $\overline{\mathrm{CSO}}=0$ and $\mathrm{CS} 1=1$. |
| RSO-RS1 | 8-9 | Register select inputs. Used to select D/A input registers or control/address registers in the write mode. |
| DGND | 10 | Digital ground $=0 \mathrm{~V}$. All digital signals are referenced to that pin. |
| TEST | 11 | Test input. Used to reduce testing time. <br> That pin must be connected to DGND in all applications. |
| V - | 12 | Negative power supply voltage $=-5 \vee \pm 5 \%$ |
| AGND | 13 | Analog ground $=0 \mathrm{~V}$. <br> Reference point for analog signals. |
| EXI | 14 | Programmable analog input tied to filter or attenuator input according to the RC4 register content. |
| ATO | 15 | Analog transmit output. |
| EEO | 16 | Analog echo cancelling output. |
| V+ | 17 | Positive power supply voltage: $+5 \mathrm{~V} \pm 5 \%$. |
| CLK | 18 | 1.44 MHz clock input. Used for internal sequencing. |
| TxCCLK | 19 | Transmit conversion clock input. Must be derived from CLK. |
| DO-D4 | 20-24 | See pins No. 1-3. |

## FUNCTIONAL DESCRIPTION

The TS68950 is a transmit analog interface circuit dedicated to voice-grade MODEMs, telephony and speech applications. The TS68950, the TS68951 (receive analog front-end circuit) and the TS68952 (clock generator) constitute an analog front-end chip set useful for implementation of synchronous MODEMs operating on two or four wires according to the CCITT V.26, V. 26 bis, V. 27, V. 27 bis, V. 27 ter and V. 29 recommendations or BELL 208 and 209 standards, or in two wires full-duplex according to CCITT V.22, V. 22 bis or BELL 212A (split band) and CCITT V. 26 ter and V. 32 (echo cancelling).

By receiving digital samples from a DSP like the TS68930/31, the TS68950 delivers two analog signals: the transmitted ( $T x$ ) signal that will be sent on the line and the estimated echo signal that will be subtracted from the received ( Rx ) signal on the TS68951 Rx chip.
The digital Tx and estimated echo samples are converted to analog during the low state and the high state of the TxCCLK clock, respectively.

## MAIN FUNCTIONS (See block diagram)

- 12 bit digital to analog converter multiplexed on two channels.
- Tx signal sample and hold running with Tx sampling frequency TxCCLK.
- Tx low-pass filter with continuous-time smoothing.
- Programmable attenuator from 0 to -22 dB with 2 dB steps.
- Estimated echo sample and hold running with Tx sampling frequency TxCCLK.


## DSP INTERFACE SIGNALS

The TS68950 interfaces to the signal processor via an 8 bit data bus (only used in writing mode), two chip select lines, two register select lines, a read/ write line and an enable line.

Data bus (D0-D7) - The write only data lines allow the transfer of data from the DSP to the TS68950. Input buffers are high-impedance devices.
Enable ( $\overline{\mathrm{E}})$ - The enable pulse $(\overline{\mathrm{E}})$ is the basic timing signal that is supplied to the TS68950. All the other signals are referenced to the leading and trailing edges of the $\bar{E}$ pulse.

Read/Write ( $R / \bar{W}$ ) - This signal is generated by the DSP to control the direction of data transfers on the data bus. A low level state on the TS68950 read/ write line enables the input buffers and data is transferred from the DSP to the TS68950 on the $\bar{E}$ signal if the circuit has been selected. The device is unselected when a high level signal is applied to the $R / \bar{W}$ pin.
Chip Select ( $\overline{\mathrm{CSO}}, \mathrm{CS} 1$ ) - These two input signals are used to select the chip. CSO must be low and CS1 must be high for selection of the device. Data transfers are then performed under the control of the enable and $R / \bar{W}$ signals. The chip select lines must be stable for the duration of the $\bar{E}$ pulse.

Register Select (RS0, RS1) - The two register select lines are used to access the different registers inside the chip. For instance these two lines are used in conjunction with the internal control register ARC to select a particular register RC4. The register select lines must be stable when the $\bar{E}$ signal is low.

## CLOCK INTERFACE BETWEEN TS68950 AND TS68952

The TS68950 receives two clock lines from the Clock Generator TS68952.

## Master clock sequencing (CLK)

The typical frequency is 1.44 MHz but the recurrence frequency must be an exact multiple of the terminal clock frequency. The Tx DPLL included in the clock generator circuit (TS68952) operates by adding or subtracting pulses to a 2.88 MHz internal clock. This corresponds to phase leads or phase lags of about 350 ns duration. To ensure correct device operation, clock synchronization must be done immediately after the negative-going transition of TxCCLK clock.


## Transmit Conversion Clock (TxCCLK)

The conversion clock TxCCLK must be derived from the master clock CLK. Three nominal values are possible: $9.6 \mathrm{kHz}, 8 \mathrm{kHz}$ and 7.2 kHz .9 .6 kHz is the highest allowable frequency. To run properly the TxCCLK clock must be a submultiple of CLK/5:

## TxCCLK $\times 5 \times \mathbf{N}=$ CLK (with $\mathbf{N}$ integer)

This is ensured when using the TS68952 clock generator.
The sampling clock of the switched capacitor filter section is obtained by dividing the CLK frequency by five and performing internal synchronization on the leading edges of TXCCLK.
The Tx samples are converted from digital to analog during the low state of TxCCLK. The estimated echo samples are converted during the high state of TxCCLK.

## INTERNAL CONTROLS

## Power-on

The chip contains internal power-on reset logic to initialize the RC4 control register in order to avoid undesirable signal transmission on the telephone line.

## Internal addressing

| RS0 | RS1 | Access | $\mathbf{3 2 0}$ ns cycle <br> number |
| :---: | :---: | :--- | :---: |
| 0 | 0 | TR1 transmitted sample register | 2 |
| 0 | 1 | TR2 estimated echo sample <br> register | 2 |
| 1 | 0 | ARC address register | 1 |
| 1 | 1 | RC4 control register (if addressed <br> by ARC) | 1 |

## Sample registers (TR1 and TR2)

TR1 is the transmitted sample register and TR2 the estimated echo sample register. TR1 and TR2 store two's complement 12 bit data (DACO to DAC11). As indicated below, writing each sample requires two cycles.

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| First cycle | DAC 3 | $\begin{gathered} \text { DAC } \\ 2 \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { DAC } \\ 1 \end{array}$ | $\begin{array}{\|c} \hline \text { DAC } \\ 0 \end{array}$ | x | x | x | x |
| Second cycle | DAC | $\begin{gathered} \hline \text { DAC } \\ 10 \end{gathered}$ | $\begin{gathered} \text { DAC } \\ 9 \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { DAC } \\ 8 \end{array}$ | $\begin{gathered} \text { DAC } \\ 7 \end{gathered}$ | $\begin{gathered} \hline \text { DAC } \\ 6 \end{gathered}$ | $\begin{gathered} \hline \text { DAC } \\ 5 \end{gathered}$ | $\begin{gathered} \text { DAC } \\ 4 \end{gathered}$ |

An internal flip-flop is used to select the first or the second byte. It advances one count on the positivegoing edge of the $\bar{E}$ pulse when the sample registers are selected ( $\overline{\mathrm{CSO}}=0, \mathrm{CS} 1=1$ and RSO $=0$ ). When the sample registers are disabled, the latch is reset on any $\bar{E}$ positive-going edge. Both TR1 and TR2 registers are sampled by the DAC on the falling edge of TxCCLK. Therefore their contents must remain stable during this edge.

## Control register (RC4)

The RC4 control register has two different functions. Its four most significant bits give the transmit attenuator gain following the table below.

D7 D6 D5 D4 D3 D2 D1 D0 RC4 REGISTER

| ATT | $\begin{gathered} A T T \\ 3 \end{gathered}$ | $\begin{gathered} \mathrm{ATT} \\ 2 \end{gathered}$ | $\begin{gathered} A T T \\ 1 \end{gathered}$ | $-$ | EM2 | EM1 | $-$ | Attenuation (dB) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |  |  |  |  | 0 |
| 0 | 0 | 0 | 1 |  |  |  |  | 2 |
| 0 | 0 | 1 | 0 |  |  |  |  | 4 |
| 0 | 0 | 1 | 1 |  |  |  |  | 6 |
| 0 | 1 | 0 | 0 |  |  |  |  | - 8 |
| 0 | 1 | 0 | 1 |  |  |  |  | 10 |
| 0 | 1 | 1 | 0 |  |  |  |  | 12 |
| 0 | 1 | 1 | 1 |  |  |  |  | 14 |
| 1 | 0 | 0 | 0 |  |  |  |  | 16 |
| 1 | 0 | 0 | 1 |  |  |  |  | 18 |
| 1 | 0 | 1 | 0 |  |  |  |  | 20 |
| 1 | 0 | 1 | 1 |  |  |  |  | 22 |
| 1 | 1 | 0 | 0 |  |  |  |  | Infinite |
| 1 | 1 | 0 | 1 |  |  |  |  | Infinite |
| 1 | 1 | 1 | 0 |  |  |  |  | Infinite |
| 1 | 1 | 1 | 1 |  |  |  |  | Infinite |

Depending on the EM1 and EM2 states in the RC4 register, the programmable analog input (EXI) can be connected to the filter input or to the transmit attenuator input.

D7 D6 D5 D4 D3 D2 D1 D0 RC4 REGISTER

| ATT | ATT | ATT | ATT |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 4 | 3 | 2 | 1 | - |  |  | - | EX2 |
|  |  |  |  |  | 0 | 0 |  | disabled |
|  |  |  |  |  | 0 | 1 |  | transmit filter input |
|  |  |  |  |  | 1 | 0 |  | transmit attenuator input |
|  |  |  |  |  | 1 | 1 |  | disabled |

Following power-up, all RC4 bits are preset at one, EXI input is disabled and the transmit signal is cancelled.

DO and D3 bits are not used in the RC4 register.

## Address register (ARC)

The address register stores 3 bits (D5, D6 and D7). Among the 8 possible addresses, only one is used inside the TS68950 (RC4 address).


The address of the ARC register is automatically increased by one each time the control register is accessed. This allows indirect or cyclical addressing to RC4.

## EEO OUTPUT WAVEFORM

The EEO output is not valid during $\mathrm{S} / \mathrm{H}$ sampling. The output presents at this time the $\mathrm{S} / \mathrm{H}$ offset voltage.
This offset voltage appears at the 24th CLK period after rise transition of TxCCLK and disappears at the 31 th.

Waveform


## MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| DGND digital ground to AGND analog ground |  | -0.3 to +0.3 | V |
| $\mathrm{~V}^{+}$supply voltage to DGND or AGND ground |  | -0.3 to +7 | V |
| $\mathrm{~V}^{-}$supply voltage to DGND or AGND ground |  | -7 to +0.3 | V |
| Voltage at any digital input or output | $\mathrm{V}_{\mathrm{t}}$ | $\mathrm{DGND}-0.3$ to $\mathrm{V}^{+}+0.3$ | V |
| Voltage at any analog input or output | $\mathrm{V}_{\text {in }}$ | $\mathrm{V}^{-}-0.3$ to $\mathrm{V}^{+}+0.3$ | V |
| Analog output current | $\mathrm{I}_{\text {out }}$ | -10 to +10 | mA |
| Power dissipation | $\mathrm{P}_{\text {tot }}$ | 500 | mW |
| Operating temperature range | $\mathrm{t}_{\text {amb }}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature range | $\mathrm{t}_{\text {stot }}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Pin temperature (soldering 10 s .1 | $\mathrm{t}_{\text {sold }}$ | +260 | ${ }^{\circ} \mathrm{C}$ |

Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the operational sec-
tions of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Standard CMOS handling procedures should be employed to avoid possible damage to device

## ELECTRICAL OPERATING CHARACTERISTICS

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Positive Supply Voltage | $\mathrm{V}^{+}$ | 4.75 | 5 | 5.25 | V |
| Negative Supply Voltage | $\mathrm{V}^{-}$ | -5.25 | -5.0 | -4.75 | V |
| $\mathrm{~V}^{+}$Operating current | $1^{+}$ | - |  | 15 | mA |
| $\mathrm{~V}^{-}$Operating current | $1^{-}$ | -15 |  | - | mA |

## D.C. AND OPERATING CHARACTERISTICS

Unless otherwise noted, electrical characteristics are specified over the operating range. Typical values are given for $\mathrm{V}^{+}=+5 \mathrm{~V}, \mathrm{~V}^{-}=-5 \mathrm{~V}$ and $\mathrm{t}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$.
DIGITAL INTERFACE

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input low level voltage | $\mathrm{V}_{\text {IL }}$ |  |  | 0.8 | V |
| Input high level voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 |  |  | V |
| Input low level current DGND $<\mathrm{V}_{1}<\mathrm{V}_{\text {ILmax }}$ | IIL | $-10$ |  | 10 | $\mu \mathrm{A}$ |
| Input high level current $\mathrm{v}_{\mathrm{IHmin}}<\mathrm{v}_{1}<\mathrm{v}^{+}$ | ${ }^{\prime} \mathrm{IH}$ | $-10$ |  | 10 | $\mu \mathrm{A}$ |

## ANALOG INTERFACE, EXI PROGRAMMABLE INPUT

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input voltage swing | $\mathrm{V}_{\mathrm{in}}$ | -2.5 |  | +2.5 | V |
| Input current <br> (Input Tx filter selected) | $\mathrm{I}_{\mathrm{in}}$ | -10 |  | +10 | $\mu \mathrm{~A}$ |
| Input capacitance <br> (Input ATT selected) <br> f < 50 kHz <br> $\mathrm{f}>50 \mathrm{kHz}$ | $\mathrm{C}_{\mathrm{in}}$ |  |  |  |  |
| Input resistance <br> (Input ATT selected) |  |  |  |  |  |

ANALOG INTERFACE, ATO TRANSMIT OUTPUT

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Output DC offset | $\mathrm{V}_{\mathrm{OS}}$ | -250 |  | +250 | mV |
| Load capacitance | $\mathrm{C}_{\mathrm{L}}$ |  |  | 50 | pF |
| Load resistance | $\mathrm{R}_{\mathrm{L}}$ | 1200 |  |  | $\Omega$ |
| Output voltage swing <br> $R_{\mathrm{L}}>1200 \Omega$ <br> and $C_{\mathrm{L}}<50 \mathrm{pF}$ | $\mathrm{V}_{\text {out }}$ | -2.5 |  | +2.5 | V |
| Output resistance |  |  |  |  |  |

## ANALOG INTERFACE, EEO ESTIMATED ECHO OUTPUT

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Output DC offset | $\mathrm{V}_{\mathrm{os}}$ | -100 |  | +100 | mV |
| Load capacitance | $\mathrm{C}_{\mathrm{L}}$ |  |  | 50 | pF |
| Load resistance | $\mathrm{R}_{\mathrm{L}}$ | 10 |  |  | $\mathrm{k} \Omega$ |
| Output voltage swing <br> $R_{\mathrm{L}}>10 \mathrm{k} \Omega$ and <br> $\mathrm{C}_{\mathrm{L}}<50 \mathrm{pF}$ | $\mathrm{V}_{\mathrm{out}}$ | -2.5 |  | +2.5 | V |
| Output resistance |  |  |  |  |  |

DAC TRANSFER CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Converter resolution |  |  | 12 |  |  |
| Nominal output peak to peak amplitude | $V_{\text {out }}$ (max) |  | 5.0 |  | Bit |
| Least significant bit amplitude | LSB |  | 1.2 |  | V |
| Integral linearity error |  | -1 |  | +1 | LSB |
| Differential linearity error |  | -0.7 |  | +0.7 | LSB |

TRANSMIT FILTER TRANSFER CHARACTERISTICS (see annexe 1)

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Absolute passband gain at 1 kHz | $\mathrm{G}_{\mathrm{AR}}$ |  | 0 |  | dB |
| Gain relative to gain at 1 kHz <br> without $\sin \mathrm{x} / \mathrm{x}$ correction of DAC sampling <br> Below 3100 Hz <br> 3200 Hz <br> 4000 Hz <br> 5000 Hz to 12000 Hz <br> 12000 Hz and above | G RR |  |  |  |  |
| Absolute delay |  | -0.5 |  |  |  |
| 600 Hz to 3000 Hz |  | -3 |  |  |  |

## ATTENUATOR TRANSFER CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Absolute gain at 0 dB nominal value | $\mathrm{A}_{\mathrm{T}}$ |  | 0 |  | dB |
| Attenuation relative to nominal value | $\mathrm{R}_{\mathrm{AT}}$ | -5.0 |  | +0.5 | dB |
| Maximum attenuation | $\mathrm{B}_{\mathrm{AT}}$ | 40 |  |  | dB |

GENERAL TRANSFER CHARACTERISTICS (from DATA BUS to ATO)

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ATO absolute gain at 1 kHz | $\mathrm{G}_{\text {AX }}$ | $-0.5$ | 0 | $+0.5$ | dB |
| ATO psophometric noise |  |  |  | 100 | $\mu \mathrm{V}$ |
| ATO positive power supply rejection ratio. $\begin{aligned} & \mathrm{Vac}-200 \mathrm{mVpp} \\ & \mathrm{f}=1 \mathrm{kHz} \end{aligned}$ |  |  | 40 |  | dB |
| ATO negative power supply rejection ratio. $\begin{aligned} & \mathrm{V}_{\mathrm{ac}}=200 \mathrm{mVpp} \\ & \mathrm{f}=1 \mathrm{kHz} \end{aligned}$ |  |  | 40 |  | dB |
| Signal to harmonic distorsion ratio (psophometric band) |  | 60 |  |  | dB |

GENERAL TRANSFER CHARACTERISTICS (from DATA BUS to EEO)

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| EEO absolute gain at 1 kHz | $\mathrm{G}_{\mathrm{AX}}$ | -0.5 | 0 | +0.5 | dB |
| EEO psophometric noise |  |  |  | 100 | $\mu \mathrm{~V}$ |
| EEO positive power supply rejection ratio. <br> $\mathrm{ac}=200 \mathrm{mVpp}$ <br> $\mathrm{f}=1 \mathrm{kHz}$ <br> EEO negative power supply rejection ratio. <br> $V_{\text {ac }}=200 \mathrm{mVpp}$ <br> $\mathrm{f}=1 \mathrm{kHz}$ |  |  |  |  |  |

BUS TIMING CHARACTERISTICS (See Notes 1 and 2)

| Ident number | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Cycle time | $\mathrm{t}_{\text {cyc }}$ | 320 |  | ns |
| 2 | Pulse width, $\bar{E}$ low level | ${ }^{\text {t W WEL }}$ | 180 |  | ns |
| 3 | Pulse width, $\bar{E}$ high level | ${ }^{\text {t WEH }}$ | 100 |  | ns |
| 4 | Clock rise and fall time | $t_{r}, t_{f}$ |  | 20 | ns |
| 5 | Control signal hold time | ${ }^{\text {t HCE }}$ | 10 |  | ns |
| 6 | Control signal set-up time | ${ }^{\text {t }}$ SCE | 40 |  | ns |
| 7 | Input data set-up time | ${ }^{\text {t }}$ SDI | 120 |  | ns |
| 8 | Input data hold time | ${ }^{\text {t }} \mathrm{HDI}$ | 10 |  | ns |



FIGURE 1 - BUS TIMING

## Notes:

1. Voltage levels shown are $\mathrm{VL}<0.4 \mathrm{~V}, \mathrm{VH}>2.4 \mathrm{~V}$, unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.2 V , unless otherwise specified.

## CLOCK TIMING CHARACTERISTICS

| Ident number | Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | CLK clock period | $\mathrm{P}_{\mathrm{C}}$ |  | 695 |  | ns |
| 2 | CLK phase leading clock period | $\mathrm{P}_{\mathrm{CL}}$ |  | 348 |  | ns |
| 3 | CLK low level width | ${ }^{\text {t W CL }}$ | 150 |  |  | ns |
| 4 | CLK high level width | ${ }^{\text {t WCH }}$ | 150 |  |  | ns |
| 5 | CLK rise and fall time |  |  |  | 100 | ns |
| 6 | TxCCLK rise and fall time | ${ }^{\text {t }}$ RT, ${ }^{\text {t }}$ FT |  |  | 100 | ns |
| 7 | TxCCLK delay time | ${ }^{t} \mathrm{DC}$ | 20 |  | 130 | ns |



FIGURE 2-CLOCK TIMING


TRANSMIT LOW-PASS FILTER TYPICAL RESPONSE AND LIMITS CHART



TRANSMIT LOW-PASS FILTER TYPICAL GROUP DELAY AND LIMITS CHART

APPENDIX 1


## PHYSICAL DIMENSIONS

## CB-68



$\square$

The TS68951 is the receive section of a MODEM analog front-end. The MODEM consists of TS68950/51/52 analog front-end chip sets and TS68930/31 digital signal processor; it is able to run voice-grade applications, which conforms to CCITT V.22/BIS, V.26/TER, V.27, V. 29, V. 32 and V. 33 recommendations as well as BELL 212A, 208 and 209 standards.

## Main features

- Programmable band-pass filter.
- Back channel rejection filter (selected by programming)
- Reconstruction filter (selected by programming)
- Continuous-time anti-aliasing and smoothing filters
- Programmable gain amplifier (from 0 dB to 46.5 dB with 1.5 dB steps)
- 12 bit $A / D$ converter with asynchronous multiplexing of two plesiochronous channels (one channel for echo cancellation)
- Carrier level detector with programmable threshold.
- Digital interface: 8 bit bi-directional data bus, 6 bit control bus.
- Dual power supplies +5 V and -5 V
- Designed to operate with TS68950 transmit unit and TS68952 clock generator.

CMOS
MODEM RECEIVE ANALOG INTERFACE

PIN ASSIGNMENT

| $\text { D5 } \sqrt{1}$ | 28 | D4 |
| :---: | :---: | :---: |
| D6 2 | 27 | D3 |
| D7 $\square^{3}$ | 26 | D2 |
| $\overline{\mathrm{E}} \square^{4}$ | 25 | D1 |
| $\mathrm{R} / \overline{\mathrm{W}} \square 5$ | 24 | DO |
| $\overline{C S O}-6$ | 23 | TxCCLK |
| CS1 $\square^{7}$ | 22 | RxCCLK |
| RSO 8 | 21 | CLK |
| RS1 9 | 20 | $\mathrm{v}^{+}$ |
| DGND 10 | 19 | AGC2 |
| EEI 11 | 18 | CD1 |
| AGC1 12 | 17 | LEI |
| RFO 13 | 16 | RAI |
| $v-\square 14$ | 15 | AGND |



PIN DESCRIPTION

| Name | No. | Description |
| :---: | :---: | :---: |
| D5-D7 | 1.3 | Data bus |
| $\overline{\mathrm{E}}$ | 4 | Enable input. Enables selection inputs. Active on a low level for read operation. Active on a positive edge for write operation. |
| R/ $\bar{W}$ | 5 | Read/write Selection input. Read operation is selected on a high level. Write operation is selected on a low level. |
| $\overline{\mathrm{CSO}}-\mathrm{CS} 1$ | 6-7 | Chip select inputs. The chip set is selected when $\overline{\mathrm{CSO}}=0$ and $\mathrm{CS} 1=1$. |
| RSO-RS 1 | 8-9 | Register select inputs. Select the register involved in a read or write operation. |
| DGND | 10 | Digital ground. All digital signals are referenced to this pin. |
| EEI | 11 | Estimated echo input. When operating in echo cancelling mode, this signal is added to the reception bandpass filter output. |
| AGC1 | 12 | Analog input of the automatic gain control amplifier and of the carrier level detector. |
| RFO | 13 | Reception filter analog output. Designed to be connected to AGC1 input through a $1 \mu \mathrm{~F}$ non polarised capacitor. |
| V - | 14 | Negative power supply. $V-=-5 \vee \pm 5 \%$. |
| AGND | 15 | Analog ground. All analog signals are referenced to this pin. |
| RAI | 16 | Receive analog input. Analog input tied to the transmission line. |
| LEI | 17 | Local echo input. Analog input subtracted from the receive anti-aliasing filter output. |
| CD1 | 18 | This pin must be connected to the analog ground through a $1 \mu \mathrm{~F}$ non polarised capacitor, in order to cancel the offset voltage of the carrier level detector amplifier. |
| AGC2 | 19 | This pin must be connected to the analog ground through a $1 \mu \mathrm{~F}$ non polarised capacitor, in order to cancel the offset voltage of the AGC amplifier. |
| V+ | 20 | Positive power supply $\mathrm{V}^{+}=+5 \mathrm{~V} \pm 5 \%$. |
| CLK | 21 | Master clock input. Nominal frequency 1.44 MHz . |
| RxCCLK | 22 | Receive conversion clock. |
| TxCCLK | 23 | Transmit conversion clock. |
| DO-D4 | 24-28 | Data bus. |




## FUNCTIONAL DESCRIPTION

The TS68951 is a receive analog interface for voicegrade MODEM. It is able to perform the receive interface function for three types of synchronous MODEM:

- Four-wire or two-wire half duplex MODEM.
- Two-wire full duplex band-split MODEM.
- Two-wire full duplex echo cancelling MODEM.


## Four-wire or two-wire half duplex MODEM and two-wire band-split MODEM

In these modes of operation, EEI input must be tied to the analog ground. The analog signal treatment of receive input is shown in figure 1.
Programming requirements:

- Band-pass filter cut-off frequencies.
- Back channel rejection filter (presence or absence according to the application).
- SCF1 or SCF2 output as input of CTF2.
- AGC gain.
- Carrier level detector threshold.

The receive samples are coded at RxCCLK rate and can be read from receive register (RR1).

## Two-wire echo cancelling MODEM

This mode of operation uses the full capabilities of the TS68951. The analog treatment of receive input is shown in figure 2. The echo cancelling operation is achieved by means of subtraction of the LEI signal from the output of CTF1 duplexer and addition of the EEI signal to the output of SC1.
After the local echo reduction by the duplexer the resultant signal consists of the receive signal plus
the echo signal generated by the transmission line mismatch: this undesirable signal is then cancelled at the output of the Rx band-pass filter.
Programming requirements:

- Band-pass filter cut-off frequencies.
- SCF1 output as input of S/H2.
- Output of S/H2 as input of SCF3 and output of SCF3 as input of CTF2.
- AGC gain.
- Carrier level detector threshold.

Residual signal samples from $\mathrm{S} / \mathrm{H} 2$ output are coded at TxCCLK rate and can be read from receive register 2 (RR2), hence the signal processor may correlate them with the transmit samples to update the coefficients of the filter that generates the estimated echo.
The receive signal samples are coded at RxCCLK rate and can be read from receive register 1 (RR1).

## FUNCTIONAL SPECIFICATIONS

## Bus and Registers Control

For any operation involving bus and registers, the chip select bits CSO and CS1 must be valid (CSO $=0$ and CS1 = 1).
The seven internal registers are divided in four write only registers and three read-only registers.

## Write operation

There are three control registers (RC3, RC5, RC6) and one address register (ARC) which can be written; but only ARC can be directly addressed.
The control registers are indirectly addressed by the word contained in ARC according to table 1.

| Addressed control register | Word contained in ARC |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| RC3 | 0 | 1 | 0 | X | X | X | X | X |
| RC5 | 1 | 0 | 0 | X | X | X | X | X |
| RC6 | 1 | 0 | 1 | X | X | X | X | X |

X: don't care
table 1

When a write operation is selected (refer to table 3) the data present on the bus are strobed on a positive edge of $\bar{E}$ and the content of ARC is incremented.

Note: Addresses of RC3 and RC5 are separated by two increments.

## Read operation

There are two 12 bit receive registers (RR1, RR2) and a 1 bit carrier detector register (CDR).

RR2 contains the coded samples of the residual signal and RR1 the coded samples of the receive signal.

The active bit of CDR is $D 7$ : $D 0$ to $D 6$ are forced to 0 .

When the RMS value of CTF2 output is greater than the programmed threshold, bit 7 of CDR is set. The nominal response time of the carrier detector to a signal settlement or removal is 1.78 ms .

When a read operation is selected (refer to table 3) the data are sent to the bus on a low level of $\overline{\bar{E}}$; a high level on $\bar{E}$ sets the output bus drivers in a high impedance state.

As the bus has only 8 bits, the content of RR1 or RR2 must be read in two cycles. The four less significant bits are transferred in the first cycle and the eight most significant bits are transferred in the second cycle according to the format, table 2.

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| First cycle | $R R \times 3$ | $R R \times 2$ | $R R \times 1$ | $R R \times 0$ | 0 | 0 | 0 | 0 |
| Second cycle | $R R \times 11$ | $R R \times 10$ | $R R \times 9$ | $R R \times 8$ | $R R \times 7$ | $R R \times 6$ | $R R \times 5$ | $R R \times 4$ |

TABLE 2

An internal latch selects the first or the second byte and is automatically incremented on a positive edge of $E$ when one of the receive registers is addressed. This latch is not reset at power-on, so it needs to be
reset before the first read operation: reset occurs on any positive edge of $\bar{E}$ for any operation, provided none of the receive registers is addressed; the first byte is selected when reset.

| $\mathbf{R} / \overline{\mathbf{W}}$ | RSO | RS1 |  |
| :---: | :---: | :---: | :--- |
| 0 | 1 | 1 | Operation |
| 0 | 1 | 0 | Write control register addressed by ARC |
| 1 | 0 | 1 | Write address register (ARC) |
| 1 | 0 | 0 | Read receive register 2 (RR2) (Residual signal sample) |
| 1 | 1 | 0 | Read receive register 1 (RR1) (Receive signal sample) |

TABLF 3

RR1 and RR2 output code:
The output code is a 2 's complement delivering values from- 2048 up to +2047 . Since the converter codes voltage between -V ref and +V ref, the theoretical decision voltage corresponding to code C can be computed as follows:

$$
V_{c}=\frac{2 C+1}{4095} \quad V_{r e f}
$$

where $\mathrm{V}_{\text {ref }}$ is the reference voltage of the $\mathrm{A} / \mathrm{D}$ converter, $\mathrm{V}_{\text {ref }}$ nominal value is 2.5 V and C is the algebraic value of code $C$.

## Example:

Assume the output code is the hexadecimal value $\$ 8 \mathrm{~B} 1$; the algebraic value of this code $\mathrm{C}=-1871$ therefore $\mathrm{V}_{\mathrm{C}}=-2.283 \mathrm{~V}$.

## CONTROL REGISTERS DESCRIPTION

## Power-on

The control regsisters ate not mothalized at power on:
 ing any word from the outpult retys: 1 :r:.

## Register RC3

The content of RC3 sets the -3 dB cut-off frequencies of SCF1 receive band-pass filter, determines the presence or the absence of SCF2 back channel rejection filter and of SCF3 reconstruction filter, and selects receive signal path to the second filtering section: without echo-cancelling the output of SCF1 or SCF2 is selected; with echo-cancelling the output of $\mathrm{S} / \mathrm{H} 2$ is selected
The band pass filter consists of a bth order ellipmo low-pass filter and of a 2 and order high-pass filter whose cut off frequencres can be programmed by (LP1, LP2) and (HP1, HP2) respectively, (refer table 4).

The rejection filter is present when REJ bit is high.
The reconstruction filter is present when REC bit is high.

S/H2 output is selected when S/A bit is high


TABLE 4
X: don't care

Register RC5
The content of RC5 sets the gain of the AGC amplifier between 0 dB and 46.5 dB with 1.5 dB steps

Note: The AGC loop control is performed by the signal processor.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | Do | RC5 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | AGC gain (dB) |
| 0 | 0 | 0 | 0 | 0 | $x$ | x | x | 0 |
| 0 | 0 | 0 | 0 | 1 | x | $x$ | $x$ | 1.5 |
| 0 | 0 | 0 | 1 | 0 | x | $x$ | $x$ | 3 |
| 0 | 0 | 0 | 1 | 1 | x | x | x | 4.5 |
| 0 | 0 | 1 | 0 | 0 | x | $x$ | $x$ | 6 |
| 0 | 0 | 1 | 0 | 1 | x | $x$ | x | 7.5 |
| 0 | 0 | 1 | 1 | 0 | x | x | x | 9 |
| 0 | 0 | 1 | 1 | 1 | x | x | x | 10.5 |
| 0 | 1 | 0 | 0 | 0 | x | $x$ | x | 12 |
| 0 | 1 | 0 | 0 | 1 | $x$ | $\times$ | $x$ | 13.5 |
| " | 1 | 0 | 1 | $1)$ | x | $\times$ | $\times$ | 14 |
| 11 | 1 | 11 | 1 | 1 | - | * | * | 16.1. |
| (1) | 1 | 1 | 11 | ${ }^{1}$ | * | , | $x$ | 14 |
| 0 | 1 | 1 | 0 | 1 | $\times$ | x | x | 19! |
| 0 | 1 | 1 | 1 | 0 | x | x | $x$ | 21 |
| 0 | 1 | 1 | 1 | 1 | $x$ | $x$ | x | 22.5 |
| 1 | 0 | 0 | 0 | 0 | x | x | x | 24 |
| 1 | 0 | 0 | 0 | 1 | x | x | x | 25.5 |
| 1 | 0 | 0 | 1 | 0 | x | x | x | 27 |
| 1 | 0 | 0 | 1 | 1 | x | $x$ | x | 28.5 |
| 1 | 0 | 1 | 0 | 0 | x | x | x | 30 |
| 1 | 0 | 1 | 0 | 1 | x | $x$ | $x$ | 31.5 |
| 1 | 0 | 1 | 1 | 0 | x | x | X | 33 |
| 1 | 0 | 1 | 1 | 1 | x | x | x | 34.5 |
| 1 | 1 | 0 | 0 | 0 | x | x | x | 36 |
| 1 | 1 | 0 | 0 | 1 | $x$ | $x$ | $x$ | 37.5 |
| 1 | 1 | 0 | 1 | 0 | $x$ | x | x | 39 |
| 1 | 1 | 0 | 1 | 1 | $x$ | $\times$ | x | 40.5 |
| 1 | 1 | 1 | 0 | 0 | $x$ | $x$ | $x$ | 42 |
| 1 | 1 | 1 | 0 | 1 | $x$ | $x$ | $\times$ | 436 |
| 1 | 1 | 1 | 1 | 0 | $x$ | x | $x$ | 45 |
| 1 | 1 | 1 | 1 | 1 | x | x | x | 46.5 |

TABLE 5
X: don't care

## Register RC6

The content of RC6 sets the carrier level detector threshold. (Refer to table 6).

The threshold values are grouped by pair; values belonging to each pair have 2.5 dB separation which allows the signal processor to perform software hysteresis.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | RC6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 |  |  |  |  |  |  |  |
| 0 | 0 | 1 | $x$ | $x$ | $x$ | $x$ | $x$ | -29.85 |
| 0 | 1 | 0 | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ |
| 0 | 1 | 1 | $x$ | $x$ | $x$ | $x$ | $x$ | -27.35 |
| 1 | 0 | 0 | $x$ | $x$ | $x$ | $x$ | $x$ | -36.65 |
| 1 | 0 | 1 | $x$ | $x$ | $x$ | $x$ | $x$ | -46.75 |
| 1 | 1 | $x$ | $x$ | $x$ | $x$ | $x$ | -46.25 |  |
| 1 |  |  |  |  |  |  |  |  |

## CLOCK

The master clock CLK, the receive conversion clock (RxCCLK) and the transmit conversion clock (TxCCLK) are generated in the TS68952 clock generator. There are three possible frequencies for the conversion clocks: $7.2 \mathrm{kHz}, 8 \mathrm{kHz}$ and 9.6 kHz .
The frequency of RxCCLK and TxCCLK is controlled by two independant Digital Phase Locked Loops (DPLL). TxCCLK can be synchronised on an external Terminal Clock (TxSCLK) or on the Rx bit rate clock; in these cases 350 ns discrete phase shifts occurs on CLK and TxCCLK synchronously with TxCCLK negative edge with a repetition rate of $600 \mathrm{~Hz}, 800$ Hz or 1000 Hz according to the programmation of RC:1 control register in the TS68952.

## AGC and CLD AMPLIFIERS

The AGC consists of two cascaded amplifiers A1 and A2, fig. 3. AC coupling is obtained from C1 and C2 external capacitors. C2 can be used as an auxiliary input for performing an analog loop located after echo cancellation. The carrier level detector (CLD) amplifier A3 also needs an external capacitor C3.

## A/D CONVERSION

The A/D converter is a 12 bit resolution, 8 bit minimum integral linearity, monotonic converter. The input voltage ranges from -2.5 V to +2.5 V ; and the conversion time is better than $50 \mu \mathrm{~s}$.

## ASYNCHRONOUS MULTIPLEXING

Samples on the output of S/H1 and S/H2 are converted respectively at RxCCLK frequency and TxCCLK frequency. Since RxCCLK and TxCCLK are plesiochronous, the order of conversion is determined by an asynchronous logic. The output register RR1 and RR2 are respectively loaded on the negative edge of RxCCLK and TxCCLK.


FIGURE 3. Rx AMPLIFIERS SCHEMATIC

ELECTRICAL SPECIFICATIONS
The electrical specifications are given for operating temperature range ( $0^{\circ} \mathrm{C}, 70^{\circ} \mathrm{C}$ ). MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply voltage between $\mathrm{V}^{+}$and AGNC or DGND |  | -0.3 to +7 | V |
| Supply voltage between $\mathrm{V}^{-}$and AGND or DGND |  | -7 to +0.3 | $\checkmark$ |
| Voltage between AGND and DGND |  | -0.3 to +0.3 | V |
| Digital input voltage |  | DGND-0.3 to $\mathrm{V}^{+}+0.3$ | V |
| Digital output voltage |  | DGND -0.3 to $\mathrm{V}^{+}+0.3$ | V |
| Digital output current |  | -20 to +20 | mA |
| Analog input voltage |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-0.3}$ to $\mathrm{V}^{+}+0.3$ | V |
| Analog output voltage |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-0.3}$ to $\mathrm{V}^{+}+0.3$ | V |
| Analog output current |  | -10 to +10 | mA |
| Puwer dissipation |  | 500 | mW |
| Ourrating temperature | $T_{\text {oper }}$ | 0 to +70 | " 6 |
| Sturate temperatur. | $\mathrm{r}_{\mathrm{st}} \mathrm{g}$ | (65) 60 - 150 | $\because$ |

POWER SUPPLIES
DGND A(iND) ()V

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Positive power supply | $\mathrm{V}^{+}$ | 4.75 | - | 5.25 | V |
| Negative power supply | V | -5.25 | - | -4.75 | V |
| Positive supply current (receive signal level 0 dBm ) | $1^{+}$ | - | - | 20 | mA |
| Negative supply current (receive signal level 0 dBm ) | $\mathrm{I}^{-}$ | -20 | - | - | mA |

DIGITAL INTERFACE

## Control inputs

$V_{\text {oltages }}$ referenced to $\mathrm{DGND}=0 \mathrm{~V}$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Low level input voltage <br> High level input voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | - | 0.8 | V |
| Low level input current DGND $<\mathrm{V}_{1}<0.8 \mathrm{~V}$ | $\mathrm{~V}_{1 \mathrm{H}}$ | 2.2 | - | - | V |
| High level input current $2.2 \mathrm{~V}<\mathrm{V}_{1}<\mathrm{V}^{+}$ | $\mathrm{V}_{\mathrm{IL}}$ | -10 | - | 10 | $\mu \mathrm{~A}$ |

## DATA BUS

Voltages eferencedtol)(iNI) ()V

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Low level input voltage | $V_{\text {IL }}$ | - | - | 0.8 | V |
| High level input voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 | - | - | V |
| Low level output voltage ( ${ }^{\prime} \mathrm{OL}=2.5 \mathrm{~mA}$ ) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V |
| High level output voltage ( ${ }^{\text {OL }}=2.5 \mathrm{~mA}$ ) | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V |
| High impedance output current (when $\tilde{E}$ is high and DGND $<\mathrm{V}_{1}<\mathrm{V}^{+}$) | ${ }^{\prime} \mathrm{OZ}$ | $-50$ | - | 50 | $\mu \mathrm{A}$ |

## ANALOG INTERFACE

All voltages referenced to AGND $=0 \mathrm{~V}$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input voltage EEI,LEI,RAI | $\mathrm{V}_{\text {in }}$ | -2.5 | - | 2.5 | V |
| Input current EEI,LEI,RAI $\left(-2.5 \mathrm{~V}<\mathrm{V}_{\text {in }}<2.5 \mathrm{~V}\right)$ | $\mathrm{I}_{\text {in }}$ | -1 | - | 1 | $\mu \mathrm{~A}$ |
| Input resistance AGC1, AGC2 | $\mathrm{R}_{\text {in }}$ | 1.5 | - | - | $\mathrm{k} \Omega$ |
| Input resistance CD1 | $\mathrm{R}_{\text {in }}$ | 0.7 | - | - | $\mathrm{k} \Omega$ |
| Output voltage RFO CL $=50 \mathrm{pF}, \mathrm{RL}=1 \mathrm{k} \Omega$ | $\mathrm{V}_{\text {out }}$ | -2.5 | - | 2.5 | V |
| Output resistance RFO | $\mathrm{R}_{\text {out }}$ | - | - | 2 | $\Omega$ |
| Load resistance RFO | $\mathrm{R}_{\mathrm{L}}$ | 1 | - | - | $\mathrm{k} \Omega$ |
| Load capacitance RFO | $\mathrm{C}_{\mathrm{L}}$ | - | - | 50 | pF |

## BUS TIMING CHARACTERISTICS

(See foot notes 1 and 2 on timing diagrams)

| Characteristic |  | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Ciycle 11.6. | (1) | ${ }^{1} \mathrm{CYC}$ | 320 |  | - | ns |
| Palor widthe low level | (2) | 'WH: | 180 |  | - | ns |
| Pulse widht h high level | (3) | ${ }^{\text {'WEH }}$ | 100 | $\cdots$ | - | ns |
| Clock rise and fall timu: | (4) | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | - | 20 | ns |
| Control signal hold time | (5) | ${ }^{\text {t HCE }}$ | 10 | - | - | ns |
| Control signal set-up time | (6) | ${ }^{\text {t SCE }}$ | 40 | - | - | ns |
| Input data set-up time | (7) | ${ }^{\text {t SDI }}$ | 120 | - | - | ns |
| Input data hold time | (8) | ${ }^{\text {tHDI }}$ | 10 | - | - | ns |
| Output data set-up time <br> ( 1 TTL load and CL=50 pF) | (9) | ${ }^{\text {t }}$ SDO | - | - | 150 | ns |
| Output high impedance delay time ( 1 TLL load and $\mathrm{CL}=50 \mathrm{pF}$ ) | (10) | ${ }^{\text {d }} \mathrm{dz}$ | - | - | 80 | ns |

## RECEPTION CHARACTERISTICS

PERFORMANCE OF THE WHOLE RECEPTION CHAIN (input RAI or LEI, output RR1)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Gain. $\left(A G C \text { gain }=0 \mathrm{~dB}, \mathrm{~B} \times C C L K=9600 \mathrm{~Hz}, \mathrm{~V}_{\text {in }}=775 \mathrm{mV}_{\mathrm{eff}}, f=2000 \mathrm{~Hz}\right)$ | G | $-0.5$ | - | 0.5 | dB |
| Total harmonic distortion $\text { (AGC gain }=0 \mathrm{~dB}, \mathrm{RxCCLK}=9600 \mathrm{~Hz}, V_{\text {in }}=775 \mathrm{mV} \text { eff, } f=2000 \mathrm{~Hz} \text { ) }$ | TD | - | - | -58 | dB |
| Equivalent RMS noise: <br> (AGC gam O) dB, RAI, I \& I 1 1 1 thed to A(GND) | $N$ |  | - | 1.2 | $\mathrm{mV}_{\text {eff }}$ |

Note: Noise depends on AGC gain value.

PERFORMANCE OF THE RECEPTION SUB-CHAIN (from RAI input to S/H2 input)

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\left.\begin{array}{l}\text { Total distortion } \\ (R \times C C L K \\ \end{array}=9600 \mathrm{~Hz}, \mathrm{~V}_{\text {in }}=1.6 \mathrm{~V}_{\text {eff }}, \mathrm{f}=2000 \mathrm{~Hz}\right)$ | TD | - | - | -72 | dB |

## WRITE OPERATION



READ OPERATION


Notes:

1. Voltage levels shown are $\mathrm{V}_{\mathrm{IL}}<0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}>2.4 \mathrm{~V}$, unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.2 V , unless otherwise specified.

RECEIVE BAND-PASS FILTER AND REJECTION FILTER (input RAI, output RFO)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
| Reference gain $\left(\mathrm{V}_{\text {in }}=775 \mathrm{mV}_{\mathrm{eff}}, f=1800 \mathrm{~Hz}\right)$ | $\mathrm{G}_{\text {ref }}$ | $-0.5$ | - | 0.5 | dB |
| $\begin{aligned} & \text { Relative gain to } G_{\text {ref }} \\ & 0 \mathrm{~Hz}<\mathrm{f}<3000 \mathrm{~Hz} \\ & \mathrm{f}=3200 \mathrm{~Hz} \\ & \mathrm{f}>6250 \mathrm{~Hz} \end{aligned}$ | Grel | $\begin{gathered} -0.4 \\ -3 \\ - \end{gathered}$ | $-$ | $\begin{gathered} 0.3 \\ 0.3 \\ -60 \end{gathered}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \end{aligned}$ |
| Group propagation delay time $(f=1800 \mathrm{~Hz})$ | $\mathrm{T}_{\mathrm{gp}}$ | - | - | 300 | $\mu \mathrm{s}$ |
| Group propagation delay time distortion ( $600 \mathrm{~Hz}<\mathrm{f}<3000 \mathrm{~Hz}$ ) | $\mathrm{T}_{\mathrm{gpd}}$ | - | - | 360 | $\mu \mathrm{s}$ |
| High-Pass filter ( $\mathrm{Fs}^{\text {¢ }}$ 72kHz) |  |  |  |  |  |
| Reference gain $\left(V_{\text {In }}=775 \mathrm{mV}_{\mathrm{eff}}{ }^{\circ} \quad 1800 \mathrm{~Hz}\right)$ | $\mathrm{G}_{\text {ref }}$ | $-0.5$ | - | 0.5 | dB |
|  | $G_{r e l}$ | $\begin{gathered} 0.4 \\ 3 \end{gathered}$ | - | $\begin{aligned} & 0.3 \\ & 0.5 \\ & -25 \end{aligned}$ | dB <br> dB <br> dB |
| 1, (1) 1800)l: | ${ }^{1} 96$ |  |  | 50 | $\mu \mathrm{s}$ |
| Group propactation delay time distortion $(600 \mathrm{~Hz}<\mathrm{f} \cdot 3000 \mathrm{~Hz})$ | $T_{\text {gpd }}$ | - | - | 450 | $\mu \mathrm{s}$ |
| High-Pass filter and rejection filter ( $\mathrm{Fs}=\mathbf{7 2 \mathrm { kHz }}$ ) |  |  |  |  |  |
| Reference gain $\left(V_{\text {in }}=775 \mathrm{mV}_{\mathrm{eff}}, \mathrm{f}=1800 \mathrm{~Hz}\right)$ | $\mathrm{G}_{\text {ref }}$ | -1 | - | 0 | dB |
| Relative gain to $\mathrm{G}_{\text {ref }}$ $\begin{aligned} & f=100 \mathrm{~Hz} \\ & \mathrm{f}=370 \mathrm{~Hz} \\ & 390 \mathrm{~Hz}<\mathrm{f}<450 \mathrm{~Hz} \\ & \mathrm{f}=470 \mathrm{~Hz} \\ & \mathrm{f}=900 \mathrm{~Hz} \end{aligned}$ | Grel | - - - | - | $\begin{aligned} & -25 \\ & -27 \\ & -30 \\ & -27 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \end{aligned}$ |
| Group propagation delay time (f 1800 Hz ) | $T_{\text {gp }}$ | - | - | 75 | $\mu \mathrm{s}$ |
| (itoup) propagation delay time distortion ( $600 \mathrm{~Hz}<\mathrm{f}<3000 \mathrm{~Hz}$ ) | $T_{\text {gpd }}$ | - | - | 1400 | $\mu \mathrm{s}$ |

Note: The measurement frequencies are integer sub-multiples of filters sampling frequencies.

RECONSTRUCTION FILTER

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Reconstruction filter (Fs 288 kHz ) |  |  |  |  |  |
| Reference gain $\left(V_{\text {in }}=775 \mathrm{mV}_{\text {eff }}, f=2000 \mathrm{~Hz}\right)$ | $\mathrm{G}_{\text {ref }}$ | $-0.3$ | - | 0.3 | dB |
| Relative gain to $\mathrm{G}_{\text {ref }}$ $\begin{aligned} & 0 \mathrm{~Hz}<\mathrm{f}<2900 \mathrm{~Hz} \\ & \mathrm{f}=3100 \mathrm{~Hz} \\ & \mathrm{f}>6000 \mathrm{~Hz} \end{aligned}$ | Grel | $\begin{gathered} -0.4 \\ -3 \\ - \end{gathered}$ | - | $\begin{gathered} 0.3 \\ 0.3 \\ -60 \end{gathered}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \end{aligned}$ |
| Group propagation delay time $(f=1800 \mathrm{~Hz})$ | $T_{\text {gp }}$ | - | - | 300 | $\mu \mathrm{s}$ |
| Group propagation delay time distortion ( $600 \mathrm{~Hz}<\mathrm{f}<3000 \mathrm{~Hz}$ ) | Tgpd | - | - | 440 | $\mu \mathrm{s}$ |
| Whole reception filtering chain (input RAI or LEI, output RFO) |  |  |  |  |  |
| Reference gain $\left(\mathrm{V}_{\text {in }}=775 \mathrm{mV}_{\mathrm{eff}^{\prime}}, \mathrm{f}=2000 \mathrm{~Hz}, \mathrm{RC} 3=\$ \mathrm{AO}\right)$ | $\mathrm{G}_{\text {ref }}$ | -0.5 | - | 0.5 | dB |
| Noise on RFO <br> (RAI, LEI, EEI tied to AGND $250 \mathrm{~Hz}<\mathrm{f}<3200 \mathrm{~Hz}$ ) | $\mathrm{N}_{\text {rfo }}$ | - | - | 300 | $\mu \mathrm{V}$ eff |

PERFORMANCE OF RESIDUAL SIGNAL CHANNEL AND A/D CONVERTER (input EEI, output RR2)

| Characteristic | Symbol | Min | Typ | Max | Unit V |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input voltage (peak to peak) | $v_{\text {in }}$ | - | - | 5 |  |
| A/D converter resolution | $\mathrm{R}_{\text {esh }}$ | - | - | 12 | Bit |
| Analog increment | LSB | - | 1.2 | - | mV |
| Integral linearity error | Eil | $-16$ | - | 16 | LSB |
| Differential linearity error | $E_{\text {dl }}$ | $-0.7$ | - | 0.7 | LSB |
| Offset voltage | $V_{\text {OS }}$ | -100 | - | 100 | LSB |

AGC AMPLIFIER AND A/D CONVERTER (input AGC1, output RR1)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Relative gain to programmed gain $\begin{aligned} & 0 \mathrm{~dB} \leqslant \mathrm{AGC} \leqslant 24 \mathrm{~dB} \\ & 25.5 \mathrm{~dB} \leqslant \mathrm{AGC} \leqslant 46.5 \mathrm{~dB} \end{aligned}$ | Grel | $\begin{gathered} -0.5 \\ -1 \end{gathered}$ | - | $\begin{gathered} 0.5 \\ 1 \end{gathered}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \end{aligned}$ |
| Offset voltage | $v_{\text {os }}$ | -70 | - | 70 | LSB |

CARRIER LEVEL DETECTOR (input AGC1, output CDR)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Relative threshold to programmed gain $\begin{aligned} & 0 \mathrm{~dB}<\mathrm{AGC}<24 \mathrm{~dB} \\ & 25.5 \mathrm{~dB} \leqslant \mathrm{AGC} \leqslant 46.5 \mathrm{~dB} \end{aligned}$ | $\mathrm{T}_{\text {ret }}$ | $\begin{gathered} -0.5 \\ -1 \end{gathered}$ | - | $\begin{gathered} 0.5 \\ 1 \end{gathered}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \end{aligned}$ |
| Hysteresis | $\mathrm{H}_{\mathrm{yst}}$ | 2 | - | 3 | dB |
| Input offset voltage <br> 1st threshold pair 2nd threshold pair 3rd threshold pair | $\mathrm{V}_{\text {os }}$ | $\begin{aligned} & -1 \\ & -2 \\ & -3 \end{aligned}$ | $-$ | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & m V \\ & m V \\ & m V \end{aligned}$ |
| Detection delay time <br> $0 \mathrm{mV}_{\text {eff }}$ to 775 mV eff transition or 775 mV eff to $0 \mathrm{~V}_{\text {eff }}$ transition | $T_{\text {dd }}$ | 1 | - | 3 | ms |



Rx LOW-PASS FIL.TER TYPICAL RESPONSE AND LIMITS CHART (Fs $\mathbf{= 2 8 8 k H z}$ )



## RX HIGH-PASS FILTER TYPICAL RESPONSE AND LIMITS CHART (Fs -72 kHz )

FREQUENCY ( kHz )


FREQUENCY (kHz)


## RX BAND-PASS FILTER TYPICAL RESPONSE AND LIMITS CHART

(HP: $\mathrm{Fs}=\mathbf{7 2 k H z}, \mathrm{LP} . \mathrm{Fs}_{\mathrm{s}}=\mathbf{2 8 8 k H z}$ )

FREQUENCY (kHz)


RX BAND-PASS FILTER TYPICAL GROUP DELAY TIME AND LIMITS CHART (HP: $F_{s}=72 \mathrm{kHz}, \mathrm{LP}: \mathrm{Fs}_{\mathrm{s}}=\mathbf{2 8 8} \mathrm{kHz}$ )


Rx BAND-PASS AND REJECTION FILTER TYPICAL RESPONSE AND LIMITS CHART (HP AND REJ. : $F s=\mathbf{7 2 k H z}, L P: F s=288 k H z$ )


Rx BAND-PASS AND REJECTION FILTER TYPICAL RESPONSE AND LIMITS CHART
(HP AND REJ. :Fs $=\mathbf{7 2 k H z}$, LP: $F s=288 \mathbf{k H z}$ )


Rx BAND-PASS AND REJECTION FILTER TYPICAL GROUP DELAY TIME AND LIMITS CHART (HP AND REJ. : $F_{s}=\mathbf{7 2 k H z}, L P: F_{s}=\mathbf{2 8 8 k} \mathbf{H z}$ )


Rx HIGH-PASS AND REJECTION FILTER TYPICAL RESPONSE AND LIMITS CHART (Fs = $\mathbf{7 2 k H z}$


Rx BAND-PASS FILTER TYPICAL RESPONSE FOR V. 22 MODE (LOW CHANNEL) (HP: Fs $=\mathbf{7 2 k H z}, L P: \mathbf{f s}=\mathbf{1 4 4} \mathbf{k H z}$ )


FREQUENCY (kHz)


Rx BAND-PASS FILTER TYPICAL RESPONSE FOR V. 22 MODE (HIGH CHANNEL) (HP AND REJ.: $F s=144 \mathrm{kHz}$, LP: $\mathrm{Fs}=\mathbf{2 8 8} \mathrm{kHz}$ )


Rx BAND-PASS FILTER TYPICAL GROUP DELAY TIME FOR V. 22 MODE (HIGH CHANNEL) (HP AND REJ.: $F s=144 \mathrm{kHz}$, LP: $F s=288 \mathrm{kHz}$ )


RECONSTRUCTION FILTER TYPICAL RESPONSE AND LIMITS CHART


RECONSTRUCTION FILTER TYPICAL RESPONSE AND LIMITS CHARTS


## PHYSICAL DIMENSIONS

CB-132

J SUFFIX CERDIP PACKAGE


## ALSO AVAILABLE C SUFFIX CERAMIC PACKAGE



P SUFFIX<br>PLASTIC PACKAGE



## DATA SHEET

The TS68952 generates all the clock frequencies needed to implement standard voice-grade MODEMS up to 19200 bps according to the CCITT V.22, V.26, V.27, V.29, V. 32 and V. 33 or BELL 212A, 208 and 209 recommendations.

It can be associated with the TS68950 and the TS68951 to give a MODEM Analog Front-End Chip Set.

Main features:

- Independent Tx and Rx clock generators with Digital Phase Locked Loops (DPLLs).
- Tx DPLL synchronization on external terminal clock or internal Rx clock.
- Four external clocks available (plesiochronous on Tx and Rx channels): bit rate clock, baud rate clock, sampling clock and multiplexing clock.
- Chip programming and control via a standard 8 bit bus.



## SILICON GATE CMOS

## MODEM TRANSMIT/RECEIVE CLOCK GENERATOR

## CASE CB-132



P SUFFIX PLASTIC PACKAGE

## ALSO AVAILABLE

C SUFFIX
CERAMIC PACKAGE

J SUFFIX
CERDIP PACKAGE


PIN DESCRIPTION

| Name | No. | Description |
| :---: | :---: | :---: |
| D5-D7 | 1-3 | Data bus inputs to internal registers |
| $\overline{\mathrm{E}}$ | 4 | Enable input. Data are strobed on the positive transitions of this input |
| $R / \bar{W}$ | 5 | Read/Write selection input. Internal registers can be written when R/W $=0$. Reading mode is only used for Rx analog front-end chip |
| $\overline{\mathrm{CSO}}-\mathrm{CS} 1$ | 6-7 | Chip Select inputs. The chip set is selected when $\overline{\mathrm{CSO}}=0$ and CS1 $=1$ |
| RSO-RS1 | 8-9 | Register Select inputs. Used to select address or control registers |
| TO | 10 | Test Output. Must be left open |
| TxSCLK | 11 | Transmit Synchronizing Clock input. Normally tied to an external terminal clock. When this pin is tied to a permanent logical level, transmit DPLLfree-runs or can be synchronized to the receive clock system. |
| DGND | 12 | Digital ground $=0 \mathrm{~V}$. Alrdigital signals are referenced to this pin |
| XTAL1 | 13 | Crystal oscillator or pulse generator input |
| XTAL2 | 14 | Crystal oscillator output |
| CLK | 15 | 1.44 MHz Clock output. Useful for Tx and Rx analog front-end chips |
| TxRCLK | 16 | Transmit baud Rate Clock output |
| $\mathrm{V}^{+}$ | 17 | Positive power supply voltage $=+5 \mathrm{~V} \pm 5 \%$ |
| TxMCLK | 18 | Transmit Multiplexing Clock output |
| RxMCLK | 19 | Receive Multiplexing Clock output |
| RxRCLK | 20 | Receive baud Rate Clock output |
| RxCCLK | 21 | Receive Conversión Clock output |
| RxCLK | 22 | Receive bit rate Clock output |
| TxCLK | 23 | Transmit bit rate Clock output |
| TxCCLK | 24 | Transmit Conversion Clock output |
| D1-D4 | 25-28 | Data bus inputs to internal registers (DO is not used) |

## FUNCTIONAL DESCRIPTION

The TS68952 is a purely digital circuit that synthesises all the frequencies requested to implement synchronous voice-grade MODEMs from 1200 bps to 19200 bps. It consists of two clock generators using Digital Phase Locked Loops (DPLLs). Frequency programming and DPLL updating can be obtained through four control registers accessed by indirect or cyclical addressing.

This circuit is a part of a three chip Modem Analog

Front-End that also includes the TS68950 transmitting analog interface and the TS68951 receiving analog interface.

## POWER-UP INITIAL CONDITIONS

Following power-up, the eight transmit and receive clock outputs are undefined and may deliver any frequencies. Control registers RC1 and RC2 must be properly programmed to obtain the wanted operation.


FIGURE 1 - DPLL LEAD AND LAG

## CLOCK GENERATION

Master clock is obtained from either a crystal tied between XTAL1 and XTAL2 pins or an external signal connected to the XTAL1 pin; in this case, the XTAL2 pin should be left open. Clock frequency nominal value is 5.76 MHz , but 5.12 MHz and 5.40 MHz frequencies are also specified for particular applications.
The different transmit ( $T x$ ) and receive ( $R x$ ) clocks are obtained by frequency division in several counters and output selection through digital multiplexers. They can be synchronized on external signal via two independent digital phase locked loops (DPLL).

## TRANSMIT DPLL

As shown on figure 1, the TxDPLL operates by adding or subtracting pulses to a 2.88 MHz internal clock, with a reference frequency that is a submultiple of the programmed "rate clock" frequency. This corresponds to phase leads or phase lags of about 350 ns duration, more precisely, two master clock periods.
The Tx DPLL can be synchronized on an external terminal clock tied to TxSCLK pin or on the receive bit clock RxCLK internally generated from the RxDPLL. It can also free-run without any phase shift, when the TxSCLK input is tied to a fixed logical level.

## TRANSMIT CLOCKS

The TS68952 delivers four synchronous Tx clocks:

- a bit clock, TxCLK, whose frequency equals the bit rate of the MODEM,
- a baud clock, TxRCLK, whose frequency equals the baud rate of the MODEM,
- a conversion clock, TxCCLK, that gives the sampling frequency of the $T_{x}$ converter,
- a multiplexing clock, TxMCLK, usable when several terminals are multiplexed on a single physical link.

The frequencies of these four clocks are programmable through RC1 and RC2 control registers. Their cyclical ratio is exactly $1: 2$, except for the 16.8 kHz frequency whose cyclical ratio is slightly modulated around $1: 2$, and their relative phase locking is ensured without user
intervention, by periodic reset of the counters.
Immediate phasing of these clocks on the synchronizing external TxSCLK or internal RxCLK clock can be obtained through bit 7 of RC8 register. The content of this register is automatically cleared after phasing completion.

The TS68952 also delivers, on pin CLK, a 1.44 MHz clock that is synchronous with the Tx clock system and will be used as the main clock of the TS68950/51 analog interface circuits.

## RECEIVE DPLL

RxDPLL phase shifts are performed by addition and subtraction of pulses from an internal 1.44 MHz clock under the control of RC8 register. Two modes of operation are provided:

- a coarse phase lag whose amplitude has been loaded into RC7 register, can be controlled by one bit of RC8 register. This mode is useful for a fast synchronization of the RxDPLL. The phase lag is obtained by suppressing a variable number of pulses at the input of the counters,
- a fine phase shift with lead or lag amplitude equal to two master clock periods, can be controlled by two bits of RC8. This mode corresponds to normal operation. The phase shifts are obtained by addition or suppression of pulses as indicated in figure 1.
RC8 register is automatically cleared when the programmed phase shift is completed. Simultaneous programming of Tx and Rx control bits of this register has to be avoided.


## RECEIVE CLOCKS

The TS68952 delivers four Rx clocks with the same nominal frequency values as their $T x$ counterparts:

- a bit clock RxCLK,
- a baud clock RxRCLK,
- a conversion clock RxCCLK,
- a multiplexing clock RxMCLK.

The Rx and Tx output clocks are plesiochronous.

BIT CLOCK FREQUENCY PROGRAMMING (TX AND Rx)

| RC1 REGISTER |  |  |  |  |  |  | OUTPUT FREQUENCY (kHz) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |  |  |
| HB4 | HB3 | HB2 | HB1 | HR3 | HR2 | HR1 | $\mathrm{F}_{\mathrm{Q}}=5.76 \mathrm{MHz}$ | $\mathrm{F}_{\mathrm{Q}}=5.40 \mathrm{MHz}$ | $\mathrm{F}_{\mathrm{Q}}=5.12 \mathrm{MHz}$ |
| 0 | 0 | 0 | 0 |  |  |  | 19.2 |  |  |
| 0 | 0 | 0 | 1 |  |  |  | 16.8 |  |  |
| 0 | 0 | 1 | 0 |  |  |  | 14.4 |  |  |
| 0 | 0 | 1 | 1 |  |  |  | 12.0 |  |  |
| 0 | 1 | 0 | 0 |  |  |  | 9.6 |  |  |
| 0 | 1 | 0 | 1 |  |  |  | 7.2 |  | 6.4 |
| 0 | 1 | 1 | 0 |  |  |  | 6.4 |  |  |
| 0 | 1 | 1 | 1 |  |  |  | 6.0 |  |  |
| 1 | 0 | 0 | 0 |  |  |  | 4.8 |  |  |
| 1 | 0 | 0 | 1 |  |  |  | 3.2 | 3.0 |  |
| 1 | 0 | 1 | 0 |  |  |  | 2.4 |  |  |
| 1 | 0 | 1 | 1 |  |  |  | 1.2 |  |  |
| 1 | 1 | 0 | 0 |  |  |  | 0.6 |  |  |
| 1 | 1 | 0 | 1 |  |  |  | 0.6 |  |  |
| 1 | 1 | 1 | 0 |  |  |  | 0.6 |  |  |
| 1 | 1 | 1 | 1. |  |  |  | 0.6 |  |  |

$\mathrm{F}_{\mathrm{Q}}=$ crystal oscillator frequency

RATE CLOCK FREQUENCY PROGRAMMING (Tx AND Rx)

| RC1 REGISTER |  |  |  |  |  |  | OUTPUT FREQUENCY ( $\mathbf{~ k H z ) ~}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |  |  |
| HB4 | HB3 | HB2 | HB1 | HR3 | HR2 | HR1 | $\mathrm{F}_{\mathbf{Q}}=5.76 \mathrm{MHz}$ | $\mathrm{F}_{\mathrm{Q}}=5.40 \mathrm{MHz}$ | $\mathrm{F}_{\mathrm{Q}}=5.12 \mathrm{MHz}$ |
|  |  |  |  | 0 | 0 | 0 | 2.4 |  | 2.133 |
|  |  |  |  | 0 | 0 | 1 | 2.0* |  |  |
|  |  |  |  | 0. | 1 | 0 | 1.6** | 1.5 |  |
|  |  |  |  | 0 | 1 | 1 | 1.2 |  |  |
|  |  |  |  | 1 | 0 | 0 | 0.6 |  |  |
|  |  |  |  | 1 | 0 | 1 | 0.6 |  |  |
|  |  |  |  | 1 | 1 | 0 | 0.6 |  |  |
|  |  |  |  | 1 | 1 | 1 | 0.6 |  |  |

Note: Phase shift frequency of Tx DPLL is 600 Hz except for (*) 1000 Hz and for (**) 2000 Hz .

CONVERSION CLOCK FREQUENCY PROGRAMMING (Tx AND Rx)

| RC2 REGISTER |  |  |  |  |  |  | OUTPUT FREQUENCY (kHz) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |  |  |
| HM3 | HM2 | HM1 | HS2 | HS1 | HTHR | - | $\mathrm{F}_{\mathrm{Q}}=5.76 \mathrm{MHz}$ | $\mathrm{F}_{\mathrm{Q}}=5.40 \mathrm{MHz}$ | $\mathrm{F}_{\mathrm{Q}}=5.12 \mathrm{MHz}$ |
|  |  |  | 0 | 0 |  |  | 9.6 | 9.0 | 8.533 |
|  |  |  | 0 | 1 |  |  | 8.0 | 7.5 |  |
|  |  |  | 1 | 0 |  |  | 7.2 |  |  |
|  |  |  | 1 | 1 |  |  | 7.2 |  |  |

MULTIPLEXING CLOCK FREQUENCY PROGRAMMING (TXAND RX)

| RC2 REGISTER |  |  |  |  |  |  | OUTPUT FREQUENCY (kHz) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |
| HM3 | HM2 | HM1 | HS2 | HS1 | HTHR | - | $\mathrm{F}_{\mathrm{Q}}=5.76 \mathrm{MHz}$ |
| 0 | 0 | 0 |  |  |  |  | 1440 |
| 0 | 0 | 1 |  |  |  |  | 288 |
| 0 | 1 | 0 |  |  |  |  | 12 |
| 0 | 1 | 1 |  |  |  |  | 9.6 |
| 1 | 0 | 0 |  |  |  |  | 7.2 |
| 1 | 0 | 1 |  |  |  |  | 4.8 |
| 1 | 1 | 0 |  |  |  |  | 2.4 |
| 1 | 1 | 1 |  |  |  |  | 1.2 |

TX SYNCHRONIZATION SIGNAL PROGRAMMING

| RC2 REGISTER |  |  |  |  |  |  | SYNCHRONIZATION SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |
| HM3 | HM2 | HM1 | HS2 | HS1 | HTHR | - |  |
|  |  |  |  |  | 0 |  | RxCLK |
|  |  |  |  |  | 1 |  | TxSCLK (note 1) |

Note: 1-TxDPLL free-runs if there is no transition on this input.

Tx CLOCK GENERAL RESET

| RC8 REGISTER (notes 2,3) |  |  |  |  |  |  | RESETTING TRANSITION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |
| MPE | SPR | AVRE | VAL | INIT | - | - |  |
| 1 | 0 | 0 | 0 | 0 |  |  | Next negative-going transition on synchronization clock |

Note: 2-RC8 register is cleared after the programmed control operation is completed.
Note: 3 - INIT bit is only used for test purpose

Rx CLOCK PHASE SHIFT PROGRAMMING

| RC8 REGISTER (note 2) |  |  |  |  |  |  | ACTION ON Rx DPLL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |
| MPE | SPR | AVRE | VAL | INIT | - | - |  |
| 0 | 1 | 0 | 0 | 0 |  |  | Phase lag of programmed amplitude |
| 0 | 0 | 0 | 1 | 0 |  |  | Phase lag of two main clock periods |
| 0 | 0 | 1 | 1 | 0 |  |  | Phase lead of two main clock periods |

Rx CLOCK PHASE SHIFT AMPLITUDE PROGRAMMING

| RC7 REGISTER |  |  |  |  |  |  | PHASE SHIFT IN DEGREES |  | NUMBER OF MASTER CLOCK PULSES SUPPRESSED |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |  |  |
| SP5 | SP4 | SP3 | SP2 | SP1 | - | - | 1200 bauds* | 1600 bauds |  |
| 0 | 0 | 0 | 0 | 0 |  |  | 1.5 | 2 | 20 |
| 0 | 0 | 0 | 0 | 1 |  |  | 3 | 4 | 40 |
| 0 | 0 | 0 | 1 | 0 |  |  | 4.5 | 6 | 60 |
| 0 | 0 | 0 | 1 | 1 |  |  | 6 | 8 | 80 |
| 0 | 0 | 1 | 0 | 0 |  |  | 7.5 | 10 | 100 |
| 0 | 0 | 1 | 0 | 1 |  |  | 9 | 12 | 120 |
| 0 | 0 | 1 | 1 | 0 |  |  | 10.5 | 14 | 140 |
| 0 | 0 | 1 | 1 | 1 |  |  | 12 | 16 | 160 |
| 0 | 1 | 0 | 0 | 0 |  |  | 13.5 | 18 | 180 |
| 0 | 1 | 0 | 0 | 1 |  |  | 15 | 20 | 200 |
| 0 | 1 | 0 | 1 | 0 |  |  | 16.5 | 22 | 220 |
| 0 | 1 | 0 | 1 | 1 |  |  | 18 | 24 | 240 |
| 0 | 1 | 1 | 0 | 0 |  |  | 19.5 | 26 | 260 |
| 0 | 1 | 1 | 0 | 1 |  |  | 21. | 28 | 280 |
| 0 | 1 | 1 | 1 | 0 |  |  | 22.5 | 30 | 300 |
| 0 | 1. | 1 | 1 | 1 |  |  | 24 | 32 | 320 |
| 1 | 0 | 0 | 0 | 0 |  |  | 22.5 | 30 | 300 |
| 1 | 0 | 0 | 0 | 1 |  |  | 45 | 60 | 600 |
| 1 | 0 | 0 | 1 | 0 |  |  | 67.5 | 90 | 900 |
| 1 | 0 | 0 | 1 | 1 |  |  | 90 | 120 | 1200 |
| 1 | 0 | 1 | 0 | 0 |  |  | 112.5 | 150 | 1500 |
| 1 | 0 | 1 | 0 | 1 |  |  | 135 | 180 | 1800 |
| 1 | 0 | 1 | 1 | 0 |  |  | 157.5 | 210 | 2100 |
| 1 | 0 | 1 | 1 | 1 |  |  | 180 | 240 | 2400 |
| 1 | 1 | 0 | 0 | 0 |  |  | 202.5 | 270 | 2700 |
| 1 | 1 | 0 | 0 | 1 |  |  | 225 | 300 | 3000 |
| 1 | 1 | 0 | 1 | 0 |  |  | 247.5 | 330 | 3300 |
| 1 | 1 | 0 | 1 | 1 |  |  | 270 | 360 | 3600 |
| 1 | 1 | 1 | 0 | 0 |  |  | 292.5 |  | 3900 |
| 1 | 1 | 1 | 0 | 1 |  |  | 315 |  | 4200 |
| 1 | 1 | 1 | 1 | 0 |  |  | 337.5 |  | 4500 |
| 1 | 1 | 1 | 1 | 1 |  |  | 360 |  | 4800 |

(*) 2400 bauds: multiply by two. 600 bauds: divide by two.

## DATA BUS CONTROL

Six signals control the access from the bus to the internal registers according to the table and the timing diagram given below. Control registers are written using an indirect addressing mode where the internal
address is stored in the 3 bit ARC register. After each write operation to a control register, the ARC register value is automatically increased by one. This allows cyclical addressing of the eight registers of the MODEM chip set.

| $R / \overline{\mathbf{W}}$ | $\overline{\mathbf{C S O}}$ | $\overline{\text { CS1 }}$ | RS0 | RS1 | $\overline{\mathbf{E}}$ | ACCESSED REGISTER |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 1 | 0 | $\mathbf{f}$ | Address register ARC |
| 0 | 0 | 1 | 1 | 1 | $\mathbf{f}$ | Control register whose address is in ARC |

BUS TIMING DIAGRAM


DATA FORMAT

| DATA LOADED IN ARC |  |  | ADDRESSED REGISTER |
| :---: | :---: | :---: | :---: |
| D7 | D6 | D5 |  |
| ARC3 | ARC2 | ARC1 |  |
| 0 | 0 | 0 | RC1 |
| 0 | 0 | 1 | RC2 |
| 1 | 1 | 0 | RC7 |
| 1 | 1 | 1 | RC8 |

## MAXIMUM RATINGS

| RATING | MIN. | MAX. |
| :--- | :---: | :---: |
| $\mathrm{V}^{+}$supply voltage to DGND ground | -0.3 V | 7 V |
| Voltage at any input or output | DGND -0.3 V | $\mathrm{~V}^{+}+0.3 \mathrm{~V}$ |
| Current at any output | -20 mA | 20 mA |
| Power dissipation |  | 500 mW |
| Operating temperature range | $0^{\circ} \mathrm{C}$ | $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ | $+150^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Ambient temperature | $\mathbf{V}^{+}$ | DGND |
| :---: | :---: | :---: |
| $0^{\circ} \mathrm{C} \leqslant \mathrm{t}_{\mathrm{amb}} \leqslant+70^{\circ} \mathrm{C}$ | $+5.0 \mathrm{~V} \pm 5 \%$ | 0 V |

## ELECTRICAL OPERATING CHARACTERISTICS

Unless otherwise noted, electrical characteristics are specified over the operating range. Typical values are given for $\mathrm{V}^{+}=5.0 \mathrm{~V}$ and $\mathrm{t}_{\mathrm{amb}}=25^{\circ} \mathrm{C}$.

| CHARACTERISTIC | SYMBOL | CONDITIONS | MIN. | TYP. | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Power dissipation |  |  |  |  |  |  |
| Positive supply current | $1^{+}$ |  |  |  | 5.0 | mA |
| Digital interface |  |  |  |  |  |  |
| Input low level voltage | $\mathrm{V}_{\text {IL }}$ |  |  |  | 0.8 V | V |
| Input high level voltage | $\mathrm{V}_{\text {IH }}$ |  | 2.2 |  |  | V |
| Input low level current | IIL | DGND $\leqslant \mathrm{V}_{1} \leqslant \mathrm{~V}_{1 \mathrm{~L}}$ max | -10 |  | 10 | $\mu \mathrm{A}$ |
| Input high level current | IIH | $\mathrm{V}_{1 \mathrm{H} \text { min }} \leqslant \mathrm{V}_{1} \leqslant \mathrm{~V}^{+}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output low level current | $\mathrm{V}_{\mathrm{OL}}$ | $1_{0}=2.5 \mathrm{~mA}$ |  |  | 0.4 | V |
| Output high level current | $\mathrm{V}_{\mathrm{OH}}$ | $10=-2.5 \mathrm{~mA}$ | 2.4 |  |  | V |
| Crystal oscillator interface |  |  |  |  |  |  |
| Input low level voltage | $\mathrm{V}_{\text {IL }}$ |  |  |  | 1.5 | V |
| Input high level voltage | $\mathrm{V}_{\text {IH }}$ |  | 3.5 |  |  | V |
| Input low level current | IIL | DGND $\leqslant \mathrm{V}_{1} \leqslant \mathrm{~V}_{1 L}$ max | -15 |  |  | $\mu \mathrm{A}$ |
| Input high level current | 1 H | $\mathrm{V}_{\text {IH }}$ min $\leqslant \mathrm{V}_{1} \leqslant \mathrm{~V}^{+}$ |  |  | 15 | $\mu \mathrm{A}$ |

## TIMING CHARACTERISTICS

| CHARACTERISTIC | SYMBOL | CONDITIONS | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Data bus access |  |  |  |  |  |  |
| Control signals set-up time | ${ }^{\text {t }}$ SCE | $\overline{\mathrm{CSO}}, \mathrm{CS1} 1, \mathrm{RSO}, \mathrm{RS} 1, \mathrm{R} / \overline{\mathrm{W}}$ to $\overline{\mathrm{E}}$ | 40 |  |  | ns |
| Control signals hold time | $t^{\text {HCE }}$ | $\overline{\mathrm{CSO}}, \mathrm{CS1} 1, \mathrm{RSO}, \mathrm{RS} 1, \mathrm{R} / \overline{\mathrm{W}}$ to $\overline{\mathrm{E}}$ | 10 |  |  | ns |
| Data-in set-up time | ${ }^{\text {t }}$ SDI | D1: D7 to $\bar{E}$ | 120 |  |  | ns |
| Data-in hold time | tHOI | D1: D7 to $\overline{\mathrm{E}}$ | 10 |  |  | ns |
| Enable signal low level width | tWE | $\overline{\mathrm{E}}$ |  | 180 |  | ns |



TIMING CHARACTERISTICS (continued)

| CHARACTERISTIC | SYMBOL | CONDITIONS | MIN. | TYP. | MAX. | UNIT |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | Clock wave forms |  |  |  |  |  |  |
| Main clock period | PC | XTAL1 input | 150 | 173.6 |  | ns |  |
| Main clock low level width | tWCL | XTAL1 input | 50 |  |  | ns |  |
| Main clock high level width | tWCH | XTAL1 input | 50 |  |  | ns |  |
| Main clock rise time | tRC | XTAL1 input |  |  | 50 | ns |  |
| Main clock fall time | tFC | XTAL1 input |  |  | 50 | ns |  |
| Clock output delay time | tDC | All clock outputs $C L=50 \mathrm{pF}$ |  |  | 500 | ns |  |
| Clock output transition time | tTC | All clock outputs $C L=50 \mathrm{pF}$ |  |  | 100 | ns |  |



## TYPICAL APPLICATION



MODEM ANALOG FRONT-END CHIP SET

NOTE: $\begin{aligned} & \frac{1}{3 / 2} \text { Digital ground } \\ & \stackrel{1}{\downarrow} \text { Analog ground }\end{aligned}$

## PHYSICAL DIMENSIONS

## CB-132



ALSO AVAILABLE


P SUFFIX
PLASTIC PACKAGE
J SUFFIX CERDIP PACKAGE


## CHAPTER 8 - DATA COMMUNICATIONS ICs



## FEATURES

$\square 100 \%$ compatible with Ethernet and IEEE 802.3 specifications
$\square$ Data packets moved by block transfers over a processor bus (on-board DMA controller 24-bit linear address space)Buffer management
$\square$ Packet framingPreamble and Cyclic Redundancy Check (CRC) insertionPreamble stripping and CRC verificationGeneral 16-bit microprocessor bus interface compatible with popular processors (68000, 8086, Z8000, LSI-11)Cable fault detection
$\square$ Multicast logical address filtrationCollision handling and retryScaled N-channel MOS VLSI technology48-pin DIPSingle 5 -volt power supplySingle phase TTL level clockAll inputs and outputs TTL compatible
$\square$ Completely compatible with companion Serial Interface Adapter (SIA) chip MK68591/2.

## DESCRIPTION

The MK68590-LANCE ${ }^{\text {TM }}$ (Local Area Network Controller for Ethernet) is a 48 -pin VLSI device that simplifies the interfacing of a microcomputer or a minicomputer to an Ethernet Local Area Network. This chip operates in a local environment that includes a closely coupled memory and microprocessor. The LANCE uses scaled N-channel MOS technology and is compatible with several microprocessors.

[^53]

Figure 1. MK68590

| $\mathrm{v}_{\text {Ss }}$ | 1 | $\bullet$ | 48 | $\mathrm{v}_{\mathrm{CC}}$ |
| :---: | :---: | :---: | :---: | :---: |
| DALO7 | 2 |  | 47 | DAL08 |
| DALO6 | 3 |  | 46 | Dal09 |
| DALO5 | 4 |  | 45 | DAL10 |
| DALO4 | 5 |  | 44 | DAL11 |
| DALO3 | 6 |  | 43 | DAL12 |
| DAL02 | 7 |  | 42 | DAL13 |
| DAL.01 | 8 |  | 41 | DAL14 |
| Daloo | 9 |  | 40 | DAL15 |
| READ | 10 |  | 39 | A 16 |
| INTR | 11 |  | 38 | A 17 |
| $\overline{\text { DALI }}$ | 12 | MK68590 | 37 | A 18 |
| $\overline{\text { DALO }}$ | 13 |  | 36 | A 19 |
| $\overline{\text { DAS }}$ | 14 |  | 35 | A 20 |
| В $\overline{\text { BO/ } / \mathrm{BYTE}}$ | 15 |  | 34 | A 21 |
| $\overline{\text { BM1/BUSAKO }}$ | 16 |  | 33 | A 22 |
|  | 17 |  | 32 | A 23 |
| ALE/ $/ \overline{\text { S }}$ | 18 |  | 31 | RX |
| HLDA | 19 |  | 30 | rena |
| $\overline{\text { CS }}$ | 20 |  | 29 | TX |
| ADR | 21 |  | 28 | CLSN |
| $\overline{\text { READY }}$ | 22 |  | 27 | RCLK |
| $\overline{\text { RESET }}$ | 23 |  | 26 | TENA |
| $\mathrm{v}_{\mathbf{S S}}$ | 24 |  | 25 | TCLK |

Figure 2. LANCE Pin Assignment

## PIN DESCRIPTION

## DAL00-DAL15

## (Data/Address Bus)

Input/Output Three State. The time multiplexed Address/Data bus. These lines will be driven as a bus master and as a bus slave.

## READ

Input/Output Three State. Indicates the type of operation to be performed in the current bus cycle. When it is a bus master, LANCE drives this signal.

LANCE as bus slave:
High - The chip places data on the DAL lines. Low - The chip takes data off the DAL lines.
LANCE as bus master:
High - The chip takes data off the DAL lines.
Low - The chip places data on the DAL lines.

## INTR

(Interrupt)
Output Open Drain. When enabled, an attention signal that indicates the occurrence of one or more of the following events: a message reception or transmission has completed or an error has occurred during the transaction; the initialization procedure has completed; or a memory error has been encountered. Setting INEA in CSRO (bit 06) enables INTR.

## $\overline{\text { DALI }}$

## (Data/Address Line In)

Output Three State. An external bus transceiver control line. When LANCE is a bus master and reads from the DAL lines, $\overline{\mathrm{DALI}}$ is asserted during the data portion of the transfer.

## DALO

(Data/Address Line Out)
Output Three State. An external bus transceiver control line. When LANCE is a bus master and drives the DAL lines, $\overline{\mathrm{DALO}}$ is asserted during the address portion of a read transfer or for the duration of a write transfer.

## $\overline{\text { DAS }}$

## (Data/Strobe)

Input/Output Three State. Defines the data portion of the bus transaction. DAS is driven only as a bus master.

## $\overline{B M 0}, \overline{B M 1}$ or BYTE, $\overline{\text { BUSAKO }}$ <br> (Byte Mask)

Output Three State. Pins 15 and 16 are programmable through bit (00) of CSR3 (known as BCON). Asserting RESET clears CSR3.

```
f BCON = 0
    PIN 16 = \overline{BM1 (Output Three State)}
    PIN 15 = \overline{BMO}}\mathrm{ (Output Three State)
```

BM0, BM1 Byte Mask. Indicates the byte(s) of a bus transaction to be read or written. The BM lines are ignored as a bus slave and assume word transfers only. The LANCE drives the BM lines only when it is a bus master. Byte selection occurs as follows:

| $\overline{\text { BM1 }}$ | $\overline{\text { BMO }}$ |  |
| :--- | :--- | :--- |
|  |  |  |
| Low | Low | Whole Word |
| Low | High | Byte of DAL 08-DAL 15 |
| High | Low | Byte of DAL 00-DAL 07 |
| High | High None |  |

```
If BCON = 1
    PIN 16 = \overline{BUSAKO (Output)}
    PIN 15 = BYTE (Output Three State)
```

BYTE. An alternate byte selection line. Byte selection occurs when the BYTE and DAL (00) lines are latched during the address portion of the bus transaction. BYTE, $\overline{\mathrm{BMO}}$ and $\overline{\mathrm{BM} 1}$ are ignored when LANCE is a bus slave. There are two modes of ordering bytes depending on bit (02) of CSR3, (known as BSWP). This programmable ordering of upper and lower bytes when using BYTE and DAL (00) as selection signals is required to make the ordering compatible with various 16-bit microprocessors.

$$
B S W P=0 \quad B S W P=1
$$

BYTE DAL(00) BYTE DAL(00)

| Low | Low | Low | Low |
| :--- | :--- | :--- | :--- |
| Low | High | Low | High |
| High | High | High | Low Condition |
| High | Low | High | High |

BUSAKO. The DMA daisy chain output.

## HOLD/BUSRQ

## (Bus Hold Request)

Input/Output Open Drain. LANCE asserts this signal when it requires access to memory. HOLD is held low for the entire bus transaction. This bit is programmable through bit (00) of CSR3 (known as BCON). In the daisy chain DMA mode $(B C O N=1) \overline{B U S R Q}$ is asserted only if $\overline{B U S R Q}$ is inactive prior to assertion. Bit (00) of CSR3 is cleared when RESET is asserted.

CSR3(00) $\mathrm{BCON}=0$
PIN $17=\overline{\text { HOLD }}$ (Output Open Drain)
CSR3(00) BCON = 1
PIN $17=\overline{\text { BUSRQ }}$ (Output Open Drain)
$\overline{\text { BUSRQ }}$ will be asserted only if PIN 17 is high prior to assertion.

## ALE/AS

## (Address Latch Enable)

Output Three State. Used to demultiplex the DAL lines and define the address portion of the bus cycle. This
pin is programmable through bit (01) of CSR3. As ALE, the signal transitions from high to low at the end of the address portion of the bus the address portion of the bus transaction and remains low during the entire data portion of the transaction. As $\overline{\mathrm{AS}}$, the signal transitions from low to high at the end of the address portion of the bus transaction and remains high throughout the entire data portion of the transaction. The LANCE drives the ALE/ $\overline{A S}$ line only as a bus master.

```
CSR3(01) ACON = 0
    PIN 31 = ALE
CSR3(01) ACON = 1
    PIN 31 = \overline{AS}
```


## HLDA

## (Bus Hold Acknowledge)

Input. A response to $\overline{\mathrm{HOLD}}$ indicating that the LANCE is the Bus Master. $\overline{\mathrm{HLDA}}$ stops its response when $\overline{\mathrm{HOLD}}$ ends its assertion.

## $\overline{\mathrm{CS}}$

## (Chip Select)

Input. When asserted, $\overline{\mathrm{CS}}$ indicates LANCE is the slave device of the data transfer. $\overline{\mathrm{CS}}$ must be valid throughout the data portion of the bus cycle.

## ADR

(Register Address Port Select)
Input. When $\overline{C S}$ is asserted, ADR indicates which of the two register ports is selected. ADR must be valid throughout the data portion of the bus cycle.

| ADR | PORT |
| :---: | :---: |
| Low | Register Data Port |
| High | Register Address Port |

## $\overline{R E A D Y}$

Input/Output Open Drain. When the LANCE is a bus master, $\overline{\operatorname{READY}}$ is an asynchronous acknowledgement from external memory that will complete the data transfer. As a bus slave, the chip asserts $\overline{\text { READY }}$ when it has put data on the bus, or is about to take data off the bus. $\overline{\text { READY }}$ is a response to $\overline{\mathrm{DAS}}$. $\overline{\text { READY }}$ negates after DAS negates. Note: If $\overline{\mathrm{DAS}}$ or $\overline{\mathrm{CS}}$ deassert prior to the assertion of $\overline{\text { READY }}, \overline{\text { READY }}$ cannot assert.

## RESET

Input. Bus reset signal. Causes LANCE to cease operation and to enter an idle state.

## TLCK

## (Transmit Clock)

Input. Normally a free-running 10 MHz clock (crystalcontrolled within 0.01\% accuracy).

## TENA

## (Transmit Enable)

Output. Transmit Output Stream Enable. A level asserted with the transmit output bit stream, TX, to enable the external transmit logic.

## RCLK

(Receive Clock)
Input. Normally a 10 MHz square wave synchronized to the receive data and present only while receiving an input bit stream.

## CLSN

(Collision)
Input. A logical input that indicates that a collision is occurring on the channel.

## TX

## (Transmit)

Output. Transmit output bit stream.

## RENA

## (Receive Enable)

Input. A logical input that indicates the presence of data on the channel.

## RX

## (Receive)

Input. Receive input bit stream.

## A16-A23

## (High-Order Address Bus)

Output Three State. The additional address bits necessary to extend the DAL lines to produce a 24 -bit address. These lines will be driven only as a bus master.

## VCC

Power supply pin. +5 VDC $\pm 5$ percent.

## VSS

Ground. 0 VDC.

## FUNCTIONAL CAPABILITIES

The LANCE interfaces to a microprocessor bus characterized by time-multiplexed address and data lines. Typically, data transfers are 16 bits wide but byte transfers occur if the buffer memory address boundaries are odd. The address bus is 24 bits wide.

The Ethernet packet format consists of 64-bit preamble, a 48-bit destination address, a 48-bit source address, a 16-bit type field, and from a 46 to 1500 byte data field terminated with a 32 -bit CRC. The packets' variable widths accommodate both short-status command and terminal traffic packets and long data packets to printers and disks (1024-byte disk sectors, for example). Packets are spaced a minimum of $9.6 \mu \mathrm{sec}$ apart to allow one node enough time to receive back-to-back packets.

The LANCE operates in a minimal configuration that requires close coupling between local memory and a processor. The local memory provides packet buffering
for the chip and serves as a communication link between chip and processor. During initialization, the control processor loads the starting address of the initialization block plus the operating mode of the chip via two ports that can access four control registers into LANCE. The host processor talks directly to LANCE
only during this initial phase. All further communications are handled via a Direct Memory Access (DMA) machine under microword control contained within LANCE. Figure 3 shows a block diagram of the LANCE and SIA device used to create an Ethernet interface for a computer system.


Figure 3. Ethernet Local Area Network System Block Diagram

## FUNCTIONAL DESCRIPTION

## SERIAL DATA HANDLING

LANCE provides the Ethernet interface as follows. In the transmit mode (since there is only one transmission path, Ethernet is a half duplex system), the LANCE reads data from a transmit buffer by using DMA and appends the preamble, sync pattern (two ones after alternating ones and zeros in the preamble), and calculates and appends the complement of the 32-bit CRC. In the receive mode, the destination address, source address, type, data, and CRC fields are transferred to memory via DMA cycles. The CRC is calculated as data and transmitted CRC is received. At the end of the packet, if this calculated CRC does not agree with a constant, an error bit is set in RDM1 of the receiver descriptor ring. In the receive mode, LANCE accepts packets under four modes of operation. The first mode is a full comparison of the 48-bit destination address in the packet with the node address that was programmed into the LANCE during an initialization cycle. There are two types of logical addresses. One is a group type mask where the 48-bit address in the packet is put through a hash filter in order to map the 48-bit physical addresses into 1 of 64 logical groups. This mode can be useful if simultaneously sending packets to all of one type of a device on the network. (i.e., send a packet to all file servers or all printer servers). The second logical address is a multicast address where all nodes on the network receive the packet. The last receive mode of operation is the so called "promiscuous mode" in which a node will accept all packets on the cable regardless of their destination address.

## COLLISION DETECTION AND IMPLEMENTATION

The Ethernet CSMA/CD network access algorithm is implemented completely within LANCE. In addition to listening for a clear network cable before transmitting, Ethernet handles collisions in a predetermined way. Should two transmitters attempt to seize the network cable at the same time, they will collide, and the data on the network cable will be garbled. LANCE is constantly monitoring the Collision (CLSN) pin. This signal is generated by the transceiver when the signal level on the network cable indicates the presence of signals from two or more transmitters. If LANCE is transmitting when CLSN is asserted, it will continue to transmit the preamble (collisions normally occur while the preamble is being transmitted), then will "jam" the network for 32 bit times ( 3.2 microseconds). This jamming ensures that all nodes have enough time to detect the collision. The transmitting nodes then delay a random amount of time according to the "truncated binary backoff'" algorithm defined in the Ethernet specification to minimize the probability of the colliding nodes having multiple collisions with each other. After 16 abortive attempts to transmit a packet, LANCE will report a RTRY error due to excessive collisions and step over the trans-
mitter buffer. During reception, the detection of a collision causes that reception to be aborted. Depending on when the collision occurred, LANCE will treat this packet as an error packet if the packet has an address mismatch, as a runt packet (a packet that has less than 64 bytes), or as a legal length packet with a CRC error.

Fatal error reporting is provided by LANCE through a microprocessor interrupt and error flags in CSRO. Significant error conditions are late collision on received data, transmitter on longer than 1518 bytes, missed packet, and memory error (in which the memory did not respond, READY did not assert, to a memory cycle request).

Additional errors are reported through bits in the descriptor rings (on a buffer by buffer basis). Receive error conditions include framing, CRC and buffer errors, and overflow. Transmit descriptor rings have error bits indicating buffer, underflow, late collision, and loss of carrier. Additionally, transmit descriptor rings have a bit indicating that the transmitter has unsuccessfully tried to transmit over a busy communication link.

Transmit descriptor rings also have nine bits reserved for a Time Domain Reflectometry counter (TDR). On the occurrance of a collision, the value in the TDR will give the number of system clocks until the collision, which can be used to determine the distance to the fault.

## BUFFER MANAGEMENT

A key feature of the LANCE and its DMA channel is the flexibility and speed of communication between the LANCE and the host microprocessor through common memory locations. The basic organization of the buffer management is a circular queue of tasks in memory called descriptor rings, as shown in Figure 4. These rings control both transmit and receive operations. Up to 128 tasks may be queued on a descriptor ring for execution by the LANCE. Each entry in a descriptor ring holds a pointer to a data memory buffer and an entry for the data buffer length. Data buffers can be chained or cascaded to handle a long packet in multiple data buffer areas. The LANCE searches the descriptor rings to determine the next empty buffer. This enables it to chain buffers together or to handle back-to-back packets. As each buffer is filled, an "own" bit is reset, signaling the host processor to empty this buffer.

## MICROPROCESSOR INTERFACE

The parallel interface of LANCE has been designed to be "friendly", or easy to interface, to many popular 16-bit microprocessors. These microprocessors include the MK68000, Z8000, 8086, LSI-11, T-11, and MK68200 (the MK68200 is a 16-bit single chip microcomputer produced by Mostek, the architecture of which is modeled after the MK68000). LANCE has a wide 24-bit linear address space when in the Buster Master Mode,
allowing it to DMA the entire address space of the above microprocessors. LANCE uses no segmentation or paging methods. As such, LANCE addressing is closest to MK68000 addressing, but is compatible with the other microprocessors. When LANCE is a bus master, a programmable mode of operation allows byte addressing, either by employing a Byte/Word control signal (much like that used on the 8086 or the Z8000) or by using an Upper Data Strobe/Lower Data Strobe much like that used on the MK68000, LSI-11 and MK68200 microprocessors. A programmable polarity on the Address Strobe signal eliminates the need for external logic. LANCE interfaces with multiplexed and
demultiplexed data busses and features control signals for address/data bus transceivers.

After the initialization routine, packet reception or transmission, transmitter timeout error, a missed packet, or memory error, LANCE generates an interrupt to the host microprocessor.

The cause of the interrupt is ascertained by reading CSR0. Bit (06) of CSRO, INEA, enables or disables interrupts to the microprocessor. In a polling mode, BIT (07) of CSRO is sampled to determine when an interrupt causing condition occurred.


Figure 4. LANCE Memory Management

## LANCE INTERFACE DESCRIPTION

ALE, $\overline{\mathrm{DAS}}$ and $\overline{\operatorname{READY}}$ time all data transfers from the LANCE in the Bus Master mode. The automatic adjustment of the LANCE cycle by the READY signal allows synchronization with variable cycle time memory due either to memory refresh or to dual port access. Bus cycles are a minimum of 600 ns long and can be increased in 100 ns increments.

## READ SEQUENCE

At the beginning of a read cycle, valid addresses are placed on DAL00-DAL15 and A16-A21. The BYTE Mask signals ( $\overline{\mathrm{BM} 0}$ and $\overline{\mathrm{BM} 1}$ ) become valid the beginning of this cycle as does READ, indicating the type of cycle. The trailing edge of ALE or $\overline{\mathrm{AS}}$ strobes the addresses A0-A15 into the external latches. Approximately 100 ns later, DAL00-DAL15 go into a three state mode. There is a 50 ns delay to allow for transceiver turnaround, then DAS falls low to signal the beginning of the data portion of the cycle. At this point in the cycle, the LANCE stalls waiting for the memory device to assert READY. Upon assertion of READY, DAS makes a transition from a zero to a one, latching memory data. (DAS is low for a minimum of 200 ns ).

The bus transceiver controls, $\overline{\mathrm{DALI}}$ and $\overline{\mathrm{DALO}}$, control
the bus transceivers. DALI signals to strobe data toward the LANCE and DALO signals to strobe data or addresses away from the LANCE. During a read cycle, $\overline{\text { DALO }}$ goes inactive before DALI goes active to avoid "spiking" of bus transceivers.

## WRITE SEQUENCE

The write cycle begins exactly like a read cycle with the READ line remaining inactive. After ALE or $\overline{A S}$ pulse, the DAL00-DAL15 change from addresses to data. DAS goes active when the DALO0-DAL15 are stable. This data remains valid on the bus until the memory device asserts $\overline{R E A D Y}$. At this point, $\overline{\mathrm{DAS}}$ goes inactive, latching data into the memory device. Data is held for 75 ns after the negation of DAS.

## LANCE INTERFACE DESCRIPTION - BUS SLAVE MODE

The LANCE enters the Bus Slave Mode whenever $\overline{\mathrm{CS}}$ becomes active. This mode must be entered whenever writing or reading the four status control registers (CSR0, CSR1, CSR2, and CSR3) and the register address pointer (RAP). RAP and CSR0 may be read or written to at any time, but the LANCE must be stopped (CSR0 bit 02) when CSR1, CSR2, or CSR3 is to be written to or read.

## MK68590 ELECTRICAL SPECIFICATION

## ABSOLUTE MAXIMUM RATINGS

| Temperature Under B | $-25^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin with Respect to Ground. | -0.3 V to +7 V |
| Power Dissipation. | 2.0 W |

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 operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5$ percent unless otherwise specified.

| SYMBOL | PARAMETER | MIN | MAX | UNITS |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ |  | -0.5 | +0.8 | V |
| $\mathrm{~V}_{\mathrm{IH}}$ |  | +2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{~V}_{\mathrm{OL}}$ | $@ \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |  | +0.5 | V |
| $\mathrm{~V}_{\mathrm{OH}}$ | $@ \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | +2.4 |  | V |
| $\mathrm{I}_{\mathrm{IL}}$ | $@ \mathrm{~V}_{\mathrm{in}}=0.4$ to $\mathrm{V}_{\mathrm{CC}}$ |  | $\pm 10$ | $\mu \mathrm{~A}$ |

## CAPACITANCE

$\mathrm{F}=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | MIN | MAX | UNITS |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ |  |  | 10 | pf |
| $\mathrm{C}_{\text {OUT }}$ |  |  | 10 | pf |
| $\mathrm{C}_{\mathrm{IO}}$ |  |  | 20 | pf |

AC TIMING SPECIFICATIONS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5$ percent, unless otherwise specified.

| NO. | SIGNAL | SYMBOL | PARAMETER | TEST <br> CONDITIONS | MIN <br> $(\mathbf{n s})$ | TYP <br> (ns) | MAX <br> $(\mathbf{n s})$ |
| :---: | :--- | :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathbf{1}$ | TCLK | $\mathrm{T}_{\text {TCT }}$ | TCLK period |  | 99 |  | 101 |
| 2 | TCLK | $\mathrm{T}_{\text {TCL }}$ | TCLK low time |  | 45 |  | 55 |
| 3 | TCLK | $\mathrm{T}_{\text {TCH }}$ | TCLK high time |  | 45 |  | 55 |
| 4 | TCLK | $\mathrm{T}_{\text {TCR }}$ | Rise time of TCLK |  | 0 |  | 8 |
| 5 | TCLK | $\mathrm{T}_{\text {TCF }}$ | Fall time of TCLK |  | 0 |  | 8 |
| 6 | TENA | $\mathrm{T}_{\text {TEP }}$ | TENA propagation delay after the <br> rising edge of TCLK | $\mathrm{CL}=50 \mathrm{pf}$ |  |  | 95 |
| 7 | TENA | $\mathrm{T}_{\text {TEH }}$ | TENA hold time after the rising edge <br> of TCLK | $\mathrm{CL}=50 \mathrm{pf}$ | 5 |  |  |

AC TIMING SPECIFICATIONS (Continued)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5$ percent, unless otherwise specified.

| NO. | SIGNAL | SYMBOL | PARAMETER | TEST CONDITIONS | MIN <br> ( ns ) | $\begin{aligned} & \text { TYP } \\ & \text { (ns) } \end{aligned}$ | MAX <br> (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 8 | TX | T TDP | TX data propagation delay after the rising edge of TCL.K | $\mathrm{CL}=50 \mathrm{pf}$ |  |  | 95 |
| 9 | TX | $\mathrm{T}_{\text {TDH }}$ | TX data hold time after the rising edge of TCLK | $\mathrm{CL}=50 \mathrm{pf}$ | 5 |  |  |
| 10 | RCLK | $\mathrm{T}_{\mathrm{RCT}}$ | RCLK period |  | 85 |  | 118 |
| 11 | RCLK | $\mathrm{T}_{\mathrm{RCH}}$ | RCLK high time |  | 38 |  |  |
| 12 | RCLK | $\mathrm{T}_{\mathrm{RCL}}$ | RCLK low time |  | 38 |  |  |
| 13 | RCLK | $\mathrm{T}_{\text {RCR }}$ | Rise time of RCLK |  | 0 |  | 8 |
| 14 | RCLK | $\mathrm{T}_{\text {RCF }}$ | Fall time of RCLK |  | 0 |  | 8 |
| 15 | RX | $\mathrm{T}_{\text {RDR }}$ | RX data rise time |  | 0 |  | 8 |
| 16 | RX | $\mathrm{T}_{\text {RDF }}$ | RX data fall time |  | 0 |  | 8 |
| 17 | $R X$ | $\mathrm{T}_{\text {RDH }}$ | RX data hold time (RCLK to RX data change) |  | 5 |  |  |
| 18 | RX | $\begin{aligned} & \mathrm{T}_{\mathrm{RDS}} \\ & \text { (See Note) } \end{aligned}$ | RX data setup time (RX data stable to the rising edge of RCLK) |  | See <br> Note |  |  |
| 19 | RENA | $\mathrm{T}_{\text {DPL }}$ | RENA low time |  | 120 |  |  |
| 20 | RENA | $\mathrm{T}_{\text {RENH }}$ | RENA hold time after rising edge of RCLR |  | 40 |  |  |
| 21 | CLSN | $\mathrm{T}_{\text {CPH }}$ | CLSN high time |  | 80 |  |  |
| 22 | A/DAL | $\mathrm{T}_{\text {DOFF }}$ | Bus master driver disable after rising edge of HOLD |  | 0 |  | 50 |
| 23 | A/DAL | $\mathrm{T}_{\text {DON }}$ | Bus master driver enable after falling edge of HLDA |  | 0 |  | 150 |
| 24 | $\overline{\text { HLDA }}$ | $\mathrm{T}_{\mathrm{HHA}}$ | Delay to falling edge of $\overline{\text { HLDA }}$ from falling edge of HOLD (bus master) |  | 0 |  |  |
| 25 | $\overline{\text { RESET }}$ | $\mathrm{T}_{\text {RW }}$ | RESETpulse width low |  | 200 |  |  |
| 26 | A/DAL | $\mathrm{T}_{\text {CYCLE }}$ | Read/write, address/data cycle time |  | 600 |  |  |
| 27 | A | TXAS | Address setup time to the falling edge of ALE |  | 75 |  |  |
| 28 | A | $\mathrm{T}_{\text {XAH }}$ | Address hold time after the rising edge of $\overline{D A S}$ |  | 35 |  |  |
| 29 | DAL | $\mathrm{T}_{\text {AS }}$ | Address setup time to the falling edge of ALE |  | 75 |  |  |
| 30 | DAL | $\mathrm{T}_{\text {AH }}$ | Address hold time after the falling edge of ALE |  | 35 |  |  |
| 31 | DAL | $\mathrm{T}_{\text {RDAS }}$ | Data setup time to the rising edge of $\overline{\text { DAS }}$ (bus master read) |  | 50 |  |  |

NOTE: $T_{\text {RDS }}(\min )=T_{R C T}-25 \mathrm{~ns}$. Therefore, $T_{R C T}=100 \mathrm{~ns}$ when $T_{\text {RDS }}(\min )=75 \mathrm{~ns}$.

AC TIMING SPECIFICATIONS (Continued)
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5$ percent, unless otherwise specified.
$\left.\begin{array}{|c|l|l|l|l|c|c|c|}\hline \text { NO. } & \text { SIGNAL } & \text { SYMBOL } & \text { PARAMETER } & \begin{array}{l}\text { TEST } \\ \text { CONDITIONS }\end{array} & \begin{array}{c}\text { MIN } \\ \text { (ns) }\end{array} & \begin{array}{c}\text { TYP } \\ \text { (ns) }\end{array} & \begin{array}{c}\text { MAX } \\ \text { (ns) }\end{array} \\ \hline 32 & \text { DAL } & \mathrm{T}_{\text {RDAH }} & \begin{array}{l}\text { Data hold time after the rising edge of } \\ \text { DAS (bus master read) }\end{array} & & 0 & & \\ \hline 33 & \text { DAL } & \mathrm{T}_{\text {DDAS }} & \begin{array}{l}\text { Data setup time to the falling edge } \\ \text { of } \overline{\text { DAS (bus master write) }}\end{array} & & 0 & & \\ \hline 34 & \text { DAL } & \mathrm{T}_{\text {WDS }} & \begin{array}{l}\text { Data setup time to the rising edge } \\ \text { of } \overline{\text { AAS (bus master write) }}\end{array} & & 200 & & \\ \hline 35 & \text { DAL } & \mathrm{T}_{\text {WDH }} & \begin{array}{l}\text { Data hold time after the rising edge } \\ \text { of } \overline{\text { DAS (bus master write) }}\end{array} & & 35 & & \\ \hline 36 & \text { DAL } & \mathrm{T}_{\text {SDO1 }} & \begin{array}{l}\text { Data driver delay after the falling edge } \\ \text { of } \overline{\text { DAS (bus slave read) }}\end{array} & \text { (CSR 0,3, RAP) }\end{array}\right)$

AC TIMING SPECIFICATIONS (Continued)
$T_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5$ percent, unless otherwise specified.

| NO. | SIGNAL | SYMBOL | PARAMETER | TEST CONDITIONS | $\begin{aligned} & \text { MIN } \\ & \text { (ns) } \end{aligned}$ | $\begin{aligned} & \text { TYP } \\ & \text { (ns) } \end{aligned}$ | $\begin{gathered} \text { MAX } \\ \text { (ns) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 54 | $\overline{\mathrm{CS}}$ | $\mathrm{T}_{\text {CSH }}$ | $\overline{\mathrm{CS}}$ hold time after the rising edge of $\overline{\mathrm{DAS}}$ (Bus slave) |  | 0 |  |  |
| 55 | $\overline{\mathrm{CS}}$ | $\mathrm{T}_{\text {CSS }}$ | $\overline{\mathrm{CS}}$ setup time to the falling edge of $\overline{\mathrm{DAS}}$ (Bus slave) |  | 0 |  |  |
| 56 | ADR | $\mathrm{T}_{\text {SAH }}$ | ADR hold time after the rising edge of DAS (Bus slave) |  | 0 |  |  |
| 57 | ADR | $\mathrm{T}_{\text {SAS }}$ | ADR setup time to the falling edge of $\overline{\mathrm{DAS}}$ (Bus slave) |  | 0 |  |  |
| 58 | $\overline{\text { READY }}$ | $\mathrm{T}_{\text {ARYD }}$ | Delay from the falling edge of ALE to the falling edge of READY to insure a minimum bus cycle time ( 600 ns ) |  |  |  | 80 |
| 59 | READY | $\mathrm{T}_{\text {SRDS }}$ | Data setup time to the falling edge of READY (Bus slave read) |  | 75 |  |  |
| 60 | $\overline{\text { READY }}$ | $\mathrm{T}_{\text {RDYH }}$ | READY hold time after the rising edge of $\overline{\mathrm{DAS}}$ (Bus master) |  | 0 |  |  |
| 61 | $\overline{\text { READY }}$ | $\mathrm{T}_{\text {SRO1 }}$ | READY driver turn on after the falling edge of $\overline{\text { DAS }}$ (Bus slave) | (CSR 0,3, RAP) |  | 600 |  |
| 62 | $\overline{\text { READY }}$ | $\mathrm{T}_{\text {SRO2 }}$ | $\overline{\text { READY }}$ driver turn on after the falling edge of $\overline{\mathrm{DAS}}$ (Bus slave) | (CSR 1,2) |  | 1400 |  |
| 63 | $\overline{\text { READY }}$ | $\mathrm{T}_{\text {SRYH }}$ | READY hold time after the rising edge of DAS (Bus slave) |  | 0 |  | 35 |
| 64 | READ | $\mathrm{T}_{\text {SRH }}$ | READ hold time after the rising edge of DAS (Bus slave) |  | 0 |  |  |
| 65 | READ | $\mathrm{T}_{\mathrm{SRS}}$ | READ setup time to the falling edge of DAS (Bus slave) |  | 0 |  |  |



NOTE: This load is used on DAL00 through DAL15, READ, DALI, DALO, DAS, BM0, BM1, ALE/AS, A16 through A23, TENA, and TX.
Figure 5. Output Load Diagram


NOTE: This load is used on open drain outputs $\overline{\text { INTR}, ~ H O L D / B U S R Q, ~ a n d ~} \overline{\text { READY }}$.
Figure 6. Open Drain Output Load Diagram.


NOTE: Timing measurements are made at the following voltages unless otherwise specified.

Figure 7. Serial Link Timing Diagram - SIA Interface Signals


NOTE: The Bus Master cycle time will increase from a minimum of 600 ns in 100 ns steps until the slave device returns READY.

Figure 8. LANCE Bus Master Timing Diagram


Figure 9. LANCE Bus Slave Timing Diagram

## FEATURES

[] Compatible with Ethernet and IEEE-802.3 Specifications
$\square$ Crystal-controlled Manchester Encoder/Decoder
$\square$ Manchester Decoder acquires clock and data within six-bit times with an accuracy of $\pm 3 \mathrm{~ns}$.
$\square$ Guaranteed carrier and collision detection squelch threshold limits

- Carrier/collision detected for inputs more negative than -275 mV
- No carrier/collision for inputs more positive than -175 mV
$\square$ Input signal conditioning rejects transient noise
- Transients <10 ns for collision detector inputs
- Transients <20 ns for carrier detector inputs
$\square$ Receiver decodes Manchester data with up to $\pm 20$ ns clock jitter (at 10 MHz )
$\square$ TTL-compatible host interface
$\square$ Transmit oscillator accuracy $\pm 0.01 \%$ (without adjustments)


## GENERAL DESCRIPTION

The MK68591/2 Serial Interface Adapter (SIA) is a Manchester Encoder/Decoder compatible with Ethernet and IEEE-802.3 specifications. In an Ethernet/IEEE-802.3 application, the MK68591/2 interfaces the MK68590 Local Area Network Controller for Ethernet (LANCE ${ }^{\text {mm }}$ ) to the Ethernet transceiver cable, acquires clock and data within 6 bit-times and decodes Manchester data up to $\pm 20 \mathrm{~ns}$ phase jitter at 10 MHz . SIA provides both guaranteed signal threshold limits and transient noise suppression circuitry in both data and collision paths to minimize false start conditions.


Figure 1. Pin Assignments


Figure 2. Typical Ethernet Node


Figure 3. MK68591/2 Block Diagram

## PIN DESCRIPTION

CLSN Collision (output). A TTL active high output. Signals at the Collision $\pm$ terminals meeting threshold and pulse width requirements will produce a logic high at CLSN output. When no signal is present at Collision $\pm$, CLSN output will be low.

RX Receive Data (output). A MOS/TTL output, recovered data. When there is no signal at Receive $\pm$ and TEST is high, RX is high. RX is actuated with RCLK and remains activated until end of message. During reception, RX is synchronous with RCLK and changes after the rising edge of RCLK.

RENA Receive Enable (output). A TTL active high output. When there is no signal at Receive $\pm$ and TEST is high, RENA is low. Signals at Receive $\pm$ meeting threshold and pulse width requirements will produce a logic high at RENA. When Receive $\pm$ becomes idle, RENA returns to the low state synchronous with the rising edge of RCLK.

RCLK Receive Clock (output). A MOS/TTL output recovered clock. When there is no signal at Receive $\pm$ and TEST is high, RCLK is low. RCLK is activated after the third negative data transition at Receive $\pm$, and remains active until end of message. When TEST is low, RCLK is enabled.

Transmit (input). TTL compatible input. When TENA is high, signals at TX meeting setup and hold time to TLCK will be encoded as normal Manchester at Transmit + and Transmit -.

TX High: Transmit + is negative with respect to Transmit - for first half of data bit cell.

TX Low: Transmit + is positive with respect to Transmit - for first half of data bit cell.

Transmit Enable (input). TTL compatible input. Active high data encoder enable. Signals meeting setup and hold time to TCLK allow encoding of Manchester data from TX to Transmit + and Transmit -.

Transmit Clock (output). MOS/TTL output. TCLK provides symmetrical high and low clock signals at data rate for reference timing of data to be encoded. It also provides clock signals for the controller chip (MK68590 LANCE) and an internal timing reference for receive path voltage controlled oscillators.

Transmit (outputs). A differential line output. This line pair is intended to operate into terminated transmission lines. For signals meeting setup and hold time to TCLK at TENA and TX Manchester clock and data are outputted at Transmit $+/$ Transmit - . When operating into a $78 \Omega$ terminated transmission line, signalling meetings the required output
levels and skew for both Ethernet and IEEE-802.3 drop cables.

## Receive $+\quad$ Receiver (inputs). A differential input. Receive - A pair of internally biased line receivers consisting of a carrier detect receiver with offset threshold and noise filtering to detect the signal, and a data recovery receiver with no offset for Manchester data decoding. <br> Collision + Collision (inputs). A differential input. Collision - An internally biased line receiver input with offset threshold and noise filtering. Signals at Collision $\pm$ have no effect on data path functions. <br> Transmit Mode Select. An open collector output and sense amplifier input.

TSEL Low: Idle transmit state Transmit + is positive with respect to Transmit -.
TSEL High: Idle transmit state Transmit + and Transmit - are equal, providing "zero" differential to operate transformer coupled loads.

When connected with an RC network, TSEL is held low during transmission. At the end of transmission, the open collector output is disabled, allowing TSEL to rise and provide a smooth transmission from logic high to "zero" differential idle. Delay and output return to zero are externally controlled by the RC time constant TSEL.
$X_{1}, X_{2} \quad$ Biased Crystal Oscillator. $X_{1}$ is the input and $X_{2}$ is the bypass port. When connected for crystal operation, the system clock which appears at TCLK is half the frequency of the crystal oscillator. $X_{1}$ may be driven from an external source of two times the data rate.

RF Frequency Setting Voltage Controlled Oscillator ( $\mathrm{V}_{\mathrm{CO}}$ ) Loop Filter. This loop filter output is a reference voltage for the receive path phase detector. It also is a reference for timing noise immunity circuits in the collision and receive enable path. Nominal reference $\mathrm{V}_{\mathrm{co}}$ gain is 1.25 TCLK frequency $\mathrm{MHz} / \mathrm{V}$.

PF $\quad$ Receive Path $\mathrm{V}_{\text {co }}$ Phase Lock Loop Filter. This loop filter input is the control for receive path loop damping.

Frequency of the receive $\mathrm{V}_{\mathrm{CO}}$ is internally limited to transmit frequency $\pm$ $12 \%$. Nominal receive $\mathrm{V}_{\mathrm{CO}}$ gain is 0.25 reference $\mathrm{V}_{\mathrm{CO}}$ gain $\mathrm{MHz} / \mathrm{V}$.
$\overline{\text { TEST }} \quad$ Test Control (input). A static input that is connected to $V_{C C}$ for normal MK68591/2 operation and to ground for testing of receive path function. When TEST is grounded, RCLK and RX are enabled so that receive path loop may be functionally tested.

| GND $_{1}$ | High Current Ground |
| :--- | :--- |
| GND $_{2}$ | Logic Ground |
| GND $_{3}$ | Voltage Controlled Oscillator Ground |
| V $_{\text {CC1 }}$ | High Current and Logic Supply |
| V $_{\text {CC2 }}$ | Voltage Controlled Oscillator Supply |

## FUNCTIONAL DESCRIPTION

The MK68591/2 Serial Interface Adapter (SIA) has three basic functions. It is a Manchester Encoder/line driver in the transmit path, a Manchester Decoder with noise filtering and quick lock-on characteristics in the receive path, and a signal detect/converter ( 10 MHz differential to TTL) in the collision path. In addition, the SIA provides the interface between the TTL logic environment of LANCE and the differential signaling environment in the transceiver cable.

## TRANSMIT PATH

The transmit section encodes separate clock and NRZ* data input signals meeting the set up and hold time to TCLK at TENA and TX, into a standard Manchester II serial bit stream. The transmit outputs (Transmit +/ Transmit -) are designed to operate into terminated transmission lines. When operating into a $78 \Omega$ terminated transmission line, signaling meets the required output levels and skew for both Ethernet and IEEE-802.3.

## Transmitter Timing and Operation

A 20 MHz fundamental mode crystal oscillator provides the basic timing reference in the SIA. It is divided by two to create the transmit clock reference (TCLK). Both 20 MHz and 10 MHz clocks are fed into the Manchester Encoder to generate the transitions in the encoded data stream. The 10 MHz clock, TCLK, is used by the SIA to internally synchronize transmit data (TX) and transmit

[^54]

Figure 4. Transmit Section
enable (TENA). TCLK is also used as a stable bit-rate clock by the receive section of the SIA and by other devices in the system (the MK68590 LANCE uses TCLK to drive its internal state machine). The oscillator may use an external $0.005 \%$ crystal or an external TTL level input as a reference. Transmit accuracy of $0.01 \%$ is achieved (no external adjustments are required).

TENA is activated when the first bit of data is made available on TX. As long as TENA remains high, signals at TX will be encoded as Manchester and will appear at Transmit + and Transmit -. When TENA goes low, the differential transmit outputs go to one of the two idle states defined below:

- TSEL High: The idle state of Transmit +/ Transmit yields "zero" differential to operate transformer coupled loads (see Figure 14a).
- TSEL Low: In this idle state, Transmit + is positive to Transmit - logical high (see Figure 14b).


## RECEIVE PATH

The principle function of the receiver is the separation of the Manchester encoded data stream into clock and NRZ data.

## Input Signal Conditioning

Before the data and clock can be separated, it must be determined whether there is "real" data or unwanted noise at the transceiver interface. The MK68591/2 SIA carrier detection receiver provides a static noise margin of -175 to -275 mV for received carrier detection. These DC thresholds assure that no signal more positive than -175 mV is ever decoded and that signals more negative than -275 mV are always decoded. Transient noise of less than 10ns duration in the collision path and 20 ns duration in the data path are also rejected.

This signal conditioning prevents unwanted idle noise on the transceiver cable from causing "false starts" in
the receiver. This helps assure a valid response to "real" data.

The receiver section, shown in Figure 6, consists of two data paths. The receive data path is designed to be a zero threshold, high bandwidth receiver. The carrier detection receiver has an additional bias generator. Only data amplitudes larger than the bias level are interpreted as valid data. The noise rejection filter prevents noise transients of less than 20 ns from enabling the data receiver output. The collision detector similarly rejects noise transients of less than 10 ns .

## Receiver Section Timing

Receive Enable (RENA) is the "carrier present" indication established when a signal of sufficient amplitude $\left(\mathrm{V}_{\text {IDC }}\right)$ and duration ( $\mathrm{t}_{\text {RPWR }}$ ) is present at the receive inputs. Receive Clock (RCLK) and Receive Data (RX) become available after the third negative data transition


Figure 5. Receiver
at Receive + / Receive - inputs, and stay active until the end of a packet. During reception, RX is synchronous with RCLK, changing after the rising edge of RCLK.

The receiver detects the end of a packet when the normal transition on the differential inputs cease. After the last low-to-high transition, RENA goes low and RCLK completes one last cycle, storing the last data bit. It then becomes and remains low (see Receive End of Packet Timing diagrams). When TEST is low, RCLK continues to run, tracking data (if available) or synchronize with TCLK.

## Receive Clock Control

To insure quick capture of incoming data, the receiver phase-locked-loop is frequency locked to the transmit oscillator and it phase locks to incoming data edges. Clock and data are available within 6 bit times (accurate to within $\pm 3 \mathrm{~ns}$ ). The SIA will decode jittered data of up to $\pm 20 \mathrm{~ns}$ (see Figure 7).


Figure 6. Receiver Section Detail

## Differential I/O Terminations

The differential input for the Manchester data (receive $\pm$ ) is externally terminated by two $40.2 \Omega \pm 1 \%$ resistors and one optional common mode bypass capacitor. The differential input impedance $Z_{\text {IDF }}$ and the common mode input $Z_{I C M}$ are specified so that the Ethernet specification for cable termination impedance is met using standard $1 \%$ resistor terminators. The Collision $\pm$ differential input is terminated in exactly the same way as the receive input (see Figure 8).

## Collision Detection

The Ethernet Transceiver detects collisions on the Ethernet and generates a 10 MHz signal on the transceiver cable (Collision + / Collision -). This collision signal passes through an input stage which assures signal levels and pulse duration. When the signal is detected by the SIA, the SIA sets the CLSN line high. This condition continues for approximately 190ns after the last low-to-high transition on Collision $+/$ Collision - .


Figure 7. Maximum Jitter impact On Sampling


## NOTES:

1. Connect $R_{1}, R_{2}, C_{1}$ for 0 differential nontransmit. Connect to ground for logic 1 differential nontransmit.
2. Pin 20 shown for normal device operation.
3. Nodes A and B may be connected directly to ground for proper decoder operations, or to the common mode bypass $\mathrm{C}_{4}$ and $\mathrm{C}_{5}$. Some direct coupled transceivers require $\mathrm{C}_{4}$ and $\mathrm{C}_{5}$ to ground for proper operation.

Figure 8. MK68591/2 External Component Diagram


Figure 9. Transmit Mode Select (TSEL) Connection
ABSOLUTE MAXIMUM RATINGS*
Storage Temperature ..... -65 to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ..... to $70^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous ..... $+7.0 \mathrm{~V}$
DC Voltage Applied to Outputs for High Output State ..... -0.5 to $+V_{\text {CC }}$ max
DC Input Voltage (Logic Inputs) ..... $+5.5 \mathrm{~V}$
DC Input Voltage (Receive/Collision) ..... -6 to +6 V
Transmit $\pm$ Output Current ..... -50 to +5 mA
DC Output Current, Into Outputs ..... 100 mA
DC Input Current (Logic Inputs) ..... $\pm 30 \mathrm{~mA}$
*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 operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

DC ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE The following conditions apply unless otherwise specified:
$\mathrm{T}_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10$ percent, $\mathrm{MIN}=4.5 \mathrm{~V}, \mathrm{MAX}=5.5 \mathrm{~V}$, period of crystal oscillator $\left(\mathrm{T}_{\mathrm{OSC}}\right)=50 \mathrm{~ns}$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage RX, RENA, CLSN, TCLK, RCLK | ${ }^{\mathrm{I}} \mathrm{OH}=-1.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage RCLK, TCLK, RENA, RX, CLSN, TSEL | ${ }^{1} \mathrm{OL}=16 \mathrm{~mA}$, |  | 0.36 | 0.5 | V |
|  |  | $\mathrm{I}_{\mathrm{OL}}=1 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
| $\mathrm{V}^{\circ}$ | Differential Output Voltage $\quad \mathrm{V}_{0}$ | $R_{L}=78 \Omega$ <br> Figure 19 | 550 | 670 | 770 | mV |
|  | (Transmit +) - (Transmit -) $\overline{\text { V }}^{\text {- }}$ |  | $-550$ | -670 | $-770$ |  |
| $V_{\text {OD OFF }}$ | Transmit Differential Output Idle Voltage | $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=78 \Omega \text { Figure } 19 \\ & \mathrm{TSEL}=\mathrm{HIGH} \end{aligned}$ | -20 | 0.5 | 20 | mV |
| IOD OFF | Transmit Differential Output Idle Current |  | $-0.5$ | $\pm 0.1$ | 0.5 | mA |
| $\mathrm{V}_{\text {CMT }}$ | Common Mode Output Transmit Voltage | Figure 19$R_{L}=78 \Omega$ | 0 | 2.5 | 5 | V |
| $\mathrm{V}_{\text {ODI }}$ | Differential Output Voltage Imbalance (Transmit $\pm$ ) $\left\|\left\|\mathrm{V}_{0}\right\|-\left\|\overline{\mathrm{V}_{0}}\right\|\right.$ |  |  | 5 | 20 | mV |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage TTL |  | 2.0 |  |  | $\checkmark$ |
| ${ }_{1} \mathrm{H}$ | Input High Current TTL | $\mathrm{V}_{\mathrm{CC}}=$ Max, $\mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  | +50 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage TTL |  |  |  | 0.8 | $\checkmark$ |
| IL | Input Low Current TTL | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  | -270 | -400 | $\mu \mathrm{A}$ |
| $V_{\text {IRD }}$ | Differential Input Threshold (Rec Data) | Figure 20 | -25 | 0 | +25 | mV |
| $V_{\text {IDC }}$ | Differential Input Threshold (Carrier/Collision $\pm$ ) | Figure 20 | -175 | -225 | -275 | mV |
| ${ }^{1} \mathrm{CC}$ | Power Supply Current | ${ }^{\text {t }}$ OSC $=50 \mathrm{~ns}$ |  | 125 | 180 | mA |
|  |  | $\mathrm{t}_{\mathrm{OSC}}=50 \mathrm{~ns}, \mathrm{~T}_{\mathrm{A}}=\mathrm{Max}$ |  |  | 160 |  |
| $\mathrm{V}_{\text {IB }}$ | Input Breakdown Voltage $\mathrm{V}_{1}=+5.5$ (TX, TENA, TEST) | $\mathrm{I}_{1}=1 \mathrm{~mA}$ | 5.5 |  |  | V |
| $V_{\text {IC }}$ | Input Clamp Voltage | $\mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  | $-1.2$ | V |
| ISCO | RX, TCLK, CLSN, RENA, RCLK Short Circuit Current |  | -40 | -80 | -150 | mA |
| $\mathrm{R}_{\text {IDF }}$ | Differential Input Resistance | $\mathrm{V}_{\mathrm{CC}}=0$ to Max | 6k | 8.4k | 13k | ohm |
| $\mathrm{R}_{\text {ICM }}$ | Common Mode Input Resistance | $\mathrm{V}_{\mathrm{CC}}=0$ to Max | 1.5k | 2.1k | 7.5k | ohm |
| $\mathrm{V}_{\text {ICM }}$ | Receive and Collision Input Bias Voltage | $\mathrm{I}_{\mathbb{N}}=0$ | 1.5 | 3.5 | 4.2 | V |
| IILD | Receive and Collision Input Low Curent | $\mathrm{V}_{\text {IN }}=-1 \mathrm{~V}$ | -0.6 | -1.06 | -1.64 | mA |
| ${ }^{1} \mathrm{HDD}$ | Receive and Collision Input High Current | $\mathrm{V}_{\text {IN }}=6 \mathrm{~V}$ | +0.4 | +0.6 | +1.10 | mA |
| ${ }^{1} \mathrm{HZ}$ | Receive and Collision Input High Current | $\mathrm{V}_{\mathrm{CC}}=0, \mathrm{~V}_{\text {IN }}=+6 \mathrm{~V}$ | 0.4 | 1.28 | 1.86 | mA |

SWITCHING CHARACTERISTICS OVER OPERATING RANGE The following conditions apply unless otherwise specified: $\mathrm{T}_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10$ percent, $\mathrm{MIN}=4.5 \mathrm{~V}, \mathrm{MAX}=5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{OSC}}=50 \mathrm{~ns}$

| \# | Signal | Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RECEIVER SPECIFICATION |  |  |  |  |  |  |  |  |
| 1 | RCLK | ${ }^{\text {tRCT }}$ | RCLK Cycle Time | $C_{L}=50 \mathrm{pF}$ <br> Figure 17a <br> (See note) | 85 | 100 | 118 | ns |
| 2 | RCLK | $\mathrm{t}_{\text {RCH }}$ | RCLK High Time |  | 38 | 50 |  | ns |
| 3 | RCLK | ${ }^{\text {t }} \mathrm{RCL}$ | RCLK Low Time |  | 38 | 50 |  | ns |
| 4 | RCLK | ${ }^{\text {tren }}$ | RCLK Rise Time |  |  | 2.5 | 8 | ns |
| 5 | RCLK | ${ }^{\text {treF }}$ | RCLK Fall Time |  |  | 2.5 | 8 | ns |
| 6 | RX | $t_{\text {RDR }}$ | RX Rise Time |  |  | 2.5 | 8 | ns |
| 7 | RX | $t_{\text {RDF }}$ | RX Fall Time |  |  | 2.5 | 8 | ns |
| 8 | RX | ${ }^{\text {tr }}$ RH | RX Hold Time (RCLK to RX Change) |  | 5 | 8 |  | ns |
| 9 | RX | trDS | RX Prop Delay (RCLK to RX Stable) |  |  | 8 | 25 | ns |
| 10 | RENA | ${ }^{\text {t PPH }}$ | RENA Turn-On Delay ( $\mathrm{V}_{\text {IDC }}$ Max on Receive $\pm$ to RENA $_{H}$ ) | Figures 10, 16a, and 20 |  | 50 | 80 | ns |
| 11 | RENA | ${ }^{\text {t }}$ DPO | RENA Turn-Off Delay ( $V_{\text {IDC }}$ Min on Receive $\pm$ to RENA ${ }_{L}$ ) | Figures 11 and 20 |  | 265 | 300 | ns |
| 12 | RENA | ${ }^{\text {t }}$ DPL | RENA Low Time | Figure 11 | 120 | 200 |  | ns |
| 13 | Rec $\pm$ | ${ }^{\text {t }}$ RPWR | Receive $\pm$ Input Pulse Width to Reject (Input < V ${ }_{\text {IDC }}$ Min) | Figures 16a and 20 |  | 30 | 20 | ns |
| 14 | $R \mathrm{Rec} \pm$ | ${ }^{\text {t RPWO }}$ | Receive $\pm$ Input Pulse Width to Turn- <br> On (Input > V IDC $\operatorname{Max}$ ) | Figures 16a and 20 | 45 | 30 |  | ns |
| 15 | RCLK | ${ }_{\text {t }}^{\text {RLT }}$ | Decoder Acquisition Time | Figure 10 |  | 390 | 450 | ns |

## COLLISION SPECIFICATION

| 16 | Coll $\pm 0$ | ${ }^{\text {t CPWR }}$ | Collision Input Pulse Width to Reject (Input < V ${ }_{\text {IDC }} \mathrm{Min}$ ) | Figures 16b and 20 |  | 18 | 10 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 17 | Coll $\pm$ | ${ }^{\text {t CPWO }}$ | Collision Input Pulse Width to TurnOn (Collision $\pm$ Exceeds $\mathrm{V}_{\text {IDC }}$ Max) |  | 26 | 18 |  | ns |
| 18 | Coll $\pm$ | ${ }^{t}$ CPWE | Collision Input to Turn-Off CLSN (Input $<V_{\text {IDC }}$ Max) |  | 80 | 117 |  | ns |
| 19 | Coll $\pm$ | ${ }^{\text {t }}$ CPWN | Collision Input to Not Turn-Off CLSN (Input > V IDC Min ) |  |  | 117 | 160 | ns |
| 20 | CLSN | ${ }^{\mathrm{t}} \mathrm{CPH}$ | CLSN Turn-On Delay (VIDC Max on Collision $\pm$ to CLSN $_{H}$ ) | Figures 15, 16b, and 20 |  | 33 | 50 | ns |
| 21 | CLSN | ${ }^{\mathrm{t}} \mathrm{CPO}$ | CLSN Turn-Off Delay (VIDC Min on Collision $\pm$ to CLSN ) |  |  | 133 | 160 | ns |

TRANSMITTER SPECIFICATION

| 22 | TCLK | ${ }_{\text {t }}$ CL | TCLK Low Time | ${ }^{\mathrm{t}} \mathrm{OSC}=50 \mathrm{~ns}$ <br> Figures 17b and 18 | 45 | 50 | 55 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 23 | TCLK | ${ }^{\text {t }}$ TCH | TCLK High Time |  | 45 | 50 | 55 | ns |
| 24 | TCLK | ${ }^{\text {t }}$ TCR | TCLK Rise Time |  |  | 2.5 | 8 | ns |
| 25 | TCLK | ${ }^{\text {t }}$ TCF | TCLK Fall Time |  |  | 2.5 | 8 | ns |
| 26 | TX, TENA | ${ }_{\text {TTDS }}{ }^{\text {t }}$ TES | TX and TENA Setup Time | Figures 13, 14a, 14b, and 17b | 5 | 1.1 |  | ns |
| 27 | TX, TENA | ${ }^{\text {TOLH, }}{ }^{\text {t }}$ TEH | TX and TENA Hold Time |  | 5 | -1.1 |  | ns |
| 28 | TX $\pm$ | ${ }^{\text {t }}$ TOCE | ```Transmit }\pm\mathrm{ Output, (Bit Cell Center to Edge)``` | Figures 14a, 14b, and 19 | 49.5 | 50 | 50.5 | ns |
| 29 | TCLK | ${ }^{\text {tod }}$ | TCLK High to Transmit $\pm$ Output |  |  | 80 | 100 | ns |
| 30 | TX $\pm$ | ${ }^{\text {t }}$ TOR | Transmit $\pm$ Output Rise Time | 20 through 80 percent Figure 19 |  | 2 | 4 | ns |
| 31 | TX $\pm$ | ${ }_{\text {t }}$ TOF | Transmit $\pm$ Output Fall Time |  |  | 2 | 4 | ns |
| 32 | TX $\pm$ | $V_{O D}$ | Undershoot Voltage at Zero Differential Point on Transmit Return to Zero (End of Message) | Figure 14a |  |  | -100 | mV |

NOTE:
Assumes equal capacitance loading on RCLK and RX.


* PULSE WIDTH OF $\geq 45 \mathrm{~ns}$ IS ALWAYS RECOGNIZED. HOWEVER, PULSE WIDTH OF $\leq 20$ ns IS REJECTED.

Figure 10. Receiver Timing - Start of Packet


Figure 11. Receiver Timing - End of Packet (Last Bit $=0$ )


Figure 12. Receiver Timing - End of Packet (Last Bit $=1$ )


Figure 13. Transmitter Timing - Start of Transmission (TSEL Low, TSEL High)


Figure 14a. Transmitter Timing - End of Transmission (TSEL High)


Figure 14b. Transmitter Timing - End of Transmission (TSEL Low)


* PULSE WIDTH OF -26 ns IS GUARANTEED TO BE
RECOGNIZED: HOWEVER, PULSE WIDTH OF $\leq 10 \mathrm{~ns}$ IS RECOGNIZED: HOWEVER, PULSE WIDTH OF $\leq 10 \mathrm{~ns}$ IS REJECTED

Figure 15. Collision Timing


Figure 16a. Receive $\pm$ Input Pulse Width Timing


Figure 16b. Collision $\pm$ Input Pulse Width Timing


Figure 17b. TCLK and TX Timing



Figure 18. Test Load For RX, RENA, and TCLK
Figure 19. Transmit $\pm$ Output Test Circuit


Figure 20. Receive $\pm$ and Collision $\pm$ Input Test Circuit

CHAPTER 9 - SURFACE MOUNTED DEVICES

| 6800 MICROPROCESSORS | $\underbrace{\text { LCCC } 28}_{\text {CB-707 }}$ | LCCC 44 |  |  | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { EF6802 } \\ & \text { EF6809 } \end{aligned}$ |  | $\bullet$ |  |  | $\begin{aligned} & 1-3 \\ & 1-111 \end{aligned}$ |

6800 PERIPHERALS

| EF6821 | $\bullet$ |  |  | $2-3$ <br> EF6840 <br> EF6850 <br> EF6854 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: |

68000 MICROPROCESSORS

| TS68000 |  |  | $\bullet$ | $\bullet$ | $3-3$ <br> TS68008 |
| :---: | :---: | :---: | :---: | :---: | :---: |

## 68000 PERIPHERALS

| MK68230 <br> TS68HC901 |  |  | $\bullet$ | $4-3$ |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $4-59$ |  |  |  |  |

CRT CONTROLLER


68HC200/68200 - ROMLESS MCU

| MK68HC200/68200 <br> MK68HC200E/68200E |  |  | $\bullet$ |  | 3-265 |
| :--- | :--- | :--- | :--- | :--- | :---: |

PLCC SELECTION GUIDE

| 6800 MICROPROCESSORS | $\begin{gathered} \text { PLCC } 28 \\ \text { CB-520 } \end{gathered}$ | PLCC 44 <br> mantan mux <br> CB-521 | $\begin{gathered} \text { PLCC } 52 \\ \text { Mrevernawin } \\ \text { CB-522 } \end{gathered}$ |  | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EF6802 EF6803 EF6803U4 EF6809 EF6809E |  | $\begin{aligned} & \bullet \\ & \bullet \\ & \bullet \\ & \bullet \end{aligned}$ |  |  | $\begin{aligned} & \hline 1-3 \\ & 1-27 \\ & 1-67 \\ & 1-111 \\ & 1-151 \\ & \hline \end{aligned}$ |

6800 PERIPHERALS

| EF6821 |  | $\bullet$ |  |  | $2-3$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EF6840 |  |  |  |  | $2-15$ |
| EF6850 |  |  |  |  |  |
| EF6854 |  |  |  |  |  |
| $2-41$ |  |  |  |  |  |

68000 MICROPROCESSORS

| TS68000 |  |  | $\bullet$ | $3-3$ <br> TS68008 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |

68000 PERIPHERALS

| MK68230 |  |  |  | $4-3$ <br> MK68901 <br> TS68HC901 |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $4-29$ |  |  |  |  |  |
| $4-59$ |  |  |  |  |  |

CRT CONTROLLER

| EF9345 | $\bullet$ | $\bullet$ |  | $6-3$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EF9369 |  |  |  | $6-81$ |
| TS68483 |  |  |  | $6-97$ |
| TS68494 |  |  |  | $6-143$ |

## 68HC200/68200 ROMLESS MCU

| MK68HC200/68200 <br> MK68HC200E/68200E |  |  | $\bullet$ | $(84)$ | $3-265$ |
| :--- | :--- | :--- | :--- | :--- | :---: |

## SURFACE MOUNTED DEVICES: today's solution for state-of-the-art system designs.

Today's trend toward light weight system designs with high component density allows Surface Mounting Technology to revolutionize manufacturing in the Electronics industry.

Reduction in board assembly cost by as much as $40 \%$ and in board size by as much as $50 \%$ is a goal that can be reached throught the utilization of Surface Mounted Devices:
Active Semiconductors (SO IC's) - SO Discretes and Chip carriers as well as passive resistors and capacitor chips.

Today system designers can select package outlines that meet state-of-the-art weight/space ratio requirements while enhancing electrical performance.

By 1990, through widely accepted data, one can foresee above $50 \%$ of the world wide demand to be Surface Mounted Devices.

Included in the THOMSON SEMICONDUCTEURS family of Surface Mounted Devices are integrated circuits (SO8-SO28), Plastic Leaded Chip Carriers (PLCC) from 18 to 84 pins, Leadlen Ceramic Chip Carrier's (LCCC) from 20 to 68 pads, as well as discrete diodes and transistors in SOT 23 (TO-236).

Capacitor chips are also available in THOMSON LCC. Compared to conventional types THOMSON SC's SMD have the following features:

- Compact design enabling high packing density and significant reduction in board size and weight, for instance in consumer electronics, telecommunications and automotives.
- Easy and low cost handling through automated high speed pick and place machinery.
- Mounting capability on both sides of all types of substrates (Ceramic or PC boards) using all current methods, such as wave soldering reflow and vapor phase technics.
- Same electrical characteristics (same dice) as conventional packages, with improved high frequency, high speed switching performances due to lower lead inductance and capacitance.
- Optimized way to package VLSI circuits by utilizing plastic chip carrier along with SO packages, leading to a major advantage over chip and wire assembiy processes.



## MOUNTING METHODS

PLCC and LCCC may be mounted on either PC boards or substrates, employing different soldering methods.

## Reflow process

- This method permits the soldering of all components in a single operation. In this case, solder cream is used either by screen printing or employing a pneumatic gun. After the application of solder cream the components are mounted and the circuit is guided through an infrared or convection oven which allows the solder to melt.
In order to avoid solder spreading risks and to position the components, the board should be pre-screen printed with an insulating material.

- An other way to solder coat the board is to dip it into a soldering bath or through wave soldering. Then, flux is applied by a brush or immersion and the components are placed.

The soldering is done by reflow through an oven as above.
The result obtained by both methods is identical. However, in this case, a complete tinning of the circuit is necessary.

## Wave soldering process

The components are glued to substrate by means of an insulated glue. The board is dipped in flux and then goes through the wave soldering process.

## Hot air soldering

In this system, the soldering iron must be replaced by a hot air nozzle. Employing this method, an improvement in solder temperature control is achieved.
It is also easy to correct some soldering failures with this method.

## Heated collet

This method is used for rework and soldering PCC on the versus side of the board after wave solder.

## Vapor phase soldering (VPS)

This method uses the heat of the vapor of a boiling inert fluorinated fluid. Soldering is accomplished by either screening tin layers or by electroplating solder paste.
Components are then mounted in appropriate locations and soldered to the circuit by dipping it into the vapor of boiling inert fluorinated fluid.
The main advantages of this method are:

- Uniform workpiece temperature whatever the difference in size of the components involved
- Accurate temperature without any elaborate control (temperature of boiling inert fluid)
- Dipping time may be very short and as a consequence better soldering results are obtained
- Soldering takes place in an oxygen-free atmosphere which permits:
- to use less active soldering flux, and
- to avoid soldering flux oxidation (easy cleaning
of remaining flux).


## Remarks

Various types of high speed automatic mounting equipments for passive and active devices are available contributing to considerable reduction in production costs.

## THERMAL CHARACTERISTICS

Thermal performances of SMD are dependent upon substrate material, size, mounting process, chip area, die attach and lead frame material characteristics.


[^55]Allowable power dissipation can reach 350 mW according to device type, refer to data sheet.

Trade Marks Registered ©

Thomson Components - Mostek Corporation reserves the right to make changes in specifications and other information at any time without prior notice. Information contained herein is believed to be correct, but is provided solely for guidance in product application and not as a warranty of any kind. Thomson Components - Mostek assumes no responsibility for use of this information, nor for any infringements of patents or other rights of third parties resulting from use of this information, nor for the use of any circuitry other than circuitry embodied in a Thomson Components - Mostek product. No license is granted under any patents or patent rights of Thomson Components - Mostek.

Thomson Components - Mostek Corporation reserves the right to make changes in specifications and other information at any time without prior notice. Information contained herein is believed to be correct, but is provided solely for guidance in product application and not as a warranty of any kind. Thomson Components - Mostek assumes no responsibility for use of this information, nor for any infringements of patents or other rights of third parties resulting from use of this information, nor for the use of any circuitry other than circuitry embodied in a Thomson Components - Mostek product. No license is granted under any patents or patent rights of Thomson Components - Mostek.

The "PRELIMINARY" designation on a Thomson - Mostek data sheet indicates that the product is not characterized. The specifications are subject to change, are based on design goals or preliminary part evaluation, and are not guaranteed. Thomson - Mostek or an authorized sales representative should be consulted for current information before using this product.

The "ADVANCE INFORMATION" designation on a Thomson - Mostek publication indicates that the item described is a prospective product, is not yet available, and that the specification goals have not yet been fully established. Production is anticipated but not guaranteed. The ADVANCE INFORMATION is an initial disclosure of a new product's features and description. The specifications are subject to change at any time without notice, are based on design goals, and are not guaranteed or warranted in any way. Thomson - Mostek or an authorized sales representative should be consulted for current information before using this product or basing any designs on this ADVANCE INFORMATION. No responsibility is assumed by Thomson - Mostek for its use, nor for any infringements of patents or trademarks or other rights of third parties resulting from its use. No license is granted under any patents, patent rights, or trademarks of Thomson - Mostek.

The "APPLICATION BRIEF" or "APPLICATION NOTE" designation on a Thomson-Mostek literature item indicates that the literature item contains information regarding Thomson-Mostek features and/or their varied applications. The information given in the APPLICATION BRIEF or APPLICATION NOTE is believed to be accurate and reliable; however, the information is subject to change and is not guaranteed. No responsibility is assumed by Thomson-Mostek for its use; nor for any infringements of patents and trademarks or other rights of third parties resulting from its use. No license is granted under any patents, patent rights, or trademarks of Thomson-Mostek.


[^0]:    * Home Office

[^1]:    -If programs are not executed from on-board RAM, TAV1 applies. If programs are to be stored and executed from on-board RAM, TAV2 applies. For normal data storage in the on-board RAM, this extended delay does not apply. Programs cannot be executed from on-board RAM when using A and B parts (EF68A02, EF68A08, EF68B02, and EF68B08). On-board RAM can be used for data storage with all parts.

[^2]:    Half carry from bit 3.
    Interrupt mask
    Negative (sign bit)
    Zero (byte)
    Overtlow. 2's complement
    Carry from bit 7
    Reset Always
    Set Always
    Test and set it true, cleared otherwise
    Not Aftected

[^3]:    NOTES:

    1. If device which is addressed during this cycle uses VMA, then the Data Bus will go to the high-impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.
    2. Data is ignored by the MPU.
    3. For TST, VMA $=0$ and Operand data does not change.
    4. MS Byte of Address Bus = MS Byte of Address of BSR instruction and LS Byte of Address Bus = LS Byte of Sub-Routine Address.
[^4]:    *The EF6803 operates only in Modes 2 and 3

[^5]:    - Using maximum clock rate

[^6]:    * TST does not perform the write cycle during the sixth cycle. The sixth cycle is another address bus= \$FFFF

[^7]:    *TST does not perform the write cycle during the sixth cycle. The sixth cycle is another address bus=\$FFFF.

[^8]:    The condition code register notes are listed after Table 12.

[^9]:    *TST does not perform the write cycle during the sixth cycle. The sixth cycle is another address bus = \$FFFF

[^10]:    * TST does not perform the write cycle during the sixth cycle. The sixth cycle is another address bus= \$FFFF.

[^11]:    PC Main Program | $\$ 7 E=$ JMP |
    | :---: |
    | $\mathrm{K}_{\mathrm{H}}=$ Next Address |
    | $\mathrm{K}_{\mathrm{L}}=$ Next Address |

[^12]:    EXORciser is a registered trade mark of MOTOROLA Inc.

[^13]:    * Capacitances are periodically tested rather than $100 \%$ tested.

[^14]:    * $\overline{N M I}, \overline{F I R Q}$, and $\overline{\mathrm{RO}}$ requests are sampled on the falling edge of $Q$. One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. If IRQ and FTRQ do not remain low until completion of the current instruction they may not be recognized. However, NMI is latched and need only remain low for one cycle. No interrupts are recognized or latched between the falling edge of $\overline{R E S E T}$ and the rising edge of BS indicating $\overline{\text { RESET }}$ acknowledge.

[^15]:    * DMAVMA is a signal which is developed externally, but is a system requirement for DMA.

[^16]:    ${ }_{\sim}^{+}$and ${ }^{+}$indicate the number of additional cycles and bytes for the particular variation.

[^17]:    *The index register is incremented following the indexed access

[^18]:    Index Register
    Index Register
    Index Register + Post Byte
    Index Register + Post Byte High: Post Byte Low

    Index Register + A Register
    Index Register + B Register
    Index Register + D Register

    Index Register*
    *
    Index Register
    Index Register -
    Index Register -2

    Program Counter + Offset Byte
    Program Counter + Offset High Byte Offset Low Byte
    Direct Page Register. Address Low

    Address High Address Low

    NNNN + 1

[^19]:    * Capacitances are periodically tested rather than $100 \%$ tested.

[^20]:    1 Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}} \geq 2.4 \mathrm{~V}$, unless otherwise specified
    2. Measurement points shown are 0.8 V and 20 V , unless otherwise specified
    3. Hold time ( (9) ) for BA and BS is not specified
    4. Usable access tume is computed by: 1-4-11 max-17

[^21]:    * $\overline{N M}, ~ F I R Q$, and $\overline{R O}$ requests are sampled on the falling edge of $Q$. One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. If $\overline{I R Q}$ and FIRQ do not remain low until completion of the current instruction, they may not be recognized. However, $\overline{N M I}$ is latched and need only remain low for one cycle. No interrupts are recognized or latched between the falling edge of $\overline{R E S E T}$ and the rising edge of BS indicating $\overline{\text { RESET }}$ acknowledge. See $\overline{R E S E T}$ sequence in the MPU flowchart in Figure 14.

[^22]:    Before Execution
    $A=X X$ (don't care)
    $X=\$ F 000$

[^23]:    *The index register is incremented following the indexed access

[^24]:    *The index register is incremented following the indexed access

[^25]:    ~Number of MPU cycles (less possible push pull or indexed-mode cycles)

    * Number of program bytes
    *Denotes unused opcode

[^26]:    $\mathrm{t}_{\mathrm{r}}$ and $\mathrm{t}_{\mathrm{f}} \leq \mathrm{t}_{\text {Cyce }}$

[^27]:    NOTES
    1 Not all signals are applicable to every part
    2 Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4 \mathrm{~V}, \mathrm{~V}_{H} \geq 2.4 \mathrm{~V}$, unless otherwise specified.
    3. Measurement points shown are 0.8 V and 2.0 V . unless otherwise specified.

[^28]:    Symbols are as defined in Table 5.

[^29]:    $\overline{\mathrm{G}} 1=$ Negative transition of $\overline{\mathrm{Gate}}$ input
    W = Write Timer Latches Command
    $\mathrm{A}=$ Timer Reset (CR $10=1$ or External $\overline{\text { RESET }}=0$ )
    $N=16-B_{i t}$ Number in Counter Latch.
    TO $=$ Counter Time Out (All Zero Condition)
    I = Interrupt for a given umer
    
    (E) with the specified setup and hold time requirements

[^30]:    Note: Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted

[^31]:    $R=11.7 \mathrm{k} \Omega$ for DO-D7
    $=24 \mathrm{k} \Omega$ for $\overline{\mathrm{RTS}}$ and $T \times$ Data

[^32]:    $\cdot 1.0 \mu \mathrm{~s}$ or $10 \%$ of the pulse width, whichever is smaller.

[^33]:    -Prioritized even when PSE =0
    NOTE: Stetus bit above will inhibit one below it.

[^34]:    NOTES
    Dn = Data Register
    An = Address Register
    $X_{n}=$ Address or Data Register used as Index Register
    $\mathrm{SR}=$ Status Register
    $\mathrm{PC}=$ Program Counter
    $S P=$ Stack Pointer
    USP $=$ User Stack Pointer
    1 ) = Effective Address
    d8 $=8$-Bit Offset (Displacement)
    $d_{16}=16 \cdot$ Bit Offset (Displacement) $^{\text {(Dita }}$
    $\# x x x=$ Immediate Data

[^35]:    NOTES:
    s= source
    d $=$ destınation
    ( ) = bit number

    $$
    \begin{aligned}
    & -1 \quad)=\text { indirect } \text { with predecrement } \\
    & (\quad)+=\text { indirect } \text { with postdecrement } \\
    & \#=\text { immediate data }
    \end{aligned}
    $$

[^36]:    * The size of the index register (ix) does not affect execution time

[^37]:    + add effective address calculation time

[^38]:    NOTES
    [ ]= bit number
    \# = immediate data
    $-=$ indirect with predecrement
    $+=$ indirect with postdecrement

[^39]:    * Open Drain

[^40]:    - = Signal is negated in this cus state

[^41]:    * The size of the index register (ix) does not affect execution time.

[^42]:    $n$ is the number of registers to move

    * is the size of the index egister (ix) does not affect the instruction's execution time

[^43]:    NOTES

    1. Available for emulator only.
    2. Must be " 0 " when specifying the emulator.
    3. Contact Mostek for availability.
[^44]:    2. Plating shall be gold over nickel as specified in the detail specification.
[^45]:    1. Timing diagram shows $\mathrm{H} 1, \mathrm{H} 2, \mathrm{H} 3$, and H 4 asserted low.
    2. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.
[^46]:    V7.V4 The four most significant bits are copied from the vector register
    IV3-IV0 These bits are supplied by the CMFP. They are the binary channel number of the highest priority channel that is requesting interrupt service

[^47]:    When a bit is zero, interrupts are masked for the associated interrupt channel. When a bit is a one, interrupts are not masked for the associated interrupt channel.
    SET al MPU writes a one
    CLEARED a) MPU writes a zero
    b) Reset

[^48]:    $T_{\text {SAR }}$
    $T_{\text {DRD }}$
    THAR

[^49]:    * This curve applies to the operating case where clock output selection is programmedfor $\mathrm{C} 1=1, \mathrm{CO}=1$, and is included for comparison purposes to other operating modes

[^50]:    
    

[^51]:    $X=$ don't care.

[^52]:    NOTE: All timing is referenced to the rising edge of CLK. (See timing diagram 3)

[^53]:    LANCE is a trademark of Thomson Components - Mostek Corporation.

[^54]:    *Non-Return-to-Zero

[^55]:    Junction-ambient air thermal resistance, components reported on classical PC board (FR 4, 1.3 mm thickness, $50 \times 50 \mathrm{~mm}$ size).

